:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,system-ui,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--content-max-width: 1100px;--sidebar-width: 240px;--border-radius: 6px;--border-radius-lg: 12px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1)}:root,[data-theme=light]{color-scheme:light;--primary-green: #2d5a3d;--primary-green-light: #3d7056;--primary-green-lighter: #4d8866;--accent-green: #5a9d6f;--accent-green-light: #7bb491;--success-color: #16a34a;--warning-color: #d97706;--error-color: #dc2626;--bg-primary: #fefefe;--bg-secondary: #f8f9fa;--bg-tertiary: #f1f3f4;--bg-card: #ffffff;--bg-hover: #f5f6f7;--bg-active: #e8eaed;--text-primary: #2d3748;--text-secondary: #4a5568;--text-tertiary: #718096;--text-muted: #a0aec0;--border-light: #e2e8f0;--border-medium: #cbd5e0;--border-strong: #a0aec0;--grid-color: rgba(0, 0, 0, .08);--bg-card-transparent: rgba(255, 255, 255, .7);--bg-secondary-transparent: rgba(248, 249, 250, .8);--bg-tertiary-transparent: rgba(241, 243, 244, .8);--bg-header-transparent: rgba(255, 255, 255, .85);--bg-day-column: rgba(255, 255, 255, .6);--bg-day-content: rgba(255, 255, 255, .4);--schedule-text-lecture: #1e3a8a;--schedule-text-seminar: #78350f;--schedule-text-lab: #7c2d12;--schedule-text-tutorial: #4c1d95;--schedule-text-exercise: #14532d;--schedule-text-workshop: #831843;--schedule-text-default: #334155}[data-theme=dark]{color-scheme:dark;--primary-green: #4a9d6f;--primary-green-light: #5ab380;--primary-green-lighter: #6bc991;--accent-green: #7bb491;--accent-green-light: #8bc5a2;--success-color: #22c55e;--warning-color: #f59e0b;--error-color: #ef4444;--bg-primary: #0f1419;--bg-secondary: #1a1f29;--bg-tertiary: #242936;--bg-card: #1e2532;--bg-hover: #252b3a;--bg-active: #2a3142;--text-primary: #e2e8f0;--text-secondary: #cbd5e0;--text-tertiary: #a0aec0;--text-muted: #718096;--border-light: #2d3748;--border-medium: #4a5568;--border-strong: #718096;--grid-color: rgba(255, 255, 255, .05);--bg-card-transparent: rgba(30, 37, 50, .7);--bg-secondary-transparent: rgba(26, 31, 41, .8);--bg-tertiary-transparent: rgba(36, 41, 54, .8);--bg-header-transparent: rgba(30, 37, 50, .85);--bg-day-column: rgba(26, 31, 41, .6);--bg-day-content: rgba(26, 31, 41, .4);--schedule-text-lecture: #dbeafe;--schedule-text-seminar: #fef3c7;--schedule-text-lab: #fed7aa;--schedule-text-tutorial: #ede9fe;--schedule-text-exercise: #dcfce7;--schedule-text-workshop: #fce7f3;--schedule-text-default: #f1f5f9}a{font-weight:500;color:var(--primary-green);text-decoration:inherit;transition:color .2s ease}a:hover{color:var(--primary-green-light)}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;color:var(--text-primary);transition:background-color .3s ease,color .3s ease;font-size:14px}body{background-color:var(--bg-primary);background-image:linear-gradient(var(--grid-color) 1px,transparent 1px),linear-gradient(90deg,var(--grid-color) 1px,transparent 1px);background-size:20px 20px;background-attachment:fixed}body.auth-body{display:flex;justify-content:center;align-items:center}body.auth-body:before{display:none}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:1.75rem}h2{font-size:1.5rem}h3{font-size:1.25rem}h4{font-size:1.125rem}h5{font-size:1rem}h6{font-size:.875rem}p{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.6}button{font-family:inherit;font-size:.875rem;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;font-weight:500}button:hover{transform:translateY(-1px)}button:active{transform:translateY(0)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-medium);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--border-strong)}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:var(--primary-green);color:#fff;cursor:pointer;transition:all .25s ease}button:hover{background-color:var(--secondary-green);border-color:var(--light-green);transform:translateY(-1px)}button:focus,button:focus-visible{outline:2px solid var(--light-green);outline-offset:2px}.supabase-auth-ui_ui{background-color:var(--bg-secondary)!important;border-radius:12px!important;padding:2rem!important;box-shadow:0 10px 25px #0000004d!important;max-width:400px!important;width:100%!important}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:var(--bg-card);border:1px solid var(--border-light);border-radius:var(--border-radius-lg);padding:2rem;box-shadow:var(--shadow-lg);width:100%;max-width:400px;text-align:center}.auth-card h1{color:var(--primary-green);font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.auth-card p{color:var(--text-secondary);font-size:.875rem;margin-bottom:2rem}.auth-card .supabase-auth-ui_ui{font-family:inherit}.auth-card .supabase-auth-ui_ui input{background:var(--bg-secondary)!important;border:1px solid var(--border-light)!important;color:var(--text-primary)!important;font-size:.875rem!important}.auth-card .supabase-auth-ui_ui input:focus{border-color:var(--primary-green)!important;box-shadow:0 0 0 2px #2d5a3d1a!important}.auth-card .supabase-auth-ui_ui button{font-size:.875rem!important;font-weight:500!important;transition:all .2s ease!important}.auth-card .supabase-auth-ui_ui button:hover{transform:translateY(-1px)!important}.auth-card .supabase-auth-ui_ui label{color:var(--text-secondary)!important;font-size:.8125rem!important;font-weight:500!important}@media (max-width: 768px){.auth-container{padding:1rem}.auth-card{padding:1.5rem}.auth-card h1{font-size:1.5rem}}.dashboard{min-height:100vh;background:transparent;display:flex;flex-direction:column}.dashboard-header{background-color:var(--bg-header-transparent);border-bottom:1px solid var(--border-light);padding:0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-sm)}.header-content{max-width:var(--content-max-width);margin:0 auto;padding:.875rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem}.header-left h1{color:var(--primary-green);font-size:1.35rem;font-weight:700;margin:0;letter-spacing:-.025em}.header-nav{flex:1;display:flex;justify-content:center;margin:0 1.5rem;max-width:600px}.nav-list{list-style:none;padding:0;margin:0;display:flex;gap:.375rem;background:var(--bg-secondary);border-radius:12px;padding:.375rem;border:1px solid var(--border-light);width:100%;box-shadow:0 2px 4px #0000000a}.nav-item{background:transparent;color:var(--text-secondary);border:none;padding:.625rem 1.125rem;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;flex:1;text-align:center;min-width:0}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 2px 4px #00000014}.nav-item.active{background:var(--primary-green);color:#fff;box-shadow:0 2px 8px #22c55e40;transform:translateY(-1px)}.nav-label{display:block}.pomodoro-indicator{display:inline-block;font-size:.6rem;font-weight:600;margin-left:.5rem;padding:.1rem .3rem;border-radius:3px;font-family:Courier New,monospace;letter-spacing:.3px;vertical-align:middle}.pomodoro-indicator.work{background:#22c55e26;color:#16a34a;border:1px solid rgba(34,197,94,.25)}.pomodoro-indicator.break{background:#fb923c26;color:#ea580c;border:1px solid rgba(251,146,60,.25)}.pomodoro-indicator.paused{opacity:.6}.nav-item.active .pomodoro-indicator{background:#ffffff26;color:#fff;border:1px solid rgba(255,255,255,.25)}.floating-timer{position:fixed;bottom:20px;right:20px;z-index:1000;background:var(--bg-card);border-radius:8px;padding:.6rem .9rem;box-shadow:var(--shadow-card);border:1px solid var(--border-light);cursor:pointer;transition:all .2s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);min-width:80px}.floating-timer:hover{background:var(--bg-secondary);transform:translateY(-1px);box-shadow:0 6px 20px #00000026}.floating-timer.paused{opacity:.7}.floating-timer-content{display:flex;align-items:center;gap:.6rem}.floating-timer-time{font-family:Courier New,Monaco,Menlo,monospace;font-size:.95rem;font-weight:700;letter-spacing:.5px;transition:all .2s ease}.floating-timer-label{font-size:.7rem;color:var(--text-secondary);font-weight:500;text-transform:uppercase;letter-spacing:.5px}.floating-timer.work-mode .floating-timer-time,.floating-timer.work-mode .floating-timer-label{color:var(--primary-green)}.floating-timer.break-mode .floating-timer-time,.floating-timer.break-mode .floating-timer-label{color:#fb923c}@media (max-width: 768px){.floating-timer{bottom:15px;right:15px;padding:.6rem .8rem;min-width:90px}.floating-timer-mode,.floating-timer-time{font-size:.9rem}.floating-timer-label{font-size:.65rem}}@media (max-width: 480px){.floating-timer{bottom:10px;right:10px;padding:.5rem .7rem;min-width:80px}.floating-timer-content{gap:.4rem}.floating-timer-mode{font-size:.8rem}.floating-timer-time{font-size:.85rem}.floating-timer-label{display:none}}.header-right{display:flex;align-items:center;gap:1.25rem;flex-shrink:0}.theme-toggle-wrapper{display:flex;align-items:center;gap:.875rem;padding:.25rem;border-radius:8px;transition:background-color .2s ease}.theme-toggle-wrapper:hover{background-color:#0000000d}.theme-label{color:var(--text-tertiary);font-size:.8rem;font-weight:600;transition:color .3s ease;-webkit-user-select:none;user-select:none}.theme-label.active{color:var(--text-primary)}.theme-toggle{position:relative;width:52px;height:28px;background:var(--primary-green);border:none;border-radius:14px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);padding:0;box-shadow:0 2px 4px #0000001a}.theme-toggle.dark{background:#6b7280}.theme-toggle:hover{box-shadow:0 4px 8px #00000026;transform:translateY(-1px)}.toggle-slider{position:absolute;top:2px;left:2px;width:24px;height:24px;background:#fff;border-radius:50%;transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 6px #0003}.theme-toggle.dark .toggle-slider{transform:translate(24px)}.user-info{display:flex;align-items:center;gap:.875rem;padding:.375rem .75rem;border-radius:8px;background:var(--bg-tertiary);border:1px solid var(--border-light);transition:all .2s ease}.user-info:hover{background:var(--bg-secondary);box-shadow:0 2px 4px #00000014}.user-name{color:var(--text-primary);font-size:.875rem;font-weight:600;letter-spacing:-.01em}.logout-btn{background:var(--primary-green);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.8rem;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;box-shadow:0 2px 4px #22c55e33}.logout-btn:hover{background:#16a34a;transform:translateY(-2px);box-shadow:0 4px 12px #22c55e4d}.dashboard-main{flex:1;display:flex;justify-content:center}.dashboard-container{width:100%;max-width:var(--content-max-width);margin:0 auto;padding:1.5rem}.dashboard-content{width:100%;background:var(--bg-card-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--border-radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);overflow:hidden}@media (max-width: 1200px){.dashboard-container{max-width:none;padding:1rem}}@media (max-width: 968px){.header-left{display:none}.header-content{flex-direction:row;gap:.75rem;padding:.625rem 1rem;justify-content:space-between}.header-nav{margin:0;flex:1;max-width:400px}.header-right{flex-shrink:0;gap:.625rem}.nav-list{justify-content:center;padding:.2rem;gap:.375rem}.nav-item{flex:1;min-width:0;text-align:center;padding:.4rem .5rem;font-size:.75rem}.theme-toggle-wrapper{gap:.375rem}.theme-label{font-size:.7rem}.theme-toggle{width:40px;height:20px}.toggle-slider{width:14px;height:14px;top:3px;left:3px}.theme-toggle.dark .toggle-slider{transform:translate(20px)}.user-name{font-size:.75rem}.logout-btn{padding:.35rem .65rem;font-size:.7rem}}@media (max-width: 640px){.header-content{padding:.5rem .75rem;gap:.5rem}.user-email{display:none}.dashboard-container{padding:.75rem}.nav-item{padding:.325rem .4rem;font-size:.7rem}.theme-toggle{width:36px;height:18px}.toggle-slider{width:12px;height:12px}.theme-toggle.dark .toggle-slider{transform:translate(18px)}.theme-label{display:none}.user-name{font-size:.7rem;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.logout-btn{padding:.3rem .5rem;font-size:.65rem}}@media (max-width: 480px){.header-content{padding:.4rem .6rem;gap:.4rem}.nav-list{padding:.15rem;gap:.25rem}.nav-item{padding:.3rem;font-size:.65rem}.header-right{gap:.4rem}.theme-toggle{width:32px;height:16px}.toggle-slider{width:10px;height:10px;top:3px;left:3px}.theme-toggle.dark .toggle-slider{transform:translate(16px)}.user-name{font-size:.65rem;max-width:80px}.logout-btn{padding:.25rem .4rem;font-size:.6rem}}.main-page{padding:1.5rem;min-height:100%;background:transparent;position:relative}.main-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.page-title p{color:var(--text-secondary);font-size:.875rem;margin:0}.form-section{border-top:1px solid var(--border-light);padding-top:1.5rem;margin-top:.5rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.checkbox-label{display:inline-flex;align-items:center;gap:.6rem;color:var(--text-primary);font-weight:500;font-size:.95rem}.checkbox-label input{width:18px;height:18px;accent-color:var(--primary-green)}.dynamic-list{display:flex;flex-direction:column;gap:1rem}.dynamic-item{background:var(--bg-tertiary);border:1px solid var(--border-light);border-radius:var(--border-radius);padding:1rem;display:flex;flex-direction:column;gap:1rem}.dynamic-item.single{padding:.75rem 1rem}.item-header{display:flex;justify-content:space-between;align-items:center;font-size:.9rem;font-weight:600;color:var(--text-primary)}.add-row-button,.remove-row-button{align-self:flex-start;background:transparent;border:1px dashed var(--border-light);border-radius:var(--border-radius);color:var(--text-secondary);font-size:.85rem;font-weight:600;padding:.5rem .75rem;cursor:pointer;transition:all .2s ease}.add-row-button:hover,.remove-row-button:hover{border-color:var(--primary-green);color:var(--primary-green)}.remove-row-button{border-color:var(--border-medium);color:var(--error-color)}.remove-row-button:hover{border-color:var(--error-color);color:var(--error-color)}.subjects-grid .inline-form{display:flex;flex-direction:column;gap:1.25rem}.subjects-grid .inline-form h3{color:var(--text-primary);font-size:1.25rem;margin:0}.loading-container,.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;text-align:center;padding:2rem}.loading-spinner{width:24px;height:24px;border:2px solid var(--border-light);border-left:2px solid var(--primary-green);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:.75rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-container h2{color:var(--error-color);font-size:1.25rem;margin-bottom:.5rem}.retry-btn{background:var(--primary-green);color:#fff;padding:.5rem 1rem;border-radius:var(--border-radius);font-size:.875rem;margin-top:1rem}.retry-btn:hover{background:var(--primary-green-light)}.empty-state{text-align:center;padding:3rem 2rem}.empty-state h2{color:var(--text-secondary);font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:var(--text-tertiary);font-size:.875rem}.subjects-grid{display:flex;flex-direction:column;gap:.75rem;margin-top:1rem}.subject-card{background:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:var(--border-radius-lg);overflow:hidden;transition:all .2s ease;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.subject-card:hover{border-color:var(--border-medium);box-shadow:var(--shadow-md);transform:translateY(-1px)}.subject-card.collapsed .subject-header{border-bottom:none}.subject-header{padding:1rem;border:none;border-bottom:1px solid var(--border-light);border-left:3px solid var(--primary-green);background:var(--bg-card);display:flex;justify-content:space-between;align-items:center;gap:1rem;cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;border-radius:0;transition:background .2s ease,border-color .2s ease}.subject-header:hover{background:var(--bg-secondary)}.subject-header:focus-visible{outline:3px solid rgba(34,197,94,.25);outline-offset:2px}.subject-title{flex:1}.subject-title h3{color:var(--text-primary);font-size:1rem;font-weight:600;margin-bottom:.25rem}.subject-code{color:var(--text-tertiary);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.subject-meta{display:flex;flex-direction:column;gap:.25rem;align-items:flex-end;flex-shrink:0;margin-left:auto}.teacher-info,.credits-info{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;color:var(--text-secondary)}.label{font-weight:500;color:var(--text-tertiary)}.subject-content{display:flex;flex-direction:column;gap:1rem;padding:1rem;background:var(--bg-secondary-transparent)}.subject-description{margin:0;padding:.75rem 1rem;color:var(--text-secondary);font-size:.85rem;line-height:1.6;background:var(--bg-tertiary);border-radius:var(--border-radius);font-style:italic}.subject-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}.subject-column{display:flex;flex-direction:column;gap:1rem}.subject-empty{font-size:.8rem;color:var(--text-tertiary);background:var(--bg-tertiary);padding:.6rem .75rem;border-radius:var(--border-radius)}.expand-indicator{font-size:1.5rem;line-height:1;font-weight:400;color:var(--text-tertiary);margin-left:.5rem;min-width:1.25rem;text-align:center;transition:transform .2s ease}.subject-card.expanded .expand-indicator{color:var(--primary-green)}.schedule-section,.tasks-section,.tests-section{flex:1;min-width:0}.schedule-section h4,.tasks-section h4,.tests-section h4{color:var(--text-primary);font-size:.875rem;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-light)}.schedule-list{display:flex;flex-direction:column;gap:.375rem}.schedule-item{display:flex;flex-direction:column;gap:.35rem;padding:.5rem .6rem;background:var(--bg-tertiary);border-radius:var(--border-radius);font-size:.8rem}.schedule-day{color:var(--text-primary);font-weight:500;min-width:60px}.schedule-main,.schedule-meta{display:flex;justify-content:space-between;align-items:center;gap:.5rem}.schedule-time{color:var(--primary-green);font-weight:500;text-align:center;flex:1}.schedule-type{background:#22c55e1f;color:var(--primary-green);padding:.15rem .5rem;border-radius:999px;font-size:.7rem;text-transform:capitalize}.schedule-room{color:var(--text-secondary);text-align:right;min-width:40px}.resources-section{display:flex;flex-direction:column}.resources-section h4{color:var(--text-primary);font-size:.875rem;font-weight:600;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-light)}.resource-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:.5rem}.resource-list.single{gap:.35rem}.resource-item a{color:var(--primary-blue, #0ea5e9);font-size:.8rem;text-decoration:none;font-weight:500;word-break:break-word}.resource-item a:hover{text-decoration:underline}.resource-empty{font-size:.8rem;color:var(--text-tertiary);background:var(--bg-tertiary);padding:.5rem .75rem;border-radius:var(--border-radius)}.tasks-list{display:flex;flex-direction:column;gap:.5rem}.task-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:6px;transition:background-color .2s ease}.task-item:hover{background-color:#22c55e1a}.task-priority{width:4px;height:100%;border-radius:2px;min-height:30px}.task-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.task-title{color:var(--text-primary);font-weight:500;font-size:.9rem}.task-due{color:var(--text-secondary);font-size:.8rem}.tests-list{display:flex;flex-direction:column;gap:.5rem}.test-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background-color:var(--bg-tertiary);border-radius:6px;transition:background-color .2s ease}.test-item:hover{background-color:#22c55e1a}.test-icon{font-size:1.2rem;min-width:1.5rem}.test-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.test-title{color:var(--text-primary);font-weight:500;font-size:.9rem}.test-date{color:var(--text-secondary);font-size:.8rem}.test-type{background-color:var(--primary-green);color:#fff;padding:.2rem .6rem;border-radius:12px;font-size:.7rem;font-weight:600;text-transform:uppercase;white-space:nowrap}@media (max-width: 1024px){.subject-columns{grid-template-columns:1fr}}@media (max-width: 768px){.main-page{padding:1rem}.main-header{flex-direction:column;align-items:stretch}.page-title{text-align:left}.main-header{margin-bottom:1.5rem}.main-header h1{font-size:1.5rem}.subject-header{flex-direction:column;align-items:flex-start;gap:.75rem}.subject-meta{align-items:flex-start;width:100%}.subject-columns{grid-template-columns:1fr}}@media (max-width: 480px){.main-page{padding:.75rem}.schedule-item{flex-direction:column;align-items:flex-start;gap:.25rem}.schedule-day,.schedule-time,.schedule-room{min-width:auto;text-align:left}.subject-actions-header{flex-direction:column;width:100%;gap:.5rem}.action-btn{width:100%}}.subject-actions-header{display:flex;align-items:center;gap:.5rem;margin-left:auto}.action-btn{padding:.5rem 1rem;border-radius:6px;border:none;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.875rem;display:flex;align-items:center;gap:.25rem}.action-btn.edit-btn{background-color:#3b82f6;color:#fff}.action-btn.edit-btn:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.action-btn.delete-btn{background-color:#ef4444;color:#fff}.action-btn.delete-btn:hover{background-color:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.subject-header:disabled{cursor:default}.subject-card.editing{border:2px solid #3b82f6;box-shadow:0 4px 12px #3b82f633}.edit-subject-form{padding:1.5rem;background-color:var(--bg-secondary);border-radius:8px;margin-top:1rem}.edit-subject-form h3{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.25rem}.form-actions button{flex:1;padding:.75rem 1.5rem;border-radius:8px;border:none;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:.95rem}.cancel-button{background-color:#6b7280;color:#fff}.cancel-button:hover{background-color:#4b5563;transform:translateY(-1px);box-shadow:0 2px 8px #6b72804d}.schedule-page{padding:2rem;max-width:1600px;margin:0 auto;width:100%}.schedule-header{display:flex;flex-direction:column;gap:.35rem;margin-bottom:2rem}.schedule-header h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.schedule-header p{color:var(--text-secondary);font-size:.9rem;margin:0}.schedule-container{background-color:transparent;border-radius:12px;padding:0;margin-bottom:2rem}.schedule-grid{display:grid;grid-template-columns:80px repeat(5,1fr);gap:1px;background-color:var(--border-light);border-radius:12px;overflow:hidden;border:1px solid var(--border-light)}@media (min-width: 1440px){.schedule-grid{grid-template-columns:90px repeat(5,1fr);gap:1px}}.time-column{background-color:var(--bg-secondary)}.time-header{padding:.75rem .5rem;background-color:var(--bg-tertiary);color:var(--text-primary);font-weight:600;text-align:center;font-size:.875rem;border-bottom:1px solid var(--border-light)}.time-slot{padding:.25rem .25rem .5rem;height:80px;display:flex;align-items:flex-start;justify-content:center;background-color:var(--bg-secondary);color:var(--text-tertiary);font-size:.75rem;font-weight:500;border-bottom:1px solid var(--border-light)}.day-column{background-color:var(--bg-card);position:relative}.day-header{padding:.75rem .5rem;background-color:var(--bg-tertiary);text-align:center;border-bottom:1px solid var(--border-light)}.day-name{color:var(--text-primary);font-weight:600;font-size:.875rem}.day-content{position:relative;background-color:var(--bg-card);background-image:repeating-linear-gradient(to bottom,transparent,transparent 79px,var(--border-light) 79px,var(--border-light) 80px)}.schedule-block{position:absolute;left:6px;right:6px;border-radius:6px;padding:8px;font-size:.75rem;overflow:hidden;box-shadow:0 1px 3px #0000001a;cursor:pointer;transition:all .2s ease;border:1px solid;border-color:inherit}.schedule-block:hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}.schedule-content{height:100%;display:flex;flex-direction:column;gap:3px;font-weight:600}.subject-name{font-weight:700;font-size:.85rem;line-height:1.3;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;color:inherit;text-align:center}.subject-code{font-size:.7rem;opacity:.8;font-weight:500}.schedule-time{font-size:.7rem;opacity:.85;margin-top:auto;font-weight:600;color:inherit}.schedule-room-teacher{font-size:.7rem;opacity:.85;display:flex;justify-content:space-between;align-items:center;gap:.5rem;color:inherit;font-weight:600}.teacher-info,.room-info{font-size:.7rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;color:inherit}.room-info{text-align:right}.schedule-type{font-size:.7rem;text-transform:capitalize;opacity:.8;font-weight:500}.color-legend{margin-top:1.5rem;padding:1rem 0}.color-legend h4{color:var(--text-primary);font-size:.875rem;font-weight:600;margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.05em}.legend-items{display:flex;flex-wrap:wrap;gap:1rem}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:32px;height:20px;border-radius:4px;border:1px solid;border-color:inherit}.legend-label{color:var(--text-secondary);font-size:.8rem;text-transform:capitalize;font-weight:500}.schedule-summary{background-color:var(--bg-secondary);border-radius:12px;padding:2rem;box-shadow:0 4px 6px #0000001a}.schedule-summary h3{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.3rem}.today-classes{display:flex;flex-direction:column;gap:1rem}.class-item{display:flex;align-items:center;gap:1rem;padding:1rem;background-color:var(--bg-tertiary);border-radius:8px;transition:background-color .2s ease}.class-item:hover{background-color:#22c55e1a}.class-time{color:var(--primary-green);font-weight:600;min-width:120px}.class-info{flex:1;display:flex;flex-direction:column;gap:.25rem}.class-subject{color:var(--text-primary);font-weight:500}.class-room{color:var(--text-secondary);font-size:.9rem}.no-classes{text-align:center;color:var(--text-secondary);font-style:italic;padding:2rem}@media (max-width: 1200px){.schedule-grid{grid-template-columns:80px repeat(5,1fr)}.time-slot{padding:.5rem .25rem;font-size:.8rem}.schedule-block{font-size:.8rem;padding:6px}}@media (max-width: 768px){.schedule-page{padding:1rem}.schedule-header{margin-bottom:1.5rem}.schedule-header h2{font-size:1.5rem}.schedule-header p{font-size:.85rem}.schedule-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -1rem;padding:0 1rem}.schedule-grid{grid-template-columns:70px repeat(5,140px);min-width:770px;gap:1px}.time-column{width:70px}.time-header{padding:.625rem .375rem;font-size:.8rem}.time-slot{height:70px;padding:.375rem .25rem;font-size:.7rem}.day-column{width:140px}.day-header{padding:.625rem .5rem;font-size:.85rem}.day-content{min-height:auto}.schedule-block{font-size:.75rem;padding:4px 6px;min-height:30px}.subject-name{font-size:.75rem;font-weight:600;line-height:1.2;margin-bottom:2px}.schedule-time{font-size:.65rem;margin-bottom:2px}.schedule-room-teacher{font-size:.6rem;line-height:1.1}.teacher-info,.room-info{display:block}.schedule-container::-webkit-scrollbar{height:6px}.schedule-container::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.schedule-container::-webkit-scrollbar-thumb{background:var(--primary-green);border-radius:3px}.schedule-container::-webkit-scrollbar-thumb:hover{background:var(--primary-green-light)}}@media (max-width: 480px){.schedule-page{padding:.75rem}.schedule-header{margin-bottom:1.25rem}.schedule-header h2{font-size:1.35rem}.schedule-container{margin:0 -.75rem;padding:0 .75rem}.schedule-grid{grid-template-columns:65px repeat(5,130px);min-width:715px}.time-column{width:65px}.time-header{padding:.5rem .25rem;font-size:.75rem}.time-slot{height:65px;padding:.25rem .125rem;font-size:.65rem}.day-column{width:130px}.day-header{padding:.5rem .375rem;font-size:.8rem}.schedule-block{font-size:.7rem;padding:3px 4px;min-height:28px}.subject-name{font-size:.7rem}.schedule-time{font-size:.6rem}.schedule-room-teacher{font-size:.55rem}}.tasks-page{padding:2rem;max-width:1600px;margin:0 auto;width:100%}.tasks-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.tasks-controls{display:flex;gap:2rem;margin-bottom:2rem;padding:1.5rem;background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:12px;align-items:center;flex-wrap:wrap}.tasks-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;width:100%}@media (max-width: 768px){.tasks-stats{display:none}}.stat-item{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);padding:.65rem .75rem;border-radius:12px;box-shadow:0 2px 4px #00000014;transition:transform .18s ease;min-height:40px}.stat-item:hover{transform:translateY(-2px);box-shadow:0 3px 6px #0000001f}.stat-value{font-size:1.25rem;font-weight:700;color:var(--primary-green);line-height:1;display:inline-block;min-width:30px;text-align:center}.stat-label{color:var(--text-secondary);font-size:.8rem;font-weight:500;white-space:nowrap;opacity:.95;line-height:1;display:inline-block}@media (max-width: 968px){.tasks-stats{gap:.75rem}.stat-item{padding:.6rem .7rem;min-height:38px}.stat-value{font-size:1.15rem;min-width:28px}.stat-label{font-size:.75rem}}@media (max-width: 768px){.tasks-stats{grid-template-columns:repeat(3,1fr);gap:.625rem}.stat-item{padding:.5rem .625rem;min-height:36px;gap:.375rem}.stat-value{font-size:1.05rem;min-width:26px}.stat-label{font-size:.7rem}}@media (max-width: 640px){.tasks-stats{grid-template-columns:repeat(3,1fr);gap:.5rem}.stat-item{flex-direction:column;padding:.5rem;min-height:60px;gap:.25rem}.stat-value{font-size:1.3rem;min-width:auto}.stat-label{font-size:.7rem;text-align:center}}@media (max-width: 480px){.tasks-stats{grid-template-columns:1fr;gap:.625rem}.stat-item{flex-direction:row;justify-content:flex-start;padding:.75rem 1rem;min-height:40px;gap:.75rem}.stat-value{font-size:1.4rem;min-width:35px}.stat-label{font-size:.875rem;text-align:left}}.tasks-list{display:flex;flex-direction:column;gap:1rem}.task-card{background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 4px #0000001a;border:1px solid var(--border-light);transition:all .3s ease}.task-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.task-card.completed{opacity:.5}.task-card.high{border-left:4px solid #ef4444;background-color:#ef44440d}.task-card.medium{border-left:4px solid #f59e0b;background-color:#f59e0b0d}.task-card.low{border-left:4px solid #22c55e;background-color:#22c55e0d}.task-main{display:flex;justify-content:space-between;align-items:center;gap:1.5rem}.task-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.task-header{display:flex;flex-direction:column;gap:.5rem}.task-title-section{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.task-title{color:var(--text-primary);font-size:1.05rem;font-weight:600;margin:0;line-height:1.3}.task-subject-badge{color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:.25rem .75rem;background-color:var(--bg-tertiary);border-radius:20px}.task-description{color:var(--text-secondary);margin:0;line-height:1.4;font-size:.9rem}.task-meta{display:flex;gap:1rem;flex-wrap:wrap}.task-due-date{color:var(--text-secondary);font-size:.85rem;display:flex;align-items:center;gap:.25rem;font-weight:500}.task-actions{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:1rem;flex-shrink:0;min-width:200px}.task-buttons{display:flex;gap:.75rem;align-items:center}.task-status-checkbox{display:flex;align-items:center;order:2}.checkbox-container input[type=checkbox]{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkbox-label{color:var(--text-primary);font-size:.95rem;font-weight:500}.task-buttons{display:flex;gap:.5rem}.action-btn{padding:.4rem .85rem;border:none;border-radius:6px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap;border:1px solid transparent}.edit-btn:hover{background-color:var(--primary-green);color:#fff;border-color:var(--primary-green);transform:translateY(-1px);box-shadow:0 2px 6px #22c55e4d}.delete-btn:hover{background-color:#ef44441a;color:#ef4444;border-color:#ef44444d;transform:translateY(-1px);box-shadow:0 2px 6px #ef444433}.task-card.editing{background-color:var(--bg-secondary);border:2px solid var(--primary-green);padding:2rem}.edit-task-form{width:100%}.edit-task-form h3{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.25rem}.cancel-button{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light);padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;flex:1}.cancel-button:hover{background:var(--bg-secondary);transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.cancel-button:active{transform:translateY(0)}.submit-button{flex:1}.completed-tasks-section{margin-top:2rem}.completed-tasks-toggle{width:100%;background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:12px;padding:1rem 1.5rem;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;color:var(--text-primary);font-size:1rem;font-weight:600;text-align:left}.completed-tasks-toggle:hover{background-color:var(--bg-secondary);transform:translateY(-1px);box-shadow:0 2px 6px #0000001a}.toggle-icon{color:var(--primary-green);font-size:.9rem;transition:transform .2s ease}.completed-tasks-list{margin-top:1rem;display:flex;flex-direction:column;gap:1rem}@media (max-width: 968px){.tasks-page{padding:1.25rem}.page-title h2{font-size:1.5rem}}@media (max-width: 768px){.tasks-page{padding:1rem}.page-title h2{font-size:1.35rem}.page-title p{font-size:.85rem}.tasks-header{flex-direction:column;align-items:stretch;gap:.875rem}.page-title{text-align:left}.tasks-controls{flex-direction:column;align-items:stretch;gap:1rem}.filter-controls,.sort-controls{justify-content:space-between}.task-main{flex-direction:column;align-items:flex-start}.task-actions{width:100%;justify-content:space-between}.task-meta{flex-direction:column;gap:.5rem}.inline-form{padding:1.25rem}.form-grid{grid-template-columns:1fr;gap:1rem}}@media (max-width: 480px){.tasks-page{padding:.75rem}.page-title h2{font-size:1.2rem}.page-title p{font-size:.8rem}.tasks-header{gap:.75rem;margin-bottom:1.5rem}.form-toggle-button{padding:.625rem 1.25rem;font-size:.9rem}.inline-form{padding:1rem}.task-card{padding:.875rem 1rem}.task-actions{flex-direction:column;gap:.625rem;align-items:stretch}.task-buttons{order:1;width:100%;gap:.5rem}.action-btn{flex:1;padding:.5rem .75rem;font-size:.8rem}.task-status-checkbox{order:2;justify-content:center;padding:.375rem 0}}.tests-page{padding:2rem;max-width:1600px;margin:0 auto;width:100%}.tests-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;gap:1rem}.form-toggle-button{align-self:flex-start;background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:10px;padding:.75rem 1.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 6px #00000014}.form-toggle-button:hover{background:var(--bg-secondary);box-shadow:0 4px 10px #0000001f}.form-toggle-button:active{transform:translateY(1px)}.page-title{text-align:left}.page-title h2{color:var(--text-primary);font-size:1.75rem;font-weight:700;margin:0}.page-title p{color:var(--text-secondary);font-size:.9rem;margin-top:.25rem}.inline-form{background-color:var(--bg-secondary-transparent);border:1px solid var(--border-light);border-radius:12px;padding:1.75rem;margin-bottom:2rem;box-shadow:0 4px 12px #0000001f}.inline-form h3{color:var(--text-primary);margin-bottom:1.25rem;font-size:1.25rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{color:var(--text-primary);font-weight:500;font-size:.9rem}.form-group input,.form-group select,.form-group textarea{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light);border-radius:6px;padding:.75rem;font-size:1rem;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #22c55e1a}.form-group textarea{resize:vertical;font-family:inherit}.submit-button{background:linear-gradient(135deg,var(--primary-green),#16a34a);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.submit-button:hover{transform:translateY(-2px);box-shadow:0 6px 12px #22c55e66}.submit-button:active{transform:translateY(0)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--bg-tertiary);border-left:4px solid var(--primary-green);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}.today-alert{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;padding:1.5rem;border-radius:12px;margin-bottom:2rem;box-shadow:0 4px 6px #f59e0b4d}.today-alert h3{margin:0 0 1rem;font-size:1.2rem}.today-tests{display:flex;flex-direction:column;gap:.5rem}.today-test-item{display:flex;justify-content:space-between;align-items:center;background-color:#fff3;padding:.75rem;border-radius:6px}.tests-controls{display:flex;gap:2rem;margin-bottom:2rem;padding:1.5rem;background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);border-radius:12px;align-items:center;flex-wrap:wrap}.filter-controls,.sort-controls{display:flex;align-items:center;gap:.5rem}.filter-controls label,.sort-controls label{color:var(--text-primary);font-weight:500;font-size:.9rem}.filter-controls select,.sort-controls select{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--bg-tertiary);border-radius:6px;padding:.5rem 1rem;font-size:.9rem;cursor:pointer}.filter-controls select:focus,.sort-controls select:focus{outline:2px solid var(--primary-green);border-color:var(--primary-green)}.tests-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:2rem;width:100%}@media (max-width: 768px){.tests-stats{display:none}}.stat-item{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:.5rem;background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-light);padding:.5rem .6rem;border-radius:12px;box-shadow:0 2px 4px #00000014;transition:transform .18s ease;white-space:nowrap;min-height:34px}.stat-item:hover{transform:translateY(-2px)}.stat-value{display:block;font-size:2rem;font-weight:700;color:var(--primary-green);margin-bottom:.5rem}.stat-label{color:var(--text-secondary);font-size:.9rem;font-weight:500}.tests-list{display:flex;flex-direction:column;gap:1rem}.test-card{background-color:var(--bg-secondary-transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:1rem 1.25rem;box-shadow:0 2px 4px #0000001a;border:1px solid var(--border-light);transition:all .3s ease}.test-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.test-card.completed{opacity:.7}.test-card.editing{padding:1.5rem}.test-main{display:flex;justify-content:space-between;align-items:center;gap:1rem}.test-content{flex:1;min-width:0}.test-header{margin-bottom:.75rem}.test-title-section{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.5rem}.test-title{color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0;line-height:1.3}.test-subject-badge{color:var(--text-secondary);font-size:.85rem;font-weight:500;padding:.25rem .75rem;background-color:var(--bg-tertiary);border-radius:20px}.test-type-badge{color:#fff;padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:uppercase;display:flex;align-items:center;gap:.25rem}.test-description{color:var(--text-secondary);margin:0 0 .75rem;line-height:1.4;font-size:.9rem}.test-meta{display:flex;flex-wrap:wrap;gap:1rem;color:var(--text-secondary);font-size:.85rem}.test-meta span{display:flex;align-items:center;gap:.35rem}.test-actions{display:flex;flex-direction:row;align-items:center;justify-content:flex-end;gap:1rem;flex-shrink:0;min-width:200px}.test-buttons{display:flex;gap:.75rem;align-items:center}.action-btn{padding:.5rem 1rem;border:none;border-radius:8px;font-size:.8rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1);white-space:nowrap;border:1px solid transparent;box-shadow:0 1px 3px #0000001a}.edit-btn{background-color:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-light)}.edit-btn:hover{background-color:var(--primary-green);color:#fff;border-color:var(--primary-green);transform:translateY(-1px);box-shadow:0 2px 8px #22c55e4d}.delete-btn{background-color:var(--bg-secondary);color:var(--text-secondary);border-color:var(--border-light)}.delete-btn:hover{background-color:#ef44441a;color:#ef4444;border-color:#ef44444d;transform:translateY(-1px);box-shadow:0 2px 8px #ef444433}.action-btn:active{transform:translateY(0)}.test-status-checkbox{display:flex;align-items:center;order:2}.checkbox-container{display:flex;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;position:relative;padding:.375rem;border-radius:8px;transition:all .2s ease}.checkbox-container:hover{background-color:#22c55e14;transform:scale(1.05)}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;width:100%;height:100%;margin:0}.checkmark{position:relative;height:26px;width:26px;background-color:var(--bg-tertiary);border:2px solid var(--border-light);border-radius:8px;transition:all .2s cubic-bezier(.4,0,.2,1);flex-shrink:0;box-shadow:0 1px 3px #0000001a}.checkbox-container:hover .checkmark{border-color:var(--primary-green);box-shadow:0 2px 6px #22c55e33}.checkbox-container input:checked~.checkmark{background-color:var(--primary-green);border-color:var(--primary-green);box-shadow:0 2px 8px #22c55e4d}.checkmark:after{content:"";position:absolute;display:none;left:8px;top:4px;width:6px;height:12px;border:solid white;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{left:7px;top:3px;width:6px;height:11px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.edit-test-form{width:100%}.edit-test-form h3{color:var(--text-primary);margin-bottom:1.25rem;font-size:1.15rem}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.cancel-button{background-color:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-light);padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;width:100%}.cancel-button:hover{background-color:var(--bg-secondary)}.completed-tests-section{margin-top:2rem;border-top:1px solid var(--border-light);padding-top:1rem}.completed-tests-toggle{background:var(--bg-secondary-transparent);border:1px solid var(--border-light);border-radius:8px;padding:.75rem 1.25rem;width:100%;text-align:left;cursor:pointer;color:var(--text-secondary);font-weight:500;display:flex;align-items:center;gap:.75rem;transition:all .2s ease}.completed-tests-toggle:hover{background-color:var(--bg-tertiary);color:var(--text-primary)}.toggle-icon{font-size:.75rem;transition:transform .2s ease}.completed-tests-list{display:flex;flex-direction:column;gap:1rem;margin-top:1rem}.empty-state{text-align:center;padding:3rem;background-color:var(--bg-secondary);border-radius:12px;margin-top:2rem}.empty-state h3{color:var(--text-primary);margin-bottom:1rem}.empty-state p{color:var(--text-secondary)}@media (max-width: 768px){.tests-page{padding:1rem}.tests-header{flex-direction:column;align-items:stretch}.page-title{text-align:left}.tests-controls{flex-direction:column;align-items:stretch;gap:1rem}.filter-controls,.sort-controls{justify-content:space-between}.test-header{flex-direction:column;align-items:flex-start;gap:.5rem}.test-main{flex-direction:column}.test-right{align-self:stretch}.test-countdown{min-width:auto}.test-details{grid-template-columns:1fr;gap:.5rem}.tests-stats{grid-template-columns:repeat(2,1fr)}.today-test-item{flex-direction:column;align-items:flex-start;gap:.5rem}}.pomodoro-page{max-width:800px;margin:0 auto;padding:2rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.pomodoro-container{background:transparent;border-radius:var(--border-radius);padding:2rem}.pomodoro-container h1{text-align:center;margin-bottom:2rem;color:var(--text-primary);font-size:1.8rem;font-weight:600}.timer-section{text-align:center;margin-bottom:3rem;background:var(--bg-card);border-radius:var(--border-radius);padding:2rem;box-shadow:var(--shadow-md);border:1px solid var(--border-light)}.timer-display{margin-bottom:2rem}.timer-circle{position:relative;display:inline-block;width:200px;height:200px}.progress-ring{transform:rotate(-90deg);width:200px;height:200px}.progress-ring-circle{transition:stroke-dashoffset .3s ease-in-out;stroke-linecap:round}.work-mode .progress-ring-circle{stroke:var(--primary-green)}.break-mode .progress-ring-circle{stroke:#fb923c}.timer-content{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.timer-time{font-size:2.5rem;font-weight:700;color:var(--text-primary);font-family:Courier New,monospace;margin-bottom:.5rem}.timer-mode{font-size:1rem;color:var(--text-secondary);font-weight:500}.timer-controls{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.control-btn{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all .2s ease;min-width:100px}.start-btn,.resume-btn{background:var(--primary-green);color:#fff}.start-btn:hover,.resume-btn:hover{background:#1e3a2a;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #2d5a3d4d}.pause-btn{background:#fb923c;color:#fff}.pause-btn:hover{background:#ea580c;transform:translateY(-2px)}.stop-btn{background:#dc2626;color:#fff}.stop-btn:hover{background:#b91c1c;transform:translateY(-2px)}.settings-section{margin-bottom:2rem;padding:2rem;background:var(--bg-card);border-radius:var(--border-radius);box-shadow:var(--shadow-md);border:1px solid var(--border-light)}.settings-section h3{text-align:center;margin-bottom:1.5rem;color:var(--text-primary);font-size:1.5rem}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}.setting-item{text-align:center}.setting-item label{display:block;margin-bottom:.5rem;color:var(--text-secondary);font-weight:500}.input-controls{display:flex;align-items:center;justify-content:center;gap:.5rem}.input-controls input{width:80px;padding:.5rem;text-align:center;border:2px solid var(--border-light);border-radius:var(--border-radius);background:var(--bg-card);color:var(--text-primary);font-size:1.1rem;font-weight:600;line-height:1.2}.input-controls input:focus{outline:none;border-color:var(--primary-green)}.input-controls input:disabled{opacity:.6;cursor:not-allowed}.input-btn{width:36px;height:36px;border:2px solid var(--border-medium);background:var(--bg-card);color:var(--text-primary);border-radius:var(--border-radius);cursor:pointer;font-size:1.2rem;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.input-btn:hover:not(:disabled){background:var(--primary-green);color:#fff;border-color:var(--primary-green)}.input-btn:disabled{opacity:.4;cursor:not-allowed}.pomodoro-info{padding:2rem;background:var(--bg-card);border-radius:var(--border-radius);box-shadow:var(--shadow-md);border-left:4px solid var(--primary-green);border:1px solid var(--border-light)}.tutorial-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.tutorial-header h3{margin:0;font-size:1.3rem;color:var(--text-primary)}.tutorial-close{background:none;border:none;font-size:1.5rem;color:var(--text-tertiary);cursor:pointer;padding:.25rem;border-radius:50%;width:2rem;height:2rem;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.tutorial-close:hover{background:var(--bg-hover);color:var(--text-secondary)}.pomodoro-info ul{list-style:none;padding:0}.pomodoro-info li{position:relative;padding:.5rem 0 .5rem 2rem;color:var(--text-secondary)}.pomodoro-info li:before{content:"•";position:absolute;left:0;top:.5rem;color:var(--primary-green);font-weight:700}@media (max-width: 768px){.pomodoro-page{padding:1rem}.pomodoro-container{padding:1.5rem}.timer-time{font-size:2rem}.timer-controls{gap:.5rem}.control-btn{padding:.6rem 1rem;min-width:80px;font-size:.9rem}.settings-grid{grid-template-columns:1fr;gap:1.5rem}.settings-section{padding:1.5rem}}@media (max-width: 480px){.timer-circle,.progress-ring{width:160px;height:160px}.timer-time{font-size:1.8rem}.timer-controls{flex-direction:column;align-items:center}.control-btn{width:100%;max-width:200px}}.custom-auth{width:100%;max-width:400px}.custom-auth form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:14px;font-weight:500;color:var(--text-secondary)}.form-group input{padding:10px 15px;border:1px solid var(--border-light);border-radius:var(--border-radius);background:var(--bg-card);color:var(--text-primary);font-size:14px;transition:all .2s ease}.form-group input:focus{outline:none;border-color:var(--primary-green);box-shadow:0 0 0 3px #4caf501a}.form-group input::placeholder{color:var(--text-tertiary)}.message{padding:12px;border-radius:var(--border-radius);font-size:14px;text-align:center}.message.success{background:#4caf501a;color:var(--primary-green);border:1px solid rgba(76,175,80,.3)}.message.error{background:#f443361a;color:var(--error-color);border:1px solid rgba(244,67,54,.3)}.submit-btn{padding:12px 24px;background:var(--primary-green);color:#fff;border:none;border-radius:var(--border-radius);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;margin-top:8px}.submit-btn:hover:not(:disabled){background:var(--primary-green-light);transform:translateY(-1px);box-shadow:0 4px 8px #4caf5033}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.auth-links{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid var(--border-light)}.link-btn{background:none;border:none;color:var(--primary-green);font-size:14px;cursor:pointer;padding:4px;text-align:center;transition:all .2s ease}.link-btn:hover{color:var(--primary-green-light);text-decoration:underline}.landing-page{width:100vw;min-height:100vh;background-color:#fff;background-image:linear-gradient(rgba(0,0,0,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.03) 1px,transparent 1px);background-size:20px 20px;overflow-x:hidden;margin:0;padding:0;position:relative}body:has(.landing-page),html:has(.landing-page){margin:0!important;padding:0!important;overflow-x:hidden}#root:has(.landing-page){margin:0!important;padding:0!important;width:100vw}.landing-nav{background:#fffffffa;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:2px solid #228b22;box-shadow:0 2px 10px #0000000d;position:sticky;top:0;z-index:100;width:100vw;margin:0;padding:0;left:0;right:0}.nav-content{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;max-width:1200px;margin:0 auto;width:90%}.logo{display:flex;align-items:center;gap:.5rem;font-size:1.4rem;font-weight:700;color:#228b22}.logo-icon{font-size:2rem}.nav-actions{display:flex;gap:1rem;align-items:center}.nav-link{background:none;border:none;color:#2d5016;font-size:.95rem;cursor:pointer;padding:.6rem 1rem;transition:color .3s}.nav-link:hover{color:#228b22}.hero-section{min-height:90vh;position:relative;width:100vw;display:flex;align-items:center;margin:0;padding:0;left:0;right:0}.hero-content{display:grid;grid-template-columns:1fr 1fr;gap:4rem;padding:5rem 0;max-width:1200px;margin:0 auto;align-items:center;width:90%}.hero-text{color:#1a1a1a}.hero-title{font-size:4rem;font-weight:800;line-height:1.2;margin-bottom:1.5rem}.highlight{background:linear-gradient(120deg,#228b22,#32cd32);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.4rem;line-height:1.8;color:#4a5568;margin-bottom:2rem}.hero-form{display:flex;gap:1rem;margin-bottom:1rem}.email-input{flex:1;padding:1rem 1.5rem;border:none;border-radius:12px;font-size:1.05rem;background:#fff;box-shadow:0 4px 20px #0000001a}.hero-cta{padding:1rem 3rem;background:linear-gradient(135deg,#228b22,#32cd32);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px #228b224d}.hero-cta:hover{transform:translateY(-2px);box-shadow:0 6px 30px #228b2266}.hero-note{font-size:.9rem;color:#718096}.hero-visual{display:flex;flex-direction:column;gap:1.5rem;align-items:flex-end;justify-content:center}.visual-card{background:#fffffff2;border-radius:16px;padding:1.5rem;box-shadow:0 10px 40px #00000026;animation:float 3s ease-in-out infinite;width:100%;max-width:400px}.visual-card:nth-child(2){animation-delay:.5s;margin-right:3rem;width:100%;max-width:400px}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.preview-header{font-weight:600;color:#333;margin-bottom:1rem;font-size:1rem}.preview-content{display:flex;flex-direction:column;gap:.75rem}.preview-bar{height:40px;border-radius:8px;animation:pulse 2s ease-in-out infinite}.preview-bar.blue{background:#93c5fd80}.preview-bar.yellow{background:#fcd34d80}.preview-bar.orange{background:#fdba7480}.preview-bar.purple{background:#c4b5fd80}.task-line{height:30px;background:#86efac4d;border-radius:6px;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.features-section{padding:6rem 0;background:linear-gradient(180deg,#f8fdf9,#fff);width:100vw;position:relative;margin:0;left:0;right:0}.features-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(34,139,34,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(34,139,34,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.section-header{text-align:center;margin-bottom:4rem;max-width:700px;margin-left:auto;margin-right:auto;padding:0 5%;position:relative;z-index:1;display:flex;flex-direction:column;align-items:center}.section-header h2{font-size:2.75rem;font-weight:700;color:#1a202c;margin-bottom:.75rem;text-align:center}.section-header p{font-size:1.15rem;color:#718096;text-align:center;margin:0}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto;width:90%;position:relative;z-index:1}.feature-card{padding:2rem;border-radius:16px;background:#fff;transition:transform .3s,box-shadow .3s;text-align:center;border:1px solid rgba(34,139,34,.1);position:relative;z-index:1}.feature-card:hover{transform:translateY(-5px);box-shadow:0 10px 30px #0000001a}.feature-icon{font-size:3.25rem;margin-bottom:1rem}.feature-title{font-size:1.4rem;font-weight:600;color:#1a202c;margin-bottom:.75rem}.feature-description{color:#718096;line-height:1.6;font-size:1.05rem}.how-it-works-section{padding:6rem 0;background:linear-gradient(135deg,#2d5016,#1e7e1e);color:#fff;position:relative;width:100vw;margin:0;left:0;right:0}.how-it-works-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.08) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.08) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.how-it-works-section .section-header h2,.how-it-works-section .section-header p{color:#fff}.steps-container{display:flex;justify-content:center;align-items:center;gap:2rem;max-width:1200px;margin:0 auto;flex-wrap:wrap;width:90%;position:relative;z-index:1}.step{flex:1;min-width:250px;text-align:center;padding:2rem;background:#ffffff26;border-radius:16px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2)}.step-number{width:60px;height:60px;border-radius:50%;background:#fff;color:#1e7e1e;display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:800;margin:0 auto 1.5rem;box-shadow:0 4px 15px #0003}.step h3{font-size:1.5rem;margin-bottom:.75rem;color:#fff;font-weight:600}.step p{color:#fffffff2;line-height:1.6;font-size:1rem}.step-arrow{font-size:2rem;opacity:.7;color:#fff}.testimonials-section{padding:6rem 0;background:#fafafa;width:100vw;position:relative;margin:0;left:0;right:0}.testimonials-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:2rem;max-width:1200px;margin:0 auto;width:90%;position:relative;z-index:1}.testimonial-card{padding:2rem;background:#fff;border-radius:16px;box-shadow:0 4px 20px #0000000d;border:1px solid rgba(34,139,34,.1);transition:all .3s ease;position:relative;z-index:1}.testimonial-card:hover{box-shadow:0 8px 30px #228b221a;transform:translateY(-3px)}.testimonial-quote{font-size:1.2rem;line-height:1.8;color:#2d3748;margin-bottom:1.5rem;font-style:italic}.testimonial-author{display:flex;align-items:center;gap:1rem}.author-image{font-size:3rem}.author-name{font-weight:600;color:#1a202c}.author-role{font-size:.9rem;color:#718096}.stats-section{padding:4rem 0;background:linear-gradient(135deg,#e8f5e9,#f1f8f4);position:relative;width:100vw;margin:0;left:0;right:0;border-top:1px solid rgba(34,139,34,.1);border-bottom:1px solid rgba(34,139,34,.1)}.stats-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(34,139,34,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(34,139,34,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.stats-grid{display:flex;justify-content:center;align-items:center;gap:3.5rem;max-width:1000px;margin:0 auto;width:90%;position:relative;z-index:1;padding:1rem 0}.stats-grid>.stat-item{padding:0;text-align:center;transition:none;position:relative;background:transparent;border-radius:0;border:none;box-shadow:none;min-width:0;display:flex;flex-direction:column;align-items:center;gap:.25rem}.stats-grid>.stat-item+.stat-item{padding-left:2.5rem;margin-left:2.5rem;border-left:1px solid rgba(0,0,0,.06)}.stat-number{font-size:2.75rem;font-weight:700;margin-bottom:0;color:#228b22;line-height:1;letter-spacing:-.02em}.stat-label{font-size:1rem;color:#6b7280;font-weight:500;line-height:1.2}.cta-section{padding:6rem 0;background:#fafafa;width:100vw;position:relative;margin:0;left:0;right:0}.cta-section:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(0,0,0,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(0,0,0,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.cta-content{max-width:800px;margin:0 auto;text-align:center;padding:0 5%;position:relative;z-index:1}.cta-content h2{font-size:2.9rem;font-weight:700;color:#1a202c;margin-bottom:1rem}.cta-content p{font-size:1.3rem;color:#718096;margin-bottom:2rem}.cta-button{padding:.6rem 1.5rem;background:linear-gradient(135deg,#228b22,#32cd32);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px #228b224d}.cta-button-large{padding:1rem 2.5rem;background:linear-gradient(135deg,#228b22,#32cd32);color:#fff;border:none;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .3s,box-shadow .3s;box-shadow:0 4px 20px #228b224d}.cta-button-large{padding:1.25rem 3rem;font-size:1.2rem}.cta-button:hover,.cta-button-large:hover{transform:translateY(-2px);box-shadow:0 6px 30px #228b2266}.cta-note{margin-top:1rem;color:#718096;font-size:.9rem}.landing-footer{background:#1a202c;color:#fff;width:100vw;position:relative;margin:0;padding:0;left:0;right:0}.landing-footer:before{content:"";position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:20px 20px;pointer-events:none}.footer-content{display:grid;grid-template-columns:2fr 3fr;gap:4rem;max-width:1200px;margin:0 auto;width:90%;padding:4rem 0 3rem;position:relative;z-index:1}.footer-links{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}.footer-brand{position:relative;z-index:1}.footer-brand .logo{color:#fff;margin-bottom:1rem}.footer-brand p{margin-top:1rem;opacity:.8;line-height:1.6}.footer-column{position:relative;z-index:1}.footer-column h4{margin-bottom:1rem;font-size:1.1rem;color:#fff}.footer-column a{display:block;color:#ffffffb3;text-decoration:none;margin-bottom:.75rem;transition:color .3s}.footer-column a:hover{color:#fff}.footer-bottom{text-align:center;padding:2rem 0;border-top:1px solid rgba(255,255,255,.1);opacity:.7;max-width:1200px;margin:0 auto;width:90%;position:relative;z-index:1}@media (max-width: 1024px){.hero-content{grid-template-columns:1fr;gap:3rem;text-align:center}.hero-title{font-size:2.5rem}.hero-visual{max-width:500px;margin:0 auto}.visual-card:nth-child(2){margin-right:0}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}.footer-content{grid-template-columns:1fr;gap:2rem}.footer-links{grid-template-columns:repeat(3,1fr)}}@media (max-width: 768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1rem}.hero-form{flex-direction:column}.section-header h2{font-size:2rem}.step-arrow{display:none}.nav-content{padding:1rem 0}.nav-actions{gap:.5rem}.nav-link{padding:.5rem;font-size:.9rem}.stats-grid{grid-template-columns:1fr;gap:1rem}.stat-number{font-size:1.75rem}.footer-links{grid-template-columns:1fr}}
