@import "https://fonts.googleapis.com/css2?family=Figtree:wght@400;500;600;700;800&display=swap";:root{--bg:#f8f7fc;--surface:#fff;--surface-2:#f1eef9;--text:#5a5070;--text-h:#1e1730;--text-muted:#9a93ae;--accent:#7c3aed;--accent-light:#ede9fe;--accent-border:#7c3aed40;--accent-bg:#7c3aed14;--danger:#dc2626;--danger-bg:#dc262614;--warn:#d97706;--warn-bg:#d977061a;--success:#059669;--success-bg:#05966914;--border:#e4dff2;--code-bg:#f1eef9;--shadow-sm:0 1px 2px #1e17300f;--shadow:0 4px 12px #1e173014, 0 1px 3px #1e17300d;--shadow-lg:0 16px 40px #1e173024;--radius-sm:8px;--radius:12px;--radius-lg:16px;--radius-xl:20px;--sans:"Figtree", system-ui, sans-serif;--heading:"Figtree", system-ui, sans-serif;--mono:ui-monospace, Consolas, monospace;font:16px/150% var(--sans);color:var(--text);background:var(--bg);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;font-synthesis:none}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial;--bg:#120f1d;--surface:#1c1728;--surface-2:#241e35;--text:#9689b4;--text-h:#f0ecf9;--text-muted:#6b608a;--accent:#a78bfa;--accent-light:#a78bfa26;--accent-border:#a78bfa4d;--accent-bg:#a78bfa1a;--border:#2d2545;--code-bg:#241e35;--shadow-sm:0 1px 2px #0000004d;--shadow:0 4px 12px #0000004d;--shadow-lg:0 16px 40px #00000080}}*,:before,:after{box-sizing:border-box}body{margin:0}#root{border-inline:1px solid var(--border);background:var(--bg);flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}h1,h2,h3{font-family:var(--heading);color:var(--text-h)}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px;font-weight:800}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.22px;margin:0 0 8px;font-size:22px;font-weight:700;line-height:118%}@media (width<=1024px){h2{font-size:18px}}p{margin:0}code{font-family:var(--mono);background:var(--code-bg);color:var(--text-h);border-radius:4px;padding:4px 8px;font-size:15px;line-height:135%}.app-shell{flex-direction:column;min-height:100dvh;display:flex}.app-header{z-index:100;background:var(--surface);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;height:56px;padding:0 16px;display:flex;position:sticky;top:0}.app-header-avatar{background:var(--accent-light);width:34px;height:34px;color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;font-weight:700;text-decoration:none;transition:background .15s,color .15s;display:flex}.app-header-avatar:hover{background:var(--accent);color:#fff}.app-header-flat-name{color:var(--text-h);text-align:center;white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:14px;font-weight:600;overflow:hidden}.app-header-flat-select{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:14px;font-family:var(--sans);color:var(--text-h);cursor:pointer;outline:none;flex:1;max-width:200px;padding:6px 10px;font-weight:500;transition:border-color .15s}.app-header-flat-select:focus{border-color:var(--accent)}.app-header-signout{border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;font-family:var(--sans);cursor:pointer;color:var(--text);white-space:nowrap;background:0 0;padding:6px 12px;font-weight:500;transition:background .15s,color .15s}.app-header-signout:hover{background:var(--surface-2);color:var(--text-h)}.app-shell-content{flex:1;padding-bottom:72px;overflow-y:auto}.bottom-nav{background:var(--surface);border-top:1px solid var(--border);z-index:100;width:100%;max-width:1126px;height:64px;padding:0 4px;padding-bottom:env(safe-area-inset-bottom);align-items:stretch;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.bottom-nav a{letter-spacing:.3px;color:var(--text-muted);border-radius:var(--radius);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;padding:6px 4px;font-size:10px;font-weight:600;text-decoration:none;transition:color .2s;display:flex;position:relative}.bottom-nav a.active{color:var(--accent)}.bottom-nav a.active:before{content:"";background:var(--accent-light);border-radius:var(--radius);z-index:-1;position:absolute;inset:4px 6px}.sheet-backdrop{z-index:200;background:#00000073;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet-body{background:var(--surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-height:90dvh;box-shadow:var(--shadow-lg);padding:16px 20px 32px;overflow-y:auto}.sheet-handle{background:var(--border);border-radius:2px;width:36px;height:4px;margin:0 auto 16px}.calendar-nav{justify-content:space-between;align-items:center;padding:12px 12px 8px;display:flex}.calendar-nav-btn{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;color:var(--text);box-shadow:var(--shadow-sm);justify-content:center;align-items:center;font-size:18px;line-height:1;transition:background .15s,color .15s,border-color .15s;display:flex}.calendar-nav-btn:hover{background:var(--accent-light);color:var(--accent);border-color:var(--accent-border)}.calendar-nav-title{color:var(--text-h);font-size:16px;font-weight:700}.calendar-grid{grid-template-columns:repeat(7,1fr);gap:2px;padding:4px 8px 8px;display:grid}.calendar-day-header{text-align:center;letter-spacing:.5px;text-transform:uppercase;color:var(--text-muted);padding:4px 0 6px;font-size:10px;font-weight:600}.calendar-day{border-radius:var(--radius-sm);cursor:pointer;flex-direction:column;align-items:center;gap:3px;min-height:44px;padding:5px 4px;transition:background .15s;display:flex}.calendar-day:hover{background:var(--accent-light)}.calendar-day.today .day-number{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:24px;height:24px;display:flex}.calendar-day.other-month{opacity:.25}.day-number{font-size:13px;font-weight:500;line-height:1}.dot-row{flex-wrap:wrap;justify-content:center;gap:2px;display:flex}.assignment-dot{border-radius:50%;width:6px;height:6px}.auth-page{text-align:left;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:24px 16px 48px;display:flex}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:400px;box-shadow:var(--shadow-lg);padding:36px 32px}.auth-logo{color:var(--accent);letter-spacing:-.5px;text-align:center;justify-content:center;align-items:center;gap:10px;margin-bottom:28px;font-size:24px;font-weight:800;display:flex}.auth-title{color:var(--text-h);margin:0 0 20px;font-size:20px;font-weight:700}.auth-field{margin-bottom:14px}.auth-field label{color:var(--text-h);letter-spacing:.2px;margin-bottom:6px;font-size:13px;font-weight:600;display:block}.auth-field input{border:1.5px solid var(--border);border-radius:var(--radius);width:100%;font-size:16px;font-family:var(--sans);color:var(--text-h);background:var(--bg);box-sizing:border-box;outline:none;padding:11px 14px;transition:border-color .15s,box-shadow .15s}.auth-field input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.auth-btn{border-radius:var(--radius);background:var(--accent);color:#fff;width:100%;font-size:16px;font-weight:700;font-family:var(--sans);cursor:pointer;letter-spacing:.1px;border:none;margin-top:8px;padding:13px;transition:opacity .15s,transform .1s}.auth-btn:disabled{opacity:.5;cursor:default}.auth-btn:not(:disabled):hover{opacity:.9;transform:translateY(-1px)}.auth-btn:not(:disabled):active{transform:translateY(0)}.auth-error{border-radius:var(--radius-sm);background:var(--danger-bg);color:var(--danger);border:1px solid #dc262626;margin:10px 0 0;padding:10px 14px;font-size:14px;font-weight:500}.auth-switch{text-align:center;color:var(--text);margin-top:20px;font-size:14px}.auth-switch button{color:var(--accent);font-size:14px;font-weight:600;font-family:var(--sans);cursor:pointer;background:0 0;border:none;margin-left:4px;padding:0}.dev-quicklogin{border-top:1px dashed var(--border);margin-top:16px;padding-top:14px}.dev-quicklogin button{border:1px dashed var(--border);border-radius:var(--radius-sm);width:100%;font-size:12px;font-family:var(--sans);color:var(--text-muted);cursor:pointer;background:0 0;padding:8px;transition:background .15s}.dev-quicklogin button:hover{background:var(--surface-2)}.auth-hint{color:var(--text-muted);text-align:center;margin-top:14px;font-size:13px;line-height:1.5}.loading-page{color:var(--text-muted);justify-content:center;align-items:center;padding:4rem 1rem;font-size:.9rem;display:flex}.tasks-page{padding:16px}.tasks-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.tasks-title{color:var(--text-h);letter-spacing:-.3px;margin:0;font-size:24px;font-weight:800}.banana-score{color:var(--warn);background:var(--warn-bg);border-radius:20px;align-items:center;gap:4px;padding:5px 11px;font-size:13px;font-weight:600;display:inline-flex}.task-section{margin-bottom:24px}.task-section-label{letter-spacing:.08em;text-transform:uppercase;border-radius:20px;align-items:center;margin-bottom:10px;padding:4px 10px;font-size:11px;font-weight:700;display:inline-flex}.task-section-label.overdue{color:var(--danger);background:var(--danger-bg)}.task-section-label.due-soon{color:var(--warn);background:var(--warn-bg)}.task-section-label.upcoming{color:var(--text-muted);background:var(--surface-2)}.task-card{text-align:left;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;width:100%;font-family:var(--sans);border-left-width:3px;align-items:center;gap:12px;margin-bottom:8px;padding:14px 16px;transition:box-shadow .15s,transform .1s;display:flex}.task-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.task-card:active{transform:translateY(0)}.task-card.overdue{border-left-color:var(--danger)}.task-card.due-soon{border-left-color:var(--warn)}.task-card.upcoming{border-left-color:var(--border)}.task-card-body{flex:1;min-width:0}.task-card-name{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:15px;font-weight:600;overflow:hidden}.task-card-meta{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.task-card-missed{color:var(--danger);font-weight:500}.task-card-arrow{color:var(--text-muted);flex-shrink:0}.tasks-empty{text-align:center;padding:64px 16px}.tasks-empty-icon{margin-bottom:12px;font-size:48px;display:block}.tasks-empty-text{color:var(--text);font-size:16px;font-weight:600}.tasks-empty-sub{color:var(--text-muted);margin-top:4px;font-size:14px}.super-admin-nav{border-bottom:1px solid var(--border);gap:1rem;padding:.75rem 1rem;display:flex}.btn-primary{border-radius:var(--radius-sm);background:var(--accent);color:#fff;cursor:pointer;font-weight:600;font-family:var(--sans);white-space:nowrap;border:none;padding:6px 14px}.btn-primary:hover{opacity:.9}.btn-ghost{border-radius:var(--radius-sm);border:1px solid var(--border);cursor:pointer;font-weight:600;font-family:var(--sans);color:var(--text);background:0 0;padding:6px 12px}.btn-danger{background:var(--danger);color:#fff;border-radius:var(--radius-sm);cursor:pointer;font-family:var(--sans);border:none;padding:6px 12px;font-weight:600}.btn-danger:hover{opacity:.85}.text-danger{color:var(--danger);font-size:.875rem}
