*,:before,:after,::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border:0 solid #e5e7eb}:before,:after{--tw-content:""}html,:host{-webkit-text-size-adjust:100%;tab-size:4;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;line-height:1.5}body{line-height:inherit;margin:0}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-feature-settings:normal;font-variation-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-feature-settings:inherit;font-variation-settings:inherit;font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:#0000;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{margin:0;padding:0;list-style:none}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder{opacity:1;color:#9ca3af}textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background:0 0% 100%;--foreground:222.2 84% 4.9%;--card:0 0% 100%;--card-foreground:222.2 84% 4.9%;--popover:0 0% 100%;--popover-foreground:222.2 84% 4.9%;--primary:222.2 47.4% 11.2%;--primary-foreground:210 40% 98%;--secondary:210 40% 96.1%;--secondary-foreground:222.2 47.4% 11.2%;--muted:210 40% 96.1%;--muted-foreground:215.4 16.3% 46.9%;--accent:210 40% 96.1%;--accent-foreground:222.2 47.4% 11.2%;--destructive:0 84.2% 60.2%;--destructive-foreground:210 40% 98%;--border:214.3 31.8% 91.4%;--input:214.3 31.8% 91.4%;--ring:222.2 84% 4.9%;--radius:.5rem}.\!container{width:100%!important;margin-left:auto!important;margin-right:auto!important;padding-left:2rem!important;padding-right:2rem!important}.container{width:100%;margin-left:auto;margin-right:auto;padding-left:2rem;padding-right:2rem}@media (width>=1280px){.\!container{max-width:1280px!important}.container{max-width:1280px}}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.absolute{position:absolute}.relative{position:relative}.sticky{position:sticky}.isolate{isolation:isolate}.block{display:block}.inline{display:inline}.flex{display:flex}.table{display:table}.grid{display:grid}.hidden{display:none}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.items-center{align-items:center}.rounded{border-radius:.25rem}.bg-slate-950{--tw-bg-opacity:1;background-color:rgb(2 6 23/var(--tw-bg-opacity,1))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity,1))}.p-2{padding:.5rem}.p-4{padding:1rem}.px-2{padding-left:.5rem;padding-right:.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.\!filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)!important}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,-webkit-backdrop-filter,backdrop-filter;transition-duration:.15s;transition-timing-function:cubic-bezier(.4,0,.2,1)}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0), var(--tw-enter-translate-y,0), 0) scale3d(var(--tw-enter-scale,1), var(--tw-enter-scale,1), var(--tw-enter-scale,1)) rotate(var(--tw-enter-rotate,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0), var(--tw-exit-translate-y,0), 0) scale3d(var(--tw-exit-scale,1), var(--tw-exit-scale,1), var(--tw-exit-scale,1)) rotate(var(--tw-exit-rotate,0))}}.paused{animation-play-state:paused}:root{color:#172033;font-synthesis:none;text-rendering:optimizelegibility;background:#eef2f7;font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}body{min-width:320px;margin:0}a{color:inherit}button,input,select,textarea{font:inherit}button{color:#fff;cursor:pointer;background:#315efb;border:0;border-radius:10px;padding:12px 16px;font-weight:700}button:disabled{cursor:not-allowed;opacity:.6}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline-offset:2px;outline:3px solid #9db4ff}input,select,textarea{border:1px solid #c9d3e5;border-radius:10px;width:100%;padding:10px 12px}input[type=checkbox],input[type=radio]{border:0;border-radius:0;width:auto;margin:0;padding:0}.form-grid{border:0;gap:12px;margin:0;padding:0;display:grid}label{gap:6px;font-weight:700;display:grid}.page-card{background:#fff;border-radius:18px;width:min(480px,100vw - 32px);margin:80px auto;padding:32px;box-shadow:0 20px 50px #1720331f}.skip-link{z-index:10;color:#fff;background:#172033;border-radius:999px;padding:10px 14px;position:fixed;top:16px;left:16px;transform:translateY(-160%)}.skip-link:focus{transform:translateY(0)}.app-shell{grid-template-columns:280px minmax(0,1fr);min-height:100vh;display:grid}.app-sidebar{color:#fff;background:#172033;align-content:start;gap:24px;height:100vh;padding:28px;display:grid;position:sticky;top:0}.app-sidebar__brand{font-size:1.25rem;font-weight:800}.app-sidebar nav{gap:8px;display:grid}.app-sidebar a{color:#dbe6ff;border-radius:12px;align-items:center;gap:12px;padding:12px 14px;text-decoration:none;display:flex}.icon{flex:none;width:20px;height:20px}.nav-icon{opacity:.92}.icon-button{justify-content:center;align-items:center;padding:9px;display:inline-flex}.icon-button .icon{width:18px;height:18px}.app-sidebar a[aria-current=page],.app-sidebar a:hover{color:#fff;background:#315efb}.app-shell__body{min-width:0}.app-topbar{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffd1;border-bottom:1px solid #dce4f2;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px 24px;padding:24px clamp(20px,4vw,48px);display:flex}.app-topbar__title{flex:auto;min-width:0}.app-topbar__actions{margin-left:auto}.app-topbar h1,.app-topbar p{margin:0}.app-topbar__eyebrow{color:#526175;text-transform:uppercase;font-size:.85rem;font-weight:800}.app-topbar__actions{color:#526175;flex-wrap:wrap;align-items:center;gap:12px;display:flex}.app-content{width:min(1280px,100%);margin:0 auto;padding:32px clamp(20px,4vw,48px) 56px}.route-stub{gap:24px;display:grid}.route-stub__hero,.state-card{background:#fff;border:1px solid #dce4f2;border-radius:18px;padding:24px;box-shadow:0 14px 34px #17203317}.route-stub__hero h2,.route-stub__hero p,.state-card h2,.state-card p{margin-top:0}.route-stub__grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px;display:grid}.state-card{gap:12px;display:grid}.state-card__icon{color:#315efb;background:#e8eeff;border-radius:16px;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.state-card__icon .icon{width:22px;height:22px}.state-card--error .state-card__icon,.state-card--forbidden .state-card__icon{color:#e0552c;background:#ffe7df}.skeleton-line{background:linear-gradient(90deg,#e8edf6 25%,#f6f8fc 50%,#e8edf6 75%) 0 0/240% 100%;border-radius:999px;width:100%;height:14px;animation:1.4s ease-in-out infinite skeleton}.skeleton-line--title{width:70%;height:22px}.modal-root{pointer-events:none;display:none;position:fixed;inset:0}@keyframes skeleton{0%{background-position:120% 0}to{background-position:-120% 0}}@media (width<=900px){.app-shell{grid-template-columns:1fr}.app-sidebar{height:auto;position:static}.app-sidebar nav,.app-topbar,.route-stub__grid{grid-template-columns:1fr}.app-topbar{flex-direction:column;align-items:stretch}}.auth-card{gap:16px;display:grid}.auth-form{gap:12px;display:grid}.field-error{color:#b42318;margin:-6px 0 0;font-size:.9rem}.form-status{border-radius:10px;margin:0;padding:10px 12px}.form-status--success{color:#067647;background:#e7f8ef}.form-status--error{color:#b42318;background:#fff1f0}.secondary-button{color:#172033;background:#eef2ff}.language-switcher{grid-auto-flow:column;align-items:center;gap:8px;display:flex}.language-switcher select{min-width:110px;padding:8px 10px}.breadcrumbs{color:#526175;margin-top:8px;font-size:.9rem}.drawer-toggle{margin-bottom:10px;display:none}.mobile-drawer{display:none}@media (width<=900px){.app-shell>.app-sidebar{display:none}.drawer-toggle{display:inline-flex}.mobile-drawer{display:block}.mobile-drawer .app-sidebar{height:auto;display:grid;position:static}}.schedule-toolbar{flex-wrap:wrap;align-items:center;gap:8px;padding:14px 16px;display:flex}.schedule-toolbar>div[role=group]{gap:6px;display:inline-flex}.schedule-toolbar button{color:#172033;background:#eef2ff;padding:8px 14px;font-weight:600}.schedule-toolbar button:hover{background:#e1e8ff}.schedule-toolbar button[aria-pressed=true]{color:#fff;background:#315efb}.schedule-toolbar>span{color:#526175;margin-left:auto;font-size:.9rem;font-weight:600}@media (width<=700px){.schedule-toolbar>span{flex-basis:100%;margin-left:0}}.student-page{gap:20px;display:grid}.student-page__header{justify-content:space-between;align-items:center;gap:16px;display:flex}.dashboard-counters,.dashboard-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;display:grid}.student-filters{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:end}.tabs{flex-wrap:wrap;gap:8px;display:flex}.tabs a,.secondary-link{color:#172033;background:#eef2ff;border-radius:10px;padding:10px 12px;font-weight:700;text-decoration:none}.tabs a[aria-current=page],.tabs button[aria-selected=true]{color:#fff;background:#315efb}.ghost-button{color:#172033;background:#f6f8fc}.danger-button{color:#fff;background:#d92d20}.link-button{color:#315efb;text-align:left;background:0 0;padding:0}.data-table{border-collapse:collapse;background:#fff;border-radius:18px;width:100%;overflow:hidden;box-shadow:0 14px 34px #17203317}.data-table th,.data-table td{text-align:left;vertical-align:top;border-bottom:1px solid #dce4f2;padding:12px}.row-actions{flex-wrap:wrap;gap:8px;display:flex}.confirm-modal{z-index:20;background:#17203373;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.student-form,.student-card-hero{gap:12px;display:grid}@media (width<=700px){.data-table{display:block;overflow-x:auto}.student-page__header{flex-direction:column;align-items:stretch}}.stack-xl{gap:24px;display:grid}.stack-m{gap:16px;display:grid}.stack-sm{gap:8px;display:grid}.page-section{gap:16px;display:grid}.section-heading{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.section-heading h2{margin:0}.filter-group,.filter-bar,.filter-row,.view-toggle{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.filter-chip,.filter-bar>button,.view-toggle>button{color:#172033;background:#eef2ff;padding:8px 14px;font-weight:600}.filter-chip:hover,.filter-bar>button:hover,.view-toggle>button:hover{background:#e1e8ff}.filter-chip--active,.filter-chip[aria-pressed=true],.filter-bar>button.is-active,.filter-bar>button[aria-pressed=true],.view-toggle>button.is-active,.view-toggle>button[aria-pressed=true]{color:#fff;background:#315efb}.details-list{gap:14px;margin:0;display:grid}.details-list>div{gap:2px;display:grid}.details-list dt{color:#526175;font-size:.85rem;font-weight:700}.details-list dd{margin:0;font-weight:600}.activity-list,.report-list,.access-list{gap:12px;margin:0;padding:0;list-style:none;display:grid}.activity-list>li,.report-list>li,.access-list>li{background:#fff;border:1px solid #dce4f2;border-radius:14px;padding:14px 16px}.activity-list>li button,.report-list>li button{margin-top:8px}.report-row{gap:8px;display:grid}.report-row__head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.access-list__row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;display:flex}.access-list__actions{flex-wrap:wrap;gap:8px;display:flex}.pagination{flex-wrap:wrap;align-items:center;gap:12px;margin-top:8px;display:flex}.pagination-caption{color:#526175;font-size:.9rem}.form-field{gap:6px;display:grid}.form-field>span{font-weight:700}.form-check{align-items:center;gap:10px;display:flex}.form-hint,.hint,.form-field .muted{color:#526175;font-size:.9rem;font-weight:400}.muted,.meta,.remaining{color:#526175}.status-message{border-radius:10px;padding:10px 12px}.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}.schedule-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;display:grid}.schedule-grid h3{margin:0 0 8px}.schedule-grid ul{gap:10px;margin:0;padding:0;list-style:none;display:grid}.schedule-lesson{border:1px solid #dce4f2;border-radius:12px;gap:4px;padding:12px;display:grid}.schedule-lesson strong{font-size:1rem}.schedule-lesson>div{flex-wrap:wrap;gap:8px;margin-top:6px;display:flex}.materials-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:16px;margin:0;padding:0;list-style:none;display:grid}.materials-grid__card{background:#fff;border:1px solid #dce4f2;border-radius:16px;gap:8px;padding:18px;display:grid;box-shadow:0 10px 26px #17203312}.materials-grid__subject{color:#526175;text-transform:uppercase;margin:0;font-size:.85rem;font-weight:700}.materials-grid__card .row-actions{margin-top:auto}.materials-controls,.materials-page__controls{flex-wrap:wrap;align-items:end;gap:12px;display:flex}.invite-link-card{gap:10px;display:grid}.invite-link-input{flex:240px;width:auto;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}progress{appearance:none;background:#e8eeff;border:0;border-radius:999px;width:100%;height:8px;overflow:hidden}progress::-webkit-progress-bar{background:#e8eeff;border-radius:999px}progress::-webkit-progress-value{background:#315efb;border-radius:999px}progress::-moz-progress-bar{background:#315efb;border-radius:999px}.storage-meter__body{gap:8px;display:grid}.storage-meter__body p,.storage-meter__remaining{margin:0}.storage-meter__remaining{color:#526175;font-size:.9rem}.storage-meter__error{gap:8px;display:grid}.upload-progress{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.upload-progress progress{flex:160px;width:auto}.upload-progress span{color:#526175;font-size:.9rem}.report-progress{gap:6px;display:grid}.report-progress small,.report-row__meta{color:#526175;font-size:.9rem}.report-row__meta{flex-wrap:wrap;gap:12px;display:flex}.status-badge{white-space:nowrap;border-radius:999px;align-items:center;padding:.15rem .55rem;font-size:.8rem;font-weight:600;line-height:1.4;display:inline-flex}.status-badge--success{color:#067647;background:#e7f8ef}.status-badge--danger{color:#b42318;background:#fff1f0}.status-badge--warning{color:#92400e;background:#fef3c7}.status-badge--info{color:#175cd3;background:#eff8ff}.status-badge--neutral{color:#475467;background:#f2f4f7}.proof-preview,.proof-preview__doc{gap:8px;display:grid}.proof-preview__image{border-radius:12px;max-width:100%;height:auto;max-height:min(70vh,600px);display:block}.proof-preview__pdf{border:1px solid #dce4f2;border-radius:12px;width:100%;height:min(70vh,600px)}.is-danger{background:#fff5f5}tr.is-danger>td{border-top:1px solid #fee4e2;border-bottom:1px solid #fee4e2}section.state-card.is-danger{background:#fff5f5;border-left:3px solid #d92d20}.report-failure{color:#b42318;margin:0;font-size:.9rem}:root{--ui-bg:#f4f6fa;--ui-surface:#fff;--ui-surface-muted:#f8fafc;--ui-text:#111827;--ui-muted:#5f6b7a;--ui-border:#d9e1ec;--ui-border-strong:#c4cfdd;--ui-primary:#2563eb;--ui-primary-hover:#1d4ed8;--ui-primary-soft:#eef4ff;--ui-danger:#d92d20;--ui-danger-hover:#b42318;--ui-focus:#93c5fd;--ui-shadow-sm:0 1px 2px #1018280d}body{background:var(--ui-bg);color:var(--ui-text);font-size:15px;line-height:1.5}button,.secondary-link,.tabs a{border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;min-height:36px;padding:8px 12px;transition:background-color .12s,border-color .12s,color .12s,box-shadow .12s;display:inline-flex}button{background:var(--ui-primary);box-shadow:none;color:#fff;font-weight:650}button:hover:not(:disabled){background:var(--ui-primary-hover)}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--ui-focus);outline-offset:2px}input,select,textarea{border-color:var(--ui-border-strong);color:var(--ui-text);background:#fff;border-radius:8px;min-height:38px;padding:8px 10px}textarea{resize:vertical;min-height:96px}label,.form-field>span{color:var(--ui-text);font-size:.92rem;font-weight:650}.form-grid{gap:14px}form.form-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));align-items:start}.form-grid label{align-items:stretch;gap:6px;display:grid}.form-check{color:var(--ui-text);flex-direction:row;align-items:center;gap:9px;display:flex}.form-grid label:has(>input[type=checkbox]){color:var(--ui-text);flex-direction:row;align-items:center;gap:9px;display:flex}.form-grid label:has(>input[type=radio]){color:var(--ui-text);flex-direction:row;align-items:center;gap:9px;display:flex}label:has(>input[type=checkbox]){color:var(--ui-text);flex-direction:row;align-items:center;gap:9px;display:flex}label:has(>input[type=radio]){color:var(--ui-text);flex-direction:row;align-items:center;gap:9px;display:flex}fieldset{border:1px solid var(--ui-border);border-radius:8px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px;margin:0;padding:12px;display:grid}legend{color:var(--ui-text);padding:0 6px;font-size:.92rem;font-weight:700}form.form-grid>fieldset,form.form-grid>p,form.form-grid>.field-error,form.form-grid>.form-status,form.form-grid>.status-message{grid-column:1/-1}form.form-grid>label:has(textarea){grid-column:1/-1}form.form-grid>label:has(input[type=file]){grid-column:1/-1}form.form-grid>button{justify-self:start}.page-card{border:1px solid var(--ui-border);box-shadow:var(--ui-shadow-sm);border-radius:10px}.app-shell{background:var(--ui-bg);grid-template-columns:252px minmax(0,1fr)}.app-sidebar{background:#111827;gap:20px;padding:20px 16px}.app-sidebar__brand{letter-spacing:0;border-bottom:1px solid #ffffff1a;padding:4px 8px 16px;font-size:1rem}.app-sidebar nav{gap:4px}.app-sidebar a{color:#d1d5db;border-radius:8px;gap:10px;min-height:40px;padding:9px 10px}.app-sidebar a:hover{color:#fff;background:#1f2937}.app-sidebar a[aria-current=page]{box-shadow:var(--ui-shadow-sm);color:#111827;background:#fff}.app-topbar{border-bottom-color:var(--ui-border);background:#ffffffeb;gap:12px 20px;padding:16px clamp(16px,3vw,32px)}.app-topbar h1{color:var(--ui-text);font-size:clamp(1.35rem,2vw,1.75rem);line-height:1.2}.app-topbar__eyebrow,.breadcrumbs,.app-topbar__actions,.form-hint,.hint,.muted,.meta,.remaining,.pagination-caption,.details-list dt{color:var(--ui-muted)}.app-topbar__actions{gap:8px}.language-switcher select{min-height:34px}.app-content{width:min(1180px,100%);padding:24px clamp(16px,3vw,32px) 48px}.student-page,.route-stub,.stack-xl{gap:18px}.route-stub__hero.student-page__header{box-shadow:none;background:0 0;border:0;padding:0}.route-stub__hero.student-page__header h2{margin:0;font-size:1.35rem;line-height:1.25}.route-stub__hero.student-page__header p{color:var(--ui-muted);max-width:72ch;margin:4px 0 0}.route-stub__hero,.state-card,.page-section{background:var(--ui-surface);border:1px solid var(--ui-border);box-shadow:var(--ui-shadow-sm);border-radius:8px;padding:16px}.state-card{gap:10px}.state-card h2,.state-card h3,.page-section h2,.page-section h3{color:var(--ui-text);margin:0;line-height:1.25}.state-card p,.page-section p{margin-bottom:0}.state-card__icon{color:#0f766e;background:#e8f5f3;border-radius:8px;width:36px;height:36px}.secondary-button,.ghost-button,.secondary-link{border-color:var(--ui-border-strong);color:var(--ui-text);background:#fff;font-weight:650}.secondary-button:hover:not(:disabled),.ghost-button:hover:not(:disabled),.secondary-link:hover{background:var(--ui-surface-muted);color:var(--ui-text);border-color:#aeb9c8}.danger-button{color:var(--ui-danger);background:#fff;border-color:#fecdca}.danger-button:hover:not(:disabled){color:var(--ui-danger-hover);background:#fff5f5;border-color:#fda29b}.link-button{color:var(--ui-primary);background:0 0;border:0;justify-content:flex-start;min-height:0;padding:0}.link-button:hover:not(:disabled){color:var(--ui-primary-hover);background:0 0;text-decoration:underline}.filter-bar,.view-toggle{background:#e8edf5;border-radius:8px;align-items:center;gap:4px;width:fit-content;padding:4px;display:flex}.filter-bar>button,.view-toggle>button,.filter-chip{color:#3f4b5c;background:0 0;border:0;min-height:32px;padding:6px 10px}.filter-chip:hover,.filter-bar>button:hover,.view-toggle>button:hover{color:var(--ui-text);background:#ffffffb3}.filter-chip--active,.filter-chip[aria-pressed=true],.filter-bar>button.is-active,.filter-bar>button[aria-pressed=true],.view-toggle>button.is-active,.view-toggle>button[aria-pressed=true]{box-shadow:var(--ui-shadow-sm);color:var(--ui-text);background:#fff}.tabs{background:#e8edf5;border-radius:8px;gap:4px;width:fit-content;padding:4px;overflow-x:auto}.tabs a,.tabs button{color:#3f4b5c;background:0 0;border:0;min-height:32px;padding:6px 10px;text-decoration:none}.tabs a[aria-current=page],.tabs button[aria-selected=true]{box-shadow:var(--ui-shadow-sm);color:var(--ui-text);background:#fff}.data-table{border:1px solid var(--ui-border);border-collapse:separate;border-spacing:0;box-shadow:none;background:#fff;border-radius:8px;overflow:hidden}.data-table th,.data-table td{border-bottom:1px solid var(--ui-border);padding:10px 12px}.data-table th{background:var(--ui-surface-muted);color:#475467;letter-spacing:0;text-transform:uppercase;font-size:.78rem;font-weight:750}.data-table tbody tr:hover{background:#fbfcff}.data-table tbody tr:last-child td{border-bottom:0}.data-table td:first-child{color:var(--ui-text);font-weight:650}.row-actions{gap:6px}.row-actions label{min-width:190px}.status-badge{border:1px solid #0000;border-radius:999px;gap:6px;padding:.16rem .55rem;font-size:.76rem;font-weight:700}.status-badge:before{content:"";opacity:.85;background:currentColor;border-radius:999px;width:6px;height:6px}.status-badge--success{color:#067647;background:#ecfdf3;border-color:#abefc6}.status-badge--danger{color:#b42318;background:#fff1f0;border-color:#fecdca}.status-badge--warning{color:#b54708;background:#fffaeb;border-color:#fedf89}.status-badge--info{color:#175cd3;background:#eff8ff;border-color:#b2ddff}.status-badge--neutral{color:#475467;background:#f8fafc;border-color:#d0d5dd}.dashboard-counters,.dashboard-grid{gap:12px}.dashboard-counters .state-card{align-content:center;min-height:96px}.dashboard-counters strong{color:var(--ui-text);font-size:2rem;line-height:1}.dashboard-counters span,.dashboard-grid p,.state-card small{color:var(--ui-muted)}.activity-list>li,.report-list>li,.access-list>li,.materials-grid__card,.schedule-lesson{border-color:var(--ui-border);box-shadow:none;border-radius:8px}.form-status,.status-message{border:1px solid #0000;border-radius:8px}.form-status--success,.status-message--success{border-color:#abefc6}.form-status--error,.status-message--error{border-color:#fecdca}section.state-card.is-danger,.is-danger{background:#fff8f7}section.state-card.is-danger{border-left-color:var(--ui-danger)}.confirm-modal{background:#11182785}.confirm-modal .state-card{width:100%;max-width:min(520px,100vw - 32px)}@media (width<=900px){.app-shell{grid-template-columns:1fr}.app-sidebar{padding:16px}.app-content{padding-top:20px}.filter-bar,.view-toggle,.tabs{width:100%}}@media (width<=700px){button,.secondary-link,.tabs a{min-height:38px}.page-section,.state-card{padding:14px}.data-table{border-radius:8px}}
