:root{--bg:#0b1020;--text:#e8eefc;--muted:#aab3c7;--primary:#4f7cff;--primary-600:#3f66d0;--primary-light:#4f7cff40;--card:#11182e;--border:#223055;--surface:#131b35;--background:#0b1020;--success:#22c55e;--danger:#ef4444;--danger-light:#ef444433;--warning:#eab308;--radius:.5rem;--radius-sm:.375rem;--radius-md:.5rem;--radius-lg:.75rem;--vw:1vw;--vh:1vh;--vmin:1vmin;--vmax:1vmax;--space-xs:calc(.5rem + .2vw);--space-sm:calc(1rem + .5vw);--space-md:calc(1.5rem + .8vw);--space-lg:calc(2rem + 1vw);--space-xl:calc(3rem + 1.5vw);--space-2xl:calc(4rem + 2vw);--text-xs:calc(.75rem + .2vw);--text-sm:calc(.875rem + .3vw);--text-base:calc(1rem + .4vw);--text-lg:calc(1.125rem + .5vw);--text-xl:calc(1.25rem + .6vw);--text-2xl:calc(1.5rem + .8vw);--text-3xl:calc(1.875rem + 1vw);--text-4xl:calc(2.25rem + 1.2vw);--text-5xl:calc(3rem + 1.5vw);--text-6xl:calc(3.75rem + 2vw);--container-full:100vw;--container-sm:min(100vw,640px);--container-md:min(100vw,768px);--container-lg:min(100vw,1024px);--container-xl:min(100vw,1280px);--container-2xl:min(100vw,1536px)}[data-theme=light]{--bg:#f1f5f9;--text:#0f172a;--muted:#64748b;--primary:#3b82f6;--primary-600:#2563eb;--primary-light:#3b82f633;--card:#fff;--border:#e2e8f0;--surface:#fff;--background:#f8fafc}[data-theme=light] body{background:radial-gradient(1200px 800px at 10% 10%,#e2e8f0 0%,var(--bg)40%,#cbd5e1 100%)}*{box-sizing:border-box}html,body,#root{z-index:0;width:100vw;height:100vh;position:relative;overflow-x:hidden}body{background:radial-gradient(1200px 800px at 10% 10%,#0f1730 0%,var(--bg)40%,#070a15 100%);color:var(--text);font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,Apple Color Emoji,Segoe UI Emoji;font-size:var(--text-base);margin:0;padding:0;line-height:1.5;position:relative}.watermark{opacity:.6;z-index:-1;pointer-events:none;background-position:100%;background-repeat:no-repeat;background-size:contain;width:100vw;height:100vh;position:fixed;top:0;right:-40vw}.landing{grid-template-rows:auto 1fr auto;width:100vw;max-width:100vw;min-height:100vh;display:grid;position:relative}.landing__header{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);width:100vw;max-width:100vw;padding-left:max(var(--space-md),5vw);padding-right:max(var(--space-md),5vw);z-index:10;background:var(--card);justify-content:space-between;align-items:center;margin:0;display:flex;position:relative}.brand{align-items:center;gap:var(--space-sm);display:flex}.brand__logo{object-fit:contain;border-radius:4px;width:auto;height:calc(4rem + 1.5vw)}.brand__name{letter-spacing:.5px;font-weight:700;font-size:var(--text-lg)}.nav{gap:var(--space-md);align-items:center;display:flex}.nav__link{color:var(--muted);font-size:var(--text-sm);text-decoration:none;transition:color .2s}.nav__link:hover{color:var(--text)}.hero{width:100vw;max-width:100vw;padding:var(--space-2xl)max(var(--space-md),5vw);text-align:center;z-index:5;flex-direction:column;justify-content:center;min-height:calc(100vh - 200px);margin:0;display:flex;position:relative}.hero h1{margin:0 0 var(--space-md);font-size:var(--text-5xl);font-weight:700;line-height:1.1}.hero__subtitle{margin:0 auto var(--space-xl);max-width:min(70vw,50rem);color:var(--muted);font-size:var(--text-lg);line-height:1.4}.hero__actions{justify-content:center;gap:var(--space-md);margin-top:var(--space-lg);flex-wrap:wrap;display:flex}.btn{padding:var(--space-sm)var(--space-md);border:1px solid var(--border);color:var(--text);background:var(--card);font-size:var(--text-base);cursor:pointer;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border-radius:.625rem;font-family:inherit;text-decoration:none;transition:all .2s;display:inline-block}.btn--small{padding:var(--space-xs)var(--space-sm);font-size:var(--text-sm)}.btn--primary{background:var(--primary);border-color:var(--primary);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.btn--primary:hover{background:var(--primary-600);border-color:var(--primary-600)}.btn:hover{transform:translateY(-1px)}.features{width:100vw;max-width:100vw;padding:var(--space-xl)max(var(--space-md),5vw);gap:var(--space-lg);z-index:5;background:var(--surface);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);grid-template-columns:repeat(auto-fit,minmax(min(20vw,18rem),1fr));margin:0;display:grid;position:relative}.feature{background:var(--card);border:1px solid var(--border);padding:var(--space-lg);border-radius:.75rem;transition:transform .2s,box-shadow .2s}.feature:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.feature h3{margin:0 0 var(--space-sm);font-size:var(--text-xl);font-weight:600}.feature p{font-size:var(--text-sm);color:var(--muted);margin:0;line-height:1.4}.footer{width:100vw;max-width:100vw;padding:var(--space-sm)max(var(--space-md),5vw);border-top:1px solid var(--border);color:var(--muted);font-size:var(--text-xs);text-align:center;margin:0}.modal{padding:var(--space-md);z-index:1000;background:#00000080;place-items:center;display:grid;position:fixed;inset:0}.modal__dialog{background:var(--card);border:1px solid var(--border);border-radius:.75rem;width:100%;max-width:28rem;box-shadow:0 10px 30px #0000004d}.modal__header{padding:var(--space-md);border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.modal__header h2{font-size:var(--text-xl);margin:0;font-weight:600}.modal__content{padding:var(--space-lg);gap:var(--space-sm);display:grid}.icon-btn:hover{background:#ffffff1a}.portal{padding:var(--space-md);border:1px solid var(--border);color:var(--text);text-align:left;font-size:var(--text-base);cursor:pointer;background:#0e152b;border-radius:.625rem;font-family:inherit;transition:all .2s}.portal:hover{border-color:var(--primary);background:#1a2332;transform:translateY(-1px)}@media (min-width:640px){.watermark{opacity:.7;width:120vw;right:-50vw}.landing__header{padding-left:max(var(--space-lg),6vw);padding-right:max(var(--space-lg),6vw)}.brand__logo{height:calc(4.5rem + 1.8vw)}.hero{padding:var(--space-2xl)max(var(--space-lg),6vw)}.features{padding:var(--space-2xl)max(var(--space-lg),6vw);grid-template-columns:repeat(auto-fit,minmax(min(25vw,20rem),1fr))}.footer{padding:var(--space-md)max(var(--space-lg),6vw)}}@media (min-width:1024px){.watermark{opacity:.8;width:140vw;right:-60vw}.landing__header{padding-left:max(var(--space-xl),8vw);padding-right:max(var(--space-xl),8vw)}.brand__logo{height:calc(5rem + 2vw)}.hero{padding:var(--space-2xl)max(var(--space-xl),8vw);min-height:calc(100vh - 150px)}.hero h1{font-size:calc(3.5rem + 2vw)}.hero__subtitle{font-size:var(--text-2xl);max-width:min(60vw,45rem)}.features{padding:var(--space-2xl)max(var(--space-xl),8vw);gap:var(--space-xl);grid-template-columns:repeat(3,1fr)}.footer{padding:var(--space-lg)max(var(--space-xl),8vw)}}@media (min-width:1536px){.hero h1{font-size:calc(4rem + 2.5vw)}.hero__subtitle{font-size:var(--text-3xl);max-width:min(50vw,55rem)}.features{gap:calc(1.5rem + 1vw)}}.landing--mobile .landing__header{padding-left:max(var(--space-xs),3vw);padding-right:max(var(--space-xs),3vw)}.landing--mobile .brand__logo{height:calc(2.5rem + 1vw)}.landing--mobile .hero{padding:var(--space-lg)max(var(--space-sm),3vw);min-height:calc(100vh - 200px)}.landing--mobile .features{padding:var(--space-lg)max(var(--space-sm),3vw);gap:var(--space-md);grid-template-columns:1fr}.landing--mobile .footer{padding:var(--space-sm)max(var(--space-sm),3vw)}.admin-dashboard{background:var(--background);grid-template-rows:auto 1fr;width:100vw;min-height:100vh;display:grid}.admin-header{padding:var(--space-sm)var(--space-md);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:var(--card);justify-content:space-between;align-items:center;display:flex}.admin-header__brand{align-items:center;gap:var(--space-sm);display:flex}.admin-header__logo{object-fit:contain;border-radius:4px;width:auto;height:calc(4rem + 1.5vw)}.admin-header__title h1{font-size:var(--text-xl);color:var(--text);margin:0}.admin-header__subtitle{font-size:var(--text-sm);color:var(--muted)}.admin-header__user{align-items:center;gap:var(--space-sm);display:flex}.admin-header__user-info{font-size:var(--text-sm);color:var(--muted)}.admin-main{grid-template-columns:280px 1fr;min-height:calc(100vh - 80px);display:grid}.admin-sidebar{background:var(--card);border-right:1px solid var(--border);width:280px;padding:var(--space-md)0;overflow-x:hidden}.admin-nav{gap:var(--space-xs);flex-direction:column;display:flex}.admin-nav__item{align-items:center;gap:var(--space-sm);padding:var(--space-sm);color:var(--muted);font-size:var(--text-base);cursor:pointer;text-align:left;box-sizing:border-box;background:0 0;border:none;width:100%;transition:all .2s;display:flex}.admin-nav__item:hover{color:var(--primary);background:#4f7cff1a}.admin-nav__item--active{color:var(--primary);border-right:3px solid var(--primary);background:#4f7cff33}.admin-nav__icon{font-size:var(--text-lg)}.admin-nav__label{font-weight:500}.admin-content{padding:var(--space-lg);background:var(--background);overflow-y:auto}.admin-overview-grid{gap:var(--space-xl);margin-top:var(--space-lg);grid-template-columns:1fr 1fr;display:grid}.features-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.feature-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:transform .2s,box-shadow .2s}.feature-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0003}.feature-card h3{margin:0 0 var(--space-sm);font-size:var(--text-lg);color:var(--text)}.feature-card p{font-size:var(--text-sm);color:var(--muted);margin:0;line-height:1.4}.sidebar-toggle{color:var(--text);cursor:pointer;padding:var(--space-sm);border-radius:var(--radius);font-size:var(--text-xl);background:0 0;border:none;justify-content:center;align-items:center;min-width:44px;min-height:44px;display:none}.sidebar-toggle:hover{background:#4f7cff1a}.sidebar-backdrop{z-index:998;background:#00000080;display:none;position:fixed;inset:0}.sidebar-backdrop.is-open{display:block}.student-dashboard{background:var(--background);flex-direction:column;min-height:100vh;display:flex}.student-header{background:var(--card);border-bottom:1px solid var(--border);padding:var(--space-md)var(--space-lg);justify-content:space-between;align-items:center;display:flex;box-shadow:0 2px 4px #0000001a}.student-header__brand{align-items:center;gap:var(--space-md);display:flex}.student-header__logo{object-fit:contain;border-radius:4px;width:auto;height:calc(4rem + 1.5vw)}.student-header__title h1{font-size:var(--text-xl);color:var(--text);margin:0;font-weight:600}.student-header__subtitle{font-size:var(--text-sm);color:var(--muted)}.student-header__user{align-items:center;gap:var(--space-md);display:flex}.student-header__user-info{font-size:var(--text-sm);color:var(--muted)}.student-dashboard__content{flex:1;display:flex}.student-sidebar{background:var(--card);border-right:1px solid var(--border);width:280px;padding:var(--space-md)0;overflow:hidden auto}.student-nav{gap:var(--space-xs);flex-direction:column;display:flex}.student-nav__item{align-items:center;gap:var(--space-sm);padding:var(--space-sm);color:var(--muted);text-align:left;cursor:pointer;font-size:var(--text-base);box-sizing:border-box;background:0 0;border:none;width:100%;transition:all .2s;display:flex}.student-nav__item:hover{color:var(--primary);background:#4f7cff1a}.student-nav__item.active{color:var(--primary);border-right:3px solid var(--primary);background:#4f7cff33}.student-nav__icon{font-size:var(--text-lg)}.student-nav__label{font-weight:500}.student-main{padding:var(--space-md);flex:1;overflow-y:auto}.student-content{width:100%}.student-content h2{margin:0 0 var(--space-sm)0;color:var(--text);font-size:var(--text-2xl);font-weight:600}.student-content p{margin:0 0 var(--space-md)0;color:var(--muted);font-size:var(--text-base);line-height:1.6}.placeholder-content{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center}.placeholder-content p{color:var(--muted);margin:0;font-style:italic}.welcome-message{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);margin-top:var(--space-md)}.welcome-message p{color:var(--text);font-size:var(--text-lg);margin:0}.teacher-dashboard{background:var(--background);flex-direction:column;min-height:100vh;display:flex}.teacher-header{background:var(--card);border-bottom:1px solid var(--border);padding:var(--space-md)var(--space-lg);justify-content:space-between;align-items:center;display:flex;box-shadow:0 2px 4px #0000001a}.teacher-header__brand{align-items:center;gap:var(--space-md);display:flex}.teacher-header__logo{object-fit:contain;border-radius:4px;width:auto;height:calc(4rem + 1.5vw)}.teacher-header__title h1{font-size:var(--text-xl);color:var(--text);margin:0;font-weight:600}.teacher-header__subtitle{font-size:var(--text-sm);color:var(--muted)}.teacher-header__user{align-items:center;gap:var(--space-md);display:flex}.teacher-header__user-info{font-size:var(--text-sm);color:var(--muted)}.teacher-dashboard__content{flex:1;display:flex}.teacher-sidebar{background:var(--card);border-right:1px solid var(--border);width:280px;padding:var(--space-md)0;overflow:hidden auto}.teacher-nav{gap:var(--space-xs);flex-direction:column;display:flex}.teacher-nav__item{align-items:center;gap:var(--space-sm);padding:var(--space-sm);color:var(--muted);text-align:left;cursor:pointer;font-size:var(--text-base);box-sizing:border-box;background:0 0;border:none;width:100%;transition:all .2s;display:flex}.teacher-nav__item:hover{color:var(--primary);background:#4f7cff1a}.teacher-nav__item.active{color:var(--primary);border-right:3px solid var(--primary);background:#4f7cff33}.teacher-nav__icon{font-size:var(--text-lg)}.teacher-nav__label{font-weight:500}.teacher-main{padding:var(--space-md);flex:1;overflow-y:auto}.teacher-content{width:100%}.teacher-content h2{margin:0 0 var(--space-sm)0;color:var(--text);font-size:var(--text-2xl);font-weight:600}.teacher-content p{margin:0 0 var(--space-md)0;color:var(--muted);font-size:var(--text-base);line-height:1.6}@media (max-width:768px){.sidebar-toggle{display:flex}.admin-header__logo{height:2.5rem}.admin-header__title h1{font-size:var(--text-base)}.admin-header__user-info{display:none}.admin-main{grid-template-columns:1fr}.admin-sidebar{z-index:1000;width:280px;max-width:85vw;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0000004d}.admin-sidebar.is-open{transform:translate(0)}.admin-content{padding:var(--space-md)}.admin-overview-grid{grid-template-columns:1fr}.student-header__logo{height:2.5rem}.student-header__title h1{font-size:var(--text-base)}.student-header__user-info{display:none}.student-sidebar{z-index:1000;width:280px;max-width:85vw;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0000004d}.student-sidebar.is-open{transform:translate(0)}.student-main{padding:var(--space-md)}.teacher-header__logo{height:2.5rem}.teacher-header__title h1{font-size:var(--text-base)}.teacher-header__user-info{display:none}.teacher-sidebar{z-index:1000;width:280px;max-width:85vw;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);box-shadow:4px 0 20px #0000004d}.teacher-sidebar.is-open{transform:translate(0)}.teacher-main{padding:var(--space-md)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.table-header{align-items:stretch;gap:var(--space-sm);flex-direction:column}.table-filters{flex-direction:column;align-items:stretch}.search-box{max-width:none}.form-row{grid-template-columns:1fr}.portal-header{gap:var(--space-sm);flex-wrap:wrap}.portal-header__actions{flex-wrap:wrap}}.table-header{margin-bottom:var(--space-lg);justify-content:space-between;align-items:flex-start;gap:var(--space-md);display:flex}.table-header__title h2{margin:0 0 var(--space-xs)0;font-size:var(--text-2xl);color:var(--text)}.table-header__title p{color:var(--muted);font-size:var(--text-base);margin:0}.table-header__actions{gap:var(--space-sm);display:flex}.table-filters{margin-bottom:var(--space-md);justify-content:space-between;align-items:center;gap:var(--space-md);display:flex}.search-box{flex:1;max-width:400px}.search-input{width:100%;padding:var(--space-sm);border:1px solid var(--border);background:var(--card);color:var(--text);font-size:var(--text-base);border-radius:.5rem}.search-input:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #4f7cff33}.table-stats{font-size:var(--text-sm);color:var(--muted)}.table-container{background:var(--card);border:1px solid var(--border);border-radius:.75rem;overflow:hidden}.data-table{border-collapse:collapse;width:100%}.data-table th{color:var(--text);font-weight:600;font-size:var(--text-sm);padding:var(--space-md);text-align:left;border-bottom:1px solid var(--border);background:#4f7cff1a}.data-table td{padding:var(--space-md);border-bottom:1px solid var(--border);font-size:var(--text-sm);color:var(--text)}.data-table tr:hover{background:#4f7cff0d}.data-table tr:last-child td{border-bottom:none}.empty-state{text-align:center;color:var(--muted);font-style:italic;padding:var(--space-xl)!important}.student-name,.teacher-name{align-items:center;gap:var(--space-xs);display:flex}.student-gender,.teacher-gender{font-size:var(--text-sm);opacity:.7}.status-badge{font-size:var(--text-xs);text-transform:uppercase;border-radius:.25rem;padding:.25rem .5rem;font-weight:600;display:inline-block}.status-badge--active{color:#22c55e;background:#22c55e33}.status-badge--inactive{color:#ef4444;background:#ef444433}.status-badge--graduated{color:#3b82f6;background:#3b82f633}.action-buttons{gap:var(--space-xs);flex-wrap:nowrap;align-items:center;display:flex}.action-buttons .btn{white-space:nowrap;flex-shrink:0;min-width:fit-content}.btn--danger{color:#ef4444;background:#ef444433;border:1px solid #ef44444d}.btn--danger:hover{background:#ef44444d}.pagination{justify-content:center;align-items:center;gap:var(--space-md);margin-top:var(--space-lg);display:flex}.error-message{padding:var(--space-sm);color:#ef4444;margin-bottom:var(--space-md);background:#ef44441a;border:1px solid #ef44444d;border-radius:.5rem;justify-content:space-between;align-items:center;display:flex}.error-message button{color:#ef4444;cursor:pointer;font-size:var(--text-lg);background:0 0;border:none}.modal{z-index:1000;padding:var(--space-md);background:#000c;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal__dialog{background:var(--card);border:1px solid var(--border);border-radius:.75rem;flex-direction:column;width:90%;max-width:550px;max-height:calc(100vh - 100px);display:flex;overflow:hidden;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}.modal__header{padding:var(--space-lg);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;display:flex}.modal__header h3{font-size:var(--text-xl);color:var(--text);margin:0}.modal__close{color:var(--muted);font-size:var(--text-xl);cursor:pointer;padding:var(--space-xs);background:0 0;border:none;border-radius:.25rem;justify-content:center;align-items:center;width:24px;height:24px;transition:all .2s;display:flex}.modal__close:hover{color:#ef4444;background:#ef44441a}.modal__content{padding:var(--space-md);flex:1;overflow-y:auto}.icon-btn{color:var(--muted);font-size:var(--text-lg);cursor:pointer;padding:var(--space-xs);background:0 0;border:none;border-radius:.25rem;transition:all .2s}.icon-btn:hover{color:#ef4444;background:#ef44441a}.student-form{gap:var(--space-sm);flex-direction:column;min-width:0;display:flex}.student-form .form-group{min-width:0}.form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.form-group{gap:var(--space-xs);flex-direction:column;display:flex}.form-group label{font-size:var(--text-sm);color:var(--text);font-weight:600}.form-group input,.form-group select{width:100%;padding:var(--space-sm);border:1px solid var(--border);background:var(--card);color:var(--text);font-size:var(--text-base);box-sizing:border-box;border-radius:.5rem}.form-group input:focus,.form-group select:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 2px #4f7cff33}.role-filter-select{background-color:var(--card)!important;color:var(--text)!important;border:1px solid var(--border)!important;font-weight:500!important}.role-filter-select:hover{border-color:var(--primary)!important;background-color:#4f7cff0d!important}.role-filter-select:focus{outline:none;border-color:var(--primary)!important;background-color:var(--card)!important;box-shadow:0 0 0 2px #4f7cff4d!important}.role-filter-select option{background-color:var(--card)!important;color:var(--text)!important;padding:var(--space-sm)!important;font-weight:500!important}.role-filter-select option:checked{background-color:var(--primary)!important;color:#fff!important;font-weight:600!important}.form-section{border-top:1px solid var(--border);padding-top:var(--space-md)}.form-section h4{margin:0 0 var(--space-md)0;color:var(--text);font-size:var(--text-lg)}.form-actions{justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--border);display:flex}.reports-view{gap:var(--space-lg);flex-direction:column;display:flex}.reports-header h2{margin:0 0 var(--space-xs)0;font-size:var(--text-2xl);color:var(--text)}.reports-header p{color:var(--muted);font-size:var(--text-base);margin:0}.reports-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.report-card{background:var(--card);border:1px solid var(--border);padding:var(--space-lg);text-align:center;border-radius:.75rem;transition:all .2s}.report-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #4f7cff1a}.report-card__icon{font-size:var(--text-4xl);margin-bottom:var(--space-md)}.report-card h3{margin:0 0 var(--space-sm)0;font-size:var(--text-lg);color:var(--text)}.report-card p{margin:0 0 var(--space-md)0;color:var(--muted);font-size:var(--text-sm)}.reports-section{background:var(--card);border:1px solid var(--border);padding:var(--space-lg);border-radius:.75rem}.reports-section h3{margin:0 0 var(--space-md)0;font-size:var(--text-lg);color:var(--text)}.stats-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));display:grid}.stat-item{text-align:center}.stat-value{font-size:var(--text-3xl);color:var(--primary);margin-bottom:var(--space-xs);font-weight:700}.stat-label{font-size:var(--text-sm);color:var(--muted)}.wizard-modal{max-width:800px;max-height:90vh}.wizard-progress{justify-content:center;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-bottom:1px solid var(--border);display:flex}.progress-step{background:var(--card);border:2px solid var(--border);width:40px;height:40px;color:var(--muted);border-radius:50%;justify-content:center;align-items:center;font-weight:600;transition:all .3s;display:flex}.progress-step.active{background:var(--primary);border-color:var(--primary);color:var(--text)}.wizard-step{gap:var(--space-md);flex-direction:column;min-height:400px;display:flex}.wizard-step h3{margin:0 0 var(--space-md)0;font-size:var(--text-xl);color:var(--text);text-align:center}.review-section{background:var(--card);border:1px solid var(--border);padding:var(--space-md);margin-bottom:var(--space-md);border-radius:.5rem}.review-section h4{margin:0 0 var(--space-sm)0;font-size:var(--text-lg);color:var(--primary)}.review-section p{margin:var(--space-xs)0;color:var(--text)}.wizard-actions{padding:var(--space-md);border-top:1px solid var(--border);justify-content:space-between;align-items:center;gap:var(--space-sm);display:flex}.wizard-actions .btn{min-width:120px}.student-list{margin:var(--space-md)0}.student-list h3{margin:0 0 var(--space-md)0;font-size:var(--text-lg);color:var(--text)}.search-form{margin-bottom:var(--space-md);padding:var(--space-md);background:var(--card);border:1px solid var(--border);border-radius:.5rem}.students-grid{gap:var(--space-md);margin-bottom:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(300px,1fr));display:grid}.student-card{background:var(--card);border:2px solid var(--border);padding:var(--space-md);cursor:pointer;border-radius:.5rem;justify-content:space-between;align-items:center;transition:all .2s;display:flex}.student-card:hover{border-color:var(--primary);transform:translateY(-2px)}.student-card.selected{border-color:var(--primary);background:#4f7cff1a}.student-info h4{margin:0 0 var(--space-xs)0;font-size:var(--text-base);color:var(--text)}.student-info p{margin:var(--space-xs)0;font-size:var(--text-sm);color:var(--muted)}.selection-indicator{font-size:var(--text-xl);color:var(--primary);font-weight:700}.pagination{justify-content:center;align-items:center;gap:var(--space-md);margin:var(--space-md)0;display:flex}.pagination-info{font-size:var(--text-sm);color:var(--muted)}.no-data{text-align:center;padding:var(--space-xl);color:var(--muted);font-style:italic}.portal-header{padding:var(--space-lg)0;border-bottom:1px solid var(--border);margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.portal-header__brand{align-items:center;gap:var(--space-md);display:flex}.portal-header__logo{border-radius:50%;width:60px;height:60px}.portal-header__title h1{font-size:var(--text-3xl);color:var(--text);margin:0}.portal-header__subtitle{font-size:var(--text-sm);color:var(--muted)}.portal-header__actions{gap:var(--space-sm);align-items:center;display:flex}.selection-section{margin-bottom:var(--space-lg);padding:var(--space-md);background:var(--card);border:1px solid var(--border);border-radius:.5rem}.selection-section h3{margin:0 0 var(--space-md)0;font-size:var(--text-lg);color:var(--primary)}.guardians-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.guardian-card{background:var(--surface);border:2px solid var(--border);padding:var(--space-md);cursor:pointer;border-radius:.5rem;justify-content:space-between;align-items:center;transition:all .2s;display:flex}.guardian-card:hover{border-color:var(--primary);transform:translateY(-2px)}.guardian-card.selected{border-color:var(--primary);background:#4f7cff1a}.guardian-info h4{margin:0 0 var(--space-xs)0;font-size:var(--text-base);color:var(--text)}.guardian-info p{margin:var(--space-xs)0;font-size:var(--text-sm);color:var(--muted)}.table-description{font-size:var(--text-sm);color:var(--muted);margin:0}.assignment-form{gap:var(--space-lg);flex-direction:column;display:flex}.assignment-modal .modal__dialog{width:95vw;max-width:900px}.assignment-form .form-row{gap:var(--space-md);flex-direction:column;display:flex}.assignment-form .form-group{width:100%}.assignment-form input,.assignment-form select{box-sizing:border-box;width:100%}.selected-students-summary{margin-top:var(--space-md);padding:var(--space-md);background:var(--surface);border:1px solid var(--border);border-radius:.5rem}.selected-students-summary h4{margin:0 0 var(--space-sm)0;font-size:var(--text-base);color:var(--primary)}.selected-students-list{gap:var(--space-xs);flex-direction:column;display:flex}.selected-student-item{padding:var(--space-xs)var(--space-sm);background:var(--card);border:1px solid var(--border);border-radius:.25rem;justify-content:space-between;align-items:center;display:flex}.selected-student-item span{font-size:var(--text-sm);color:var(--text)}.selected-student-item .btn--small{padding:var(--space-xs)var(--space-sm);font-size:var(--text-xs)}@media (max-width:768px){.wizard-modal{max-width:95vw;max-height:95vh}.wizard-step{min-height:300px}.wizard-actions{gap:var(--space-sm);flex-direction:column}.wizard-actions .btn{width:100%}}.academic-foundation-management{gap:var(--space-lg);flex-direction:column;display:flex}.academic-setup-wizard{background:var(--background);flex-direction:column;min-height:100vh;display:flex}.wizard-container{max-width:1200px;padding:var(--space-lg);gap:var(--space-lg);flex-direction:column;margin:0 auto;display:flex}.wizard-progress{gap:var(--space-xs);flex-direction:column;display:flex}.progress-bar{background:var(--border);border-radius:4px;width:100%;height:8px;overflow:hidden}.progress-fill{background:var(--primary);height:100%;transition:width .3s}.progress-text{text-align:center;font-size:var(--text-sm);color:var(--muted);font-weight:500}.wizard-main{background:var(--surface);border-radius:var(--radius-lg);padding:var(--space-xl);box-shadow:var(--shadow-md);min-height:600px}.wizard-header{text-align:center;margin-bottom:var(--space-xl)}.wizard-header h2{font-size:var(--text-2xl);color:var(--text);margin-bottom:var(--space-sm);font-weight:700}.wizard-header p{font-size:var(--text-lg);color:var(--muted);max-width:600px;margin:0 auto}.wizard-content{gap:var(--space-xl);flex-direction:column;display:flex}.setup-overview{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border)}.setup-overview h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.setup-checklist{gap:var(--space-md);margin:0;padding:0;list-style:none;display:grid}.setup-checklist li{align-items:center;gap:var(--space-sm);font-size:var(--text-lg);color:var(--text);padding:var(--space-sm);background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);display:flex}.current-status{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border)}.current-status h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.status-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.status-item{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);display:flex}.status-icon{font-size:var(--text-xl)}.existing-items{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border)}.existing-items h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.no-items{color:var(--muted);text-align:center;padding:var(--space-lg);font-style:italic}.items-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fill,minmax(250px,1fr));display:grid}.item-card{background:var(--surface);border-radius:var(--radius-sm);padding:var(--space-md);border:1px solid var(--border);transition:all .2s}.item-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.item-card h4{font-size:var(--text-lg);color:var(--text);margin-bottom:var(--space-xs);font-weight:600}.item-card p{font-size:var(--text-sm);color:var(--muted);margin:0}.create-form{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border)}.create-form h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.create-form .form-group{margin-bottom:var(--space-md)}.create-form label{font-size:var(--text-sm);color:var(--text);margin-bottom:var(--space-xs);font-weight:500;display:block}.create-form input,.create-form select{width:100%;padding:var(--space-sm);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:var(--text-base);background:var(--surface);color:var(--text);transition:border-color .2s}.create-form input:focus,.create-form select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-light);outline:none}.periods-preview,.departments-preview{background:var(--surface);border-radius:var(--radius-sm);padding:var(--space-md);border:1px solid var(--border);margin-bottom:var(--space-md)}.periods-preview h4,.departments-preview h4{font-size:var(--text-lg);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.periods-list,.departments-list{gap:var(--space-sm);flex-direction:column;display:flex}.period-item,.department-item{padding:var(--space-sm);background:var(--background);border-radius:var(--radius-sm);border:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.period-name,.department-name{color:var(--text);font-weight:500}.period-time{font-size:var(--text-sm);color:var(--muted)}.completion-summary{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border);margin-bottom:var(--space-lg)}.completion-summary h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.summary-grid{gap:var(--space-md);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));display:grid}.summary-item{align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);display:flex}.summary-icon{font-size:var(--text-xl)}.next-steps{background:var(--background);border-radius:var(--radius-md);padding:var(--space-lg);border:1px solid var(--border)}.next-steps h3{font-size:var(--text-xl);color:var(--text);margin-bottom:var(--space-md);font-weight:600}.next-steps ul{gap:var(--space-sm);flex-direction:column;margin:0;padding:0;list-style:none;display:flex}.next-steps li{align-items:center;gap:var(--space-sm);font-size:var(--text-base);color:var(--text);padding:var(--space-sm);background:var(--surface);border-radius:var(--radius-sm);border:1px solid var(--border);display:flex}.wizard-navigation{padding:var(--space-lg);background:var(--surface);border-radius:var(--radius-lg);border:1px solid var(--border);justify-content:space-between;align-items:center;display:flex}.step-indicator{gap:var(--space-sm);align-items:center;display:flex}.step-dot{background:var(--border);border-radius:50%;width:12px;height:12px;transition:all .3s}.step-dot.active{background:var(--primary);transform:scale(1.2)}.step-dot.completed{background:var(--success)}.error-message{background:var(--danger-light);color:var(--danger);padding:var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--danger);margin-bottom:var(--space-lg);justify-content:space-between;align-items:center;display:flex}.error-close{color:var(--danger);font-size:var(--text-xl);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;width:24px;height:24px;padding:0;display:flex}.loading{min-height:400px;font-size:var(--text-lg);color:var(--muted);justify-content:center;align-items:center;display:flex}.management-header{text-align:center;margin-bottom:var(--space-lg)}.management-header h1{margin:0 0 var(--space-sm)0;font-size:var(--text-3xl);color:var(--text);font-weight:600}.management-header p{color:var(--muted);font-size:var(--text-lg);margin:0;line-height:1.6}.tab-navigation{margin-bottom:var(--space-lg)}.tab-list{gap:var(--space-sm);padding-bottom:var(--space-sm);display:flex;overflow-x:auto}.tab-button{background:var(--card);border:1px solid var(--border);padding:var(--space-md);cursor:pointer;text-align:left;border-radius:.75rem;min-width:200px;transition:all .2s}.tab-button:hover{border-color:var(--primary);transform:translateY(-2px)}.tab-button.active{background:var(--primary);border-color:var(--primary);color:var(--text)}.tab-button.active .tab-content h3{color:var(--text)}.tab-button.active .tab-content p{color:#fffc}.tab-content h3{margin:0 0 var(--space-xs)0;font-size:var(--text-lg);color:var(--text);font-weight:600}.tab-content p{font-size:var(--text-sm);color:var(--muted);margin:0;line-height:1.4}.tab-content-area{min-height:400px}.setup-requirements{margin-top:var(--space-xl);padding:var(--space-lg);background:var(--card);border:1px solid var(--border);border-radius:.75rem}.setup-requirements h3{margin:0 0 var(--space-lg)0;font-size:var(--text-xl);color:var(--text);text-align:center}.requirements-grid{gap:var(--space-lg);grid-template-columns:repeat(auto-fit,minmax(300px,1fr));display:grid}.requirement-card{background:var(--surface);border:1px solid var(--border);padding:var(--space-lg);border-radius:.5rem}.requirement-card h4{margin:0 0 var(--space-md)0;font-size:var(--text-lg);color:var(--primary);font-weight:600}.requirement-card p{margin:0 0 var(--space-md)0;color:var(--muted);font-size:var(--text-sm);line-height:1.5}.requirement-card ul{padding-left:var(--space-md);color:var(--text);font-size:var(--text-sm);margin:0}.requirement-card li{margin-bottom:var(--space-xs);line-height:1.4}.grade-badge{font-size:var(--text-sm);text-transform:uppercase;background:var(--primary);color:var(--text);border:1px solid var(--primary);border-radius:.375rem;padding:.25rem .75rem;font-weight:600;display:inline-block}.text-muted{color:var(--muted);font-style:italic}.term-management,.period-management,.score-range-management{gap:var(--space-lg);flex-direction:column;display:flex}@media (max-width:768px){.tab-list{gap:var(--space-sm);flex-direction:column}.tab-button{min-width:auto}.requirements-grid{grid-template-columns:1fr}}
