:root{--font-apple:-apple-system, BlinkMacSystemFont, "SF Pro Text", "SF Pro Display", "Helvetica Neue", "Segoe UI", "Noto Sans", sans-serif;font-family:var(--font-apple);--radius-xs:6px;--radius-sm:10px;--radius-md:14px;--radius-lg:20px;--radius-xl:28px;--radius-full:999px;--sidebar-width:260px;--transition-micro:.12s cubic-bezier(.25, .1, .25, 1);--transition-fast:.2s cubic-bezier(.25, .1, .25, 1);--transition-base:.35s cubic-bezier(.25, .1, .25, 1);--transition-slow:.5s cubic-bezier(.25, .1, .25, 1);--transition-spring:.5s cubic-bezier(.34, 1.56, .64, 1);--apple-blue:#007aff;--apple-green:#34c759;--apple-red:#ff3b30;--apple-orange:#ff9500;--apple-yellow:#fc0;--apple-purple:#af52de;--apple-teal:#5ac8fa;--accent-blue:var(--apple-blue);--accent-red:var(--apple-red)}[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg-primary:#f8f8fa;--bg-secondary:#fff;--bg-tertiary:#f9f9fb;--bg-sidebar:#ffffffbf;--bg-glass:#ffffffbf;--bg-glass-hover:#ffffffd9;--bg-elevated:#fff;--surface-primary:#fffffffa;--surface-secondary:#00000008;--surface-tertiary:#0000000d;--surface-active:#007aff14;--text-primary:#1d1d1f;--text-secondary:#86868b;--text-tertiary:#aeaeb2;--text-link:#007aff;--accent:#007aff;--accent-hover:#0066d6;--accent-subtle:#007aff1a;--accent-glow:#007aff26;--border-primary:#00000014;--border-secondary:#0000000d;--border-active:#007aff4d;--shadow-xs:0 1px 2px #0000000a;--shadow-sm:0 2px 8px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--shadow-xl:0 16px 48px #0000001f;--shadow-card:0 1px 3px #0000000f, 0 4px 12px #0000000a;--shadow-card-hover:0 4px 16px #0000001a, 0 2px 6px #0000000f;--blur-md:blur(24px);--blur-lg:blur(40px);--scrollbar-thumb:#00000026;--scrollbar-hover:#00000040;--badge-green-bg:#34c7591a;--badge-green-text:#248a3d;--badge-green-border:#34c75933;--badge-amber-bg:#ff95001a;--badge-amber-text:#c93400;--badge-amber-border:#ff950033;--badge-red-bg:#ff3b3014;--badge-red-text:#d70015;--badge-red-border:#ff3b3026;--badge-blue-bg:#007aff14;--badge-blue-text:#0040dd;--badge-blue-border:#007aff26;--ring-green:#34c759;--ring-amber:#ff9500;--ring-red:#ff3b30;--ring-track:#0000000f;--input-bg:#fffffffa;--input-border:#0000001a;--input-focus-border:#007aff80;--input-focus-ring:#007aff1f;--modal-overlay:#0003;--glass-blur:32px;--glass-saturation:200%;--glass-bg-card:#ffffffbf;--glass-bg-card-hover:#ffffffd9;--glass-border:#ffffffe6;--glass-shadow:0 8px 32px #0000000a, inset 0 0 0 1px #ffffffb3;--glass-shadow-hover:0 12px 48px #00000014, inset 0 0 0 1px #ffffffe6;--glass-bg-elevated:#ffffffd9;--gradient-page:radial-gradient(at 0% 0%, #007aff26 0, transparent 50%), radial-gradient(at 50% 0%, #af52de1f 0, transparent 50%), radial-gradient(at 100% 0%, #ff95001f 0, transparent 50%);--border-glass:#fffc}[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-primary:#0f1012;--bg-secondary:#15161a;--bg-tertiary:#1a1c22;--bg-elevated:#191b20;--surface-primary:#181a20a6;--surface-secondary:#ffffff0d;--surface-tertiary:#ffffff14;--surface-active:#dc143c2e;--text-primary:#f5f5f7;--text-secondary:#b3b3ba;--text-tertiary:#6a6a72;--text-link:#dc143c;--accent:#dc143c;--accent-hover:#b8102e;--accent-subtle:#dc143c24;--accent-glow:#dc143c38;--border-primary:#ffffff1a;--border-secondary:#ffffff12;--border-active:#dc143c6b;--shadow-xs:0 1px 2px #00000057;--shadow-sm:0 4px 12px #0006;--shadow-md:0 8px 24px #00000075;--shadow-lg:0 14px 40px #00000085;--shadow-xl:0 24px 64px #0000009e;--shadow-card:0 10px 28px #0000005c;--shadow-card-hover:0 16px 40px #00000080;--blur-md:blur(24px);--blur-lg:blur(40px);--scrollbar-thumb:#ffffff24;--scrollbar-hover:#ffffff38;--badge-green-bg:#30d1581f;--badge-green-text:#30d158;--badge-green-border:#30d15833;--badge-amber-bg:#ff9f0a1f;--badge-amber-text:#ff9f0a;--badge-amber-border:#ff9f0a33;--badge-red-bg:#dc143c1a;--badge-red-text:#dc143c;--badge-red-border:#dc143c2e;--badge-blue-bg:#60a5fa1a;--badge-blue-text:#60a5fa;--badge-blue-border:#60a5fa2e;--ring-green:#30d158;--ring-amber:#ff9f0a;--ring-red:#dc143c;--ring-track:#ffffff14;--input-bg:#ffffff0a;--input-border:#ffffff17;--input-focus-border:#dc143c80;--input-focus-ring:#dc143c1f;--modal-overlay:#0a0b0ea3;--glass-blur:24px;--glass-saturation:200%;--glass-bg-card:#16181ec7;--glass-bg-card-hover:#1e2128d9;--glass-border:#ffffff1a;--glass-shadow:0 4px 24px #0000004d, inset 0 0 0 .5px #ffffff0f;--glass-shadow-hover:0 8px 40px #0006, inset 0 0 0 .5px #ffffff14;--glass-bg-elevated:#1a1c23e6;--gradient-page:radial-gradient(at 14% 8%, #dc143c29 0, transparent 42%), radial-gradient(at 86% 0%, #5ac8fa1a 0, transparent 38%), radial-gradient(at 100% 100%, #ff950014 0, transparent 36%), linear-gradient(180deg, #171920 0%, #111318 100%);--bg-sidebar:#15171ed1;--bg-glass:#161920cc;--bg-glass-hover:#1e222ce0;--border-glass:#ffffff1a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;background:#000;height:100%}body{min-height:100dvh;font-family:var(--font-apple);background:var(--bg-primary);background-image:var(--gradient-page);color:var(--text-primary);transition:background var(--transition-base), color var(--transition-base);background-attachment:fixed;font-size:14px;line-height:1.5;overflow-x:hidden}@media (width<=768px){body{min-height:calc(100dvh + 1.5px)}}body.mobile-sheet-open{overflow:hidden}.glass{background:var(--bg-glass);-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--border-glass);box-shadow:var(--glass-shadow,0 8px 32px 0 #0000000d);will-change:backdrop-filter;isolation:isolate;transform:translateZ(0)}.glass-card{background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));border-radius:var(--radius-lg);box-shadow:var(--glass-shadow);transition:all var(--transition-base);isolation:isolate;transform:translateZ(0)}.glass-card:hover{background:var(--glass-bg-card-hover,var(--bg-glass-hover));box-shadow:var(--glass-shadow-hover);transform:translateY(-2px)translateZ(0)}.glass-subtle{background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(12px)saturate(160%);border:1px solid var(--glass-border,var(--border-glass));isolation:isolate;transform:translateZ(0)}#root{min-height:100dvh;position:relative}h1,h2,h3,h4,h5,h6,p,ul,ol,figure,blockquote{margin:0}img,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit;color:inherit}button{cursor:pointer;background:0 0;border:0}input,select,textarea{border:1px solid var(--input-border);border-radius:var(--radius-sm);background:var(--input-bg);width:100%;color:var(--text-primary);transition:border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);padding:10px 14px;font-size:.875rem}input:focus,select:focus,textarea:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}input::placeholder{color:var(--text-tertiary)}::selection{background:var(--accent-subtle);color:var(--text-primary)}::-webkit-scrollbar{display:none}*{-ms-overflow-style:none;scrollbar-width:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-8px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}@keyframes pulseSoft{0%,to{opacity:1}50%{opacity:.4}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes shimmer{0%{background-position:-200%}to{background-position:200%}}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.3s both fadeIn}.animate-fade-in-up{animation:.45s both fadeInUp}.animate-fade-in-down{animation:.4s both fadeInDown}.animate-fade-in-scale{animation:.4s both fadeInScale}.animate-scale-in{animation:.35s both scaleIn}.animate-slide-up{animation:.5s both slideUp}.delay-1{animation-delay:60ms}.delay-2{animation-delay:.12s}.delay-3{animation-delay:.18s}.stagger-children>*{animation:.45s both fadeInUp}.stagger-children>:first-child{animation-delay:0s}.stagger-children>:nth-child(2){animation-delay:50ms}.stagger-children>:nth-child(3){animation-delay:.1s}.stagger-children>:nth-child(4){animation-delay:.15s}.stagger-children>:nth-child(5){animation-delay:.2s}.stagger-children>:nth-child(6){animation-delay:.25s}.stagger-children>:nth-child(7){animation-delay:.3s}.stagger-children>:nth-child(8){animation-delay:.35s}.stagger-children>:nth-child(9){animation-delay:.4s}.stagger-children>:nth-child(10){animation-delay:.45s}.badge{border-radius:var(--radius-full);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border:1px solid #0000;justify-content:center;align-items:center;min-height:24px;padding:0 10px;font-size:.7rem;font-weight:700;display:inline-flex}.badge-green{color:var(--badge-green-text);background:var(--badge-green-bg);border-color:var(--badge-green-border)}.badge-amber{color:var(--badge-amber-text);background:var(--badge-amber-bg);border-color:var(--badge-amber-border)}.badge-red{color:var(--badge-red-text);background:var(--badge-red-bg);border-color:var(--badge-red-border)}.badge-blue{color:var(--badge-blue-text);background:var(--badge-blue-bg);border-color:var(--badge-blue-border)}.spinner{border:2px solid var(--border-primary);border-top-color:var(--accent);border-radius:999px;width:18px;height:18px;animation:.7s linear infinite spin}.empty-state{border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-secondary));background:var(--glass-bg-card,var(--surface-primary));min-height:280px;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));text-align:center;place-items:center;gap:10px;padding:48px 24px;animation:.4s both fadeInUp;display:grid;transform:translateZ(0)}.empty-state .icon{width:48px;height:48px;color:var(--text-tertiary)}.empty-state h3{color:var(--text-primary);font-size:1rem;font-weight:700}.empty-state p{max-width:40ch;color:var(--text-secondary);font-size:.85rem}.mobile-day-order-badge,.greeting-mobile,.subtitle-mobile{display:none}@media (width<=768px){body{background-attachment:scroll}.greeting-desktop,.subtitle-desktop{display:none}.greeting-mobile,.subtitle-mobile{display:inline}.mobile-day-order-badge{margin-bottom:16px;display:flex}}.apple-modal-overlay{z-index:10000;isolation:isolate;pointer-events:auto;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;transform:translateZ(0);-webkit-backdrop-filter:blur(20px)saturate(180%)!important;background:#0a0b0e73!important}.apple-modal-card{border-radius:var(--radius-xl);background:var(--glass-bg-elevated,var(--bg-elevated));-webkit-backdrop-filter:blur(32px)saturate(200%);border:1px solid var(--glass-border,var(--border-primary));width:100%;max-width:480px;max-height:85vh;box-shadow:var(--shadow-xl);isolation:isolate;flex-direction:column;animation:.3s both scaleIn;display:flex;overflow:hidden;transform:translateZ(0)}[data-theme=dark] .apple-modal-card{-webkit-backdrop-filter:blur(40px)saturate(200%);background:#16181ed1}@supports not ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){[data-theme=light]{--glass-bg-card:#fffffff2;--glass-bg-card-hover:#fffffffa;--glass-bg-elevated:#fffffffa;--glass-border:#0000001a;--bg-glass:#fffffff2;--bg-glass-hover:#fffffffa;--bg-sidebar:#fffffff5;--surface-primary:#fffffff5}[data-theme=dark]{--glass-bg-card:#14161cf5;--glass-bg-card-hover:#1c1f26fa;--glass-bg-elevated:#181a20fa;--glass-border:#ffffff1f;--bg-glass:#14161cf5;--bg-glass-hover:#1c1f26fa;--bg-sidebar:#12141afa;--surface-primary:#16181ef5}}.login-wrapper{background:var(--bg-primary);min-height:100dvh;transition:background var(--transition-base);place-items:center;padding:24px;display:grid;position:relative;overflow:hidden}.login-bg{pointer-events:none;animation:1.5s fadeIn;position:absolute;inset:0}[data-theme=dark] .login-bg{background:radial-gradient(at 30% 20%,#0a84ff14 0%,#0000 60%),radial-gradient(at 70% 80%,#af52de0f 0%,#0000 50%)}[data-theme=light] .login-bg{background:radial-gradient(at 30% 20%,#007aff0f 0%,#0000 60%),radial-gradient(at 70% 80%,#5856d60a 0%,#0000 50%)}.login-card{z-index:1;border-radius:var(--radius-xl);background:var(--glass-bg-elevated,var(--bg-glass));-webkit-backdrop-filter:blur(32px)saturate(200%);border:1px solid var(--glass-border,var(--border-glass));width:100%;max-width:420px;transition:all var(--transition-base);isolation:isolate;flex-direction:column;gap:32px;padding:48px 40px;animation:.7s slideUp;display:flex;position:relative;transform:translateZ(0);box-shadow:0 16px 64px #00000026,inset 0 0 0 .5px #ffffff4d}.login-logo{text-align:center;flex-direction:column;align-items:center;gap:14px;display:flex}.login-logo-icon{background:var(--accent);color:#fff;width:60px;height:60px;box-shadow:0 8px 24px var(--accent-glow);transition:background var(--transition-base), box-shadow var(--transition-base);border-radius:16px;justify-content:center;align-items:center;animation:.5s .15s both fadeInScale;display:flex}.login-logo h1{letter-spacing:-1px;color:var(--text-primary);font-size:28px;font-weight:800}.login-logo p{color:var(--text-secondary);margin-top:-4px;font-size:14px;font-weight:500}.login-theme-toggle{border-radius:var(--radius-full);background:var(--surface-secondary);border:1px solid var(--border-secondary);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);z-index:2;justify-content:center;align-items:center;display:flex;position:absolute;top:16px;right:16px}.login-theme-toggle:hover{background:var(--surface-tertiary);color:var(--text-primary);transform:scale(1.05)}.login-theme-toggle:active{transform:scale(.95)}.login-form{flex-direction:column;gap:18px;display:flex}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{color:var(--text-secondary);letter-spacing:.02em;font-size:.78rem;font-weight:600}.form-input{border-radius:var(--radius-sm);border:1px solid var(--input-border);background:var(--input-bg);min-height:46px;color:var(--text-primary);transition:all var(--transition-fast);padding:0 14px;font-size:.88rem}.form-input:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.form-input::placeholder{color:var(--text-tertiary)}.form-input:disabled{opacity:.5;cursor:not-allowed}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper .form-input{width:100%;padding-right:46px}.password-toggle-btn{width:32px;height:32px;color:var(--text-tertiary);transition:all var(--transition-fast);cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:12px}.password-toggle-btn:hover{color:var(--text-primary);background:var(--surface-secondary)}.password-toggle-btn:active{transform:scale(.92)}.login-btn{color:#fff;background:var(--accent);cursor:pointer;min-height:48px;transition:all var(--transition-fast);border:none;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:0 20px;font-size:.9rem;font-weight:700;display:inline-flex;position:relative;overflow:hidden}.login-btn:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 8px 24px var(--accent-glow);transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)scale(.98)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{border-radius:var(--radius-sm);border:1px solid var(--badge-red-border);background:var(--badge-red-bg);color:var(--badge-red-text);padding:12px 14px;font-size:.82rem;font-weight:600;animation:.3s fadeInUp}.login-status{flex-direction:column;gap:8px;display:flex}.login-status-step{border-radius:var(--radius-sm);background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));color:var(--text-secondary);border:1px solid var(--glass-border,var(--border-glass));isolation:isolate;align-items:center;gap:10px;padding:10px 14px;font-size:.82rem;font-weight:500;animation:.3s both fadeInUp;display:flex;transform:translateZ(0)}.login-status-step.active{background:var(--badge-amber-bg);color:var(--badge-amber-text);border-color:var(--badge-amber-border)}.login-status-step.done{background:var(--badge-green-bg);color:var(--badge-green-text);border-color:var(--badge-green-border)}.login-status-dot{background:var(--text-tertiary);width:7px;height:7px;transition:background var(--transition-fast);border-radius:999px;flex-shrink:0}.login-status-step.active .login-status-dot{background:var(--badge-amber-text);animation:1.2s infinite pulseSoft}.login-status-step.done .login-status-dot{background:var(--badge-green-text)}.login-install-suggestion{background:var(--surface-primary);border:1px solid var(--border-glass);box-shadow:var(--shadow-md);border-radius:20px;justify-content:space-between;align-items:center;gap:12px;margin-bottom:-10px;padding:14px 14px 14px 18px;display:flex;position:relative;overflow:hidden}[data-theme=dark] .login-install-suggestion{background:linear-gradient(#ffffff0d 0%,#ffffff05 100%);border-color:#ffffff1a}.install-content{flex:1;align-items:center;gap:12px;min-width:0;display:flex}.install-icon-wrap{background:var(--accent-subtle);width:40px;height:40px;color:var(--accent);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.install-text h3{color:var(--text-primary);margin:0 0 2px;font-size:14px;font-weight:700}.install-text p{color:var(--text-secondary);margin:0;font-size:11px;font-weight:500;line-height:1.2}.ios-install-steps{color:var(--accent);background:var(--surface-secondary);border-radius:10px;align-items:center;gap:6px;padding:6px 10px;font-size:12px;font-weight:700;display:flex}.install-action-btn{background:var(--accent);color:#fff;border:none;border-radius:12px;padding:8px 14px;font-size:12px;font-weight:700}.install-hint{color:var(--text-tertiary);text-transform:uppercase;font-size:10px;font-weight:600}.install-close-btn{width:24px;height:24px;color:var(--text-tertiary);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.login-footer{color:var(--text-tertiary);text-align:center;font-size:.72rem}@media (width<=768px){.login-wrapper{padding:calc(16px + env(safe-area-inset-top,0px)) 16px calc(28px + env(safe-area-inset-bottom,0px));place-items:center}.login-card{border-radius:28px;gap:24px;max-width:460px;margin-top:0;padding:36px 28px 28px}.login-logo{text-align:center;align-items:center}.form-group label{text-align:left}.login-logo p{max-width:26ch;margin-top:0}.login-form{gap:16px}.login-btn{min-height:50px}}@media (width<=480px){.login-wrapper{padding:16px}.login-card{border-radius:var(--radius-lg);margin-top:0;padding:30px 22px 24px}.login-logo h1{font-size:24px}}.dashboard-layout{--ease-soft:cubic-bezier(.4, 0, .2, 1);--ease-emphasized:cubic-bezier(.3, 1.5, .5, 1);--ease-in-out-quint:cubic-bezier(.83, 0, .17, 1);background:var(--bg-primary);min-height:100dvh;transition:background var(--transition-base);display:flex;overflow:hidden}@keyframes apple-pop-press{0%{transform:scale(1)}25%{transform:scale(.88)}60%{transform:scale(1.08)}to{transform:scale(1)}}@keyframes apple-pop-ripple{0%{opacity:.4;transform:translate(-50%,-50%)scale(.2)}40%{opacity:.2}to{opacity:0;filter:blur(12px);transform:translate(-50%,-50%)scale(5.5)}}@keyframes apple-pop-icon-hop{0%{transform:translateY(0)scale(1)}35%{transform:translateY(-7px)scale(1.2)rotate(-3deg)}65%{transform:translateY(1.5px)scale(.96)rotate(1.5deg)}to{transform:translateY(0)scale(1)rotate(0)}}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));z-index:1100;height:auto;transition:all var(--transition-base);border-radius:var(--radius-xl);box-shadow:var(--glass-shadow,0 8px 32px 0 #0000000f);border:1px solid var(--glass-border,#ffffff73);isolation:isolate;flex-direction:column;display:flex;position:fixed;top:16px;bottom:16px;left:16px;overflow:hidden;transform:translateZ(0)}.dashboard-layout.sidebar-collapsed .sidebar{opacity:0;transform:translate(-300px)}.sidebar-header{align-items:center;gap:14px;padding:28px 24px;display:flex}.sidebar-logo{background:var(--accent);color:#fff;width:40px;height:40px;box-shadow:0 4px 12px var(--accent-glow);transition:transform var(--transition-fast), background var(--transition-base);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logo:hover{transform:scale(1.05)}.sidebar-brand h2{letter-spacing:-.5px;color:var(--text-primary);font-size:20px;font-weight:800}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:0 12px;display:flex;overflow-y:auto}.sidebar-item{color:var(--text-primary);opacity:.8;transition:all var(--transition-fast);cursor:pointer;isolation:isolate;border-radius:12px;align-items:center;gap:14px;padding:11px 16px;font-size:14px;font-weight:500;display:flex;position:relative;overflow:hidden}.sidebar-item:after{content:"";background:var(--accent);opacity:0;z-index:0;pointer-events:none;border-radius:999px;width:32px;height:32px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.2)}.sidebar-item.tap-burst{animation:apple-pop-press .42s var(--ease-emphasized)}.sidebar-item.tap-burst:after{animation:apple-pop-ripple .42s var(--ease-soft)}.sidebar-item.tap-burst .sidebar-item-icon{animation:apple-pop-icon-hop .42s var(--ease-emphasized)}.sidebar-item:hover{background:var(--bg-glass-hover);opacity:1;transform:translate(2px)}.sidebar-item.active{background:var(--surface-active);color:var(--accent);opacity:1;font-weight:600}.sidebar-item-icon{width:22px;height:22px;transition:transform var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-item.active .sidebar-item-icon{color:var(--accent);transform:scale(1.08)}.sidebar-overlay{z-index:1099;background:var(--modal-overlay);-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity var(--transition-base);display:none;position:fixed;inset:0}.sidebar-overlay.show{opacity:1;pointer-events:auto}.main-content{margin-left:calc(var(--sidebar-width) + 32px);transition:margin var(--transition-base);z-index:10;flex:1;height:100dvh;padding:32px 40px 40px 0;position:relative;overflow-y:auto}.dashboard-layout.sidebar-collapsed .main-content{margin-left:40px}.content-viewport{flex-direction:column;flex:1;width:100%;max-width:1600px;display:flex}.top-bar-container{justify-content:space-between;align-items:center;margin-bottom:32px;display:flex}.top-bar-container.compact{z-index:20;pointer-events:none;justify-content:flex-end;margin-bottom:-12px;position:relative}.top-bar-container.compact .top-bar-actions{pointer-events:auto}.greeting-section{flex-direction:column;gap:4px;display:flex}.greeting-text{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;font-size:13px;font-weight:600}.date-text{letter-spacing:-.8px;color:var(--text-primary);font-size:28px;font-weight:800}.top-bar-actions{align-items:center;gap:12px;display:flex;position:relative}.action-btn{border-radius:var(--radius-full);background:var(--glass-bg-card,var(--bg-glass));width:40px;height:40px;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);isolation:isolate;justify-content:center;align-items:center;display:flex;transform:translateZ(0)}.action-btn:hover{background:var(--bg-glass-hover);color:var(--text-primary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.action-btn:active{transform:translateY(0)scale(.96)}.action-btn.spinning svg{animation:1s linear infinite spin}.theme-toggle-btn:hover{color:var(--accent)}.user-profile-pill{border-radius:var(--radius-full);background:var(--glass-bg-card,var(--bg-glass));height:40px;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));cursor:pointer;transition:all var(--transition-fast);isolation:isolate;align-items:center;gap:10px;padding:0 6px 0 16px;display:flex;transform:translateZ(0)}.user-profile-pill:hover{background:var(--bg-glass-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.user-name{color:var(--text-primary);font-size:13px;font-weight:600}.user-avatar{border-radius:var(--radius-full);background:var(--accent);color:#fff;justify-content:center;align-items:center;width:30px;height:30px;font-size:11px;font-weight:700;display:flex}.profile-dropdown-card{background:var(--glass-bg-elevated,#ffffffd9);-webkit-backdrop-filter:blur(40px)saturate(200%);border:1px solid var(--glass-border,#00000014);border-radius:var(--radius-lg);z-index:100;isolation:isolate;width:320px;padding:24px;animation:.25s fadeInDown;position:absolute;top:52px;right:0;transform:translateZ(0);box-shadow:0 24px 64px #0000002e,inset 0 0 0 .5px #fff6}[data-theme=dark] .sidebar{background:var(--bg-sidebar);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%));border-color:var(--glass-border);box-shadow:var(--glass-shadow)}[data-theme=dark] .action-btn,[data-theme=dark] .user-profile-pill{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%));border-color:var(--glass-border);box-shadow:var(--glass-shadow)}[data-theme=dark] .action-btn:hover,[data-theme=dark] .user-profile-pill:hover{background:var(--glass-bg-card-hover);box-shadow:var(--glass-shadow-hover);border-color:#ffffff24}[data-theme=dark] .profile-dropdown-card{background:var(--glass-bg-elevated);-webkit-backdrop-filter:blur(40px)saturate(200%);border-color:var(--glass-border);box-shadow:0 32px 72px #00000080,inset 0 0 0 .5px #ffffff0f}.dropdown-user-info{text-align:center;flex-direction:column;align-items:center;gap:8px;display:flex}.user-avatar-large{border-radius:var(--radius-full);background:var(--accent);color:#fff;width:64px;height:64px;box-shadow:0 8px 24px var(--accent-glow);justify-content:center;align-items:center;font-size:22px;font-weight:800;display:flex}.dropdown-user-info h3{color:var(--text-primary);letter-spacing:-.02em;font-size:18px;font-weight:800}.dropdown-user-info p{color:var(--text-secondary);font-size:12px}.dropdown-divider{background:var(--border-secondary);opacity:.6;height:1px;margin:20px -24px}.dropdown-reg{color:var(--text-primary);letter-spacing:.02em;font-size:12px;font-weight:600}.dropdown-details{flex-direction:column;gap:8px;display:flex}.dropdown-detail-row{border-bottom:1px solid var(--border-secondary);justify-content:space-between;align-items:flex-start;gap:20px;padding:12px 0;display:flex}.dropdown-detail-row:last-child{border-bottom:none}.dropdown-detail-label{color:var(--text-primary);text-transform:uppercase;letter-spacing:.06em;flex-shrink:0;margin-top:3px;font-size:10px;font-weight:800}.dropdown-detail-value{color:var(--text-primary);text-align:right;word-break:break-word;max-width:180px;font-size:13px;font-weight:600;line-height:1.5}.logout-button{border-radius:var(--radius-md);width:100%;color:var(--badge-red-text);background:var(--badge-red-bg);transition:all var(--transition-fast);justify-content:center;align-items:center;gap:10px;margin-top:4px;padding:12px;font-size:14px;font-weight:700;display:flex}.logout-button:hover{background:var(--apple-red);color:#fff}.overview-hero{flex-direction:column;gap:28px;display:flex}.welcome-card{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-secondary));border-radius:var(--radius-lg);box-shadow:var(--glass-shadow,var(--shadow-card));transition:all var(--transition-base);isolation:isolate;align-items:center;gap:20px;padding:28px 32px;display:flex;transform:translateZ(0)}.welcome-icon{background:var(--accent-subtle);width:48px;height:48px;color:var(--accent);border-radius:14px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.welcome-text h2{letter-spacing:-.5px;color:var(--text-primary);font-size:22px;font-weight:800}.welcome-text p{color:var(--text-secondary);margin-top:4px;font-size:14px}.today-schedule-section{flex-direction:column;gap:16px;margin-top:8px;display:flex}.section-header{justify-content:space-between;align-items:center;display:flex}.section-header h3{color:var(--text-primary);letter-spacing:-.3px;font-size:18px;font-weight:700}.day-order-badge{background:var(--accent);color:#fff;letter-spacing:.5px;border-radius:8px;padding:4px 10px;font-size:11px;font-weight:800}.schedule-horizontal-scroll{scrollbar-width:none;gap:16px;padding-bottom:8px;display:flex;overflow-x:auto}.schedule-horizontal-scroll::-webkit-scrollbar{display:none}.schedule-empty-state{background:var(--surface-primary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);text-align:center;padding:24px 20px}.schedule-empty-state p{color:var(--text-secondary);margin:0;font-size:14px}.schedule-item-card{background:var(--glass-bg-card,var(--surface-primary));min-width:240px;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-secondary));border-radius:var(--radius-lg);transition:all var(--transition-base);isolation:isolate;flex-direction:column;gap:12px;padding:20px;display:flex;position:relative;overflow:hidden;transform:translateZ(0)}.schedule-item-card.current{border-color:var(--accent);background:var(--surface-active);box-shadow:0 0 0 1px var(--accent)}.item-time{color:var(--text-secondary);align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.schedule-item-card.current .item-time{color:var(--accent)}.item-subject{color:var(--text-primary);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;height:42px;font-size:15px;font-weight:700;line-height:1.4;display:-webkit-box;overflow:hidden}.item-footer{justify-content:space-between;align-items:center;margin-top:4px;display:flex}.item-room{color:var(--text-secondary);align-items:center;gap:5px;font-size:12px;font-weight:500;display:flex}.item-type{text-transform:uppercase;color:var(--accent);background:var(--accent-subtle);border-radius:6px;padding:2px 8px;font-size:10px;font-weight:700}.progress-container{background:var(--border-secondary);width:100%;height:4px;position:absolute;bottom:0;left:0}.progress-bar{background:var(--accent);height:100%;transition:width .5s ease-out}.overview-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:14px;display:grid}.overview-card{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-secondary));border-radius:var(--radius-lg);box-shadow:var(--glass-shadow,var(--shadow-card));cursor:pointer;transition:all var(--transition-fast);isolation:isolate;flex-direction:column;align-items:center;gap:12px;padding:28px 20px;display:flex;transform:translateZ(0)}.overview-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);transform:translateY(-2px)}.overview-card:active{transform:translateY(0)scale(.98)}.overview-card-icon{background:var(--accent-subtle);width:44px;height:44px;color:var(--accent);transition:all var(--transition-fast);border-radius:12px;justify-content:center;align-items:center;display:flex}.overview-card:hover .overview-card-icon{background:var(--accent);color:#fff}.overview-card-label{color:var(--text-primary);font-size:13px;font-weight:600}.ov-welcome{margin-bottom:4px}.ov-welcome h2{color:var(--text-primary);letter-spacing:-.5px;font-size:26px;font-weight:800}.ov-welcome-date{display:none}.ov-welcome p{color:var(--text-secondary);margin-top:4px;font-size:14px}.tod-section{background:radial-gradient(circle at 86% 12%, color-mix(in srgb, var(--accent) 10%, white 90%) 0%, transparent 56%), linear-gradient(138deg, color-mix(in srgb, var(--accent) 5%, white 95%) 0%, color-mix(in srgb, var(--surface-primary) 92%, white 8%) 74%);border:1px solid color-mix(in srgb, var(--accent) 10%, var(--border-secondary));border-radius:var(--radius-lg);box-shadow:var(--shadow-card);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:20px 22px;display:flex;position:relative;overflow:hidden}.tod-section:after{content:"";pointer-events:none;background:linear-gradient(#ffffff14,#0000 45%);position:absolute;inset:0}.tod-header-row{opacity:.85;margin-bottom:8px}.tod-header-row h3{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin:0;font-size:13px;font-weight:700}.tod-quote{color:var(--text-primary);white-space:pre-line;letter-spacing:.1px;max-width:62ch;margin:0 auto;font-size:16px;font-style:italic;font-weight:700;line-height:1.7}.tod-author{color:var(--text-secondary);letter-spacing:.2px;margin:2px auto 0;font-size:13px;font-weight:700}.tod-loading,.tod-fallback{color:var(--text-secondary);text-align:center;margin:0 auto;font-size:14px}[data-theme=dark] .tod-section{background:radial-gradient(circle at 84% 14%,#dc143c21 0%,#0000 58%),linear-gradient(140deg,#dc143c17 0%,#2a2e38d1 76%);border-color:#dc143c33}[data-theme=dark] .tod-section:after{background:linear-gradient(#ffffff0b,#0000 54%)}[data-theme=dark] .tod-quote{color:#f5f5f7;font-style:italic}[data-theme=dark] .tod-author,[data-theme=dark] .tod-loading,[data-theme=dark] .tod-fallback{color:#b8b8be}.ov-stats-row{grid-template-columns:repeat(4,1fr);gap:14px;display:grid}.ov-stat-card{background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));border-radius:var(--radius-lg);transition:all var(--transition-base);isolation:isolate;align-items:flex-start;gap:14px;padding:18px 20px;display:flex;transform:translateZ(0)}.ov-stat-card:hover{background:var(--glass-bg-card-hover,var(--bg-glass-hover));box-shadow:var(--glass-shadow-hover);transform:translateY(-2px)translateZ(0)}.ov-stat-icon-wrap{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ov-att{color:#34c759;background:#34c75926}.ov-marks{color:#007aff;background:#007aff26}.ov-courses{color:#5856d6;background:#5856d626}.ov-day{color:#ff9f0a;background:#ff9f0a26}.ov-dayorder-card{border-color:#ff9f0a66}.ov-stat-body{flex-direction:column;gap:2px;display:flex}.ov-stat-label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.ov-stat-value{color:var(--text-primary);letter-spacing:-.5px;font-size:22px;font-weight:800;line-height:1.2}.ov-stat-sub{color:var(--text-secondary);margin-top:2px;font-size:11px}.home-alerts-row{gap:12px;margin-bottom:24px;display:flex}.home-alert-pill{background:var(--surface-primary);border:1px solid var(--border-secondary);cursor:pointer;transition:all var(--transition-base);border-radius:16px;flex:1;align-items:center;gap:12px;padding:12px 16px;display:flex}.home-alert-pill:hover{border-color:var(--accent);background:var(--surface-secondary);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}.alert-pill-icon{background:var(--accent-subtle);width:40px;height:40px;color:var(--accent);border-radius:12px;justify-content:center;align-items:center;display:flex}.skip-pill .alert-pill-icon{color:#34c759;background:#34c7591a}.marks-pill .alert-pill-icon{color:#007aff;background:#007aff1a}.alert-pill-content{flex-direction:column;display:flex}.alert-pill-label{text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.05em;font-size:11px;font-weight:700}.alert-pill-value{color:var(--text-primary);font-size:14px;font-weight:700}.section-subhead{color:var(--text-secondary);margin-top:2px;font-size:13px}.home-attendance-alert{background:#ff3b3014;border:1px solid #ff3b3033;border-radius:14px;flex-direction:column;gap:12px;padding:14px;display:flex}.home-attendance-alert-header{align-items:flex-start;gap:10px;display:flex}.home-attendance-alert-icon{color:#ff3b30;flex-shrink:0}.home-attendance-alert-header h4{color:var(--text-primary);margin:0;font-size:14px;font-weight:700}.home-attendance-alert-header p{color:var(--text-secondary);margin:2px 0 0;font-size:13px}.home-attendance-alert-list{flex-wrap:wrap;gap:8px;display:flex}.home-attendance-alert-chip{color:#b42318;background:#ff3b301f;border-radius:999px;align-items:center;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.now-row{grid-template-columns:1fr 1fr;gap:14px;display:grid}.now-card{background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));border-radius:var(--radius-lg);transition:all var(--transition-base);isolation:isolate;flex-direction:column;gap:8px;padding:20px;display:flex;transform:translateZ(0)}.now-current{background:#34c75914;border-color:#34c75966}.now-card-top{justify-content:space-between;align-items:center;display:flex}.now-pill{text-transform:uppercase;letter-spacing:.5px;border-radius:6px;padding:3px 10px;font-size:11px;font-weight:700}.now-pill-current{color:#34c759;background:#34c75933}.now-pill-next{color:var(--accent);background:#007aff26}.now-mins-left{color:#34c759;font-size:12px;font-weight:600}.now-subject{color:var(--text-primary);font-size:16px;font-weight:700;line-height:1.3}.now-meta{color:var(--text-secondary);font-size:12px}.now-time-str{color:var(--text-secondary);margin-top:4px;font-size:13px;font-weight:600}.now-progress-track{background:#34c75933;border-radius:2px;height:4px;margin-top:8px;overflow:hidden}.now-progress-fill{background:#34c759;border-radius:2px;height:100%;transition:width .5s}.full-day-sched{flex-direction:column;gap:2px;display:flex}.full-day-sched h4{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.6px;margin-bottom:6px;font-size:11px;font-weight:700}.sched-row{transition:background var(--transition-base);border-radius:10px;align-items:center;gap:16px;padding:11px 14px;display:flex}.sched-row:hover{background:var(--surface-secondary)}.sched-row-active{background:#34c75914}.sched-row-active:hover{background:#34c7591f}.sched-time{color:var(--text-secondary);flex-shrink:0;width:64px;font-size:12px;font-weight:600}.sched-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sched-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:600;overflow:hidden}.sched-code{color:var(--text-tertiary);font-size:11px}.sched-type{color:var(--text-secondary);background:var(--surface-secondary);border-radius:6px;flex-shrink:0;padding:3px 8px;font-size:11px;font-weight:600}.home-footer{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--bg-glass));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));isolation:isolate;flex-direction:column;justify-content:center;align-items:center;gap:16px;padding:14px 18px;display:flex;transform:translateZ(0)}.home-footer-text{color:var(--text-secondary);text-align:center;margin:0;font-size:13px;font-weight:600}.home-footer-links{align-items:center;gap:10px;display:flex}.home-footer-link{width:34px;height:34px;color:var(--text-secondary);background:var(--surface-primary);border:1px solid var(--border-secondary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;display:inline-flex}.home-footer-link:hover{color:var(--accent);border-color:var(--border-active);transform:translateY(-1px)}@media (width<=768px){.sidebar,.sidebar-overlay{display:none}.dashboard-layout{height:auto;min-height:auto;display:block;overflow:visible}.main-content{padding:calc(12px + env(safe-area-inset-top,0px)) 16px calc(112px + env(safe-area-inset-bottom,0px)) 16px;height:auto;margin-left:0;overflow-y:visible}.dashboard-layout.sidebar-collapsed .main-content{margin-left:0}.top-bar-container.mobile-top-bar{z-index:60;justify-content:center;margin-bottom:20px;display:flex;position:relative}.mobile-top-shell{-webkit-backdrop-filter:blur(24px)saturate(200%);border:1px solid var(--border-glass);width:fit-content;min-width:280px;max-width:calc(100% - 32px);box-shadow:var(--glass-shadow,0 8px 24px #0000001f);isolation:isolate;background:#ffffffbf;border-radius:50px;justify-content:space-between;align-items:center;gap:12px;margin:8px auto;padding:6px 6px 6px 12px;display:flex;transform:translateZ(0)}[data-theme=dark] .mobile-top-shell{background:var(--glass-bg-elevated,#0e0f14b8);border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.mobile-brand-block{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.mobile-brand-logo{background:var(--accent);color:#fff;width:36px;height:36px;box-shadow:0 6px 16px var(--accent-glow);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.mobile-brand-copy{flex-direction:column;gap:4px;min-width:0;display:flex;overflow:hidden}.mobile-brand-kicker{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;font-size:11px;font-weight:700;line-height:1.4}.mobile-brand-title{color:var(--text-primary);letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;min-width:0;max-width:100%;font-size:17px;font-weight:700;line-height:1.2;display:block;overflow:hidden}.mobile-brand-meta{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.02em;font-size:11px;font-weight:600;line-height:1}.mobile-day-order-pill{background:var(--accent);color:#fff;width:fit-content;box-shadow:0 4px 10px var(--accent-glow);border-radius:20px;margin-top:2px;padding:3px 10px;font-size:10px;font-weight:800;display:inline-flex}.top-bar-container.mobile-top-bar .top-bar-actions{flex-shrink:0;align-items:center;gap:8px}.top-bar-container.mobile-top-bar .action-btn,.top-bar-container.mobile-top-bar .user-profile-pill{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:50%;justify-content:center;width:36px;min-width:36px;height:36px;padding:0}[data-theme=dark] .top-bar-container.mobile-top-bar .action-btn,[data-theme=dark] .top-bar-container.mobile-top-bar .user-profile-pill{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%));border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.top-bar-container.mobile-top-bar .user-name{display:none}.top-bar-container.mobile-top-bar .user-avatar{width:34px;height:34px}.profile-dropdown-card{width:auto;max-width:none;max-height:85vh;padding:28px 20px calc(24px + env(safe-area-inset-bottom,0px));z-index:2000;opacity:1;pointer-events:none;background:var(--glass-bg-elevated,#ffffffd1);-webkit-backdrop-filter:blur(28px)saturate(200%);border:1px solid var(--glass-border,var(--border-primary));isolation:isolate;border-bottom:none;border-radius:32px 32px 0 0;transition:transform .55s cubic-bezier(.16,1,.3,1),opacity .3s;position:fixed;inset:auto 4px 0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -12px 40px #0000001f}[data-theme=dark] .profile-dropdown-card{background:var(--glass-bg-elevated,#1c1c1ec7);border-color:var(--glass-border)}.profile-dropdown-card:before{content:"";background:#0000001a;border-radius:99px;width:40px;height:5px;position:absolute;top:10px;left:50%;transform:translate(-50%)}[data-theme=dark] .profile-dropdown-card:before{background:#ffffff26}.profile-dropdown-card.show{pointer-events:auto;transform:translate(0,0)}.profile-dropdown-card .dropdown-details{flex-direction:column;gap:0;margin-top:8px;display:flex}.profile-dropdown-card .dropdown-detail-row{border-bottom:1px solid #0000000d;flex-direction:column;align-items:flex-start;gap:4px;padding:12px 0}[data-theme=dark] .profile-dropdown-card .dropdown-detail-row{border-bottom-color:#ffffff0d}.profile-dropdown-card .dropdown-detail-row:last-child{border-bottom:none}.profile-dropdown-card .dropdown-detail-value{text-align:left;max-width:100%;color:var(--text-primary);font-size:.95rem;font-weight:600;line-height:1.3}.profile-dropdown-card .dropdown-detail-label{text-transform:uppercase;letter-spacing:.04em;color:var(--text-tertiary);font-size:.7rem;font-weight:700}.content-viewport{width:100%;padding-bottom:4px}.overview-hero{gap:20px}.ov-welcome{text-align:center;margin-bottom:2px}.ov-welcome h2{letter-spacing:-.02em;overflow-wrap:anywhere;font-size:clamp(22px,5.5vw,24px);line-height:1.2}.ov-welcome p{margin-top:4px;font-size:13px}.ov-welcome-date{color:var(--text-secondary);margin-top:2px;font-size:12px;font-weight:600;display:block}.overview-hero{gap:16px;padding-bottom:100px}.tod-section{margin-bottom:0;padding:16px}.tod-header-row h3{letter-spacing:.1em;font-size:11px}.tod-quote{margin-top:8px;font-size:14px}.ov-stats-row{scroll-snap-type:x mandatory;scrollbar-width:none;gap:12px;margin:0 -2px;padding:2px 2px 8px;display:flex;overflow-x:auto}.ov-stats-row::-webkit-scrollbar{display:none}.ov-stat-card{scroll-snap-align:start;border-radius:20px;min-width:min(82vw,290px);padding:16px}@media (width<=430px){.ov-stat-card{min-width:min(88vw,260px);padding:14px}}.home-alerts-row{flex-direction:row;gap:10px;margin-top:4px;display:flex}.home-alert-pill{border-radius:20px;flex:1;gap:10px;min-width:0;padding:12px}.alert-pill-icon{width:36px;min-width:36px;height:36px}.alert-pill-label{font-size:10px}.alert-pill-value{font-size:13px}.today-schedule-section{border-radius:24px;margin-top:4px;padding:18px 16px}.today-schedule-section .section-header{margin-bottom:16px}@media (width<=430px){.today-schedule-section{border-radius:20px;padding:16px 14px}.schedule-header h3{font-size:1.1rem}}.day-order-badge{background:var(--accent);color:#fff;border-radius:6px;padding:3px 8px;font-size:10px;display:flex}.mobile-top-shell{border:1px solid var(--glass-border,#dee2ea99);box-shadow:var(--glass-shadow,0 8px 32px #0000000f);background:#ffffffbf;border-radius:22px;padding:6px 6px 6px 14px}.tod-section{border-radius:24px;padding:18px}.tod-quote{font-size:14px;line-height:1.6}.section-header{flex-direction:column;align-items:flex-start;gap:10px}.home-attendance-alert{border-radius:16px;padding:14px}.now-row{grid-template-columns:1fr}.now-card{border-radius:22px}.full-day-sched{gap:0}.sched-row{border-bottom:1px solid var(--border-secondary);border-radius:0;flex-wrap:wrap;align-items:flex-start;gap:10px 12px;padding:14px 0}.sched-row:last-child{border-bottom:none;padding-bottom:0}.sched-row:hover{background:0 0}.sched-time{width:auto;min-width:54px}.sched-name{white-space:normal}.sched-type{margin-left:auto}.schedule-empty-state{border-radius:22px;padding:20px 18px}.home-footer{border-radius:22px;align-items:center;gap:12px;padding:16px}.home-footer-text{font-size:12px}.mobile-sheet-overlay{z-index:1180;-webkit-backdrop-filter:blur(10px);opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:#14171e85;display:block;position:fixed;inset:0}[data-theme=dark] .mobile-sheet-overlay{background:#07090cc7}body.mobile-sheet-open .top-bar-container.mobile-top-bar{opacity:0;visibility:hidden;pointer-events:none}.mobile-sheet-overlay.show{opacity:1;pointer-events:auto}.mobile-more-sheet{z-index:2100;width:auto;max-width:none;max-height:85vh;padding:28px 20px calc(32px + env(safe-area-inset-bottom,0px));background:var(--glass-bg-elevated,#ffffffd1);-webkit-backdrop-filter:blur(28px)saturate(200%);border:1px solid var(--glass-border,var(--border-primary));opacity:1;pointer-events:none;isolation:isolate;border-bottom:none;border-radius:32px 32px 0 0;transition:transform .55s cubic-bezier(.16,1,.3,1);display:block;position:fixed;inset:auto 4px 0;overflow-y:auto;transform:translateY(100%);box-shadow:0 -12px 40px #0000001f}.mobile-more-sheet:before{content:"";background:#0000001a;border-radius:99px;width:42px;height:5px;position:absolute;top:12px;left:50%;transform:translate(-50%)}[data-theme=dark] .mobile-more-sheet:before{background:#ffffff26}[data-theme=dark] .mobile-more-sheet{background:var(--glass-bg-elevated,#1c1c1ec7);border-color:var(--glass-border)}.mobile-more-sheet.show{pointer-events:auto;transform:translate(0,0)}.mobile-sheet-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.mobile-sheet-kicker{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px;font-size:11px;font-weight:700;display:block}.mobile-sheet-head h2{letter-spacing:-.04em;color:var(--text-primary);font-size:22px;font-weight:800}.mobile-sheet-close{width:36px;min-width:36px;height:36px}[data-theme=dark] .mobile-sheet-close{color:#d0d3da;background:#1c1f27e6;border-color:#ffffff1a}.mobile-more-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.mobile-more-card{text-align:left;background:var(--surface-primary);border:1px solid var(--border-secondary);min-height:96px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);isolation:isolate;border-radius:22px;flex-direction:column;align-items:flex-start;gap:8px;padding:16px;display:flex;position:relative;overflow:hidden}.mobile-more-card:after{content:"";background:var(--accent);opacity:0;z-index:0;pointer-events:none;border-radius:999px;width:36px;height:36px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.2)}.mobile-more-card.tap-burst{animation:apple-pop-press .42s var(--ease-emphasized)}.mobile-more-card.tap-burst:after{animation:apple-pop-ripple .42s var(--ease-soft)}.mobile-more-card.tap-burst .mobile-more-card-icon{animation:apple-pop-icon-hop .42s var(--ease-emphasized)}.mobile-more-card.active{background:var(--surface-active);border-color:var(--border-active)}.mobile-more-card-icon{background:var(--accent-subtle);width:40px;height:40px;color:var(--accent);border-radius:14px;justify-content:center;align-items:center;display:flex}.mobile-more-card-title{color:var(--text-primary);font-size:15px;font-weight:700}.mobile-more-card-subtitle{color:var(--text-secondary);font-size:12px}.mobile-tabbar{left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom,0px));z-index:1250;-webkit-backdrop-filter:blur(24px)saturate(200%);border:1px solid var(--glass-border,#dfe3eb99);box-shadow:var(--glass-shadow,0 20px 45px #0000002e);isolation:isolate;background:#ffffffbf;border-radius:28px;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;padding:10px 10px 12px;display:grid;position:fixed;transform:translateZ(0)}@media (display-mode:standalone){.mobile-tabbar{bottom:calc(8px + env(safe-area-inset-bottom,0px));box-shadow:0 4px 20px #00000026}}@supports not ((-webkit-backdrop-filter:blur(1px)) or (backdrop-filter:blur(1px))){.mobile-top-shell,.mobile-tabbar,.mobile-more-sheet,.profile-dropdown-card{background:#12151ce6;border-color:#ffffff24}.mobile-sheet-overlay{background:#0a0c1094}[data-theme=light] .mobile-top-shell,[data-theme=light] .mobile-tabbar,[data-theme=light] .mobile-more-sheet,[data-theme=light] .profile-dropdown-card{background:#f8f9fceb;border-color:#0000001a}[data-theme=light] .mobile-sheet-overlay{background:#2022283d}}[data-theme=dark] .mobile-tabbar{background:var(--glass-bg-elevated,#0d0f15b8);border-color:var(--glass-border);box-shadow:var(--glass-shadow)}.mobile-tabbar-item{min-width:0;color:var(--text-secondary);transition:background .24s var(--ease-soft), color .24s var(--ease-soft), transform .24s var(--ease-emphasized);isolation:isolate;border-radius:18px;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:8px 4px;display:flex;position:relative;overflow:hidden}.mobile-tabbar-item:after{content:"";background:var(--accent);opacity:0;z-index:0;pointer-events:none;border-radius:999px;width:24px;height:24px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)scale(.2)}.mobile-tabbar-item.active{color:var(--accent);background:var(--surface-active)}[data-theme=dark] .mobile-tabbar-item.active{background:#dc143c1f;box-shadow:inset 0 1px #ffffff0a}.mobile-tabbar-item:active{transform:scale(.94)}.mobile-tabbar-item.tap-burst{animation:apple-pop-press .42s var(--ease-emphasized)}.mobile-tabbar-item.tap-burst:after{animation:apple-pop-ripple .42s var(--ease-soft)}.mobile-tabbar-item.tap-burst .mobile-tabbar-icon{animation:apple-pop-icon-hop .42s var(--ease-emphasized)}}.mobile-tabbar-icon{z-index:1;width:24px;height:24px;transition:transform .28s var(--ease-emphasized);justify-content:center;align-items:center;display:flex;position:relative}.mobile-tabbar-label{z-index:1;white-space:nowrap;letter-spacing:.02em;font-size:10px;font-weight:700;position:relative}@media (width<=400px){.overview-grid{grid-template-columns:repeat(2,1fr)}.mobile-top-shell{padding:14px}.mobile-brand-title{font-size:18px}.mobile-more-grid{grid-template-columns:1fr}.mobile-tabbar{gap:4px;padding-inline:6px}.mobile-tabbar-label{font-size:9px}}.dev-footer{border-top:1px solid var(--glass-border,#0000000d);flex-direction:column;gap:12px;margin-top:auto;padding:24px;display:flex}.dev-footer.sidebar-mode{padding:24px 20px}.dev-footer.sheet-mode{background:var(--surface-secondary);border-top:1px solid var(--border-secondary);margin-top:12px;padding:24px 24px 40px}.dev-text{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;text-align:center;font-size:.72rem;font-weight:700}.dev-links{justify-content:center;gap:16px;display:flex}.dev-link{color:var(--text-secondary);transition:all var(--transition-fast);background:var(--surface-secondary);border-radius:12px;justify-content:center;align-items:center;padding:10px;display:flex}.dev-link svg{width:18px;height:18px}.dev-link:hover{color:var(--accent);background:var(--accent-subtle);transform:translateY(-2px);box-shadow:0 4px 12px #0000000d}[data-theme=dark] .dev-link{color:var(--text-tertiary);background:#ffffff08}[data-theme=dark] .dev-link:hover{background:var(--accent-subtle);color:var(--accent);box-shadow:0 4px 12px #0003}[data-theme=dark] .dev-footer.sidebar-mode{border-top-color:#ffffff0f}[data-theme=dark] .dev-footer.sheet-mode{background:#00000026;border-top-color:#ffffff0f}.dev-footer.mobile-home-mode{border-top:1px solid var(--border-secondary);background:0 0;margin-top:18px;padding:24px 24px 0}[data-theme=dark] .dev-footer.mobile-home-mode{border-top-color:#ffffff14}.apple-page-container{flex-direction:column;gap:28px;width:100%;max-width:1600px;margin:0 auto;padding:32px 24px 64px;animation:.45s both fadeInUp;display:flex}@media (width<=768px){.apple-page-container{gap:20px;padding:20px 12px 48px}}@media (width<=430px){.apple-page-container{gap:16px;padding:16px 8px 100px!important}}.subpage-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.subpage-title-group{flex-direction:column;gap:4px;display:flex}.subpage-title{letter-spacing:-.03em;color:var(--text-primary);font-size:1.85rem;font-weight:800;line-height:1.2}.subpage-desc{color:var(--text-secondary);font-size:.9rem;font-weight:500;line-height:1.4}@media (width<=768px){.subpage-header{flex-direction:column;align-items:stretch;gap:20px}.subpage-header .apple-btn{width:100%;padding:12px 20px}.subpage-title{font-size:1.5rem}.subpage-desc{font-size:.82rem}}@media (width<=430px){.subpage-title{letter-spacing:-.02em;font-size:1.35rem}.subpage-desc{font-size:.78rem;line-height:1.3}.subpage-header{gap:14px}}.apple-btn{border-radius:var(--radius-sm);cursor:pointer;background:var(--accent);color:#fff;transition:background var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);white-space:nowrap;border:none;justify-content:center;align-items:center;gap:8px;padding:10px 20px;font-size:.85rem;font-weight:600;display:inline-flex}.apple-btn:hover{background:var(--accent-hover);box-shadow:0 4px 14px var(--accent-glow)}.apple-btn:active{transform:scale(.98)}.apple-btn:disabled{opacity:.45;cursor:not-allowed;transform:none}.apple-btn.primary{background:var(--accent);color:#fff}.apple-btn.secondary{background:var(--surface-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.apple-btn.secondary:hover{background:var(--surface-tertiary);box-shadow:none}.apple-btn.danger{background:var(--ring-red);color:#fff}.apple-btn.danger:hover{filter:brightness(1.1);box-shadow:0 4px 14px #ff3b3040}.apple-btn.blur{background:var(--accent-subtle);color:var(--accent);border:1px solid var(--border-active)}.apple-btn.blur:hover{background:var(--accent);color:#fff;box-shadow:0 4px 14px var(--accent-glow)}.apple-btn.full-width{width:100%}.apple-btn-secondary{border-radius:var(--radius-sm);cursor:pointer;border:1px solid var(--border-primary);background:var(--surface-primary);color:var(--text-primary);transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);white-space:nowrap;align-items:center;gap:8px;padding:9px 18px;font-size:.82rem;font-weight:600;display:inline-flex}[data-theme=dark] .apple-btn-secondary{-webkit-backdrop-filter:var(--blur-md)}@media (width<=430px){.apple-btn-secondary{border-radius:8px;padding:8px 14px;font-size:.78rem}}.apple-btn-secondary:hover{background:var(--surface-tertiary);border-color:var(--border-active);box-shadow:var(--shadow-sm)}.apple-btn-secondary:active{transform:scale(.98)}.apple-btn-secondary.active{background:var(--accent-subtle);border-color:var(--border-active);color:var(--accent)}.prediction-overlay-hint{background:var(--accent-subtle);color:var(--accent);text-align:center;border-top:1px solid var(--border-active);letter-spacing:.05em;text-transform:uppercase;padding:8px 20px;font-size:.72rem;font-weight:800}.od-date-pill.predict{background:var(--accent-subtle);border-color:var(--border-active);color:var(--accent)}.clear-all-predict{color:var(--text-tertiary);cursor:pointer;background:0 0;border:none;padding:4px 8px;font-size:.75rem;font-weight:700;text-decoration:underline;transition:color .2s}.clear-all-predict:hover{color:var(--ring-red)}.subpage-actions{align-items:center;gap:10px;display:flex}@media (width<=768px){.subpage-actions{grid-template-columns:1fr 1fr;width:100%;margin-top:4px;display:grid}.subpage-actions .apple-btn-secondary{text-align:center;justify-content:center;height:100%;padding:12px 10px;font-size:.78rem}}.attendance-group-container{flex-direction:column;gap:16px;margin-bottom:32px;display:flex}.attendance-group-title{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:8px;margin-bottom:4px;font-size:.85rem;font-weight:700;display:flex}.attendance-group-title:before{content:"";background:var(--accent);border-radius:4px;width:3px;height:14px;display:block}.attendance-grid-apple{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:18px;display:grid}@media (width<=430px){.attendance-grid-apple,.marks-grid-apple{gap:12px}}.attendance-card-apple{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));box-shadow:var(--glass-shadow,var(--shadow-card));transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);isolation:isolate;flex-direction:column;display:flex;overflow:hidden;transform:translateZ(0)}[data-theme=dark] .attendance-card-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.attendance-card-apple:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);transform:translateY(-2px)}@media (width<=430px){.attendance-card-apple .card-top,.marks-card-apple .card-header{padding:16px 16px 12px}.attendance-card-apple .card-metrics,.marks-card-apple .card-body{padding:12px 16px}.attendance-card-apple .card-actions,.marks-card-apple .card-footer{padding:10px 16px}}.attendance-card-apple .card-top{justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 20px 0;display:flex}.attendance-card-apple .course-info{flex-direction:column;flex:1;gap:6px;min-width:0;display:flex}.attendance-card-apple .course-info h3{color:var(--text-primary);line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.92rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.attendance-card-apple .course-meta{color:var(--text-secondary);align-items:center;gap:6px;font-size:.75rem;font-weight:500;display:flex}.attendance-card-apple .course-meta .code{color:var(--text-secondary);font-weight:600}.attendance-card-apple .course-meta .dot{opacity:.4}.percent-ring{flex-shrink:0;width:56px;height:56px;position:relative}.percent-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.percent-ring svg path:first-child{stroke:var(--ring-track)}.percent-ring svg path:last-child{stroke:currentColor;stroke-linecap:round;transition:stroke-dasharray var(--transition-base)}.percent-ring .pct-text{color:var(--text-primary);justify-content:center;align-items:center;font-size:.7rem;font-weight:800;display:flex;position:absolute;inset:0}.progress-green{color:var(--ring-green)}.progress-amber{color:var(--ring-amber)}.progress-red{color:var(--ring-red)}.attendance-card-apple .card-metrics{align-items:center;gap:0;padding:16px 20px;display:flex}.attendance-card-apple .card-metrics .metric{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;display:flex}.attendance-card-apple .card-metrics .metric:not(:last-child){border-right:1px solid var(--border-secondary)}.attendance-card-apple .card-metrics .metric .label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem;font-weight:600}.attendance-card-apple .card-metrics .metric .value{color:var(--text-primary);font-size:.95rem;font-weight:700}.status-pill{border-radius:var(--radius-full);letter-spacing:.02em;white-space:nowrap;align-items:center;padding:3px 10px;font-size:.7rem;font-weight:700;display:inline-flex}.status-pill.green{background:var(--badge-green-bg);color:var(--badge-green-text);border:1px solid var(--badge-green-border)}.status-pill.amber{background:var(--badge-amber-bg);color:var(--badge-amber-text);border:1px solid var(--badge-amber-border)}.status-pill.red{background:var(--badge-red-bg);color:var(--badge-red-text);border:1px solid var(--badge-red-border)}.status-pill.neutral{background:var(--surface-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary)}.attendance-card-apple .card-actions{border-top:1px solid var(--border-secondary);background:var(--surface-secondary);justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.od-indicator{align-items:center;gap:8px;display:flex}.od-indicator .label{color:var(--text-secondary);font-size:.75rem;font-weight:600}.od-indicator .count{color:var(--accent);background:var(--accent-subtle);border-radius:var(--radius-full);padding:2px 10px;font-size:.85rem;font-weight:800}.od-controls{align-items:center;gap:6px;display:flex}.adj-btn{border-radius:var(--radius-xs);background:var(--surface-primary);border:1px solid var(--border-primary);width:30px;height:30px;color:var(--text-primary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);justify-content:center;align-items:center;font-size:1rem;font-weight:700;display:flex}.adj-btn:hover{background:var(--accent-subtle);border-color:var(--border-active);color:var(--accent)}.adj-btn:active{transform:scale(.98)}.adj-btn:disabled{opacity:.35;cursor:not-allowed;transform:none}.marks-insights-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.marks-insight-card{border-radius:var(--radius-md);border:1px solid var(--border-secondary);background:var(--surface-primary);box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:14px 16px;display:flex}.marks-insight-card .kicker{text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);font-size:.7rem;font-weight:700}.marks-insight-card .value{color:var(--text-primary);font-size:1.35rem;font-weight:800;line-height:1.2}.marks-insight-card .subject{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.82rem;font-weight:600;overflow:hidden}.marks-insight-card.top{border-color:color-mix(in srgb, var(--badge-green-border) 70%, var(--border-secondary));background:color-mix(in srgb, var(--badge-green-bg) 52%, var(--surface-primary))}.marks-insight-card.low{border-color:color-mix(in srgb, var(--badge-red-border) 70%, var(--border-secondary));background:color-mix(in srgb, var(--badge-red-bg) 62%, var(--surface-primary))}@media (width<=640px){.marks-insights-row{grid-template-columns:1fr;gap:10px}}.marks-grid-apple{grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:18px;display:grid}@media (width<=768px){.marks-grid-apple{grid-template-columns:1fr;gap:14px}}.marks-card-apple{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));box-shadow:var(--glass-shadow,var(--shadow-card));transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);isolation:isolate;flex-direction:column;display:flex;overflow:hidden;transform:translateZ(0)}[data-theme=dark] .marks-card-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.marks-card-apple:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);transform:translateY(-2px)}.marks-card-apple .card-header{justify-content:space-between;align-items:flex-start;gap:16px;padding:20px 20px 16px;display:flex}.marks-card-apple .title-group{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.marks-card-apple .title-group h3{color:var(--text-primary);line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.92rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.marks-card-apple .title-group .meta{color:var(--text-secondary);font-size:.72rem;font-weight:500}.marks-card-apple .big-score{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.marks-card-apple .big-score .fraction{color:var(--text-primary);letter-spacing:-.02em;font-size:1.25rem;font-weight:800}.marks-card-apple .big-score .fraction span{color:var(--text-tertiary);font-size:.8rem;font-weight:600}.marks-card-apple .big-score .percentage{letter-spacing:.01em;color:var(--text-primary);font-size:.72rem;font-weight:700}.marks-card-apple .marks-graph-apple{border-top:1px solid var(--border-secondary);flex-direction:column;justify-content:flex-end;gap:12px;min-height:120px;margin-top:16px;padding:8px 0 16px;display:flex}.marks-graph-legend{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;align-items:center;gap:6px;margin-bottom:4px;font-size:11px;font-weight:700;display:flex}.marks-graph-legend .dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 8px var(--accent-glow);border-radius:50%}.marks-trend-svg{width:100%;height:80px;display:block;overflow:visible}.marks-grid-line{stroke:var(--text-tertiary);stroke-width:.3px;opacity:.15}.marks-trend-line-dashed{fill:none;stroke:var(--text-tertiary);stroke-width:.8px;stroke-dasharray:2 2;opacity:.3}.marks-trend-line{fill:none;stroke:var(--accent);stroke-width:1.6px;stroke-linecap:round;stroke-linejoin:round}.marks-trend-point{fill:var(--accent);stroke:var(--bg-secondary);stroke-width:1px}.marks-axis-label{fill:var(--text-secondary);opacity:.8;font-size:4px;font-weight:700}.marks-trend-fill{transition:opacity var(--transition-base);opacity:.6}.marks-graph-labels{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:4px;padding:8px 4px 2px;display:flex}.marks-graph-labels span{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-full);background:var(--surface-secondary);border:1px solid var(--border-secondary);white-space:nowrap;padding:2px 8px;font-size:.6rem;font-weight:700}[data-theme=dark] .marks-grid-line{stroke:#7887af3d}[data-theme=dark] .marks-grid-line.vertical{stroke:#7887af33}.marks-trend-empty{border-radius:var(--radius-sm);width:100%;height:60px;color:var(--text-tertiary);border:1px dashed var(--border-secondary);justify-content:center;align-items:center;font-size:.78rem;font-weight:500;display:flex}.marks-card-apple .exams-list{flex-direction:column;gap:6px;padding:0 16px 16px;display:flex}.marks-card-apple .exam-row{border-radius:var(--radius-sm);background:var(--surface-secondary);border:1px solid var(--border-secondary);transition:background var(--transition-fast);justify-content:space-between;align-items:center;gap:12px;padding:10px 14px;display:flex}.marks-card-apple .exam-row:hover{background:var(--surface-tertiary)}.marks-card-apple .exam-row:last-child{border-bottom:1px solid var(--border-secondary)}.marks-card-apple .exam-row .exam-name{color:var(--text-secondary);letter-spacing:.01em;font-size:.78rem;font-weight:600}.marks-card-apple .exam-row .exam-val{color:var(--accent);font-variant-numeric:tabular-nums;background:var(--accent-subtle);border:1px solid color-mix(in srgb, var(--accent) 20%, transparent);border-radius:var(--radius-full);white-space:nowrap;padding:3px 10px;font-size:.78rem;font-weight:800}.sgpa-panel-apple{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));box-shadow:var(--glass-shadow,var(--shadow-card));isolation:isolate;flex-direction:column;gap:24px;padding:24px;display:flex;transform:translateZ(0)}[data-theme=dark] .sgpa-panel-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.sgpa-section-apple{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-primary));box-shadow:var(--glass-shadow,var(--shadow-card));isolation:isolate;flex-direction:column;gap:24px;margin-bottom:24px;padding:32px;animation:.45s both fadeInUp;display:flex;transform:translateZ(0)}[data-theme=dark] .sgpa-section-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}@media (width<=768px){.sgpa-section-apple{gap:16px;padding:20px 16px}}.sgpa-inline-container{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-primary));isolation:isolate;flex-direction:column;gap:clamp(20px,4vw,32px);margin-bottom:clamp(24px,6vw,48px);padding:clamp(20px,5vw,40px);animation:.5s cubic-bezier(.2,.8,.2,1) both slideDownIn;display:flex;transform:translateZ(0)}[data-theme=dark] .sgpa-inline-container{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.sgpa-inline-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:24px;display:flex}.sgpa-inline-header .header-left .title-row{align-items:center;gap:16px;margin-bottom:8px;display:flex}.sgpa-inline-header h2{letter-spacing:-.03em;color:var(--text-primary);font-size:1.75rem;font-weight:800}.sgpa-inline-header .back-btn{border:1px solid var(--border-secondary);background:var(--surface-secondary);width:40px;height:40px;color:var(--text-primary);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;transition:all .2s;display:flex}.sgpa-inline-header .back-btn:hover{background:var(--surface-tertiary);transform:translate(-3px)}.sgpa-inline-header .header-actions{align-items:center;gap:16px;display:flex}.target-all-dropdown{background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-secondary);align-items:center;gap:12px;padding:8px 16px;transition:all .2s cubic-bezier(.4,0,.2,1);display:flex}.target-all-dropdown:hover{border-color:var(--accent);background:var(--surface-tertiary)}.target-all-dropdown span{color:var(--text-secondary);white-space:nowrap;font-size:.85rem;font-weight:600}.target-all-dropdown select{color:var(--accent);cursor:pointer;appearance:none;text-align:center;background:0 0;border:none;outline:none;padding:0 4px;font-size:1.05rem;font-weight:800}.sgpa-summary-badge{background:var(--surface-secondary);border-radius:var(--radius-md);border:1px solid var(--border-secondary);flex-direction:column;align-items:center;min-width:140px;padding:12px 28px;display:flex}.sgpa-summary-badge.excellent{background:var(--badge-green-bg);border-color:var(--badge-green-border)}.sgpa-summary-badge .lbl{text-transform:uppercase;color:var(--text-tertiary);font-size:.65rem;font-weight:700}.sgpa-summary-badge .val{color:var(--text-primary);font-size:1.6rem;font-weight:900;line-height:1.2}.sgpa-item-card .header-main{align-items:center;gap:16px;display:flex}.sgpa-item-card .course-info{flex-direction:column;gap:2px;display:flex}.sgpa-item-card .course-info h3{margin:0;font-size:.9rem;font-weight:750}.sgpa-item-card .course-info .code{color:var(--text-tertiary);font-size:.72rem;font-weight:600}.input-wrap{align-items:center;display:flex;position:relative}.input-wrap input{padding:10px 14px;background:var(--input-bg);border:1px solid var(--border-primary);width:100%;color:var(--text-primary);border-radius:10px;padding-right:48px;font-size:.95rem;font-weight:700}.input-wrap .denom{color:var(--text-tertiary);font-size:.8rem;font-weight:600;position:absolute;right:14px}.sgpa-item-footer .pct-info{color:var(--text-tertiary);font-size:.7rem;font-weight:700}@keyframes slideDownIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@media (width<=768px){.sgpa-inline-container{margin-bottom:32px;padding:24px 16px}.sgpa-inline-header{flex-direction:column;align-items:flex-start;gap:20px}.sgpa-inline-header .header-actions{flex-direction:column-reverse;align-items:stretch;gap:12px;width:100%}.target-all-dropdown,.sgpa-summary-badge{justify-content:space-between;width:100%;min-width:0}}@media (width<=480px){.sgpa-inline-header h2{font-size:1.4rem}.sgpa-inline-container{border-radius:var(--radius-md);gap:24px;padding:20px 12px}.target-all-dropdown{padding:10px 14px}}.sgpa-big-badge{border-radius:var(--radius-md);background:var(--surface-secondary);border:1px solid var(--border-secondary);text-align:center;flex-direction:column;align-items:center;gap:2px;min-width:120px;padding:14px 24px;transition:all .3s cubic-bezier(.4,0,.2,1);display:flex}.sgpa-big-badge:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}@media (width<=640px){.sgpa-panel-top{text-align:left;flex-direction:column;align-items:flex-start}.sgpa-big-badge{width:100%;padding:18px}}.marks-graph-legend{color:var(--text-secondary);justify-content:center;align-self:center;align-items:center;gap:6px;font-size:.7rem;font-weight:600;display:inline-flex}.marks-graph-legend .dot{background:var(--accent);border-radius:50%;width:8px;height:8px}.sgpa-big-badge .label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.65rem;font-weight:600}.marks-axis-label{fill:var(--text-tertiary);font-size:2.6px;font-weight:600}.sgpa-big-badge .value{color:var(--text-primary);letter-spacing:-.03em;font-size:1.65rem;font-weight:800;line-height:1.2}.sgpa-big-badge.excellent{background:var(--badge-green-bg);border-color:var(--badge-green-border)}.sgpa-big-badge.excellent .value{color:var(--badge-green-text)}.sgpa-big-badge.good{background:var(--badge-blue-bg);border-color:var(--badge-blue-border)}.sgpa-big-badge.good .value{color:var(--badge-blue-text)}.sgpa-grid-apple{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;display:grid}.cgpa-auto-panel{border-top:1px solid var(--border-secondary);flex-direction:column;gap:14px;margin-top:4px;padding-top:18px;display:flex}.cgpa-select-row{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.cgpa-semester-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;display:grid}.cgpa-actions-row{flex-wrap:wrap;gap:10px;display:flex}.cgpa-state-note{color:var(--text-secondary);font-size:.82rem;font-weight:600}.cgpa-state-note.error{color:var(--badge-red-text)}@media (width<=768px){.cgpa-select-row{grid-template-columns:1fr}.sgpa-grid-apple{grid-template-columns:1fr;gap:14px}}.sgpa-item-card{border-radius:var(--radius-md);background:var(--glass-bg-card,var(--bg-tertiary));-webkit-backdrop-filter:blur(12px)saturate(160%);border:1px solid var(--glass-border,var(--border-secondary));isolation:isolate;flex-direction:column;gap:14px;padding:18px;transition:all .2s;display:flex;transform:translateZ(0)}[data-theme=dark] .sgpa-item-card{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.sgpa-item-card.disabled{opacity:.45;pointer-events:none}.sgpa-item-card.disabled header,.sgpa-item-card.disabled .sgpa-inputs-row,.sgpa-item-card.disabled .grade-slider-wrap,.sgpa-item-card.disabled .sgpa-item-footer{filter:grayscale(.5)}.sgpa-item-card header{justify-content:space-between;align-items:center;gap:10px;display:flex}.sgpa-item-card .course-name{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.sgpa-item-card .course-name h3{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:700;line-height:1.3;overflow:hidden}.apple-switch{flex-shrink:0;width:40px;height:24px;display:inline-block;position:relative}.apple-switch input{opacity:0;width:0;height:0;position:absolute}.apple-switch .slider{background:var(--surface-tertiary);border-radius:var(--radius-full);border:1px solid var(--border-primary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast);position:absolute;inset:0}.apple-switch .slider:before{content:"";width:18px;height:18px;transition:transform var(--transition-fast);background:#fff;border-radius:50%;position:absolute;bottom:2px;left:2px;box-shadow:0 1px 3px #00000026}.apple-switch input:checked+.slider{background:var(--accent);border-color:var(--accent)}.apple-switch input:checked+.slider:before{transform:translate(16px)}.remove-btn{border-radius:var(--radius-xs);width:32px;height:32px;color:var(--text-tertiary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.remove-btn:hover{background:var(--badge-red-bg);color:var(--badge-red-text)}.sgpa-inputs-row{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}@media (width<=480px){.sgpa-inputs-row{grid-template-columns:1fr;gap:12px}}.apple-input-group{flex-direction:column;gap:4px;display:flex}.apple-input-group label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem;font-weight:600}.apple-input-group input,.apple-input-group select{border-radius:var(--radius-xs);border:1px solid var(--border-primary);background:var(--input-bg);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:8px 10px;font-size:.82rem;font-weight:600}.apple-input-group input:focus,.apple-input-group select:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.grade-slider-wrap{flex-direction:column;gap:8px;display:flex}.grade-slider-wrap .slider-header{color:var(--text-secondary);font-size:.78rem;font-weight:600}.grade-slider-wrap .slider-header strong{color:var(--accent);font-weight:800}.apple-range{appearance:none;border-radius:var(--radius-full);background:var(--ring-track);background-image:linear-gradient(var(--accent), var(--accent));cursor:pointer;background-repeat:no-repeat;border:none;outline:none;width:100%;height:6px;padding:0}.apple-range::-webkit-slider-thumb{appearance:none;background:var(--accent);cursor:pointer;width:20px;height:20px;transition:transform var(--transition-fast);border:3px solid #fff;border-radius:50%;box-shadow:0 1px 4px #0003}.apple-range::-webkit-slider-thumb:hover{transform:scale(1.15)}.apple-range::-moz-range-thumb{background:var(--accent);cursor:pointer;border:3px solid #fff;border-radius:50%;width:20px;height:20px;box-shadow:0 1px 4px #0003}.grade-marks{justify-content:space-between;padding:0 2px;display:flex}.grade-marks span{color:var(--text-tertiary);transition:color var(--transition-fast), font-weight var(--transition-fast);font-size:.68rem;font-weight:600}.grade-marks span.active{color:var(--accent);font-weight:800}.sgpa-item-footer{border-top:1px solid var(--border-secondary);justify-content:space-between;align-items:center;gap:12px;padding-top:12px;display:flex}.sgpa-item-footer .needed{flex-direction:column;gap:1px;display:flex}.sgpa-item-footer .needed .lbl{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.03em;font-size:.68rem;font-weight:600}.sgpa-item-footer .needed .val{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:1rem;font-weight:800}.diff-tag{border-radius:var(--radius-full);letter-spacing:.02em;align-items:center;padding:4px 12px;font-size:.7rem;font-weight:700;display:inline-flex}.diff-tag.green{background:var(--badge-green-bg);color:var(--badge-green-text);border:1px solid var(--badge-green-border)}.diff-tag.amber{background:var(--badge-amber-bg);color:var(--badge-amber-text);border:1px solid var(--badge-amber-border)}.diff-tag.red{background:var(--badge-red-bg);color:var(--badge-red-text);border:1px solid var(--badge-red-border)}.diff-tag.neutral{background:var(--surface-secondary);color:var(--text-secondary);border:1px solid var(--border-secondary)}.timetable-v2{padding-bottom:40px}.title-with-icon{align-items:center;gap:12px;display:flex}.page-icon-small{background:var(--accent-subtle);width:32px;height:32px;color:var(--accent);border-radius:8px;justify-content:center;align-items:center;display:flex}.day-selector-scroller{scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;gap:10px;margin-bottom:20px;padding:16px 4px;display:flex;overflow-x:auto}.day-selector-scroller::-webkit-scrollbar{display:none}.day-tab{background:var(--surface-secondary);border:1px solid var(--border-secondary);color:var(--text-secondary);white-space:nowrap;cursor:pointer;transition:all var(--transition-fast);border-radius:12px;padding:8px 18px;font-size:.82rem;font-weight:700}.day-tab.active{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.day-tab:hover:not(.active){background:var(--surface-tertiary);border-color:var(--border-primary)}.timetable-day-group{margin-bottom:32px}.day-group-title{color:var(--text-primary);margin:0 0 16px 4px;font-size:.95rem;font-weight:700}.classes-grid-v2{grid-template-columns:1fr;gap:14px;display:grid}@media (width>=1024px){.classes-grid-v2{grid-template-columns:repeat(2,1fr)}}.class-card-v2{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));border-radius:var(--radius-lg);transition:all var(--transition-base);box-shadow:var(--glass-shadow,var(--shadow-sm));isolation:isolate;padding:18px 20px;transform:translateZ(0)}[data-theme=dark] .class-card-v2{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.class-card-v2:hover{border-color:var(--border-active);box-shadow:var(--shadow-md);transform:translateY(-2px)}@media (width<=430px){.class-card-v2{border-radius:16px;padding:14px 16px}.course-name{font-size:.88rem;line-height:1.3}}.card-main-info{justify-content:space-between;gap:16px;display:flex}.left-content{flex-direction:column;flex:1;gap:8px;display:flex}.course-name{color:var(--text-primary);font-size:.92rem;font-weight:700;line-height:1.4}.course-meta{color:var(--text-tertiary);flex-wrap:wrap;align-items:center;gap:6px;font-size:.72rem;font-weight:600;display:flex}.course-meta .dot{opacity:.4}.room-pill{background:var(--surface-secondary);color:var(--text-secondary);border-radius:8px;align-self:flex-start;align-items:center;gap:5px;margin-top:2px;padding:4px 10px;font-size:.7rem;font-weight:600;display:inline-flex}.right-content{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:8px;display:flex}.time-range{color:var(--text-secondary);white-space:nowrap;font-size:.75rem;font-weight:700}.type-tag-v2{text-transform:uppercase;letter-spacing:.04em;border-radius:6px;padding:3px 10px;font-size:.65rem;font-weight:800}.type-tag-v2.theory{background:var(--badge-blue-bg);color:var(--badge-blue-text);border:1px solid var(--badge-blue-border)}.type-tag-v2.practical,.type-tag-v2.lab{background:var(--badge-green-bg);color:var(--badge-green-text);border:1px solid var(--badge-green-border)}@media (width<=768px){.class-card-v2{padding:16px}.card-main-info{flex-direction:row}.course-name{font-size:.88rem}}.courses-grid-apple{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:18px;display:grid}@media (width<=768px){.courses-grid-apple{grid-template-columns:1fr;gap:14px}}.course-card-apple{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));box-shadow:var(--glass-shadow,var(--shadow-card));transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);isolation:isolate;display:flex;overflow:hidden;transform:translateZ(0)}[data-theme=dark] .course-card-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.course-card-apple:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);transform:translateY(-2px)}.course-card-apple .card-accent{background:var(--accent);border-radius:0;flex-shrink:0;width:5px}.course-card-apple .card-content{flex-direction:column;flex:1;gap:10px;min-width:0;padding:18px 20px;display:flex}.course-code-tag{border-radius:var(--radius-full);background:var(--accent-subtle);color:var(--accent);letter-spacing:.03em;align-self:flex-start;padding:3px 10px;font-size:.68rem;font-weight:700;display:inline-flex}.course-card-apple .card-content h3{color:var(--text-primary);font-size:.92rem;font-weight:700;line-height:1.3}.course-meta-row{border-top:1px solid var(--border-secondary);align-items:center;gap:20px;padding-top:10px;display:flex}.meta-item{flex-direction:column;gap:2px;display:flex}.meta-item .lbl{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.65rem;font-weight:600}.meta-item .val{color:var(--text-primary);font-size:.82rem;font-weight:700}.val-tag{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.03em;align-items:center;padding:2px 8px;font-size:.7rem;font-weight:700;display:inline-flex}.val-tag.theory{background:var(--badge-blue-bg);color:var(--badge-blue-text);border:1px solid var(--badge-blue-border)}.val-tag.practical,.val-tag.lab{background:var(--badge-green-bg);color:var(--badge-green-text);border:1px solid var(--badge-green-border)}.apple-modal-overlay{z-index:10000;pointer-events:auto;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0;transform:translateZ(0);-webkit-backdrop-filter:blur(16px)saturate(180%)!important;background:#0a0b0e73!important}[data-theme=dark] .apple-modal-overlay{background:#0006!important}.apple-modal-card{border-radius:var(--radius-xl);background:var(--bg-elevated);border:1px solid var(--border-primary);width:100%;max-width:480px;max-height:85vh;box-shadow:var(--shadow-xl);flex-direction:column;animation:.3s both scaleIn;display:flex;overflow:hidden}[data-theme=dark] .apple-modal-card{background:var(--bg-secondary);-webkit-backdrop-filter:var(--blur-lg)}.apple-modal-card.compact{max-width:420px}.apple-modal-header{border-bottom:1px solid var(--border-secondary);align-items:center;gap:12px;padding:20px 24px 16px;display:flex}.apple-modal-header h2{color:var(--text-primary);letter-spacing:-.01em;flex:1;font-size:1.05rem;font-weight:800}.apple-modal-close{border-radius:var(--radius-full);background:var(--surface-secondary);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.apple-modal-close:hover{background:var(--surface-tertiary);color:var(--text-primary)}.warning-icon-wrap{border-radius:var(--radius-sm);background:var(--badge-amber-bg);width:40px;height:40px;color:var(--badge-amber-text);flex-shrink:0;justify-content:center;align-items:center;display:flex}.apple-modal-body{flex-direction:column;gap:16px;padding:20px 24px;display:flex;overflow-y:auto}.apple-modal-body .primary-text{color:var(--text-primary);font-size:.88rem;font-weight:500;line-height:1.5}.apple-modal-body .secondary-text{color:var(--text-secondary);font-size:.85rem;font-weight:500;line-height:1.5}.apple-bullet-list{flex-direction:column;gap:10px;margin:0;padding:0;list-style:none;display:flex}.apple-bullet-list li{color:var(--text-secondary);align-items:flex-start;gap:12px;font-size:.82rem;font-weight:500;line-height:1.6;display:flex}.apple-bullet-list li span{flex:1}.apple-bullet-list li:before{content:"";background:var(--accent);border-radius:50%;flex-shrink:0;width:5px;height:5px;margin-top:8px}.apple-bullet-list li strong{color:var(--text-primary);font-weight:700}.apple-modal-footer{border-top:1px solid var(--border-secondary);justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px 20px;display:flex}.apple-form-group{flex-direction:column;gap:12px;display:flex}.date-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=480px){.date-row{gap:8px}.input-field input{padding:8px 6px;font-size:.78rem}}.input-field{flex-direction:column;gap:4px;display:flex}.input-field label{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em;font-size:.68rem;font-weight:600}.input-field input{border-radius:var(--radius-xs);border:1px solid var(--border-primary);background:var(--input-bg);color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);padding:9px 12px;font-size:.82rem;font-weight:600}.input-field input:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.od-date-scroller{flex-wrap:wrap;gap:8px;padding:4px 0;display:flex}.od-date-pill{border-radius:var(--radius-full);background:var(--accent-subtle);border:1px solid var(--border-active);color:var(--accent);align-items:center;gap:6px;padding:5px 12px;font-size:.75rem;font-weight:600;animation:.25s both fadeInScale;display:inline-flex}.od-date-pill button{width:18px;height:18px;color:var(--accent);cursor:pointer;transition:background var(--transition-fast);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;display:flex}.od-date-pill button:hover{background:var(--accent);color:#fff}.skippro-page{position:relative}.skippro-disclaimer-modal{overflow:hidden}.skippro-disclaimer-modal .modal-title-row{align-items:center;gap:12px;display:flex}.skippro-disclaimer-modal .warning-icon{color:var(--badge-red-text);align-items:center;display:flex}.skippro-disclaimer-modal .disclaimer-intro{color:var(--text-secondary);margin-bottom:20px;font-size:14.5px;line-height:1.55}.skippro-disclaimer-modal .disclaimer-list{gap:14px;margin-bottom:24px;padding:0;list-style:none;display:grid}.skippro-disclaimer-modal .disclaimer-list li{color:var(--text-secondary);align-items:flex-start;gap:12px;font-size:13.5px;line-height:1.45;display:flex}.skippro-disclaimer-modal .disclaimer-list .dot{color:var(--apple-blue);margin-top:-1px;font-size:18px;font-weight:900;line-height:1}.skippro-disclaimer-modal .disclaimer-danger-box{background:var(--badge-red-bg);border:1px solid var(--badge-red-border);border-radius:12px;padding:16px}.skippro-disclaimer-modal .disclaimer-danger-box p{color:var(--badge-red-text);text-align:center;margin:0;font-size:13px;font-weight:600;line-height:1.5}.skippro-stats-grid{grid-template-columns:repeat(3,1fr);gap:14px;display:grid}@media (width<=768px){.skippro-stats-grid{grid-template-columns:1fr;gap:12px}.skippro-page .subpage-header{gap:16px;margin-bottom:24px}}.skippro-stat-card{border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-primary));background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));box-shadow:var(--glass-shadow,var(--shadow-card));text-align:center;transition:transform var(--transition-fast), box-shadow var(--transition-fast);isolation:isolate;flex-direction:column;align-items:center;gap:4px;padding:18px 16px;display:flex;transform:translateZ(0)}[data-theme=dark] .skippro-stat-card{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}[data-theme=dark] .skippro-page .skippro-stat-card{background:linear-gradient(#070709f2 0%,#0c0c0ee6 100%);border-color:#ffffff14;box-shadow:0 22px 44px #00000080,inset 0 1px #ffffff0a}.skippro-stat-card:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}@media (width<=430px){.skippro-stat-card{border-radius:18px;padding:14px 10px}}.skippro-stat-card .lbl{text-transform:uppercase;letter-spacing:.04em;font-size:.72rem;font-weight:600}.skippro-stat-card .val{letter-spacing:-.03em;font-size:1.65rem;font-weight:800}.skippro-stat-card.safe{border-color:var(--badge-green-border)}.skippro-stat-card.safe .lbl,.skippro-stat-card.safe .val{color:var(--badge-green-text)}.skippro-stat-card.caution{border-color:var(--badge-amber-border)}.skippro-stat-card.caution .lbl,.skippro-stat-card.caution .val{color:var(--badge-amber-text)}.skippro-stat-card.risk{border-color:var(--badge-red-border)}.skippro-stat-card.risk .lbl,.skippro-stat-card.risk .val{color:var(--badge-red-text)}.skippro-controls-row{flex-wrap:wrap;align-items:flex-end;gap:14px;display:flex}.apple-select{border-radius:var(--radius-sm);border:1px solid var(--border-primary);background:var(--input-bg);color:var(--text-primary);cursor:pointer;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2386868B' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding:9px 36px 9px 14px;font-size:.82rem;font-weight:600}.apple-select:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.skippro-grid-apple{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px;display:grid}@media (width<=768px){.skippro-grid-apple{grid-template-columns:1fr;gap:14px}}.skippro-card-apple{border-radius:var(--radius-lg);background:var(--glass-bg-card,var(--bg-glass));min-height:100%;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-glass));box-shadow:var(--glass-shadow);transition:all var(--transition-base);isolation:isolate;flex-direction:column;display:flex;overflow:hidden;transform:translateZ(0)}[data-theme=dark] .skippro-card-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}[data-theme=dark] .skippro-page .skippro-card-apple{border-color:#ffffff14;box-shadow:0 24px 52px #00000085,inset 0 0 0 1px #ffffff0a}.skippro-card-apple:hover{box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.skippro-card-apple.green{border-color:var(--badge-green-border)}.skippro-card-apple.amber{border-color:var(--badge-amber-border)}.skippro-card-apple.red{border-color:var(--badge-red-border)}.skippro-card-apple .card-top{justify-content:space-between;align-items:flex-start;gap:12px;height:110px;padding:18px 20px 14px;display:flex}.skippro-card-apple .course-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.skippro-card-apple .course-info .code{color:var(--text-tertiary);letter-spacing:.02em;font-size:.7rem;font-weight:600}.skippro-card-apple .course-info h3{color:var(--text-primary);line-clamp:2;-webkit-line-clamp:2;-webkit-box-orient:vertical;font-size:.88rem;font-weight:700;line-height:1.3;display:-webkit-box;overflow:hidden}.skippro-card-apple .course-info .meta{color:var(--text-secondary);align-items:center;gap:5px;margin-top:2px;font-size:.72rem;font-weight:500;display:flex}.status-badge{border-radius:var(--radius-full);letter-spacing:.06em;text-transform:uppercase;white-space:nowrap;flex-shrink:0;align-items:center;padding:4px 12px;font-size:.62rem;font-weight:800;display:inline-flex}.status-badge.green{background:var(--badge-green-bg);color:var(--badge-green-text);border:1px solid var(--badge-green-border)}.status-badge.amber{background:var(--badge-amber-bg);color:var(--badge-amber-text);border:1px solid var(--badge-amber-border)}.status-badge.red{background:var(--badge-red-bg);color:var(--badge-red-text);border:1px solid var(--badge-red-border)}.skippro-card-apple .card-main{flex-direction:column;flex:1;justify-content:flex-end;gap:0;padding:0 20px;display:flex}.stat-row{border-bottom:1px solid var(--border-secondary);justify-content:space-between;align-items:center;min-height:44px;padding:10px 0;display:flex}.stat-row:last-child{border-bottom:none}.stat-row .lbl{color:var(--text-secondary);font-size:.78rem;font-weight:500}.stat-row .val{color:var(--text-primary);font-variant-numeric:tabular-nums;font-size:.85rem;font-weight:700}.stat-row.highlight{background:var(--surface-secondary);border-bottom:none;margin:0 -20px;padding:12px 20px}[data-theme=dark] .skippro-page .stat-row.highlight{background:linear-gradient(#ffffff0e 0%,#ffffff09 100%);border-top:1px solid #ffffff08;border-bottom:1px solid #ffffff08}.stat-row.highlight .lbl{color:var(--text-primary);font-weight:600}.stat-row.highlight .val.big{color:var(--accent);font-size:1.15rem;font-weight:800}.skippro-card-apple .card-footer{border-top:1px solid var(--border-secondary);background:var(--surface-secondary);color:var(--text-secondary);align-items:center;padding:12px 20px;font-size:.72rem;font-weight:600;display:flex}[data-theme=dark] .skippro-page .skippro-card-apple .course-info .code{color:#9b9ba1}[data-theme=dark] .skippro-page .skippro-card-apple .card-footer{color:#b5b5bb;background:#ffffff0a}[data-theme=dark] .skippro-page .skippro-card-apple.green{border-color:#30d15847}[data-theme=dark] .skippro-page .skippro-card-apple.amber{border-color:#ff9f0a42}[data-theme=dark] .skippro-page .skippro-card-apple.red{border-color:#dc143c47}[data-theme=dark] .skippro-page .skippro-disclaimer-modal{background:linear-gradient(#08080afa 0%,#0e0e11f0 100%);border-color:#ffffff14;box-shadow:0 30px 78px #000000b8,inset 0 1px #ffffff0d}.resources-page-apple{max-width:100%;min-height:calc(100vh - 96px)}.resources-page-apple .semesters-grid-apple{grid-template-columns:repeat(auto-fit,minmax(230px,1fr))}.resources-page-apple .resources-subjects-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}.resources-page-apple .resources-footer-note{margin-top:auto}.apple-back-btn{border-radius:var(--radius-full);border:1px solid var(--border-primary);background:var(--surface-primary);width:fit-content;color:var(--text-secondary);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast);align-items:center;gap:8px;padding:8px 14px;font-size:.78rem;font-weight:700;display:inline-flex}.apple-back-btn:hover{background:var(--surface-tertiary);border-color:var(--border-active);color:var(--text-primary)}.apple-back-btn:active{transform:scale(.98)}.semesters-grid-apple{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;display:grid}.semester-card-apple{border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-primary));background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));box-shadow:var(--glass-shadow,var(--shadow-card));cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);isolation:isolate;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:16px;display:grid;transform:translateZ(0)}[data-theme=dark] .semester-card-apple{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.semester-card-apple:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);transform:translateY(-2px)}.sem-badge{border-radius:var(--radius-full);background:var(--accent-subtle);border:1px solid var(--border-active);min-width:68px;height:34px;color:var(--accent);letter-spacing:.06em;justify-content:center;align-items:center;padding:0 12px;font-size:.68rem;font-weight:800;display:inline-flex}.sem-content{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.sem-content h3{color:var(--text-primary);margin:0;font-size:.95rem;font-weight:750;line-height:1.3}.sem-content p{color:var(--text-secondary);margin:0;font-size:.76rem;font-weight:600}.sem-arrow{width:30px;height:30px;color:var(--text-tertiary);background:var(--surface-secondary);border:1px solid var(--border-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.resources-search-bar{justify-content:flex-start;align-items:center;width:100%;display:flex}.search-input-wrap{border-radius:var(--radius-md);border:1px solid var(--border-primary);background:var(--input-bg);width:min(520px,100%);color:var(--text-tertiary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast), color var(--transition-fast);align-items:center;gap:10px;padding:11px 14px;display:flex}.search-input-wrap:focus-within{border-color:var(--input-focus-border);color:var(--accent);box-shadow:0 0 0 3px var(--input-focus-ring)}.search-input-wrap input{width:100%;color:var(--text-primary);background:0 0;border:none;outline:none;font-size:.84rem;font-weight:600}.search-input-wrap input::placeholder{color:var(--text-tertiary);font-weight:500}.resources-subjects-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.resource-subject-card{border-radius:var(--radius-md);border:1px solid var(--glass-border,var(--border-primary));background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));box-shadow:var(--glass-shadow,var(--shadow-card));transition:transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast), background var(--transition-fast);isolation:isolate;grid-template-columns:auto 1fr;align-items:center;gap:12px;padding:14px;text-decoration:none;display:grid;transform:translateZ(0)}[data-theme=dark] .resource-subject-card{background:var(--glass-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur,24px)) saturate(var(--glass-saturation,200%))}.resource-subject-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--border-active);background:var(--surface-secondary);transform:translateY(-2px)}@media (width<=430px){.resource-subject-card{border-radius:18px;padding:14px 16px}}.subject-icon-wrap{border-radius:var(--radius-sm);width:38px;height:38px;color:var(--accent);background:var(--accent-subtle);border:1px solid var(--border-active);flex-shrink:0;justify-content:center;align-items:center;display:flex}.subject-info{flex-direction:column;flex:1;gap:4px;min-width:0;display:flex}.subject-info h3{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:.86rem;font-weight:700;line-height:1.3;overflow:hidden}.subject-info .external-hint{color:var(--accent);align-items:center;gap:6px;font-size:.72rem;font-weight:600;display:inline-flex}.resources-subjects-grid .empty-state{border-radius:var(--radius-md);border:1px dashed var(--border-primary);background:var(--surface-secondary);grid-column:1/-1;margin-top:8px;padding:26px 18px}.resources-subjects-grid .empty-state p{color:var(--text-secondary);text-align:center;font-size:.84rem;font-weight:600}.resources-footer-note{border-radius:var(--radius-md);background:var(--surface-secondary);border:1px solid var(--border-secondary);text-align:center;margin-top:4px;padding:12px 14px}.resources-footer-note p{color:var(--text-secondary);margin:0;font-size:.75rem;font-weight:500;line-height:1.5}.resources-footer-note a{color:var(--text-primary);text-decoration:none}.resources-footer-note a:hover{color:var(--accent)}@media (width<=480px){.apple-page-container{gap:18px;padding:16px 12px 40px}.subpage-title{font-size:1.35rem}.attendance-card-apple .card-top{padding:16px 16px 0}.attendance-card-apple .card-metrics{padding:14px 16px}.attendance-card-apple .card-actions{padding:10px 16px}.marks-card-apple .card-header{padding:16px 16px 12px}.marks-card-apple .exams-list{padding:0 16px 12px}.sgpa-panel-apple{padding:18px}.sgpa-inputs-row{grid-template-columns:1fr;gap:8px}.class-item-apple{grid-template-columns:80px 1fr;gap:14px;padding:16px;display:grid}.section-header,.course-card-apple .card-content{padding:14px 16px}.apple-modal-overlay{padding:16px;transform:translateZ(0);-webkit-backdrop-filter:blur(12px)saturate(160%)!important;background:#0000008c!important}[data-theme=dark] .apple-modal-overlay{background:#000000b8!important}.apple-modal-card{border-radius:24px;max-width:360px;margin:0 auto;box-shadow:0 10px 40px #00000024;-webkit-backdrop-filter:blur(30px)saturate(190%)!important;background:#fffffff0!important}[data-theme=dark] .apple-modal-card{background:#1a1a1cf5!important}.apple-modal-header{padding:18px 20px 12px}.apple-modal-header h2{font-size:1rem}.apple-modal-body{gap:12px;padding:12px 20px 18px}.apple-modal-body .primary-text{font-size:.85rem;line-height:1.4}.apple-bullet-list li{gap:8px;font-size:.78rem}.apple-modal-footer{gap:8px;padding:12px 20px 18px;flex-direction:row!important}.apple-modal-footer .apple-btn{border-radius:12px;flex:1;width:100%;min-height:42px;font-size:.8rem}.skippro-card-apple .card-top{padding:14px 16px 10px}.skippro-card-apple .card-main{padding:0 16px}.stat-row.highlight{margin:0 -16px;padding:12px 16px}.skippro-card-apple .card-footer{padding:10px 16px}.skippro-page .subpage-header{gap:10px}.semesters-grid-apple,.resources-subjects-grid{grid-template-columns:1fr;gap:12px}.semester-card-apple,.resource-subject-card{padding:13px}.search-input-wrap{width:100%;padding:10px 12px}.resources-footer-note{padding:11px 12px}.sgpa-panel-top{flex-direction:column;align-items:flex-start}.sgpa-big-badge{flex-direction:row;justify-content:space-between;align-self:stretch;padding:12px 18px}}.cgpa-page{gap:22px}.cgpa-header-actions{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.cgpa-hero-card{border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:radial-gradient(circle at 92% 10%, color-mix(in srgb, var(--accent) 18%, transparent) 0%, transparent 34%), var(--surface-primary);box-shadow:var(--shadow-card);grid-template-columns:1.2fr 1fr;gap:16px;padding:24px;display:grid}.cgpa-hero-main{flex-direction:column;gap:6px;display:flex}.cgpa-kicker{text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-size:.75rem;font-weight:700}.cgpa-hero-main h2{letter-spacing:-.04em;color:var(--text-primary);font-size:clamp(2.1rem,5vw,3rem);font-weight:800;line-height:1}.cgpa-hero-main p{color:var(--text-secondary);max-width:42ch;font-size:.86rem}.cgpa-hero-grid{grid-template-columns:repeat(2,minmax(0,1fr));align-content:start;gap:10px;display:grid}.cgpa-mini-stat{border:1px solid var(--border-secondary);background:var(--surface-secondary);border-radius:14px;flex-direction:column;gap:4px;padding:14px;display:flex}.cgpa-mini-stat span{color:var(--text-secondary);font-size:.74rem;font-weight:600}.cgpa-mini-stat strong{color:var(--text-primary);font-size:1.15rem;font-weight:800}.cgpa-sheet,.cgpa-target-card{border-radius:var(--radius-lg);border:1px solid var(--border-primary);background:var(--surface-primary);box-shadow:var(--shadow-card);padding:20px}.cgpa-sheet-head{flex-direction:column;gap:3px;margin-bottom:14px;display:flex}.cgpa-sheet-head h3{color:var(--text-primary);font-size:1.05rem;font-weight:700}.cgpa-sheet-head p{color:var(--text-secondary);font-size:.82rem}.cgpa-grid-head{grid-template-columns:1.4fr .8fr .8fr .6fr;gap:10px;padding:0 4px 8px;display:grid}.cgpa-grid-head.auto-credits{grid-template-columns:1.2fr .8fr 1fr}.cgpa-grid-head span{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;font-weight:700}.cgpa-rows{flex-direction:column;gap:10px;display:flex}.cgpa-row{border:1px solid var(--border-secondary);background:var(--surface-secondary);border-radius:14px;grid-template-columns:1.4fr .8fr .8fr .6fr;gap:10px;padding:12px;display:grid}.cgpa-row.auto-credits{grid-template-columns:1.2fr .8fr 1fr;align-items:center}.cgpa-semester-tag{border:1px solid var(--border-secondary);background:var(--surface-primary);min-height:40px;color:var(--text-primary);border-radius:10px;align-items:center;padding:0 12px;font-size:.84rem;font-weight:700;display:inline-flex}.cgpa-credit-pill{border:1px solid var(--border-secondary);background:color-mix(in srgb, var(--accent) 10%, var(--surface-primary));min-height:40px;color:var(--text-primary);border-radius:10px;justify-content:center;align-items:center;padding:0 12px;font-size:.88rem;font-weight:800;display:inline-flex}.cgpa-text,.cgpa-number,.cgpa-input-block input{border:1px solid var(--input-border);background:var(--input-bg);width:100%;min-height:40px;color:var(--text-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);border-radius:10px;padding:0 12px;font-size:.86rem;font-weight:500}.cgpa-text:focus,.cgpa-number:focus,.cgpa-input-block input:focus{border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-ring);outline:none}.cgpa-remove{border:1px solid var(--border-primary);background:var(--surface-primary);min-height:40px;color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast);border-radius:10px;font-size:.8rem;font-weight:700}.cgpa-remove:hover:not(:disabled){color:var(--ring-red);border-color:color-mix(in srgb, var(--ring-red) 45%, transparent);background:color-mix(in srgb, var(--ring-red) 8%, var(--surface-primary))}.cgpa-remove:disabled{opacity:.45;cursor:not-allowed}.cgpa-target-controls{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.cgpa-input-block{flex-direction:column;gap:6px;display:flex}.cgpa-input-block label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-size:.74rem;font-weight:700}.cgpa-target-result{border:1px solid var(--border-secondary);background:var(--surface-secondary);border-radius:14px;flex-direction:column;gap:3px;margin-top:14px;padding:14px;display:flex}.cgpa-target-result .lbl{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.06em;font-size:.74rem;font-weight:700}.cgpa-target-result strong{color:var(--text-primary);letter-spacing:-.02em;font-size:1.45rem;font-weight:800}.cgpa-target-result p{color:var(--text-secondary);font-size:.82rem}.cgpa-target-result.easy{border-color:color-mix(in srgb, var(--ring-green) 45%, transparent);background:color-mix(in srgb, var(--ring-green) 9%, var(--surface-secondary))}.cgpa-target-result.medium{border-color:color-mix(in srgb, var(--ring-amber) 50%, transparent);background:color-mix(in srgb, var(--ring-amber) 10%, var(--surface-secondary))}.cgpa-target-result.hard{border-color:color-mix(in srgb, var(--ring-red) 45%, transparent);background:color-mix(in srgb, var(--ring-red) 10%, var(--surface-secondary))}@media (width<=900px){.cgpa-hero-card,.cgpa-grid-head,.cgpa-row,.cgpa-grid-head.auto-credits,.cgpa-row.auto-credits{grid-template-columns:1fr}.cgpa-grid-head{display:none}}@media (width<=768px){.cgpa-header-actions{width:100%}.cgpa-header-actions .apple-btn-secondary{flex:1;justify-content:center}.cgpa-target-controls{grid-template-columns:1fr}.cgpa-hero-card,.cgpa-sheet,.cgpa-target-card{padding:16px}.cgpa-mini-stat strong{font-size:1.02rem}}.class-card-v2.editing{cursor:pointer;border-style:dashed;transition:all .2s cubic-bezier(.19,1,.22,1);position:relative}.class-card-v2.editing:hover{border-color:var(--accent);background:var(--surface-secondary)}.class-card-v2.optional-class{opacity:.6;filter:grayscale(.5)}.type-meta-row{flex-direction:column;align-items:flex-end;gap:4px;display:flex}.optional-badge{color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em;background:var(--surface-tertiary);border:1px solid var(--border-secondary);border-radius:4px;padding:2px 6px;font-size:.62rem;font-weight:800}.edit-toggle-badge{border:1.5px solid var(--border-primary);background:var(--surface-primary);z-index:2;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;transition:all .2s;display:flex;position:absolute;top:12px;right:12px}.optional-class .edit-toggle-badge{background:var(--surface-tertiary);border-color:var(--border-secondary)}.class-card-v2:not(.optional-class) .edit-toggle-badge{background:var(--accent);border-color:var(--accent)}.class-card-v2:not(.optional-class) .edit-toggle-badge:after{content:"";border-bottom:2px solid #fff;border-right:2px solid #fff;width:4px;height:8px;margin-top:-2px;transform:rotate(45deg)}.cal-page-apple{flex-direction:column;gap:24px;animation:.45s both fadeInUp;display:flex}.cal-loading-apple,.cal-error-apple{text-align:center;background:var(--glass-bg-card,var(--surface-primary));min-height:400px;-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-secondary));border-radius:var(--radius-xl);box-shadow:var(--glass-shadow,var(--shadow-card));isolation:isolate;flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex;transform:translateZ(0)}.cal-loading-apple p{color:var(--text-secondary);font-size:.875rem;font-weight:500}.cal-error-apple p{color:var(--text-secondary);max-width:36ch;font-size:.875rem;font-weight:500;line-height:1.6}.apple-spinner{border:3px solid var(--border-primary);border-top-color:var(--accent);border-radius:50%;width:32px;height:32px;animation:.8s linear infinite spin}.cal-nav-apple{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border-radius:var(--radius-lg);border:1px solid var(--glass-border,var(--border-secondary));box-shadow:var(--glass-shadow,var(--shadow-card));isolation:isolate;align-items:center;gap:8px;padding:6px;display:flex;transform:translateZ(0)}.cal-pills-wrap{scrollbar-width:none;-ms-overflow-style:none;gap:2px;max-width:320px;display:flex;overflow-x:auto}.cal-pills-wrap::-webkit-scrollbar{display:none}.cal-pill{border-radius:var(--radius-sm);height:34px;color:var(--text-secondary);cursor:pointer;white-space:nowrap;transition:all var(--transition-fast);background:0 0;border:none;padding:0 14px;font-size:13px;font-weight:600;position:relative}.cal-pill:hover{color:var(--text-primary);background:var(--surface-secondary)}.cal-pill.active{background:var(--bg-elevated);color:var(--text-primary);box-shadow:var(--shadow-sm);border:1px solid var(--border-secondary)}.nav-btn{width:34px;height:34px;color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;display:flex}.cal-today-btn{border-radius:var(--radius-sm);border:1px solid var(--border-secondary);background:var(--bg-elevated);height:34px;color:var(--text-primary);letter-spacing:.01em;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;padding:0 12px;font-size:12px;font-weight:700}.cal-today-btn:hover:not(:disabled){background:var(--surface-tertiary);border-color:var(--border-primary)}.cal-today-btn:active:not(:disabled){transform:scale(.96)}.cal-today-btn:disabled{opacity:.45;cursor:not-allowed}.nav-btn:hover:not(:disabled){background:var(--surface-tertiary);color:var(--text-primary);transform:scale(1.05)}.nav-btn:active:not(:disabled){transform:scale(.95)}.nav-btn:disabled{opacity:.3;cursor:not-allowed}.cal-layout-apple{grid-template-columns:1fr 340px;align-items:start;gap:24px;display:grid}.cal-main-card{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-primary));border-radius:var(--radius-xl);box-shadow:var(--glass-shadow,var(--shadow-card));transition:box-shadow var(--transition-base);isolation:isolate;overflow:hidden;transform:translateZ(0)}.cal-main-card:hover{box-shadow:var(--shadow-card-hover)}.cal-weekday-row{background:var(--surface-secondary);border-bottom:1px solid var(--border-secondary);grid-template-columns:repeat(7,1fr);display:grid}.weekday{text-align:center;color:currentColor;text-transform:uppercase;letter-spacing:.8px;-webkit-user-select:none;user-select:none;border-right:1px solid var(--border-secondary);box-sizing:border-box;padding:14px 12px;font-size:11px;font-weight:700}.weekday:last-child{border-right:none}.weekday.weekend-header{color:var(--ring-red);opacity:.75}.cal-grid{grid-template-columns:repeat(7,1fr);grid-auto-rows:100px;display:grid}.cal-day-cell{border-right:1px solid var(--border-secondary);border-bottom:1px solid var(--border-secondary);cursor:default;min-width:0;transition:background var(--transition-fast);flex-direction:column;gap:6px;padding:10px;display:flex;position:relative;overflow:hidden}.cal-day-cell:nth-child(7n){border-right:none}.cal-day-cell:hover:not(.blank){background:var(--surface-secondary)}.cal-day-cell.blank{background:var(--surface-secondary);opacity:.4;pointer-events:none}.cal-day-cell.today,.cal-day-cell.today:hover{background:var(--accent-subtle)}.cal-day-cell.weekend:not(.today){background:#ff3b300a}.cal-day-cell.has-event{background:#ff95000a}.cal-day-cell.has-event:hover{background:#ff950014}.cal-day-cell.has-event.today{background:var(--accent-subtle)}.date-num{width:30px;height:30px;color:var(--text-primary);transition:all var(--transition-fast);border-radius:50%;justify-content:center;align-items:center;font-size:14px;font-weight:600;line-height:1;display:flex}.cal-day-cell.today .date-num{background:var(--accent);color:#fff;box-shadow:0 2px 8px var(--accent-glow);font-weight:700}.cal-day-cell.weekend:not(.today) .date-num{color:var(--apple-red);opacity:.65}.do-label{color:var(--accent);background:var(--accent-subtle);border-radius:var(--radius-xs);letter-spacing:.02em;width:fit-content;transition:background var(--transition-fast);padding:2px 7px;font-size:10px;font-weight:700;line-height:1.4}.event-text{color:var(--apple-orange);text-overflow:ellipsis;white-space:nowrap;background:#ff95001f;border-radius:5px;width:100%;min-width:0;max-width:100%;margin-top:auto;padding:2px 6px;font-size:10px;font-weight:600;line-height:1.5;overflow:hidden}.cal-events-sidebar{flex-direction:column;gap:20px;display:flex;position:sticky;top:32px}.cal-events-sidebar h3{color:var(--text-primary);letter-spacing:-.3px;margin:0;font-size:18px;font-weight:700}.events-list{flex-direction:column;gap:10px;display:flex}.event-item-apple{background:var(--glass-bg-card,var(--surface-primary));-webkit-backdrop-filter:blur(var(--glass-blur,20px)) saturate(var(--glass-saturation,180%));border:1px solid var(--glass-border,var(--border-secondary));border-radius:var(--radius-lg);transition:all var(--transition-fast);box-shadow:var(--glass-shadow,var(--shadow-card));cursor:pointer;isolation:isolate;align-items:center;gap:14px;padding:16px;display:flex;transform:translateZ(0)}.event-item-apple:hover{border-color:var(--border-primary);box-shadow:var(--shadow-card-hover);transform:translate(4px)}.event-item-apple:active{transform:translate(4px)scale(.99)}.date-badge{background:var(--surface-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-sm);width:48px;height:48px;transition:all var(--transition-fast);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;display:flex}.event-item-apple:hover .date-badge{background:var(--accent-subtle);border-color:var(--accent-glow)}.date-badge .day{color:var(--text-primary);font-size:18px;font-weight:800;line-height:1}.date-badge .mo{text-transform:uppercase;color:var(--accent);letter-spacing:.03em;margin-top:2px;font-size:10px;font-weight:700}.info{flex:1;min-width:0}.info h4{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:14px;font-weight:700;line-height:1.3;overflow:hidden}.info .time{color:var(--text-secondary);margin-top:4px;font-size:12px;font-weight:500;display:block}.no-events-state{text-align:center;background:var(--surface-secondary);border:1px solid var(--border-secondary);border-radius:var(--radius-lg);color:var(--text-tertiary);padding:48px 24px;font-size:14px;font-weight:500;line-height:1.6;animation:.3s both fadeIn}.cal-legend-apple{gap:20px;margin-top:8px;padding:0 4px;display:flex}.leg-item{color:var(--text-secondary);-webkit-user-select:none;user-select:none;align-items:center;gap:8px;font-size:12px;font-weight:600;display:flex}.dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dot.today{background:var(--accent);box-shadow:0 0 6px var(--accent-glow)}.dot.event{background:var(--apple-orange);box-shadow:0 0 6px #ff950040}.dot.working{background:var(--text-tertiary);opacity:.6}@media (width<=1024px){.cal-layout-apple{grid-template-columns:1fr}.cal-events-sidebar{margin-top:0;position:static}.events-list{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px;display:grid}}@media (width<=768px){.cal-page-apple{gap:12px}.subpage-header{margin-bottom:8px}.subpage-title{letter-spacing:-.02em;font-size:24px}.cal-nav-apple{background:var(--bg-glass);border-color:var(--border-glass);border-radius:14px;justify-content:space-between;gap:4px;width:100%;padding:2px}.nav-btn{background:var(--surface-secondary);border-radius:12px;width:38px;height:38px}.cal-pills-wrap{scrollbar-width:none;-webkit-overflow-scrolling:touch;flex:1;gap:4px;padding:0 4px;display:flex;overflow-x:auto}.cal-pill{border-radius:10px;flex:1;justify-content:center;align-items:center;min-width:0;height:30px;padding:0;font-size:11px;display:flex}.cal-layout-apple{grid-template-columns:1fr;gap:20px}.cal-main-card{border-color:var(--border-glass);border-radius:18px;width:100%;margin:0 auto;overflow:hidden;box-shadow:0 4px 12px #00000014}.cal-weekday-row,.cal-grid{box-sizing:border-box;width:100%;min-width:0!important}.cal-grid{grid-auto-rows:minmax(58px,auto)}.cal-day-cell{flex-direction:column;justify-content:flex-start;align-items:center;min-height:62px;padding:4px 1px;display:flex}.weekday{letter-spacing:.02em;opacity:.8;padding:8px 0;font-size:9px}.date-num{width:26px;height:26px;margin-bottom:2px;font-size:13px}.do-label{white-space:nowrap;border-radius:4px;width:auto;height:auto;margin:0 auto;padding:1px 4px;font-size:7.5px;font-weight:800;line-height:1.1;display:block}.event-text{text-align:center;white-space:normal;-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;width:100%;max-width:100%;height:auto;margin:2px auto 0;padding:1px 2px;font-size:7.5px;line-height:1.1;display:-webkit-box;overflow:hidden}.cal-day-cell:after{display:none!important}.cal-events-sidebar{background:var(--bg-glass);border:1px solid var(--border-glass);border-radius:24px;gap:16px;padding:20px}.cal-events-sidebar h3{letter-spacing:-.01em;font-size:17px}.event-item-apple{background:var(--surface-secondary);border:none;border-radius:16px;padding:12px}.date-badge{width:40px;height:40px}.date-badge .day{font-size:15px}.date-badge .mo{font-size:8px}.info h4{white-space:normal;font-size:13.5px;line-height:1.2}.cal-legend-apple{border-top:1px solid var(--border-glass);justify-content:center;padding-top:12px}}@media (width<=480px){.cal-grid{grid-auto-rows:minmax(48px,auto)}.cal-day-cell{min-height:52px;padding:4px 0}.date-num{width:22px;height:22px;font-size:11px}.do-label{padding:1px 3px;font-size:7px}.event-text{margin-top:1px;font-size:7px}.weekday{letter-spacing:.1px;padding:10px 0;font-size:8.5px}}@media (width<=430px){.apple-page-container.cal-page-apple{padding:12px 6px 32px!important}.cal-main-card{border-radius:12px}.cal-nav-apple{border-radius:10px;gap:1px;padding:1px}.nav-btn{width:34px;height:34px}.cal-pill{height:28px;font-size:9.5px}.cal-today-btn{height:28px;padding:0 6px;font-size:10.5px}.weekday{letter-spacing:0;padding:8px 0;font-size:8px}.cal-day-cell{min-height:54px;padding:2px 0}.date-num{width:20px;height:20px;margin-bottom:1px;font-size:10px}.do-label{border-radius:3px;padding:.5px 2px;font-size:6.5px}.event-text{-webkit-line-clamp:2;margin-top:1px;font-size:6.5px;line-height:1}.cal-events-sidebar{border-radius:16px;margin-top:16px;padding:12px}.cal-events-sidebar h3{font-size:15px}.event-item-apple{padding:8px}.date-badge{width:36px;height:36px}.date-badge .day{font-size:13px}.info h4{font-size:12px}}
