:root{--font-family: "Inter", sans-serif;--font-family-serif: "Roboto Serif", serif;--font-family-poppins: "Poppins", sans-serif;--font-family-montserrat: "Montserrat", sans-serif;--font-size-5: 5px;--font-size-6: 6px;--font-size-7: 7px;--font-size-8: 8px;--font-size-9: 9px;--font-size-10: 10px;--font-size-11: 11px;--font-size-12: 12px;--font-size-15: 15px;--font-size-18: 18px;--font-size-20: 20px;--font-size-25: 25px;--font-size-30: 30px;--font-size-35: 35px;--font-size-40: 40px;--font-size-45: 45px;--font-size-50: 50px;--font-size-55: 55px;--font-size-60: 60px;--font-size-65: 65px;--font-size-70: 70px;--font-size-75: 75px;--font-size-80: 80px;--font-size-85: 85px;--font-size-90: 90px;--font-size-95: 95px;--font-size-100: 100px;--font-weight-100: 100;--font-weight-200: 200;--font-weight-300: 300;--font-weight-400: 400;--font-weight-500: 500;--font-weight-600: 600;--font-weight-700: 700;--font-weight-800: 800;--font-weight-900: 900;--color-bg: #ebf7fd;--color-text: #021024;--color-accent: #4a90e2;--color-highlight: #15803d;--color-success: #10b981;--color-danger: #ef4444;--text-shadow-light: 0px 2px 4px rgba(0,0,0,.2);--box-shadow-light: 0px 2px 4px rgba(0,0,0,.2);--transition: all .3s ease-in-out;--animation: all .3s ease-in-out forwards}[data-theme=dark]{--color-bg: #021024;--color-text: #ebf7fd;--color-accent: #4ade80;--color-highlight: #bef264;--text-shadow-light: 0px 2px 6px rgba(255,255,255,.15);--box-shadow-light: 0px 1px 1px rgba(255,255,255,.15)}*{margin:0;padding:0;box-sizing:border-box;font-family:var(--font-family);-webkit-user-select:none;user-select:none}body{background:var(--color-bg);color:var(--color-text);font-weight:400;min-height:100vh;display:flex;flex-direction:row;align-items:center;justify-content:center;transition:background .4s ease,color .4s ease}::-webkit-scrollbar{display:none}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background-color:#4ade80;border-radius:10px;border:2px solid transparent;background-clip:content-box}::-webkit-scrollbar-thumb:hover{background-color:#50e3c2d9}::-webkit-scrollbar-button{display:none;width:0;height:0}::-webkit-scrollbar-track{display:none;width:0;height:0}.loader{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg);transition:background var(--duration-slow) var(--ease-default)}.theme-icon{position:fixed;top:20px;right:20px;z-index:1000}.theme-icon i{position:relative;color:var(--color-text);font-size:var(--font-size-30);cursor:pointer;transition:var(--transition)}@media(max-width:768px){.theme-icon i{font-size:var(--font-size-30)}}.theme-icon i:hover{color:var(--color-text);font-size:var(--font-size-30);filter:drop-shadow(0px 0px .5px var(--color-text));transition:var(--transition)}.sidebar{display:flex;flex-direction:column;width:240px;height:100vh;position:fixed;top:0;left:0;border-right:1px solid rgba(2,16,36,.08);padding:16px 12px;z-index:100;overflow:hidden;transition:var(--transition)}.sidebar.collapsed{width:64px;transition:var(--transition)}.sidebar.collapsed .sidebar-brand,.sidebar.collapsed .sidebar-item span{opacity:0;pointer-events:none;transition:var(--transition)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:8px 4px 5px}.sidebar-brand{font-size:var(--font-size-20);font-weight:var(--font-weight-700);color:var(--color-accent);white-space:nowrap;transition:var(--transition)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;background:none;border:none;color:var(--color-text);font-size:var(--font-size-20);cursor:pointer;padding:4px;margin-top:15px;border-radius:6px;opacity:.5;transition:var(--transition)}.sidebar-toggle:hover{opacity:1;background:#0210240d}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.sidebar-item{display:flex;align-items:center;gap:12px;width:100%;margin-top:20px;padding:10px 12px;background:none;border:none;border-radius:8px;color:var(--color-text);font-size:var(--font-size-15);font-weight:var(--font-weight-400);cursor:pointer;white-space:nowrap;transition:var(--transition);opacity:.6}.sidebar-item i{font-size:var(--font-size-20);flex-shrink:0}.sidebar-item span{transition:opacity .2s ease}.sidebar-item:hover{opacity:1;background:#0210240a}.sidebar-item.active{opacity:1;color:var(--color-accent);background:#4a90e214;font-weight:var(--font-weight-500)}[data-theme=dark] .sidebar{border-color:#ebf7fd0f}[data-theme=dark] .sidebar-toggle:hover{background:#ebf7fd0f}[data-theme=dark] .sidebar-item:hover{background:#ebf7fd0d}[data-theme=dark] .sidebar-item.active{background:#4ade8014}@media(max-width:768px){.dashboard-content{margin-left:64px}.sidebar{width:64px}.sidebar.collapsed{width:0;left:-30px;overflow:hidden}.sidebar .sidebar-toggle{position:fixed;top:20px;left:16px;z-index:101}.sidebar-brand{display:none}.sidebar-item{justify-content:center;padding:10px}.sidebar-item span{display:none}.sidebar-header{justify-content:flex-end;margin-bottom:30px}}.landing-hero{position:relative;display:flex;align-items:center;justify-content:center;width:100%;height:100vh;overflow:hidden}.landing-depth{position:absolute;will-change:transform;pointer-events:none}.landing-depth--0{inset:-50%;background:radial-gradient(ellipse 80% 70% at 50% 45%,var(--color-accent),transparent 65%);opacity:.18}.landing-depth--1{inset:-30%;background:radial-gradient(ellipse 50% 40% at 65% 55%,var(--color-highlight),transparent 55%),radial-gradient(ellipse 40% 35% at 25% 35%,var(--color-accent),transparent 50%);opacity:.2}.landing-depth--2{inset:-10%;background:radial-gradient(circle at 15% 25%,var(--color-accent),transparent 30%),radial-gradient(circle at 85% 75%,var(--color-highlight),transparent 25%);opacity:.12}.landing-hero-words{position:absolute;inset:0;will-change:transform;pointer-events:none}.landing-word{position:absolute;font-size:var(--font-size-100);font-weight:var(--font-weight-900);color:var(--color-accent);text-transform:uppercase;white-space:nowrap;letter-spacing:12px;-webkit-user-select:none;user-select:none;transition:var(--transition)}.landing-word--0{top:5%;left:-5%}.landing-word--1{top:22%;right:-8%}.landing-word--2{top:40%;left:8%}.landing-word--3{top:58%;right:3%}.landing-word--4{top:75%;left:-3%}.landing-word--5{top:90%;right:10%}.landing-hero-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;max-width:800px;padding:0 32px;text-align:center;will-change:transform,opacity;animation:landing-fade-up .9s ease both}.landing-hero-content h1{font-size:var(--font-size-80);font-weight:var(--font-weight-800);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-3px;line-height:1.05}.landing-hero-label{font-size:var(--font-size-15);font-weight:var(--font-weight-600);color:var(--color-accent);text-transform:uppercase;letter-spacing:4px;opacity:.7;transition:var(--transition)}.landing-hero-sub{font-size:var(--font-size-20);color:var(--color-text);opacity:.45;max-width:480px;line-height:1.7;transition:var(--transition)}.landing-hero-actions{display:flex;gap:16px;margin-top:16px}.landing-scroll-hint{position:absolute;bottom:32px;left:50%;z-index:2;transform:translate(-50%);cursor:pointer}.landing-scroll-hint i{font-size:var(--font-size-30);color:var(--color-accent);opacity:.5;animation:landing-bounce 2.4s ease-in-out infinite}.landing-phone{position:relative;z-index:1;flex-shrink:0;width:230px;height:480px;background:linear-gradient(165deg,#364962,#2b3a4e 40%,#263344);border-radius:40px;padding:6px;opacity:0;will-change:transform;transition:opacity .7s ease,background var(--transition);transform-style:preserve-3d;box-shadow:0 4px 8px #15233880,0 16px 40px #101c3099,0 40px 100px #0c1628b3,0 0 0 2px #394e68,0 0 0 3px #415775,inset 0 1px #ffffff26,inset 2px 0 #ffffff14,inset 0 -1px #0c16284d,inset -1px 0 #0c162833}.landing-phone.visible{opacity:1}.landing-phone:before{content:"";position:absolute;inset:0;border-radius:40px;border:1px solid transparent;border-top-color:#a0c8f033;border-left-color:#8cb4e626;border-bottom-color:#0c16284d;border-right-color:#0c162833;pointer-events:none}.landing-phone:after{content:"";position:absolute;right:-3px;top:120px;width:3px;height:44px;border-radius:0 3px 3px 0;background:linear-gradient(180deg,#394e68,#3d5068 40%,#263344);box-shadow:2px 0 4px #0c162866,inset 0 1px #ffffff1a}.landing-phone-glare{position:absolute;inset:0;border-radius:40px;background:radial-gradient(ellipse 35% 25% at 30% 20%,rgba(200,225,255,.18),transparent 60%),radial-gradient(ellipse 50% 40% at 50% 50%,rgba(160,200,255,.1),transparent 70%);background-size:200% 200%;pointer-events:none;z-index:5;transition:opacity .7s ease;mix-blend-mode:screen}.landing-phone-reflection{position:absolute;left:8%;right:8%;height:30%;border-radius:40px;background:linear-gradient(180deg,transparent 0%,rgba(140,190,255,.04) 40%,rgba(200,220,255,.07) 50%,rgba(140,190,255,.04) 60%,transparent 100%);pointer-events:none;z-index:4;will-change:transform}.landing-phone-buttons{position:absolute;left:-3px;top:100px;display:flex;flex-direction:column;gap:12px}.landing-phone-buttons:before,.landing-phone-buttons:after{content:"";width:3px;border-radius:3px 0 0 3px;background:linear-gradient(180deg,#394e68,#3d5068 40%,#263344);box-shadow:-2px 0 4px #0c162866,inset 0 1px #ffffff1a}.landing-phone-buttons:before{height:28px}.landing-phone-buttons:after{height:28px}.landing-phone-screen{width:100%;height:100%;border-radius:36px;overflow:hidden;position:relative;transition:var(--transition)}.landing-phone-screen-glow{position:absolute;inset:0;border-radius:36px;pointer-events:none;z-index:2}.landing-phone-notch{position:absolute;top:10px;left:50%;transform:translate(-50%);width:90px;height:24px;border-radius:20px;background:#000;z-index:3;display:flex;align-items:center;justify-content:flex-end;padding-right:10px;transition:var(--transition)}.landing-phone-notch:after{content:"";width:8px;height:8px;border-radius:50%;background:#0a0a0c;border:1px solid rgba(60,60,70,.5);box-shadow:inset 0 0 2px #282832cc;transition:var(--transition)}.landing-phone-home{position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:100px;height:4px;border-radius:2px;background:#ffffff40;z-index:3;transition:var(--transition)}.phone-screen-content{display:flex;flex-direction:column;gap:10px;width:100%;height:100%;background:var(--color-bg);padding:44px 14px 20px;overflow:hidden;transition:var(--transition)}.ps-bar{height:10px;border-radius:5px;background:var(--color-accent);opacity:.6;transition:var(--transition)}.ps-input{height:28px;border-radius:8px;border:1.5px solid rgba(2,16,36,.1);background:transparent}.ps-btn{height:30px;border-radius:10px;background:var(--color-accent);opacity:.8;margin-top:auto;transition:var(--transition)}.ps-card{display:flex;flex-direction:column;gap:6px;padding:12px;border-radius:10px;background:#02102408;border:1px solid rgba(2,16,36,.06)}.ps-line{height:6px;border-radius:3px;background:var(--color-text);opacity:.12;transition:var(--transition)}.ps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:8px 0}.ps-dot{aspect-ratio:1;border-radius:6px;background:var(--color-accent);opacity:.2;transition:var(--transition)}.ps-dot:nth-child(3n){opacity:.5}.ps-dot:nth-child(5n){opacity:.35}.ps-chart{display:flex;align-items:flex-end;gap:6px;height:80px;padding:4px 0}.ps-chart-bar{flex:1;border-radius:4px 4px 0 0;background:var(--color-accent);opacity:.35;transition:var(--transition)}.ps-chart-bar:nth-child(odd){opacity:.55}.ps-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:8px 12px;border-radius:10px;background:#02102408;border:1px solid rgba(2,16,36,.06)}.ps-toggle{width:32px;height:18px;border-radius:9px;background:var(--color-accent);opacity:.5;position:relative;flex-shrink:0;transition:var(--transition)}.ps-toggle-knob{position:absolute;top:3px;right:3px;width:12px;height:12px;border-radius:50%;background:var(--color-bg);transition:var(--transition)}.landing-phone-slot{flex-shrink:0;width:230px;height:480px}.landing-phone-fixed{position:fixed;z-index:1;width:300px;height:700px;opacity:0;pointer-events:none;will-change:transform,left,top,opacity}.landing-phone-fixed>div,.landing-phone-fixed canvas{background:transparent!important}.landing-phone-fixed canvas{display:block;width:100%!important;height:100%!important}.phone-screen-content--overlay{padding-top:16px}.landing-phone-glb{position:relative;z-index:1;flex-shrink:0;width:230px;height:480px;border-radius:40px;overflow:hidden;opacity:0;will-change:transform;transition:opacity .7s ease}.landing-phone-glb.visible{opacity:1}.landing-phone-glb canvas{display:block;width:100%!important;height:100%!important}[data-theme=dark] .landing-phone{box-shadow:0 4px 8px #15233880,0 16px 40px #101c3099,0 40px 100px #0c1628b3,0 0 0 2px #394e68,0 0 0 3px #415775,inset 0 1px #ffffff26,inset 2px 0 #ffffff14,inset 0 -1px #0c16284d,inset -1px 0 #0c162833}[data-theme=dark] .ps-input{border-color:#ebf7fd1a;transition:var(--transition)}[data-theme=dark] .ps-card,[data-theme=dark] .ps-toggle-row{background:#ebf7fd08;border-color:#ebf7fd0f;transition:var(--transition)}.landing-section{position:relative;display:flex;align-items:center;justify-content:center;gap:80px;width:100%;min-height:100vh;padding:80px 64px;overflow:hidden}.landing-section.reverse{flex-direction:row-reverse}.landing-section-bg{position:absolute;inset:-40%;border-radius:50%;opacity:0;will-change:transform;transition:opacity .9s ease}.landing-section:nth-child(2) .landing-section-bg{background:radial-gradient(circle at 25% 45%,var(--color-accent),transparent 50%)}.landing-section:nth-child(3) .landing-section-bg{background:radial-gradient(circle at 75% 40%,var(--color-highlight),transparent 50%)}.landing-section:nth-child(4) .landing-section-bg{background:radial-gradient(circle at 35% 65%,var(--color-accent),transparent 45%)}.landing-section:nth-child(5) .landing-section-bg{background:radial-gradient(circle at 65% 30%,var(--color-highlight),transparent 50%)}.landing-section:nth-child(6) .landing-section-bg{background:radial-gradient(circle at 45% 55%,var(--color-accent),transparent 45%)}.landing-section:nth-child(7) .landing-section-bg{background:radial-gradient(circle at 30% 50%,var(--color-highlight),transparent 50%)}.landing-section.visible .landing-section-bg{opacity:.15}.landing-section-keyword{position:absolute;font-size:clamp(100px,14vw,220px);font-weight:var(--font-weight-900);color:var(--color-accent);text-transform:uppercase;letter-spacing:14px;white-space:nowrap;pointer-events:none;-webkit-user-select:none;user-select:none;will-change:transform,opacity;transition:opacity .8s ease}.landing-section:nth-child(odd) .landing-section-keyword{right:-3%}.landing-section:nth-child(2n) .landing-section-keyword{left:-3%}.landing-section-text{position:relative;z-index:2;max-width:520px;opacity:0;will-change:transform;transition:opacity .7s ease .12s}.landing-section-text.visible{opacity:1}.landing-section-number{display:block;font-size:var(--font-size-15);font-weight:var(--font-weight-600);color:var(--color-accent);opacity:.6;letter-spacing:3px;margin-bottom:12px;transition:var(--transition)}.landing-section-text h2{font-size:var(--font-size-55);font-weight:var(--font-weight-800);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:20px;transition:var(--transition)}.landing-section-desc{font-size:var(--font-size-20);color:var(--color-text);opacity:.6;line-height:1.7;margin-bottom:14px;transition:var(--transition)}.landing-section-detail{font-size:var(--font-size-15);color:var(--color-text);opacity:.35;line-height:1.6;transition:var(--transition)}.landing-cta{position:relative;display:flex;justify-content:center;align-items:center;width:100%;min-height:100vh;overflow:hidden}.landing-cta-depth{position:absolute;will-change:transform;pointer-events:none}.landing-cta-depth--0{inset:-50%;background:radial-gradient(ellipse 80% 70% at 50% 45%,var(--color-accent),transparent 65%)}.landing-cta-depth--1{inset:-30%;background:radial-gradient(ellipse 50% 40% at 65% 55%,var(--color-highlight),transparent 55%),radial-gradient(ellipse 40% 35% at 25% 35%,var(--color-accent),transparent 50%)}.landing-cta-words{position:absolute;inset:0;will-change:transform;pointer-events:none}.landing-cta-word{position:absolute;font-size:var(--font-size-100);font-weight:var(--font-weight-900);color:var(--color-accent);text-transform:uppercase;white-space:nowrap;letter-spacing:12px;-webkit-user-select:none;user-select:none;opacity:0;transition:opacity .8s ease}.landing-cta.visible .landing-cta-word{opacity:.06}.landing-cta-word--0{top:5%;left:-5%}.landing-cta-word--1{top:22%;right:-8%}.landing-cta-word--2{top:40%;left:8%}.landing-cta-word--3{top:58%;right:3%}.landing-cta-word--4{top:75%;left:-3%}.landing-cta-word--5{top:90%;right:10%}.landing-cta-content{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:24px;max-width:800px;padding:0 32px;text-align:center;opacity:0;transform:translateY(32px);transition:opacity .8s ease,transform .8s ease}.landing-cta.visible .landing-cta-content{opacity:1;transform:translateY(0)}.landing-cta-content h2{font-size:var(--font-size-80);font-weight:var(--font-weight-800);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-3px;line-height:1.05}.auth{display:flex;width:100%;min-height:100vh}.auth .auth-banner{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;width:50%;background:#4ade801f;color:var(--color-text);transition:var(--transition)}.auth .auth-banner .auth-banner-logo{width:100px;height:100px;object-fit:contain;transition:var(--transition)}.auth .auth-banner h2{font-size:var(--font-size-40);font-weight:var(--font-weight-800);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent;letter-spacing:-1px}.auth .auth-banner p{font-size:var(--font-size-11);font-weight:var(--font-weight-600);color:var(--color-accent);text-transform:uppercase;letter-spacing:4px;opacity:.7;transition:var(--transition)}.auth .auth-card{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px;width:500px;padding:40px}.auth .auth-card .auth-verify-icon{font-size:var(--font-size-50);color:var(--color-accent);transition:var(--transition)}.auth .auth-card .auth-title{width:100%;font-size:var(--font-size-30);font-weight:var(--font-weight-700);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent;text-align:center}.auth .auth-card .auth-subtitle{font-size:var(--font-size-15);color:var(--color-text);opacity:.5;margin-top:-8px;text-align:center;transition:var(--transition)}.auth .auth-card .auth-form{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;width:min(800px,100%)}.auth .auth-card .auth-form .auth-field{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);border-radius:10px;background:color-mix(in srgb,var(--color-accent) 5%,transparent);cursor:text;transition:var(--transition)}.auth .auth-card .auth-form .auth-field:focus-within{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 8%,transparent);transition:var(--transition)}.auth .auth-card .auth-form .auth-field i{font-size:var(--font-size-20);color:var(--color-accent);transition:var(--transition)}.auth .auth-card .auth-form .auth-field input{flex:1;background:transparent;border:none;outline:none;font-size:var(--font-size-15);color:var(--color-text);-webkit-user-select:text;user-select:text;transition:var(--transition)}.auth .auth-card .auth-form .auth-field input::placeholder{color:var(--color-text);opacity:.4;transition:var(--transition)}.auth .auth-card .auth-form .auth-eye{cursor:pointer;color:var(--color-text);opacity:.4;transition:var(--transition)}.auth .auth-card .auth-form .auth-eye:hover{opacity:.8}.auth .auth-card .auth-form .auth-rules{width:100%;list-style:none;display:flex;flex-wrap:wrap;gap:6px 16px}.auth .auth-card .auth-form .auth-rules li{display:flex;align-items:center;gap:6px;font-size:var(--font-size-11);color:var(--color-danger);transition:var(--transition)}.auth .auth-card .auth-form .auth-rules li.pass{color:var(--color-success);transition:var(--transition)}.auth .auth-card .auth-form .auth-rules .auth-rule-icon{width:12px;height:12px;flex:0 0 12px}.auth .auth-card .auth-form .auth-password-group{display:flex;flex-direction:column;gap:16px;width:100%}.auth .auth-card .auth-form .auth-error{width:100%;font-size:var(--font-size-12);color:var(--color-danger);transition:var(--transition)}.auth .auth-card .auth-form .auth-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:80%;padding:14px;margin-top:8px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition);min-height:48px}.auth .auth-card .auth-form .auth-btn:hover{opacity:.85;transform:translateY(-1px)}.auth .auth-card .auth-form .auth-btn:active{transform:translateY(0);opacity:1}.auth .auth-card .auth-form .auth-btn:disabled{cursor:not-allowed;opacity:.7}.auth .auth-card .auth-form .auth-dots{display:flex;align-items:center;gap:6px}.auth .auth-card .auth-form .auth-dots span{width:7px;height:7px;border-radius:50%;background:var(--color-bg);animation:auth-dot-bounce 1.4s ease-in-out infinite;transition:var(--transition)}.auth .auth-card .auth-form .auth-dots span:nth-child(2){animation-delay:.16s}.auth .auth-card .auth-form .auth-dots span:nth-child(3){animation-delay:.32s}@keyframes auth-dot-bounce{0%,80%,to{opacity:.3;transform:scale(.8)}40%{opacity:1;transform:scale(1)}}.auth .auth-card .auth-switch{font-size:var(--font-size-12);color:var(--color-text);opacity:.6;transition:var(--transition)}.auth .auth-card .auth-switch span{color:var(--color-accent);cursor:pointer;font-weight:var(--font-weight-600)}.auth .auth-card .auth-switch span:hover{text-decoration:underline}@media(max-width:768px){.auth{flex-direction:column;width:100vw}.auth .auth-banner{width:100%;padding:32px}.auth .auth-banner h2{font-size:var(--font-size-25)}.auth .auth-banner .auth-banner-logo{width:50px;height:50px}.auth .auth-card{width:100%;padding:32px 24px}}[data-theme=dark] .auth-banner{background:#4ade801f;color:var(--color-text);transition:var(--transition)}.setup-stepper{display:flex;flex-direction:row;flex-wrap:nowrap;width:100%;margin-bottom:8px;-webkit-user-select:none;user-select:none}.setup-stepper-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}.setup-step-track{display:flex;align-items:center;width:100%}.setup-step-half{flex:1;height:2px;background:color-mix(in srgb,var(--color-text) 10%,transparent);transition:background .35s ease}.setup-step-half--done{background:color-mix(in srgb,var(--color-accent) 45%,transparent)}.setup-step-half--hidden{visibility:hidden}.setup-step-dot{width:36px;height:36px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--color-text) 14%,transparent);background:color-mix(in srgb,var(--color-text) 4%,transparent);color:color-mix(in srgb,var(--color-text) 30%,transparent);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease,transform .3s ease}.setup-step-dot i{font-size:var(--font-size-18)}.setup-step-dot--done{background:color-mix(in srgb,var(--color-accent) 12%,transparent);border-color:color-mix(in srgb,var(--color-accent) 55%,transparent);color:var(--color-accent)}.setup-step-dot--active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-bg);box-shadow:0 0 0 5px color-mix(in srgb,var(--color-accent) 15%,transparent),0 3px 10px color-mix(in srgb,var(--color-accent) 28%,transparent);transform:scale(1.15)}.setup-step-label{margin-top:8px;font-size:var(--font-size-11);font-weight:var(--font-weight-600);text-transform:uppercase;letter-spacing:1.5px;color:var(--color-text);opacity:.35;transition:var(--transition)}.setup-step-label--active{opacity:1;color:var(--color-accent)}.setup-step-label--done{opacity:.65;color:var(--color-accent)}.setup-header{display:flex;flex-direction:column;align-items:center;gap:8px;width:100%;text-align:center}.setup-title{width:100%;font-size:var(--font-size-25);font-weight:var(--font-weight-700);background:var(--color-accent);-webkit-background-clip:text;background-clip:text;color:transparent}.setup-subtitle{font-size:var(--font-size-15);color:var(--color-text);opacity:.5;transition:var(--transition)}.setup-form{display:flex;flex-direction:column;gap:8px;width:100%}.setup-form .setup-field{display:flex;align-items:center;gap:10px;width:100%;padding:12px 14px;border:1px solid color-mix(in srgb,var(--color-accent) 22%,transparent);border-radius:10px;background:color-mix(in srgb,var(--color-accent) 5%,transparent);cursor:text;transition:var(--transition)}.setup-form .setup-field:focus-within{border-color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 8%,transparent)}.setup-form .setup-field.error{border-color:var(--color-danger);animation:setup-shake .35s ease}.setup-form .setup-field i.field-icon{font-size:var(--font-size-20);color:var(--color-accent);flex-shrink:0;opacity:.5;transition:var(--transition)}.setup-form .setup-field:focus-within i.field-icon{opacity:1}.setup-form .setup-field input,.setup-form .setup-field select{flex:1;min-width:0;background:transparent;border:none;outline:none;font-size:var(--font-size-15);color:var(--color-text);font-family:var(--font-family);transition:var(--transition)}.setup-form .setup-field input::placeholder,.setup-form .setup-field select::placeholder{color:var(--color-text);opacity:.35}.setup-form .setup-field input option,.setup-form .setup-field select option{background:var(--color-bg);color:var(--color-text)}.setup-form .setup-field select{cursor:pointer}.setup-form .setup-divider{width:100%;height:1px;background:color-mix(in srgb,var(--color-accent) 12%,transparent);margin:16px 0 4px;transition:var(--transition)}.setup-form .setup-field-row{display:flex;gap:8px;width:100%}.setup-form .setup-field-row .setup-field{flex:1;min-width:0}.setup-form .setup-error-msg{display:flex;align-items:center;gap:8px;padding:10px 16px;margin-top:8px;background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 25%,transparent);border-radius:8px;font-size:var(--font-size-12);color:var(--color-danger);animation:setup-fadein .2s ease}.setup-form .setup-error-msg i{font-size:var(--font-size-15);flex-shrink:0}.setup-form .setup-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:100%;padding:14px 16px;margin-top:24px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition);min-height:50px}.setup-form .setup-btn i{font-size:var(--font-size-18)}.setup-form .setup-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 20px color-mix(in srgb,var(--color-accent) 35%,transparent)}.setup-form .setup-btn:active:not(:disabled){transform:translateY(0);filter:brightness(1);box-shadow:none}.setup-form .setup-btn:disabled{cursor:not-allowed;opacity:.45}.setup-form .setup-dots{display:flex;align-items:center;gap:5px}.setup-form .setup-dots span{width:6px;height:6px;border-radius:50%;background:var(--color-bg);animation:setup-dot-bounce 1.2s ease-in-out infinite}.setup-form .setup-dots span:nth-child(2){animation-delay:.15s}.setup-form .setup-dots span:nth-child(3){animation-delay:.3s}@keyframes setup-dot-bounce{0%,80%,to{opacity:.3;transform:scale(.75)}40%{opacity:1;transform:scale(1)}}@keyframes setup-shake{0%,to{transform:translate(0)}20%{transform:translate(-6px)}40%{transform:translate(6px)}60%{transform:translate(-4px)}80%{transform:translate(4px)}}@keyframes setup-fadein{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.setup{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100vw;min-height:100vh;background:var(--color-bg);padding:24px;transition:var(--transition)}.setup-card{display:flex;flex-direction:column;align-items:center;gap:24px;width:min(480px,100%);padding:40px;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 8%);border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:24px;box-shadow:var(--box-shadow-light);transition:var(--transition)}@media(max-width:768px){.setup{align-items:flex-start}.setup-card{padding:24px}}.dashboard{display:flex;width:100vw;min-height:100vh;position:fixed;top:0;left:0}.dashboard-right{display:flex;flex-direction:column;flex:1;margin-left:240px;height:100vh;overflow:hidden;transition:var(--transition)}@media(max-width:768px){.dashboard-right{margin-left:30px}}.dashboard.collapsed .dashboard-right{margin-left:64px}@media(max-width:768px){.dashboard.collapsed .dashboard-right{margin-left:30px}}.dashboard-topbar{flex-shrink:0;padding:20px 32px 16px;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid color-mix(in srgb,var(--color-accent) 12%,transparent);transition:background var(--transition),border-color var(--transition)}.dashboard-topbar-title{font-size:var(--font-size-25);font-weight:var(--font-weight-700);color:var(--color-text);transition:var(--transition)}.dashboard-topbar-desc{margin-top:4px;font-size:var(--font-size-15);color:var(--color-text);opacity:.55;transition:var(--transition)}.dashboard-content{flex:1;padding:32px;overflow-y:auto;transition:var(--transition)}.dh{display:grid;grid-template-columns:minmax(0,1fr) 290px;gap:16px 24px;align-items:start}@media(max-width:960px){.dh{grid-template-columns:1fr}}.dh-left{display:contents}.dh-right{grid-column:2;grid-row:1/span 2;align-self:start;min-width:0;display:flex;flex-direction:column;gap:16px}@media(max-width:960px){.dh-right{grid-column:1;grid-row:auto}}.dh-trend,.dh-top,.dh-perf,.dh-dc{padding:24px;background:color-mix(in srgb,var(--color-text) 3%,var(--color-bg));border:1px solid color-mix(in srgb,var(--color-text) 7%,transparent);border-radius:16px;transition:background var(--transition),border-color var(--transition)}.dh-trend-title,.dh-top-title,.dh-perf-title{font-size:10px;font-weight:700;letter-spacing:1.4px;text-transform:uppercase;color:var(--color-text);opacity:.4;transition:color var(--transition)}.dh-top-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.3fr);gap:16px;align-items:stretch}@media(max-width:680px){.dh-top-row{grid-template-columns:1fr}}.dh-hero{display:flex;align-items:center;gap:32px;padding:32px 36px;border-radius:24px;border:1px solid color-mix(in srgb,var(--color-accent) 18%,transparent);background:color-mix(in srgb,var(--color-accent) 6%,var(--color-bg));position:relative;overflow:hidden;transition:background var(--transition),border-color var(--transition)}.dh-hero-body{display:flex;flex-direction:column;gap:12px;flex:1;min-width:0;z-index:1}.dh-hero-top{display:flex;align-items:center;justify-content:space-between}.dh-hero-eyebrow{font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--color-accent);opacity:.6;transition:color var(--transition)}.dh-hero-classroom-badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:.3px;color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);white-space:nowrap;transition:var(--transition)}.dh-hero-school{font-size:26px;font-weight:700;color:var(--color-text);line-height:1.15;transition:color var(--transition)}.dh-hero-rule{width:100%;height:1px;background:color-mix(in srgb,var(--color-text) 8%,transparent);flex-shrink:0;transition:background var(--transition)}.dh-hero-meta{display:flex;flex-wrap:wrap;align-items:center;gap:16px 24px}.dh-hero-meta-item{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--color-text);opacity:.5;white-space:nowrap;transition:color var(--transition)}.dh-hero-meta-item i{font-size:13px;color:var(--color-accent);opacity:.65;flex-shrink:0}.dh-hero-icon{flex-shrink:0;color:var(--color-accent);opacity:.05;z-index:0}.dh-hero-icon i{font-size:96px;line-height:1}.dh-hero--skel{pointer-events:none}.dh-pill{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:999px;font-size:11px;font-weight:500;background:color-mix(in srgb,var(--color-accent) 10%,transparent);color:var(--color-accent);border:1px solid color-mix(in srgb,var(--color-accent) 18%,transparent);transition:var(--transition)}.dh-pill i{font-size:11px}.dh-donuts{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}@media(max-width:600px){.dh-donuts{grid-template-columns:1fr}}.dh-dc{display:flex;flex-direction:column;gap:16px}.dh-dc--skel{pointer-events:none}.dh-dc--sm{padding:20px;gap:16px}.dh-dc--sm .dh-dc-title{font-size:10px;font-weight:700;letter-spacing:1.2px;text-transform:uppercase;opacity:.4}.dh-dc--sm .dh-dc-icon{width:24px;height:24px}.dh-dc--sm .dh-dc-icon i{font-size:11px}.dh-dc--sm .dh-dc-body{gap:16px}.dh-dc--sm .dh-dc-legend{gap:6px}.dh-dc--sm .dh-dc-row{gap:8px}.dh-dc-head{display:flex;align-items:center;justify-content:space-between}.dh-dc-title{font-size:var(--font-size-15);font-weight:var(--font-weight-600);color:var(--color-text);transition:color var(--transition)}.dh-dc-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:12px;background:color-mix(in srgb,var(--color-accent) 10%,transparent);color:var(--color-accent);opacity:.65;flex-shrink:0;transition:var(--transition)}.dh-dc-icon i{font-size:13px}.dh-dc-body{display:flex;align-items:center;gap:24px}.dh-dc-divider{display:none}.dh-dc-legend{display:flex;flex-direction:column;gap:7px;flex:1;min-width:0}.dh-dc-row{display:flex;align-items:center;gap:8px}.dh-dc-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.dh-dc-dot--male{background:#3b82f6}.dh-dc-dot--female{background:#ec4899}.dh-dc-dot--other{background:#6b7280}.dh-dc-dot--present{background:#4ade80}.dh-dc-dot--absent{background:#f87171}.dh-dc-dot--late{background:#fb923c}.dh-dc-dot--excused{background:#60a5fa}.dh-dc-dot--unmarked{background:#6b7280}.dh-dc-dot--normal{background:#10b981}.dh-dc-dot--underweight{background:#f59e0b}.dh-dc-dot--severely_underweight{background:#ef4444}.dh-dc-dot--overweight{background:#f97316}.dh-dc-dot--obese{background:#dc2626}.dh-dc-dot--pending{background:#6b7280}.dh-dc-row-info{display:flex;align-items:baseline;gap:6px;flex:1;min-width:0}.dh-dc-row-label{font-size:11px;color:var(--color-text);opacity:.45;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition)}.dh-dc-row-count{font-size:15px;font-weight:700;color:var(--color-text);line-height:1;font-variant-numeric:tabular-nums;flex-shrink:0;transition:color var(--transition)}.dh-dc-note{display:flex;align-items:center;gap:5px;font-size:10px;color:var(--color-text);opacity:.35;margin-top:2px;transition:color var(--transition)}.dh-dc-note i{font-size:11px}.dh-dc-empty{font-size:11px;color:var(--color-text);opacity:.35;transition:color var(--transition)}.dh-perf{display:flex;flex-direction:column;gap:16px;min-width:0}.dh-perf-head{display:flex;align-items:center;justify-content:space-between}.dh-perf-empty{font-size:12px;color:var(--color-text);opacity:.35;padding:32px 0;text-align:center;transition:color var(--transition)}.slc-dot{opacity:0;transition:opacity .15s}.slc-col:hover .slc-dot{opacity:1}.dh-top{display:flex;flex-direction:column;gap:16px;height:100%}.dh-top-head{display:flex;align-items:center;justify-content:space-between}.dh-top-list{display:flex;flex-direction:column;gap:2px}.dh-top-item{display:flex;align-items:center;gap:8px;padding:9px 10px;border-radius:12px;transition:background var(--transition)}.dh-top-item:hover{background:color-mix(in srgb,var(--color-text) 4%,transparent)}.dh-top-rank{font-size:12px;font-weight:700;width:22px;text-align:center;flex-shrink:0;color:var(--color-text);opacity:.22;transition:color var(--transition)}.dh-top-rank--1{color:#f59e0b;opacity:1;font-size:15px}.dh-top-rank--2{color:#94a3b8;opacity:1}.dh-top-rank--3{color:#b45309;opacity:1}.dh-top-name{font-size:12px;font-weight:500;color:var(--color-text);flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color var(--transition)}.dh-top-avg{font-size:16px;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums;flex-shrink:0;transition:color var(--transition)}.dh-top-badge{flex-shrink:0}.dh-top-empty{font-size:12px;color:var(--color-text);opacity:.35;padding:32px 0;text-align:center;transition:color var(--transition)}.dh-card-icon-sm,.dh-trend-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:12px;background:color-mix(in srgb,var(--color-accent) 10%,transparent);color:var(--color-accent);opacity:.65;flex-shrink:0;transition:var(--transition)}.dh-card-icon-sm i,.dh-trend-icon i{font-size:13px}.dh-trend{display:flex;flex-direction:column;gap:16px;min-width:0}.dh-trend-head{display:flex;align-items:center;justify-content:space-between}.dh-trend-legend{display:flex;flex-wrap:wrap;gap:16px;align-items:center}.dh-trend-legend-item{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--color-text);opacity:.5}.dh-trend-legend-line{display:inline-block;width:16px;height:2px;border-radius:1px;flex-shrink:0}.dh-trend-legend-line--present{background:#4ade80}.dh-trend-legend-line--absent{background:#f87171}.dh-trend-legend-line--late{background:#fb923c}.dh-trend-legend-dash{display:inline-block;width:16px;height:0;border-top:2px dashed #f87171;flex-shrink:0}.dh-empty{display:flex;align-items:center;justify-content:center;padding:32px 0}.dh-empty-card{display:flex;flex-direction:column;align-items:center;gap:16px;max-width:360px;text-align:center;padding:40px;background:color-mix(in srgb,var(--color-text) 3%,var(--color-bg));border:1px solid color-mix(in srgb,var(--color-text) 8%,transparent);border-radius:24px;transition:var(--transition)}.dh-empty-card>i{font-size:48px;color:var(--color-accent);opacity:.5}.dh-empty-card h2{font-size:20px;font-weight:700;color:var(--color-text);transition:color var(--transition)}.dh-empty-card p{font-size:14px;color:var(--color-text);opacity:.45;transition:color var(--transition)}.dh-empty-btn{display:flex;align-items:center;gap:8px;margin-top:8px;padding:10px 24px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:14px;font-weight:600;cursor:pointer;transition:var(--transition)}.dh-empty-btn i{font-size:16px}.dh-empty-btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.dh-empty-btn:active{transform:none;filter:none}.dh-wizard{display:flex;flex-direction:column;gap:24px;width:100%}.dh-wizard-body{display:flex;flex-direction:column;gap:24px;width:min(700px,100%);margin:0 auto}@keyframes skShimmer{0%{background-position:-600px 0}to{background-position:600px 0}}.sk-bar{display:block;height:13px;border-radius:6px;background:linear-gradient(90deg,color-mix(in srgb,var(--color-text) 7%,transparent) 25%,color-mix(in srgb,var(--color-text) 14%,transparent),color-mix(in srgb,var(--color-text) 7%,transparent) 75%);background-size:600px 100%;animation:skShimmer 1.5s ease-in-out infinite}.sk-bar--pill{border-radius:999px}.sk-box{width:44px;height:44px;border-radius:12px;flex-shrink:0;background:linear-gradient(90deg,color-mix(in srgb,var(--color-text) 7%,transparent) 25%,color-mix(in srgb,var(--color-text) 14%,transparent),color-mix(in srgb,var(--color-text) 7%,transparent) 75%);background-size:600px 100%;animation:skShimmer 1.5s ease-in-out infinite}.dh-card--skel{pointer-events:none}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes toastIn{0%{transform:translate(calc(100% + 24px));opacity:0}to{transform:translate(0);opacity:1}}.toast-stack{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid transparent;font-size:var(--font-size-13);font-weight:var(--font-weight-500);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:all;animation:toastIn .22s ease-out forwards;max-width:320px;box-shadow:0 4px 16px #0000002e}.toast i{font-size:var(--font-size-18);flex-shrink:0}.toast-msg{flex:1}.toast-close{display:flex;align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:0;opacity:.6;color:inherit;flex-shrink:0;transition:opacity .15s}.toast-close:hover{opacity:1}.toast-close i{font-size:var(--font-size-16)}.toast--success{background:color-mix(in srgb,#10b981 18%,var(--color-bg));border-color:color-mix(in srgb,#10b981 35%,transparent);color:color-mix(in srgb,#10b981 85%,var(--color-text))}.toast--error{background:color-mix(in srgb,#ef4444 18%,var(--color-bg));border-color:color-mix(in srgb,#ef4444 35%,transparent);color:color-mix(in srgb,#ef4444 85%,var(--color-text))}.toast--info{background:color-mix(in srgb,var(--color-accent) 15%,var(--color-bg));border-color:color-mix(in srgb,var(--color-accent) 30%,transparent);color:color-mix(in srgb,var(--color-accent) 80%,var(--color-text))}.students{display:flex;flex-direction:column;gap:16px}.students-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.students-header h1{font-size:var(--font-size-25);font-weight:var(--font-weight-700);color:var(--color-text);margin-bottom:4px;transition:var(--transition)}.students-header p{color:var(--color-text);opacity:.55;font-size:var(--font-size-15);transition:var(--transition)}.students-add-btn{display:flex;align-items:center;gap:6px;flex-shrink:0;padding:10px 16px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition)}.students-add-btn i{font-size:var(--font-size-18)}.students-add-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.students-add-btn:active{transform:translateY(0);filter:brightness(1)}.students-toolbar{display:flex;align-items:center;gap:16px}.students-search{display:flex;align-items:center;gap:8px;flex:1;max-width:360px;padding:8px 16px;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 8%);border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:12px;transition:var(--transition)}.students-search i{color:var(--color-text);opacity:.4;font-size:var(--font-size-18);flex-shrink:0;transition:var(--transition)}.students-search input{flex:1;background:none;border:none;outline:none;color:var(--color-text);font-size:var(--font-size-15);transition:var(--transition)}.students-search input::placeholder{opacity:.4}.students-count{font-size:var(--font-size-12);font-weight:var(--font-weight-600);color:var(--color-text);opacity:.45;white-space:nowrap;transition:var(--transition)}.students-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 0;color:var(--color-text);text-align:center;transition:var(--transition)}.students-empty i{font-size:var(--font-size-50);opacity:.25}.students-empty p{font-size:var(--font-size-15);opacity:.5}.students-table{display:flex;flex-direction:column;border:1px solid color-mix(in srgb,var(--color-accent) 15%,transparent);border-radius:16px;overflow:hidden;transition:var(--transition)}.students-table-head,.students-table-row{display:grid;grid-template-columns:1fr 140px 80px 100px;gap:16px;padding:12px 24px;align-items:center;transition:var(--transition)}.students-table-head{background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 8%);font-size:var(--font-size-11);font-weight:var(--font-weight-600);text-transform:uppercase;letter-spacing:1.2px;color:var(--color-accent)}.students-table-row{border-top:1px solid color-mix(in srgb,var(--color-accent) 10%,transparent);font-size:var(--font-size-15);color:var(--color-text)}.students-table-row:hover{background:color-mix(in srgb,var(--color-accent) 5%,transparent);cursor:pointer}.students-table-row--skeleton{pointer-events:none;cursor:default}.students-search--disabled{opacity:.5;pointer-events:none}.students-table-name{font-weight:var(--font-weight-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.students-table-lrn{font-size:var(--font-size-12);font-family:monospace;opacity:.7}.students-status{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--font-size-11);font-weight:var(--font-weight-600);width:fit-content}.students-status--active{background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success)}.students-status--inactive{background:color-mix(in srgb,var(--color-text) 10%,transparent);color:var(--color-text);opacity:.6}.students-status--transferred,.students-status--dropped{background:color-mix(in srgb,var(--color-danger) 12%,transparent);color:var(--color-danger)}.students-overlay{position:fixed;inset:0;background:#0006;z-index:200;display:flex;justify-content:flex-end;animation:fadeIn .2s ease}.students-panel{width:min(440px,100vw);height:100%;background:var(--color-bg);border-left:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);display:flex;flex-direction:column;animation:slideInRight .25s ease;transition:var(--transition);overflow-y:auto}.students-panel--detail{width:min(600px,100vw)}.students-panel-header{display:flex;align-items:center;justify-content:space-between;padding:24px 24px 16px;border-bottom:1px solid color-mix(in srgb,var(--color-accent) 15%,transparent)}.students-panel-header h2{font-size:var(--font-size-20);font-weight:var(--font-weight-700);color:var(--color-text);transition:var(--transition)}.students-panel-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:12px;color:var(--color-text);font-size:var(--font-size-20);cursor:pointer;opacity:.5;transition:var(--transition)}.students-panel-close:hover{opacity:1;background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.students-form{display:flex;flex-direction:column;gap:16px;padding:24px}.students-form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.students-field{display:flex;flex-direction:column;gap:6px}.students-field span{font-size:var(--font-size-12);font-weight:var(--font-weight-600);color:var(--color-text);opacity:.6;transition:var(--transition)}.students-field span em{color:var(--color-accent);font-style:normal}.students-field input,.students-field select{padding:10px 16px;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 6%);border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:12px;color:var(--color-text);font-size:var(--font-size-15);outline:none;transition:var(--transition);width:100%}.students-field input:focus,.students-field select:focus{border-color:color-mix(in srgb,var(--color-accent) 60%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 12%,transparent)}.students-field input::placeholder,.students-field select::placeholder{opacity:.4}.students-field select option{background:var(--color-bg);color:var(--color-text)}.students-field--sm{grid-column:auto}.students-error{display:flex;align-items:center;gap:6px;padding:8px 16px;background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 30%,transparent);border-radius:12px;color:var(--color-danger);font-size:var(--font-size-12)}.students-error i{font-size:var(--font-size-15)}.students-submit{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 24px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition);margin-top:4px}.students-submit i{font-size:var(--font-size-18)}.students-submit:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.students-submit:active:not(:disabled){transform:translateY(0);filter:brightness(1)}.students-submit:disabled{opacity:.5;cursor:not-allowed}.students-submit--outline{background:transparent;border:1px solid color-mix(in srgb,var(--color-text) 25%,transparent);color:var(--color-text);opacity:.7}.students-submit--outline:hover:not(:disabled){opacity:1;filter:none;transform:none}.students-detail-loading{display:flex;align-items:center;justify-content:center;flex:1}.students-detail-header-name{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-width:0}.students-detail-header-name>span:first-child{font-size:var(--font-size-18);font-weight:var(--font-weight-700);color:var(--color-text);transition:var(--transition)}.students-detail-body{display:flex;flex-direction:column;gap:0;overflow-y:auto;flex:1}.students-detail-section{display:flex;flex-direction:column;gap:16px;padding:24px;border-bottom:1px solid color-mix(in srgb,var(--color-accent) 10%,transparent);transition:var(--transition)}.students-detail-section:last-child{border-bottom:none}.students-detail-section-header{display:flex;align-items:center;justify-content:space-between}.students-detail-section-header>span{display:flex;align-items:center;gap:6px;font-size:var(--font-size-11);font-weight:var(--font-weight-700);text-transform:uppercase;letter-spacing:1.2px;color:var(--color-accent);transition:var(--transition)}.students-detail-section-header>span i{font-size:var(--font-size-15)}.students-detail-edit-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;background:none;border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);border-radius:12px;color:var(--color-accent);font-size:var(--font-size-12);font-weight:var(--font-weight-500);cursor:pointer;transition:var(--transition)}.students-detail-edit-btn i{font-size:var(--font-size-12)}.students-detail-edit-btn:hover{background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.students-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 24px}.students-detail-field{display:flex;flex-direction:column;gap:3px}.students-detail-label{font-size:var(--font-size-11);font-weight:var(--font-weight-600);color:var(--color-text);opacity:.45;text-transform:uppercase;letter-spacing:.6px;transition:var(--transition)}.students-detail-value{font-size:var(--font-size-15);color:var(--color-text);font-weight:var(--font-weight-500);transition:var(--transition)}.students-detail-value--empty{opacity:.3;font-style:italic;font-weight:var(--font-weight-400)}.students-detail-edit{display:flex;flex-direction:column;gap:16px;animation:fadeIn .15s ease}.students-detail-edit-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.students-detail-edit-full{grid-column:1/-1}.students-detail-edit-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding-top:4px;border-top:1px solid color-mix(in srgb,var(--color-accent) 10%,transparent)}.students-detail-cancel-btn{padding:8px 16px;background:none;border:1px solid color-mix(in srgb,var(--color-text) 18%,transparent);border-radius:12px;color:var(--color-text);font-size:var(--font-size-12);font-weight:var(--font-weight-500);cursor:pointer;opacity:.65;transition:var(--transition)}.students-detail-cancel-btn:hover{opacity:1}.students-detail-save-btn{display:flex;align-items:center;gap:4px;padding:8px 16px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-12);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition)}.students-detail-save-btn i{font-size:var(--font-size-15)}.students-detail-save-btn:hover:not(:disabled){filter:brightness(1.1)}.students-detail-save-btn:disabled{opacity:.5;cursor:not-allowed}.reg{display:flex;flex-direction:column;gap:24px}.reg-body{display:flex;flex-direction:column;gap:24px;width:min(860px,100%);margin:0 auto}.reg-header h1{font-size:var(--font-size-25);font-weight:var(--font-weight-700);color:var(--color-text);margin-bottom:4px;transition:var(--transition)}.reg-header p{font-size:var(--font-size-15);color:var(--color-text);opacity:.55;transition:var(--transition)}.reg-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:64px 0;text-align:center;color:var(--color-text);transition:var(--transition)}.reg-empty i{font-size:var(--font-size-50);opacity:.25}.reg-empty p{font-size:var(--font-size-15);opacity:.5}.reg-form{display:flex;flex-direction:column;gap:16px;max-width:860px}.reg-section{display:flex;flex-direction:column;gap:16px;padding:24px;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 6%);border:1px solid color-mix(in srgb,var(--color-accent) 15%,transparent);border-radius:16px;transition:var(--transition)}.reg-section-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-11);font-weight:var(--font-weight-700);text-transform:uppercase;letter-spacing:1.4px;color:var(--color-accent);transition:var(--transition)}.reg-section-label i{font-size:var(--font-size-15)}.reg-grid{display:grid;gap:16px}.reg-grid--2{grid-template-columns:repeat(2,1fr)}.reg-grid--3{grid-template-columns:repeat(3,1fr)}.reg-grid--4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.reg-grid{grid-template-columns:1fr 1fr!important}}.reg-field{display:flex;flex-direction:column;gap:6px}.reg-field--full{grid-column:1/-1}.reg-field--required span:after{content:" *";color:var(--color-accent)}.reg-field span{font-size:var(--font-size-12);font-weight:var(--font-weight-600);color:var(--color-text);opacity:.55;transition:var(--transition)}.reg-field input,.reg-field select{padding:10px 16px;background:color-mix(in srgb,var(--color-bg) 80%,var(--color-accent) 5%);border:1px solid color-mix(in srgb,var(--color-accent) 18%,transparent);border-radius:12px;color:var(--color-text);font-size:var(--font-size-15);font-family:var(--font-family);outline:none;width:100%;transition:var(--transition)}.reg-field input:focus,.reg-field select:focus{border-color:color-mix(in srgb,var(--color-accent) 55%,transparent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 10%,transparent)}.reg-field input::placeholder,.reg-field select::placeholder{opacity:.35}.reg-field select{cursor:pointer}.reg-field select option{background:var(--color-bg);color:var(--color-text)}.reg-field input[type=date]::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer}.reg-error{display:flex;align-items:center;gap:8px;padding:8px 16px;background:color-mix(in srgb,var(--color-danger) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-danger) 30%,transparent);border-radius:12px;color:var(--color-danger);font-size:var(--font-size-12)}.reg-error i{font-size:var(--font-size-15);flex-shrink:0}.reg-actions{display:flex;align-items:center;justify-content:flex-end;gap:16px;padding-top:4px}.reg-btn{display:flex;align-items:center;justify-content:center;gap:6px;padding:12px 28px;background:var(--color-accent);color:var(--color-bg);border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition);min-width:160px;white-space:nowrap}.reg-btn i{font-size:var(--font-size-18)}.reg-btn:hover:not(:disabled){filter:brightness(1.1);transform:translateY(-1px)}.reg-btn:active:not(:disabled){transform:translateY(0);filter:brightness(1)}.reg-btn:disabled{opacity:.45;cursor:not-allowed}.reg-btn--ghost{background:color-mix(in srgb,var(--color-accent) 10%,transparent);color:var(--color-accent);border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);min-width:auto}.reg-btn .reg-spinner{animation:regSpin .75s linear infinite}@keyframes regSpin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.reg-success{display:flex;flex-direction:column;align-items:center;gap:16px;padding:64px 32px;max-width:480px;text-align:center;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 6%);border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:24px;animation:fadeIn .3s ease;transition:var(--transition)}.reg-success-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:color-mix(in srgb,var(--color-success) 15%,transparent);color:var(--color-success);font-size:var(--font-size-35)}.reg-success h2{font-size:var(--font-size-20);font-weight:var(--font-weight-700);color:var(--color-text);transition:var(--transition)}.reg-success p{font-size:var(--font-size-15);color:var(--color-text);opacity:.6;transition:var(--transition)}.reg-success-actions{margin-top:8px}.reg-stepper{display:flex;margin-bottom:32px;-webkit-user-select:none;user-select:none}.reg-stepper-item{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0}.reg-step-track{display:flex;align-items:center;width:100%}.reg-step-half{flex:1;height:2px;background:color-mix(in srgb,var(--color-text) 10%,transparent);transition:background .35s ease}.reg-step-half--done{background:color-mix(in srgb,var(--color-accent) 45%,transparent)}.reg-step-half--hidden{visibility:hidden}.reg-step-dot{width:30px;height:30px;border-radius:50%;border:1.5px solid color-mix(in srgb,var(--color-text) 14%,transparent);background:color-mix(in srgb,var(--color-text) 4%,transparent);color:color-mix(in srgb,var(--color-text) 30%,transparent);font-size:var(--font-size-11);font-weight:var(--font-weight-600);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s ease,border-color .3s ease,color .3s ease,box-shadow .3s ease,transform .3s ease;z-index:1}.reg-step-dot i{font-size:var(--font-size-11)}.reg-step-dot--done{background:color-mix(in srgb,var(--color-accent) 12%,transparent);border-color:color-mix(in srgb,var(--color-accent) 55%,transparent);color:var(--color-accent)}.reg-step-dot--active{background:var(--color-accent);border-color:var(--color-accent);color:#fff;box-shadow:0 0 0 5px color-mix(in srgb,var(--color-accent) 15%,transparent),0 3px 10px color-mix(in srgb,var(--color-accent) 28%,transparent);transform:scale(1.2)}.reg-step-label{font-size:var(--font-size-10);font-weight:var(--font-weight-500);color:var(--color-text);opacity:.3;margin-top:6px;white-space:nowrap;text-align:center;letter-spacing:.03em;text-transform:uppercase;transition:opacity .25s ease,color .25s ease,font-weight .25s ease;display:none}@media(min-width:480px){.reg-step-label{display:block}}.reg-step-label--done{opacity:.5}.reg-step-label--active{opacity:1;color:var(--color-accent);font-weight:var(--font-weight-700)}.att{display:flex;flex-direction:column;gap:16px}.att--skel{pointer-events:none}.att-nav{display:flex;align-items:center;gap:16px}.att-nav-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);border-radius:12px;background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 6%);color:var(--color-text);cursor:pointer;flex-shrink:0;transition:var(--transition)}.att-nav-btn i{font-size:var(--font-size-20)}.att-nav-btn:hover{background:color-mix(in srgb,var(--color-accent) 15%,transparent)}.att-nav-btn:active{transform:scale(.95)}.att-nav-label{font-size:var(--font-size-18);font-weight:var(--font-weight-700);color:var(--color-text);flex:1;transition:var(--transition)}.att-nav-today{padding:4px 12px;border:1px solid color-mix(in srgb,var(--color-accent) 30%,transparent);border-radius:12px;background:color-mix(in srgb,var(--color-accent) 10%,transparent);color:var(--color-accent);font-size:var(--font-size-12);font-weight:var(--font-weight-600);cursor:pointer;white-space:nowrap;transition:var(--transition)}.att-nav-today:hover{background:color-mix(in srgb,var(--color-accent) 20%,transparent)}.att-nav-today:active{transform:scale(.97)}.att-legend{display:flex;flex-wrap:wrap;gap:6px}.att-legend-item{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--font-size-11);font-weight:var(--font-weight-600);transition:var(--transition)}.att-legend-item--present{background:color-mix(in srgb,#4ade80 18%,transparent);color:color-mix(in srgb,#4ade80 85%,var(--color-text))}.att-legend-item--absent{background:color-mix(in srgb,#f87171 18%,transparent);color:color-mix(in srgb,#f87171 85%,var(--color-text))}.att-legend-item--late{background:color-mix(in srgb,#fb923c 18%,transparent);color:color-mix(in srgb,#fb923c 85%,var(--color-text))}.att-legend-item--excused{background:color-mix(in srgb,#60a5fa 18%,transparent);color:color-mix(in srgb,#60a5fa 85%,var(--color-text))}.att-legend-item--holiday{background:color-mix(in srgb,#c084fc 18%,transparent);color:color-mix(in srgb,#c084fc 85%,var(--color-text))}.att-legend-item--no-class{background:color-mix(in srgb,#94a3b8 18%,transparent);color:color-mix(in srgb,#94a3b8 85%,var(--color-text))}.att-empty{padding:32px;text-align:center;color:var(--color-text);opacity:.5;font-size:var(--font-size-15);transition:var(--transition)}.att-wrap{overflow:auto;max-height:calc(100vh - 230px);border:1px solid color-mix(in srgb,var(--color-text) 18%,transparent);border-radius:16px;transition:border-color var(--transition);scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--color-accent) 30%,transparent) transparent}.att-table{border-collapse:separate;border-spacing:0;min-width:100%;table-layout:fixed}.att-th{position:sticky;top:0;z-index:2;padding:8px 2px;background:color-mix(in srgb,var(--color-bg) 78%,var(--color-text) 10%);border-bottom:2px solid color-mix(in srgb,var(--color-text) 22%,transparent);font-size:var(--font-size-11);font-weight:var(--font-weight-700);text-align:center;white-space:nowrap;color:var(--color-text);transition:background var(--transition),border-color var(--transition)}.att-th--name{position:sticky;left:0;z-index:4;width:180px;min-width:180px;text-align:left;padding:8px 16px}.att-th--summary{position:sticky;right:0;z-index:4;width:160px;min-width:160px}.att-th--day{width:52px;cursor:pointer;border-right:1px solid color-mix(in srgb,var(--color-text) 10%,transparent)}.att-th--day:hover:not(.att-th--weekend){background:color-mix(in srgb,var(--color-accent) 14%,var(--color-bg))}.att-th--weekend{opacity:.4;cursor:default}.att-th--today{background:color-mix(in srgb,var(--color-accent) 20%,var(--color-bg))!important;color:var(--color-accent)!important}.att-th--holiday{background:color-mix(in srgb,#c084fc 25%,var(--color-bg));color:color-mix(in srgb,#c084fc 85%,var(--color-text))}.att-th--no-class{background:color-mix(in srgb,#94a3b8 22%,var(--color-bg));color:color-mix(in srgb,#94a3b8 80%,var(--color-text))}.att-th-dow{display:block;font-size:9px;font-weight:var(--font-weight-600);text-transform:uppercase;letter-spacing:.08em;opacity:.6;line-height:1.2;color:inherit}.att-th-num{display:block;font-size:var(--font-size-14);font-weight:var(--font-weight-700);line-height:1.3;color:inherit}.att-th-mark{display:block;font-size:9px;font-weight:var(--font-weight-700);margin-top:2px;line-height:1;letter-spacing:.03em;color:inherit}.att-th-today-label{display:block;margin-top:3px;padding:1px 4px;border-radius:3px;background:var(--color-accent);color:var(--color-bg);font-size:8px;font-weight:var(--font-weight-700);letter-spacing:.06em;text-transform:uppercase;line-height:1.4}.att-row:nth-child(2n) .att-td{background:color-mix(in srgb,var(--color-bg) 86%,var(--color-text) 5%)}.att-row:hover .att-td:not(.att-td--weekend):not(.att-td--holiday):not(.att-td--no-class){background:color-mix(in srgb,var(--color-accent) 12%,var(--color-bg))!important}.att-td{padding:0;border-bottom:1px solid color-mix(in srgb,var(--color-text) 12%,transparent);text-align:center;font-size:var(--font-size-12);font-weight:var(--font-weight-700);height:38px;background:color-mix(in srgb,var(--color-bg) 94%,var(--color-text) 6%);transition:background var(--transition),color var(--transition)}.att-td--name{position:sticky;left:0;z-index:1;text-align:left;padding:4px 16px;font-size:var(--font-size-13);font-weight:var(--font-weight-500);color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:inherit;border-right:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent)}.att-td--summary{position:sticky;right:0;z-index:1;background:inherit;border-left:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent);padding:4px 8px;white-space:nowrap}.att-td--cell{border-right:1px solid color-mix(in srgb,var(--color-text) 10%,transparent);cursor:pointer}.att-td--cell:hover:not(.att-td--weekend):not(.att-td--holiday):not(.att-td--no-class){background:color-mix(in srgb,var(--color-accent) 22%,var(--color-bg))!important;color:var(--color-accent);outline:2px solid var(--color-accent);outline-offset:-2px;position:relative;z-index:1}.att-td--weekend{background:color-mix(in srgb,var(--color-bg) 80%,var(--color-text) 8%);opacity:.45;cursor:default}.att-td--today{outline:2px solid color-mix(in srgb,var(--color-accent) 55%,transparent);outline-offset:-2px}.att-td--holiday{background:color-mix(in srgb,#c084fc 18%,var(--color-bg));cursor:default}.att-td--no-class{background:color-mix(in srgb,#94a3b8 14%,var(--color-bg));cursor:default}.att-td--present{background:color-mix(in srgb,#4ade80 32%,var(--color-bg));color:color-mix(in srgb,#4ade80 90%,var(--color-text))}.att-td--absent{background:color-mix(in srgb,#f87171 32%,var(--color-bg));color:color-mix(in srgb,#f87171 90%,var(--color-text))}.att-td--late{background:color-mix(in srgb,#fb923c 32%,var(--color-bg));color:color-mix(in srgb,#fb923c 90%,var(--color-text))}.att-td--excused{background:color-mix(in srgb,#60a5fa 32%,var(--color-bg));color:color-mix(in srgb,#60a5fa 90%,var(--color-text))}.att-sum{display:inline-flex;align-items:center;justify-content:center;padding:1px 5px;border-radius:4px;font-size:var(--font-size-11);font-weight:var(--font-weight-700);margin:1px;transition:var(--transition)}.att-sum--present{background:color-mix(in srgb,#4ade80 30%,transparent);color:color-mix(in srgb,#4ade80 95%,var(--color-text))}.att-sum--absent{background:color-mix(in srgb,#f87171 30%,transparent);color:color-mix(in srgb,#f87171 95%,var(--color-text))}.att-sum--late{background:color-mix(in srgb,#fb923c 30%,transparent);color:color-mix(in srgb,#fb923c 95%,var(--color-text))}.att-sum--excused{background:color-mix(in srgb,#60a5fa 30%,transparent);color:color-mix(in srgb,#60a5fa 95%,var(--color-text))}.att-sum--empty{opacity:.3;color:var(--color-text)}.nut{display:flex;flex-direction:column;gap:16px}.nut--skel{pointer-events:none}.nut-controls{display:flex;align-items:center;gap:16px;flex-wrap:wrap}.nut-period-tabs{display:flex;border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);border-radius:12px;overflow:hidden}.nut-period-tab{padding:6px 18px;font-size:var(--font-size-13);font-weight:var(--font-weight-600);color:var(--color-text);background:transparent;border:none;cursor:pointer;transition:var(--transition)}.nut-period-tab:hover:not(.nut-period-tab--active){background:color-mix(in srgb,var(--color-accent) 10%,transparent)}.nut-period-tab--active{background:color-mix(in srgb,var(--color-accent) 20%,transparent);color:var(--color-accent)}.nut-year-label{display:flex;align-items:center;gap:4px;font-size:var(--font-size-13);color:var(--color-text);opacity:.5;transition:var(--transition)}.nut-year-label i{font-size:var(--font-size-15)}.nut-summary{display:flex;flex-wrap:wrap;gap:8px}.nut-stat{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 24px;border-radius:16px;border:1px solid transparent;min-width:110px;transition:var(--transition)}.nut-stat i{font-size:var(--font-size-20)}.nut-stat-count{font-size:var(--font-size-25);font-weight:var(--font-weight-700);line-height:1;transition:var(--transition)}.nut-stat-label{font-size:var(--font-size-11);font-weight:var(--font-weight-600);text-align:center;line-height:1.3;transition:var(--transition)}.nut-stat--skel{background:color-mix(in srgb,var(--color-text) 5%,transparent);border-color:color-mix(in srgb,var(--color-text) 10%,transparent)}.nut-stat--severely_underweight{background:color-mix(in srgb,#ef4444 12%,transparent);border-color:color-mix(in srgb,#ef4444 25%,transparent);color:color-mix(in srgb,#ef4444 85%,var(--color-text))}.nut-stat--underweight{background:color-mix(in srgb,#f59e0b 12%,transparent);border-color:color-mix(in srgb,#f59e0b 25%,transparent);color:color-mix(in srgb,#f59e0b 85%,var(--color-text))}.nut-stat--normal{background:color-mix(in srgb,#10b981 12%,transparent);border-color:color-mix(in srgb,#10b981 25%,transparent);color:color-mix(in srgb,#10b981 85%,var(--color-text))}.nut-stat--overweight{background:color-mix(in srgb,#f97316 12%,transparent);border-color:color-mix(in srgb,#f97316 25%,transparent);color:color-mix(in srgb,#f97316 85%,var(--color-text))}.nut-stat--obese{background:color-mix(in srgb,#dc2626 12%,transparent);border-color:color-mix(in srgb,#dc2626 25%,transparent);color:color-mix(in srgb,#dc2626 85%,var(--color-text))}.nut-stat--pending{background:color-mix(in srgb,#6b7280 10%,transparent);border-color:color-mix(in srgb,#6b7280 20%,transparent);color:color-mix(in srgb,#6b7280 70%,var(--color-text))}.nut-empty{padding:32px;text-align:center;color:var(--color-text);opacity:.5;font-size:var(--font-size-15)}.nut-wrap{overflow:auto;max-height:calc(100vh - 280px);border:1px solid color-mix(in srgb,var(--color-text) 18%,transparent);border-radius:16px;transition:border-color var(--transition);scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--color-accent) 30%,transparent) transparent}.nut-table{border-collapse:separate;border-spacing:0;min-width:100%;table-layout:fixed}.nut-th{position:sticky;top:0;z-index:2;padding:8px 16px;background:color-mix(in srgb,var(--color-bg) 78%,var(--color-text) 10%);border-bottom:2px solid color-mix(in srgb,var(--color-text) 22%,transparent);font-size:var(--font-size-11);font-weight:var(--font-weight-700);text-align:center;white-space:nowrap;color:var(--color-text);transition:background var(--transition),border-color var(--transition)}.nut-th--name{position:sticky;left:0;z-index:4;width:190px;min-width:190px;text-align:left;padding:8px 16px;border-right:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent)}.nut-th--status{width:160px;min-width:160px}.nut-row:nth-child(2n) .nut-td{background:color-mix(in srgb,var(--color-bg) 86%,var(--color-text) 5%)}.nut-row:hover .nut-td{background:color-mix(in srgb,var(--color-accent) 7%,var(--color-bg))}.nut-td{padding:4px 16px;border-bottom:1px solid color-mix(in srgb,var(--color-text) 10%,transparent);font-size:var(--font-size-13);color:var(--color-text);height:42px;transition:background var(--transition),color var(--transition);vertical-align:middle}.nut-td--name{position:sticky;left:0;z-index:1;background:color-mix(in srgb,var(--color-bg) 95%,var(--color-accent) 2%);font-weight:var(--font-weight-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-right:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent)}.nut-td--center{text-align:center}.nut-td--bmi{font-weight:var(--font-weight-600);font-variant-numeric:tabular-nums}.nut-td--input{padding:3px 8px}.nut-td--status{text-align:center}.nut-input{width:80px;padding:4px 8px;border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:12px;background:color-mix(in srgb,var(--color-bg) 70%,var(--color-accent) 5%);color:var(--color-text);font-size:var(--font-size-13);text-align:center;transition:border-color var(--transition),background var(--transition)}.nut-input::-webkit-inner-spin-button,.nut-input::-webkit-outer-spin-button{-webkit-appearance:none}.nut-input{-moz-appearance:textfield;appearance:textfield}.nut-input:focus{outline:none;border-color:var(--color-accent);background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 10%)}.nut-input::placeholder{color:color-mix(in srgb,var(--color-text) 30%,transparent)}.nut-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--font-size-11);font-weight:var(--font-weight-600);white-space:nowrap;transition:var(--transition)}.nut-badge--severely_underweight{background:color-mix(in srgb,#ef4444 18%,transparent);color:color-mix(in srgb,#ef4444 85%,var(--color-text))}.nut-badge--underweight{background:color-mix(in srgb,#f59e0b 18%,transparent);color:color-mix(in srgb,#f59e0b 85%,var(--color-text))}.nut-badge--normal{background:color-mix(in srgb,#10b981 18%,transparent);color:color-mix(in srgb,#10b981 85%,var(--color-text))}.nut-badge--overweight{background:color-mix(in srgb,#f97316 18%,transparent);color:color-mix(in srgb,#f97316 85%,var(--color-text))}.nut-badge--obese{background:color-mix(in srgb,#dc2626 18%,transparent);color:color-mix(in srgb,#dc2626 85%,var(--color-text))}.nut-row--clickable{cursor:pointer}.nut-row--clickable:hover .nut-td{background:color-mix(in srgb,var(--color-accent) 10%,var(--color-bg))!important}.nut-row--active .nut-td{background:color-mix(in srgb,var(--color-accent) 14%,var(--color-bg))!important}.nut-panel-input{padding:9px 12px;border:1px solid color-mix(in srgb,var(--color-accent) 25%,transparent);border-radius:12px;background:color-mix(in srgb,var(--color-bg) 70%,var(--color-accent) 5%);color:var(--color-text);font-size:var(--font-size-15);width:100%;transition:var(--transition)}.nut-panel-input::-webkit-inner-spin-button,.nut-panel-input::-webkit-outer-spin-button{-webkit-appearance:none}.nut-panel-input{-moz-appearance:textfield;appearance:textfield}.nut-panel-input:focus{outline:none;border-color:var(--color-accent);background:color-mix(in srgb,var(--color-bg) 60%,var(--color-accent) 10%)}.nut-panel-input::placeholder{opacity:.4}.nut-panel-bmi-block{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;padding:16px 24px;border-radius:16px;background:color-mix(in srgb,var(--color-accent) 6%,transparent);border:1px solid color-mix(in srgb,var(--color-accent) 15%,transparent);transition:var(--transition)}.nut-panel-bmi-num{display:flex;align-items:baseline;gap:6px;font-size:var(--font-size-30);font-weight:var(--font-weight-700);color:var(--color-text);line-height:1;transition:var(--transition)}.nut-panel-bmi-unit{font-size:var(--font-size-12);font-weight:var(--font-weight-600);color:var(--color-text);opacity:.5;transition:var(--transition)}.nut-panel-bmi-hint{font-size:var(--font-size-12);color:var(--color-text);opacity:.4;transition:var(--transition)}.nut-badge--lg{font-size:var(--font-size-13);padding:5px 14px}.nut-panel-actions{display:flex;gap:8px}.gr{display:flex;flex-direction:column;gap:16px}.gr--skel{pointer-events:none}.gr-controls{display:flex;flex-direction:column;gap:8px}.gr-subject-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.gr-subject-tab{display:flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:999px;font-size:var(--font-size-13);font-weight:var(--font-weight-500);color:var(--color-text);background:transparent;cursor:pointer;transition:var(--transition)}.gr-subject-tab span{cursor:pointer}.gr-subject-tab:hover:not(.gr-subject-tab--active){background:color-mix(in srgb,var(--color-accent) 8%,transparent)}.gr-subject-tab--active{background:color-mix(in srgb,var(--color-accent) 18%,transparent);border-color:color-mix(in srgb,var(--color-accent) 40%,transparent);color:var(--color-accent);font-weight:var(--font-weight-600)}.gr-subject-actions{display:flex;gap:2px;margin-left:2px}.gr-subject-action{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;border-radius:4px;background:transparent;color:inherit;cursor:pointer;opacity:.6;transition:opacity .15s,background .15s}.gr-subject-action i{font-size:12px}.gr-subject-action:hover{opacity:1;background:color-mix(in srgb,var(--color-text) 10%,transparent)}.gr-subject-action--delete:hover{background:color-mix(in srgb,#ef4444 18%,transparent);color:#ef4444;opacity:1}.gr-add-btn{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border:1px dashed color-mix(in srgb,var(--color-accent) 35%,transparent);border-radius:999px;background:transparent;color:var(--color-accent);cursor:pointer;font-size:var(--font-size-16);transition:var(--transition)}.gr-add-btn:hover{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}.gr-add-input,.gr-rename-input{padding:4px 10px;border:1px solid var(--color-accent);border-radius:999px;background:color-mix(in srgb,var(--color-bg) 70%,var(--color-accent) 10%);color:var(--color-text);font-size:var(--font-size-13);outline:none;width:140px;transition:var(--transition)}.gr-system-btn{margin-left:auto;padding:4px 12px;border:1px solid color-mix(in srgb,var(--color-text) 20%,transparent);border-radius:12px;background:transparent;color:var(--color-text);font-size:var(--font-size-12);font-weight:var(--font-weight-600);cursor:pointer;opacity:.6;transition:var(--transition)}.gr-system-btn:hover{opacity:1}.gr-system-btn--active{border-color:color-mix(in srgb,var(--color-accent) 40%,transparent);color:var(--color-accent);opacity:1}.gr-quarter-tabs{display:flex;gap:4px}.gr-quarter-tab{padding:5px 14px;border:1px solid color-mix(in srgb,var(--color-accent) 20%,transparent);border-radius:12px;background:transparent;color:var(--color-text);font-size:var(--font-size-12);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition)}.gr-quarter-tab:hover:not(.gr-quarter-tab--active){background:color-mix(in srgb,var(--color-accent) 8%,transparent)}.gr-quarter-tab--active{background:color-mix(in srgb,var(--color-accent) 18%,transparent);border-color:color-mix(in srgb,var(--color-accent) 40%,transparent);color:var(--color-accent)}.gr-wrap{overflow:auto;max-height:calc(100vh - 205px);border:1px solid color-mix(in srgb,var(--color-text) 18%,transparent);border-radius:16px;transition:border-color var(--transition);scrollbar-width:thin;scrollbar-color:color-mix(in srgb,var(--color-accent) 30%,transparent) transparent}.gr-table{border-collapse:separate;border-spacing:0;min-width:100%;table-layout:fixed}.gr-th{position:sticky;top:0;z-index:2;padding:8px 16px;background:color-mix(in srgb,var(--color-bg) 78%,var(--color-text) 10%);border-bottom:2px solid color-mix(in srgb,var(--color-text) 22%,transparent);font-size:var(--font-size-11);font-weight:var(--font-weight-700);text-align:center;white-space:nowrap;color:var(--color-text);transition:background var(--transition),border-color var(--transition)}.gr-th--name{position:sticky;left:0;z-index:4;width:190px;min-width:190px;text-align:left;padding:8px 16px;border-right:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent)}.gr-th--final{color:var(--color-accent)}.gr-th--desc{min-width:160px}.gr-row:nth-child(2n) .gr-td{background:color-mix(in srgb,var(--color-bg) 86%,var(--color-text) 5%)}.gr-row:hover .gr-td{background:color-mix(in srgb,var(--color-accent) 7%,var(--color-bg))}.gr-row--avg .gr-td{border-top:2px solid color-mix(in srgb,var(--color-text) 15%,transparent)}.gr-row--clickable{cursor:pointer}.gr-row--clickable:hover .gr-td{background:color-mix(in srgb,var(--color-accent) 12%,var(--color-bg))!important}.gr-row--active .gr-td{background:color-mix(in srgb,var(--color-accent) 16%,var(--color-bg))!important}.gr-td{padding:4px 16px;border-bottom:1px solid color-mix(in srgb,var(--color-text) 10%,transparent);font-size:var(--font-size-13);color:var(--color-text);text-align:center;height:42px;vertical-align:middle;transition:background var(--transition)}.gr-td--name{position:sticky;left:0;z-index:1;background:color-mix(in srgb,var(--color-bg) 95%,var(--color-accent) 2%);text-align:left;font-weight:var(--font-weight-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-right:2px solid color-mix(in srgb,var(--color-accent) 25%,transparent)}.gr-td--input{padding:3px 8px}.gr-td--center{text-align:center}.gr-td--desc{text-align:center;min-width:160px}.gr-td--final{font-weight:var(--font-weight-700);color:var(--color-accent)}.gr-input{width:64px}.gr-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:999px;font-size:var(--font-size-11);font-weight:var(--font-weight-600);white-space:nowrap;transition:var(--transition)}.gr-badge--outstanding{background:color-mix(in srgb,#10b981 18%,transparent);color:color-mix(in srgb,#10b981 85%,var(--color-text))}.gr-badge--vs{background:color-mix(in srgb,#3b82f6 18%,transparent);color:color-mix(in srgb,#3b82f6 85%,var(--color-text))}.gr-badge--satisfactory{background:color-mix(in srgb,#6366f1 18%,transparent);color:color-mix(in srgb,#6366f1 85%,var(--color-text))}.gr-badge--fairly{background:color-mix(in srgb,#f59e0b 18%,transparent);color:color-mix(in srgb,#f59e0b 85%,var(--color-text))}.gr-badge--dnme{background:color-mix(in srgb,#ef4444 18%,transparent);color:color-mix(in srgb,#ef4444 85%,var(--color-text))}.gr-badge--inline{font-size:var(--font-size-10);padding:2px 7px;margin-left:6px;vertical-align:middle}.gr-panel-floor-note{display:flex;align-items:center;gap:4px;font-size:var(--font-size-12);color:var(--color-text);opacity:.5;margin-top:4px;transition:var(--transition)}.gr-panel-floor-note i{font-size:var(--font-size-14);flex-shrink:0}.settings{max-width:560px}.settings-title{font-size:var(--font-size-25);font-weight:var(--font-weight-600);color:var(--color-text);margin-bottom:32px;transition:var(--transition)}.settings-section{margin-bottom:28px}.settings-section-title{font-size:var(--font-size-12);font-weight:var(--font-weight-500);color:var(--color-text);opacity:.5;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px;transition:var(--transition)}.settings-card{border:1px solid rgba(2,16,36,.08);border-radius:12px;padding:20px}.settings-card-info{display:flex;align-items:center;gap:16px}.settings-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-18);font-weight:var(--font-weight-600);flex-shrink:0;transition:var(--transition)}.settings-username{font-size:var(--font-size-15);font-weight:var(--font-weight-500);color:var(--color-text);transition:var(--transition)}.settings-email{font-size:var(--font-size-12);color:var(--color-text);opacity:.5;margin-top:2px;transition:var(--transition)}.settings-card-row{display:flex;align-items:center;justify-content:space-between;gap:24px}.settings-label{font-size:var(--font-size-15);font-weight:var(--font-weight-500);color:var(--color-text);transition:var(--transition)}.settings-description{font-size:var(--font-size-12);color:var(--color-text);opacity:.5;margin-top:2px;transition:var(--transition)}.settings-toggle{width:52px;height:28px;border-radius:14px;background:#0210241f;cursor:pointer;position:relative;flex-shrink:0;transition:var(--transition)}.settings-toggle.active{background:var(--color-accent)}.settings-toggle-knob{position:absolute;top:3px;left:3px;width:22px;height:22px;border-radius:50%;background:var(--color-bg);display:flex;align-items:center;justify-content:center;transition:var(--transition)}.settings-toggle-knob i{font-size:var(--font-size-12);color:var(--color-accent)}.settings-toggle.active .settings-toggle-knob{left:27px}.settings-logout{display:flex;align-items:center;gap:8px;padding:10px 20px;border:none;border-radius:10px;background:var(--color-danger);color:#fff;font-size:var(--font-size-15);font-weight:var(--font-weight-500);cursor:pointer;white-space:nowrap;transition:var(--transition)}.settings-logout i{font-size:var(--font-size-18)}.settings-logout:hover{opacity:.85}.settings-logout:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .settings-card{border-color:#ebf7fd0f}[data-theme=dark] .settings-toggle{background:#ebf7fd1f}.landing{width:100vw;overflow-x:hidden}.landing-section-fade{position:absolute;left:0;right:0;height:140px;pointer-events:none;z-index:3;background:var(--color-bg);transition:var(--transition)}.landing-section-fade--top{top:0;mask-image:linear-gradient(to bottom,black,transparent);-webkit-mask-image:linear-gradient(to bottom,black,transparent)}.landing-section-fade--bottom{bottom:0;mask-image:linear-gradient(to top,black,transparent);-webkit-mask-image:linear-gradient(to top,black,transparent)}.landing-btn-primary,.landing-btn-secondary{padding:16px 44px;border:none;border-radius:12px;font-size:var(--font-size-15);font-weight:var(--font-weight-600);cursor:pointer;transition:var(--transition)}.landing-btn-primary{background:var(--color-accent);color:var(--color-bg);transition:var(--transition)}.landing-btn-primary:hover{opacity:.85;transform:translateY(-2px)}.landing-btn-primary:active{transform:translateY(0)}.landing-btn-secondary{background:transparent;color:var(--color-accent);border:1.5px solid var(--color-accent)}.landing-btn-secondary:hover{background:var(--color-accent);color:var(--color-bg);transform:translateY(-2px)}.landing-btn-secondary:active{transform:translateY(0)}@keyframes landing-fade-up{0%{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}@keyframes landing-bounce{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(10px)}}@media(max-width:768px){.landing-hero-content h1{font-size:var(--font-size-55);letter-spacing:-2px}.landing-word{font-size:var(--font-size-55)}.landing-section{flex-direction:column!important;gap:40px;padding:80px 32px;text-align:center}.landing-section-keyword{font-size:70px}.landing-phone{width:185px;height:390px;border-radius:34px;padding:5px}.landing-phone-3d{width:220px;height:440px}.landing-phone-screen{border-radius:30px}.landing-phone-notch{width:72px;height:20px;top:8px}.phone-screen-content{padding:36px 10px 16px}.landing-section-text h2{font-size:var(--font-size-40);letter-spacing:-2px}.landing-section-desc{font-size:var(--font-size-18)}.landing-cta-content h2{font-size:var(--font-size-55);letter-spacing:-2px}.landing-cta-word{font-size:var(--font-size-55)}}@media(max-width:480px){.landing-hero-content h1{font-size:var(--font-size-40);letter-spacing:-1px}.landing-hero-sub{font-size:var(--font-size-15)}.landing-hero-actions{flex-direction:column;width:100%}.landing-btn-primary,.landing-btn-secondary{width:100%}.landing-word{font-size:var(--font-size-40);letter-spacing:4px}.landing-cta-content h2{font-size:var(--font-size-40);letter-spacing:-1px}.landing-cta-word{font-size:var(--font-size-40);letter-spacing:4px}.landing-section{padding:64px 24px;min-height:auto}.landing-section-keyword{font-size:44px;letter-spacing:4px}.landing-section-text h2{font-size:var(--font-size-30);letter-spacing:-1px}.landing-section-desc{font-size:var(--font-size-15)}.landing-section-number{font-size:var(--font-size-12)}.landing-phone{width:160px;height:340px;border-radius:30px;padding:4px}.landing-phone-3d{width:180px;height:360px}.landing-phone-screen{border-radius:27px}.landing-phone-notch{width:60px;height:18px;top:7px}.phone-screen-content{padding:32px 8px 14px;gap:8px}}
