*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{min-height:100vh}img,svg{max-width:100%;display:block}a{color:inherit;text-decoration:none}button{font-family:inherit}:root{--brand-primary:#2563eb;--brand-secondary:#16a34a;--brand-accent:#f59e0b;--brand-primary-light:#eff6ff;--brand-primary-dark:#1d4ed8;--brand-secondary-light:#f0fdf4;--brand-accent-light:#fffbeb;--blue:#2563eb;--blue-dark:#1d4ed8;--blue-navy:#1e3a5f;--blue-deeper:#0f2440;--blue-100:#dbeafe;--blue-50:#eff6ff;--green:#16a34a;--green-dark:#15803d;--green-light:#22c55e;--green-100:#dcfce7;--green-50:#f0fdf4;--gray-900:#0f172a;--gray-700:#334155;--gray-600:#475569;--gray-400:#94a3b8;--gray-300:#cbd5e1;--gray-200:#e2e8f0;--gray-100:#f1f5f9;--gray-50:#f8fafc;--white:#fff;--text:var(--gray-900);--text-muted:var(--gray-600);--text-light:var(--gray-400);--bg:var(--white);--bg-alt:var(--gray-50);--border:var(--gray-200);--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #00000014, 0 2px 4px #0000000d;--shadow-lg:0 10px 25px #0000001a, 0 4px 8px #0000000d;--shadow-xl:0 20px 40px #0000001f;--radius-sm:6px;--radius:12px;--radius-lg:20px;--radius-full:999px;--font:"Inter", system-ui, -apple-system, "Segoe UI", sans-serif;font-family:var(--font);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}.container{max-width:1160px;margin:0 auto;padding:0 24px}h1,h2,h3{letter-spacing:-.03em;color:var(--text);line-height:1.2}.btn{border-radius:var(--radius-full);font-size:15px;font-weight:600;font-family:var(--font);cursor:pointer;white-space:nowrap;border:2px solid #0000;justify-content:center;align-items:center;gap:8px;padding:11px 24px;transition:transform .15s,box-shadow .15s,background .15s,border-color .15s;display:inline-flex}.btn:active{transform:translateY(0)!important}.btn-primary{background:var(--brand-primary);color:var(--white);border-color:var(--brand-primary)}.btn-primary:hover{background:var(--brand-primary-dark);border-color:var(--brand-primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #2563eb59}.btn-secondary{background:var(--green);color:var(--white);border-color:var(--green)}.btn-secondary:hover{background:var(--green-dark);border-color:var(--green-dark);transform:translateY(-2px);box-shadow:0 6px 20px #16a34a59}.btn-outline-white{color:var(--white);background:0 0;border-color:#ffffff73}.btn-outline-white:hover{background:#ffffff1f;border-color:#ffffffbf;transform:translateY(-2px)}.btn-ghost{color:var(--gray-700);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--gray-100);color:var(--blue)}.btn-lg{padding:14px 32px;font-size:16px}.btn-full{width:100%}.nav{z-index:200;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);background:#fffffff5;position:sticky;top:0}.nav .container{align-items:center;gap:40px;height:70px;display:flex}.logo{color:var(--text);flex-shrink:0;align-items:center;gap:10px;font-size:17px;font-weight:700;display:flex}.logo-mark{background:linear-gradient(135deg, var(--blue), var(--green));width:36px;height:36px;color:var(--white);letter-spacing:-.5px;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:800;display:flex}.nav-links{flex:1;gap:4px;display:flex}.nav-links a{border-radius:var(--radius-full);color:var(--text-muted);padding:7px 14px;font-size:14px;font-weight:500;transition:all .15s}.nav-links a:hover{color:var(--blue);background:var(--blue-50)}.nav-actions{align-items:center;gap:8px;display:flex}.nav-mobile-actions{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:8px;padding-top:12px;display:none}.nav-hamburger{cursor:pointer;border-radius:var(--radius-sm);background:0 0;border:none;flex-direction:column;gap:5px;padding:6px;display:none}.nav-hamburger span{background:var(--gray-700);border-radius:2px;width:22px;height:2px;transition:all .25s;display:block}.hero{background:linear-gradient(160deg, var(--blue-deeper) 0%, var(--blue-navy) 55%, #1a4a30 100%);text-align:center;padding:110px 0 90px;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 20%,#2563eb40 0%,#0000 70%),radial-gradient(50% 60% at 80% 40%,#16a34a33 0%,#0000 70%);position:absolute;inset:0}.hero .container{position:relative}.hero-eyebrow{border-radius:var(--radius-full);color:#ffffffe6;letter-spacing:.02em;background:#ffffff1f;border:1px solid #fff3;align-items:center;gap:8px;margin-bottom:28px;padding:6px 16px;font-size:13px;font-weight:600;display:inline-flex}.hero-eyebrow-dot{background:var(--green-light);border-radius:50%;width:7px;height:7px;animation:2s infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}.hero h1{color:var(--white);max-width:820px;margin-bottom:24px;margin-left:auto;margin-right:auto;font-size:clamp(38px,5.5vw,66px);font-weight:800}.hero h1 .accent{background:linear-gradient(90deg,#60a5fa,#4ade80);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.hero-sub{color:#ffffffb8;max-width:580px;margin:0 auto 44px;font-size:18px;line-height:1.75}.hero-actions{flex-wrap:wrap;justify-content:center;gap:14px;margin-bottom:72px;display:flex}.hero-stats{border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff14;border:1px solid #ffffff26;align-items:center;gap:0;display:inline-flex;overflow:hidden}.hero-stat{text-align:center;border-right:1px solid #ffffff1f;padding:20px 40px}.hero-stat:last-child{border-right:none}.hero-stat strong{color:var(--white);letter-spacing:-.03em;margin-bottom:4px;font-size:30px;font-weight:800;line-height:1;display:block}.hero-stat span{color:#fff9;font-size:13px;font-weight:500}.section-eyebrow{border-radius:var(--radius-full);background:var(--blue-50);color:var(--blue);letter-spacing:.08em;text-transform:uppercase;margin-bottom:16px;padding:5px 14px;font-size:12px;font-weight:700;display:inline-flex}.section-eyebrow.green{background:var(--green-50);color:var(--green-dark)}.section-eyebrow.white{color:#ffffffe6;background:#ffffff2e}.section-header{text-align:center;max-width:620px;margin:0 auto 64px}.section-header h2{margin-bottom:16px;font-size:clamp(28px,3.5vw,42px);font-weight:800}.section-header p{color:var(--text-muted);font-size:17px;line-height:1.7}.section-header.light h2{color:var(--white)}.section-header.light p{color:#ffffffb3}.features{background:var(--bg-alt);padding:100px 0}.features-grid{grid-template-columns:repeat(2,1fr);gap:24px;display:grid}.feature-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 36px;transition:transform .2s,box-shadow .2s,border-color .2s}.feature-card:hover{box-shadow:var(--shadow-lg);border-color:var(--blue-100);transform:translateY(-4px)}.feature-icon{border-radius:var(--radius);flex-shrink:0;justify-content:center;align-items:center;width:54px;height:54px;margin-bottom:24px;display:flex}.feature-icon svg{width:24px;height:24px}.feature-icon.blue{background:var(--blue-50);color:var(--blue)}.feature-icon.green{background:var(--green-50);color:var(--green-dark)}.feature-card h3{margin-bottom:12px;font-size:20px;font-weight:700}.feature-card p{color:var(--text-muted);font-size:15px;line-height:1.75}.how-it-works{background:var(--white);padding:100px 0}.steps{grid-template-columns:1fr auto 1fr auto 1fr;align-items:start;gap:16px;display:grid}.step{text-align:center}.step-num{background:linear-gradient(135deg, var(--blue), var(--green));width:60px;height:60px;color:var(--white);border-radius:50%;justify-content:center;align-items:center;margin:0 auto 20px;font-size:24px;font-weight:800;display:flex;box-shadow:0 4px 16px #2563eb4d}.step h3{margin-bottom:10px;font-size:19px;font-weight:700}.step p{color:var(--text-muted);font-size:15px;line-height:1.7}.step-connector{color:var(--gray-300);text-align:center;align-self:start;padding-top:30px;font-size:28px;font-weight:300}.social-proof{background:linear-gradient(135deg, var(--blue-50), var(--green-50));text-align:center;padding:80px 0}.social-proof p{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:32px;font-size:15px;font-weight:500}.trust-badges{flex-wrap:wrap;justify-content:center;align-items:center;gap:48px;display:flex}.trust-badge{color:var(--gray-600);align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.trust-badge svg{color:var(--blue)}.forms-section{background:linear-gradient(135deg, var(--blue-navy) 0%, var(--blue-deeper) 60%, #12351e 100%);padding:100px 0;position:relative;overflow:hidden}.forms-section:before{content:"";pointer-events:none;background:radial-gradient(55% 60% at 10% 30%,#2563eb33 0%,#0000 65%),radial-gradient(45% 55% at 90% 70%,#16a34a2e 0%,#0000 65%);position:absolute;inset:0}.forms-section .container{position:relative}.forms-section .section-header{margin-bottom:56px}.forms-grid{grid-template-columns:1fr 1fr;gap:28px;display:grid}.form-panel{border-radius:var(--radius-lg);padding:48px 44px}.form-panel-demo{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff12;border:1px solid #ffffff26}.form-panel-contact{background:var(--white);box-shadow:var(--shadow-xl)}.form-panel h3{margin:12px 0 8px;font-size:24px;font-weight:800}.form-panel-demo h3{color:var(--white)}.form-panel-contact h3{color:var(--text)}.form-panel>p{margin-bottom:32px;font-size:15px;line-height:1.7}.form-panel-demo>p{color:#ffffffa6}.form-panel-contact>p{color:var(--text-muted)}.form{flex-direction:column;gap:16px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-group label{font-size:13px;font-weight:600}.form-panel-demo .form-group label{color:#ffffffd9}.form-panel-contact .form-group label{color:var(--gray-700)}.form-group input,.form-group select,.form-group textarea{border-radius:var(--radius-sm);font-size:15px;font-family:var(--font);outline:none;width:100%;padding:12px 16px;transition:border-color .15s,box-shadow .15s,background .15s}.form-panel-demo .form-group input,.form-panel-demo .form-group select,.form-panel-demo .form-group textarea{color:var(--white);background:#ffffff1a;border:1.5px solid #fff3}.form-panel-demo .form-group input::placeholder,.form-panel-demo .form-group textarea::placeholder{color:#ffffff59}.form-panel-demo .form-group input:focus,.form-panel-demo .form-group select:focus,.form-panel-demo .form-group textarea:focus{background:#ffffff26;border-color:#fff9}.form-panel-demo .form-group select option{background:var(--blue-navy);color:var(--white)}.form-panel-contact .form-group input,.form-panel-contact .form-group select,.form-panel-contact .form-group textarea{background:var(--gray-50);border:1.5px solid var(--border);color:var(--text)}.form-panel-contact .form-group input::placeholder,.form-panel-contact .form-group textarea::placeholder{color:var(--text-light)}.form-panel-contact .form-group input:focus,.form-panel-contact .form-group select:focus,.form-panel-contact .form-group textarea:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px var(--blue-100)}.form-group select{appearance:none;cursor:pointer}.form-group textarea{resize:vertical;min-height:120px}.field-error{color:#f87171;font-size:12px;display:none}.field-error.visible{display:block}.form-panel-contact .field-error{color:#dc2626}.hp-field{display:none!important}.form-success{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:48px 24px;display:none}.form-success.visible{display:flex}.form-success-icon{background:var(--green-100);border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;display:flex}.form-success-icon svg{width:28px;height:28px;color:var(--green-dark)}.form-panel-demo .form-success-icon{background:#4ade8033}.form-panel-demo .form-success-icon svg{color:#4ade80}.form-success strong{font-size:20px;font-weight:700}.form-panel-demo .form-success strong{color:var(--white)}.form-panel-demo .form-success p{color:#ffffffa6}.form-panel-contact .form-success p{color:var(--text-muted)}.footer{background:var(--blue-deeper);color:#ffffffa6;padding:56px 0 32px}.footer-body{grid-template-columns:2fr 1fr 1fr;gap:48px;margin-bottom:48px;display:grid}.footer-brand .logo{color:var(--white);margin-bottom:14px}.footer-brand p{color:#ffffff80;max-width:280px;font-size:14px;line-height:1.7}.footer-col h4{color:var(--white);text-transform:uppercase;letter-spacing:.06em;margin-bottom:16px;font-size:13px;font-weight:700}.footer-col ul{flex-direction:column;gap:10px;list-style:none;display:flex}.footer-col ul a{color:#ffffff80;font-size:14px;transition:color .15s}.footer-col ul a:hover{color:var(--white)}.footer-bottom{border-top:1px solid #ffffff1a;justify-content:space-between;align-items:center;padding-top:28px;font-size:13px;display:flex}.footer-bottom-links{gap:24px;display:flex}.footer-bottom-links a{color:#fff6;transition:color .15s}.footer-bottom-links a:hover{color:#fffc}.login-page{grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{background:linear-gradient(160deg, var(--blue-deeper) 0%, var(--blue-navy) 55%, #12351e 100%);flex-direction:column;justify-content:center;padding:56px 64px;display:flex;position:relative;overflow:hidden}.login-left:before{content:"";pointer-events:none;background:radial-gradient(60% 50% at 20%,#2563eb4d 0%,#0000 70%),radial-gradient(50% 60% at 80% 40%,#16a34a38 0%,#0000 70%);position:absolute;inset:0}.login-left-content{position:relative}.login-left .logo{color:var(--white);align-items:center;gap:12px;margin-bottom:56px;display:flex}.login-school-logo{object-fit:contain;background:#ffffff26;border-radius:10px;width:48px;height:48px;padding:4px}.login-left h2{color:var(--white);margin-bottom:18px;font-size:clamp(30px,3.5vw,42px);font-weight:800}.login-left>.login-left-content>p{color:#ffffffa6;margin-bottom:40px;font-size:17px;line-height:1.75}.login-features{flex-direction:column;gap:16px;display:flex}.login-feature{color:#ffffffd9;align-items:center;gap:12px;font-size:15px;display:flex}.check-circle{background:var(--green);width:24px;height:24px;color:var(--white);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:13px;font-weight:700;display:flex}.login-right{background:var(--bg);justify-content:center;align-items:center;padding:56px 64px;display:flex}.login-card{width:100%;max-width:420px}.login-back{color:var(--text-muted);align-items:center;gap:6px;margin-bottom:40px;font-size:14px;transition:color .15s;display:inline-flex}.login-back:hover{color:var(--blue)}.login-card h1{margin-bottom:6px;font-size:30px;font-weight:800}.login-card>p{color:var(--text-muted);margin-bottom:32px;font-size:15px}.login-tabs{background:var(--gray-100);border-radius:var(--radius);gap:4px;margin-bottom:28px;padding:4px;display:flex}.login-tab{border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;padding:10px;font-size:14px;font-weight:600;transition:all .15s}.login-tab.active{background:var(--white);color:var(--blue);box-shadow:var(--shadow-sm)}.login-form{flex-direction:column;gap:18px;display:flex}.login-form .form-group label{color:var(--gray-700);justify-content:space-between;align-items:center;font-size:13px;font-weight:600;display:flex}.forgot-link{color:var(--blue);font-size:13px;font-weight:500}.login-form .form-group input{background:var(--gray-50);border:1.5px solid var(--border);color:var(--text);border-radius:var(--radius-sm);font-size:15px;font-family:var(--font);outline:none;width:100%;padding:13px 16px;transition:border-color .15s,box-shadow .15s}.login-form .form-group input:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px var(--blue-100)}.login-form .form-group input::placeholder{color:var(--text-light)}.password-wrap{position:relative}.password-wrap input{padding-right:48px}.show-pass{cursor:pointer;color:var(--text-light);background:0 0;border:none;align-items:center;transition:color .15s;display:flex;position:absolute;top:50%;right:14px;transform:translateY(-50%)}.show-pass:hover{color:var(--blue)}.login-divider{color:var(--text-light);align-items:center;gap:12px;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-inline-notice{border-radius:var(--radius-sm);background:var(--blue-50);border:1.5px solid var(--blue-100);color:var(--blue-dark);align-items:center;gap:10px;margin-top:4px;padding:14px 18px;font-size:14px;font-weight:500;line-height:1.5;display:none}.login-inline-notice.visible{display:flex}.login-inline-notice svg{color:var(--blue);flex-shrink:0}.login-inline-notice a{color:var(--blue);font-weight:700;text-decoration:underline}.login-notice{text-align:center;color:var(--text-muted);margin-top:20px;font-size:14px}.login-notice a{color:var(--blue);font-weight:600}.auth-loading .app-content{opacity:0;pointer-events:none}.auth-loading .auth-loader{display:flex}.auth-ready .auth-loader{display:none}.auth-loader{z-index:9999;background:var(--bg);justify-content:center;align-items:center;display:none;position:fixed;inset:0}.auth-loader-spinner{border:3px solid var(--gray-200);border-top-color:var(--blue);border-radius:50%;width:36px;height:36px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.auth-error{border-radius:var(--radius-sm);color:#b91c1c;background:#fef2f2;border:1.5px solid #fecaca;margin-bottom:8px;padding:12px 16px;font-size:14px;font-weight:500;line-height:1.5;display:none}.auth-error.visible{display:block}.auth-success{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:24px 0;display:none}.auth-success .form-success-icon{background:var(--green-100)}.auth-success strong{color:var(--text);font-size:20px;font-weight:700}.auth-success p{color:var(--text-muted);font-size:15px;line-height:1.6}.auth-page-center{background:var(--bg-alt);justify-content:center;align-items:center;min-height:100vh;padding:48px 24px;display:flex}.auth-card{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-lg);border:1px solid var(--border);padding:48px 40px}.auth-card h1{margin:12px 0 8px;font-size:26px;font-weight:800}.auth-card-sub{color:var(--text-muted);margin-bottom:28px;font-size:15px;line-height:1.7}.auth-card .login-form .form-group label{color:var(--gray-700)}.auth-card .login-form .form-group input{background:var(--gray-50);border:1.5px solid var(--border);color:var(--text)}.auth-card .login-form .form-group input::placeholder{color:var(--text-light)}.auth-card .login-form .form-group input:focus{border-color:var(--blue);background:var(--white);box-shadow:0 0 0 3px var(--blue-100)}.auth-card-footer{text-align:center;border-top:1px solid var(--border);margin-top:24px;padding-top:20px}.auth-card-footer a{color:var(--blue);font-size:14px;font-weight:600}.dash-nav{background:var(--white);border-bottom:1px solid var(--border);z-index:100;position:sticky;top:0}.dash-nav .container{align-items:center;gap:16px;height:64px;display:flex}.dash-nav-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;padding:4px 12px;font-size:12px;font-weight:700}.dash-nav-badge.admin{background:var(--blue-50);color:var(--blue)}.dash-nav-badge.parent{background:var(--green-50);color:var(--green-dark)}.dash-nav-badge.platform{color:#92400e;background:#fef3c7}.section-badge{border-radius:var(--radius-sm);background:var(--gray-100,#f1f5f9);color:var(--text);border:1px solid var(--gray-200,#e2e8f0);align-items:center;padding:4px 10px;font-size:13px;font-weight:500;display:inline-flex}.hierarchy-node:hover{background:var(--gray-50,#f8fafc)!important}.dash-nav-user{align-items:center;gap:12px;display:flex}.dash-nav-user span{color:var(--text-muted);font-size:14px;font-weight:500}.btn-sm{padding:6px 14px;font-size:13px}.dash-main{background:var(--bg-alt);min-height:calc(100vh - 64px);padding:40px 0 80px}.dash-header{margin-bottom:36px}.dash-header h1{margin-bottom:6px;font-size:28px;font-weight:800}.dash-header p{color:var(--text-muted);font-size:15px}.dash-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:20px;margin-bottom:40px;display:grid}.dash-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;transition:box-shadow .2s}.dash-card:hover{box-shadow:var(--shadow-md)}.dash-card-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:44px;height:44px;margin-bottom:16px;display:flex}.dash-card-icon svg{width:22px;height:22px}.dash-card-icon.blue{background:var(--blue-50);color:var(--blue)}.dash-card-icon.green{background:var(--green-50);color:var(--green-dark)}.dash-card h3{color:var(--text-muted);margin-bottom:8px;font-size:15px;font-weight:600}.dash-stat-number{color:var(--text);letter-spacing:-.03em;font-size:32px;font-weight:800}.dash-stat-label{color:var(--text-light);margin-top:2px;font-size:13px}.dash-section{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:32px}.dash-section h2{margin-bottom:20px;font-size:20px;font-weight:700}.dash-actions{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.dash-coming-soon{color:var(--text-light);font-size:14px;font-style:italic}.dash-tabs{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);gap:4px;margin-bottom:24px;padding:6px;display:flex}.dash-tab{border-radius:var(--radius-sm);font-size:14px;font-weight:600;font-family:var(--font);color:var(--text-muted);cursor:pointer;background:0 0;border:none;flex:1;justify-content:center;align-items:center;gap:8px;padding:12px 16px;transition:all .15s;display:inline-flex}.dash-tab:hover{background:var(--gray-50);color:var(--text)}.dash-tab.active{background:var(--brand-primary-light);color:var(--brand-primary);box-shadow:var(--shadow-sm)}.dash-tab svg{flex-shrink:0}.dash-tab-content{display:none}.dash-tab-content.active{display:block}.dash-form{flex-direction:column;gap:16px;display:flex}.dash-form .form-group label{color:var(--gray-700);font-size:13px;font-weight:600}.dash-form .form-group input,.dash-form .form-group select,.dash-form .form-group textarea{border-radius:var(--radius-sm);font-size:15px;font-family:var(--font);background:var(--gray-50);border:1.5px solid var(--border);color:var(--text);outline:none;width:100%;padding:12px 16px;transition:border-color .15s,box-shadow .15s}.dash-form .form-group input:focus,.dash-form .form-group select:focus,.dash-form .form-group textarea:focus{border-color:var(--brand-primary);background:var(--white);box-shadow:0 0 0 3px var(--brand-primary-light)}.dash-form .form-group input::placeholder,.dash-form .form-group textarea::placeholder{color:var(--text-light)}.dash-form .form-group textarea{resize:vertical;min-height:100px}.dash-form .form-group select{appearance:none;cursor:pointer}.dash-form-actions{align-items:center;gap:12px;padding-top:4px;display:flex}.dash-form-status{font-size:14px;font-weight:500}.dash-form-status.sending{color:var(--brand-primary)}.dash-form-status.success{color:var(--green)}.dash-form-status.error{color:#dc2626}.dash-form-row{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.dash-section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.dash-section-header h2{margin-bottom:0}.dash-list{flex-direction:column;gap:1px;display:flex}.dash-list-empty{text-align:center;color:var(--text-light);padding:40px 20px;font-size:15px}.dash-list-item{background:var(--gray-50);border-radius:var(--radius-sm);align-items:flex-start;gap:16px;margin-bottom:8px;padding:20px;transition:background .15s;display:flex}.dash-list-item:hover{background:var(--blue-50)}.dash-list-item.priority-urgent{border-left:4px solid #dc2626}.dash-list-item.priority-important{border-left:4px solid #f59e0b}.dash-list-item.notification-unread{background:var(--blue-50,#eff6ff);border-left:3px solid var(--brand-primary)}.attendance-grid{border-collapse:collapse;width:100%}.attendance-grid th,.attendance-grid td{text-align:left;border-bottom:1px solid var(--gray-200);padding:8px 12px;font-size:13px}.attendance-grid th{background:var(--gray-50);text-transform:uppercase;color:var(--text-muted);font-size:12px;font-weight:600}.attendance-grid select{border:1px solid var(--gray-300);border-radius:var(--radius-sm);padding:4px 8px;font-size:13px}.dash-list-item-main{flex:1;min-width:0}.dash-list-item-header{align-items:center;gap:10px;margin-bottom:6px;display:flex}.dash-list-item-header h4{color:var(--text);font-size:15px;font-weight:700;line-height:1.3}.dash-list-item-body{color:var(--text-muted);white-space:pre-wrap;margin-bottom:8px;font-size:14px;line-height:1.6}.dash-list-item-meta{color:var(--text-light);font-size:12px}.dash-priority-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;padding:2px 10px;font-size:11px;font-weight:700}.dash-priority-badge.urgent{color:#dc2626;background:#fef2f2}.dash-priority-badge.important{color:#d97706;background:#fffbeb}.dash-type-badge{border-radius:var(--radius-full);flex-shrink:0;padding:2px 10px;font-size:11px;font-weight:700}.dash-type-badge.blue{background:var(--blue-50);color:var(--blue)}.dash-type-badge.green{background:var(--green-50);color:var(--green-dark)}.dash-submission-details{color:var(--text-muted);flex-direction:column;gap:2px;margin-bottom:8px;font-size:13px;display:flex}.btn-icon{border-radius:var(--radius-sm);cursor:pointer;width:36px;height:36px;color:var(--text-light);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;transition:all .15s;display:flex}.btn-icon:hover{background:var(--gray-100);color:var(--text)}.btn-icon.danger:hover{color:#dc2626;background:#fef2f2}.btn-danger{border-radius:var(--radius-full);font-size:14px;font-weight:600;font-family:var(--font);cursor:pointer;color:var(--white);background:#dc2626;border:none;justify-content:center;align-items:center;gap:8px;padding:8px 20px;transition:background .15s;display:inline-flex}.dash-filter-tabs{background:var(--gray-100);border-radius:var(--radius-full);gap:4px;padding:3px;display:flex}.dash-filter{border-radius:var(--radius-full);font-size:13px;font-weight:600;font-family:var(--font);color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:6px 16px;transition:all .15s}.dash-filter:hover{color:var(--text)}.dash-filter.active{background:var(--white);color:var(--brand-primary);box-shadow:var(--shadow-sm)}.module-toggles{flex-wrap:wrap;gap:8px;display:flex}.module-toggle{border-radius:var(--radius-sm);background:var(--gray-50,#f8fafc);border:1px solid var(--gray-200,#e2e8f0);cursor:pointer;align-items:center;gap:6px;padding:6px 12px;font-size:13px;transition:background .15s;display:inline-flex}.module-toggle:hover{background:var(--gray-100,#f1f5f9)}.module-toggle input[type=checkbox]{margin:0}.dash-inline-form{background:var(--blue-50);border:1px solid var(--blue-100);border-radius:var(--radius);margin-bottom:20px;padding:24px}.dash-inline-form h3{color:var(--text);margin-bottom:16px;font-size:16px;font-weight:700}.modal-overlay{z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-overlay.hidden{display:none}.modal-card{background:var(--white);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-xl);padding:32px}.modal-card h3{margin-bottom:10px;font-size:20px;font-weight:700}.modal-card p{color:var(--text-muted);margin-bottom:24px;font-size:15px;line-height:1.6}.dash-form-row-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.dash-status-badge{border-radius:var(--radius-full);text-transform:uppercase;letter-spacing:.04em;flex-shrink:0;padding:2px 10px;font-size:11px;font-weight:700}.dash-status-badge.status-pending{color:#92400e;background:#fef3c7}.dash-status-badge.status-ack,.dash-status-badge.status-acknowledged{background:var(--blue-50);color:var(--blue)}.dash-status-badge.status-approved{background:var(--green-50);color:var(--green-dark)}.dash-status-badge.status-denied{color:#dc2626;background:#fef2f2}.event-item{align-items:center}.event-item.event-past{opacity:.55}.event-date-badge{border-radius:var(--radius);background:linear-gradient(135deg, var(--blue), var(--green));width:56px;height:56px;color:var(--white);flex-direction:column;flex-shrink:0;justify-content:center;align-items:center;display:flex}.event-month{text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:700;line-height:1}.event-day{font-size:22px;font-weight:800;line-height:1.1}.event-past .event-date-badge{background:var(--gray-300)}.profile-account-info{color:var(--text-muted);flex-direction:column;gap:8px;font-size:15px;display:flex}.profile-account-info strong{color:var(--text)}.dash-nav-badge.parent~.dash-tabs .dash-tab.active{background:var(--green-50);color:var(--green-dark)}.hidden{display:none!important}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=1024px){.features-grid,.footer-body{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}@media (width<=860px){.forms-grid{grid-template-columns:1fr}.steps{grid-template-columns:1fr;max-width:380px;margin:0 auto}.step-connector{display:none}.hero-stats{flex-direction:column;gap:0}.hero-stat{border-bottom:1px solid #ffffff1f;border-right:none}.hero-stat:last-child{border-bottom:none}}@media (width<=768px){.nav-links{flex-direction:column;gap:4px;display:none}.nav-links.open{background:var(--white);border-bottom:1px solid var(--border);box-shadow:var(--shadow-lg);padding:12px 24px 20px;display:flex;position:absolute;top:100%;left:0;right:0}.nav-links.open .nav-mobile-actions{display:flex}.nav .container{position:relative}.nav-actions{display:none}.nav-hamburger{margin-left:auto;display:flex}.hero{padding:80px 0 64px}.features{padding:72px 0}.features-grid{grid-template-columns:1fr}.how-it-works,.forms-section{padding:72px 0}.form-panel{padding:36px 28px}.form-row,.login-page{grid-template-columns:1fr}.login-left{display:none}.login-right{padding:48px 24px}.footer-body{grid-template-columns:1fr}.footer-brand{grid-column:auto}.footer-bottom{text-align:center;flex-direction:column;gap:16px}}@media (width<=480px){.hero h1{font-size:34px}.hero-actions{flex-direction:column;align-items:center}.trust-badges{flex-direction:column;gap:28px}.dash-tabs{flex-direction:column}.dash-form-row,.dash-form-row-2{grid-template-columns:1fr}.dash-section-header{flex-direction:column;align-items:flex-start;gap:12px}.dash-filter-tabs{flex-wrap:wrap}}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:8px;display:flex;position:fixed;top:20px;right:20px}.toast{border-radius:var(--radius-sm);color:var(--white);opacity:0;pointer-events:auto;max-width:360px;box-shadow:var(--shadow-lg);padding:12px 20px;font-size:14px;font-weight:500;transition:opacity .3s,transform .3s;transform:translate(40px)}.toast-visible{opacity:1;transform:translate(0)}.toast-success{background:#16a34a}.toast-error{background:#dc2626}.toast-info{background:#2563eb}.toast-warning{color:var(--gray-900);background:#f59e0b}.dash-table{border-collapse:collapse;width:100%;font-size:14px}.dash-table th,.dash-table td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px}.dash-table th{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;background:var(--gray-50);font-size:12px;font-weight:600}.dash-table tbody tr:hover{background:var(--gray-50)}.status-in_progress{color:#1d4ed8;background:#dbeafe}.status-escalated{color:#92400e;background:#fef3c7}.status-resolved,.status-paid{color:#166534;background:#dcfce7}.status-unpaid{color:#991b1b;background:#fee2e2}.status-partial{color:#92400e;background:#fef3c7}.status-overdue{color:#991b1b;background:#fee2e2}.status-present{color:#166534;background:#dcfce7}.status-absent{color:#991b1b;background:#fee2e2}.status-late{color:#92400e;background:#fef3c7}.status-assigned{color:#1d4ed8;background:#dbeafe}.status-completed{color:#166534;background:#dcfce7}.status-incomplete{color:#92400e;background:#fef3c7}.status-not_completed{color:#991b1b;background:#fee2e2}.dash-empty{text-align:center;color:var(--text-light);padding:40px 20px;font-size:14px}.modal-overlay{z-index:9999;opacity:0;background:#00000080;justify-content:center;align-items:center;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-visible{opacity:1}.modal-box{background:var(--white);border-radius:var(--radius);width:90%;max-width:420px;box-shadow:var(--shadow-xl);padding:28px}.modal-title{margin-bottom:8px;font-size:18px;font-weight:700}.modal-message{color:var(--text-muted);margin-bottom:20px;font-size:14px;line-height:1.5}.modal-actions{justify-content:flex-end;gap:10px;display:flex}.btn-danger{color:var(--white);border-radius:var(--radius-sm);cursor:pointer;background:#dc2626;border:none;padding:8px 18px;font-weight:600}.btn-danger:hover{background:#b91c1c}.dash-input{border:1px solid var(--gray-300);border-radius:var(--radius-sm);color:var(--text);background:var(--white);padding:8px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.dash-input:focus{border-color:var(--brand-primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.dash-form-row{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.hierarchy-tree-container{min-height:100px}.hierarchy-node{transition:background .15s,transform .1s}.hierarchy-node:hover{transform:translate(2px);background:var(--blue-50)!important}#schedule-table td{vertical-align:top;min-width:100px}#schedule-table .dash-input{padding:4px 6px;font-size:12px}.dash-status-badge.status-submitted{color:#1d4ed8;background:#dbeafe}.dash-status-badge.status-reviewed{color:#3730a3;background:#e0e7ff}.dash-status-badge.status-dispatched{color:#166534;background:#dcfce7}.dash-status-badge.status-issued{color:#92400e;background:#fef3c7}.dash-status-badge.status-returned{color:#166534;background:#dcfce7}.dash-status-badge.status-excused{color:#6b21a8;background:#f3e8ff}.dash-nav-user a.btn{font-size:13px}.toast-update{cursor:pointer;background:var(--brand-primary);color:#fff}.toast-update:hover{background:var(--brand-primary-dark)}@media (width<=768px){.dash-form-row{flex-direction:column;align-items:stretch}.dash-nav-user a.btn{display:none}#schedule-table td{min-width:80px}}.event-calendar{background:var(--gray-200);border-radius:var(--radius-sm);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.event-cal-header{background:var(--brand-primary);color:#fff;text-align:center;padding:8px 4px;font-size:12px;font-weight:600}.event-cal-day{cursor:pointer;background:#fff;min-height:80px;padding:4px 6px;transition:background .15s}.event-cal-day:hover{background:var(--brand-primary-light,#e0edff)}.event-cal-day.today{background:var(--blue-50,#eff6ff);border:2px solid var(--brand-primary)}.event-cal-day.selected{background:var(--brand-primary-light,#dbeafe)}.event-cal-day.other-month{opacity:.4;cursor:default}.event-cal-day .day-num{color:var(--gray-700);font-size:13px;font-weight:600}.event-cal-dot{border-radius:50%;width:6px;height:6px;margin:1px;display:inline-block}.event-cal-dot.academic{background:var(--blue,#3b82f6)}.event-cal-dot.exam{background:var(--red,#ef4444)}.event-cal-dot.holiday{background:var(--green,#22c55e)}.event-cal-dot.sports{background:var(--brand-accent,#f59e0b)}.event-cal-dot.cultural{background:#8b5cf6}.event-cal-dot.meeting{background:var(--gray-600,#4b5563)}.event-cal-dot.requisition{background:#f97316}.event-cal-dot.general{background:var(--gray-400,#9ca3af)}@media (width<=600px){.event-cal-day{min-height:48px;padding:2px 3px}.event-cal-header{padding:4px 2px;font-size:10px}.event-cal-day .day-num{font-size:11px}}
