:root{--color-smart-red: #C3312F;--color-learning-purple: #92278F;--color-brain-teal: #2EBCCB;--color-sky-blue: #3298CC;--color-growth-lime: #9ACD3D;--color-spark-yellow: #FFD33D;--color-charcoal: #343838;--color-deep-plum: #6E2144;--color-page-soft: #F6F8FB;--color-surface: #ffffff;--color-border: #dbe4ee;--color-border-strong: #b9c7d8;--color-muted: #667085;--color-danger-soft: #fff1f0;--color-teal-soft: #e9fbfd;--color-purple-soft: #f7eef7;--color-yellow-soft: #fff8d8;--color-shadow: rgba(52, 56, 56, .12);--font-sans: Inter, Arial, "Noto Sans Devanagari", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--text-xs: 11px;--text-sm: 13px;--text-base: 15px;--text-md: 17px;--text-lg: 20px;--text-xl: 24px;--text-2xl: 30px;--text-3xl: 38px;--text-proj: 48px;--text-proj-xl: 56px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-input: 10px;--radius-card: 16px;font-family:var(--font-sans);color:var(--color-charcoal);background:var(--color-page-soft)}*{box-sizing:border-box}html{min-width:320px;background:var(--color-page-soft)}body{margin:0;min-width:320px;color:var(--color-charcoal);background:var(--color-page-soft);font-size:var(--text-base);line-height:1.5;text-rendering:optimizeLegibility}a{color:inherit;text-decoration:none}button,input,textarea,select{font:inherit}button,a,input{transition:border-color .16s ease,box-shadow .16s ease,background-color .16s ease,transform .16s ease}button:focus-visible,a:focus-visible,input:focus-visible{outline:3px solid rgba(46,188,203,.45);outline-offset:3px}.primary-action,.secondary-action{min-height:44px;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-5);border-radius:var(--radius-input);font-weight:700;letter-spacing:0;cursor:pointer}.primary-action{border:1px solid var(--color-smart-red);background:var(--color-smart-red);color:var(--color-surface)}.primary-action:disabled{cursor:wait;opacity:.75}.secondary-action{border:1px solid var(--color-border-strong);background:var(--color-surface);color:var(--color-charcoal)}.eyebrow{margin:0 0 var(--space-2);color:var(--color-smart-red);font-size:var(--text-sm);font-weight:700;letter-spacing:0}h1{margin:0 0 var(--space-4);color:var(--color-charcoal);font-size:var(--text-2xl);font-weight:700;line-height:1.15;letter-spacing:0}p{margin:0;color:var(--color-muted);line-height:1.6}.auth-page{width:100%;min-height:100vh;display:grid;grid-template-columns:1fr;align-content:start;gap:var(--space-4);overflow-x:hidden;padding:var(--space-4);background:linear-gradient(180deg,#2ebccb1f,#f6f8fb00 220px),var(--color-page-soft)}.auth-visual{width:min(100%,560px);display:grid;gap:var(--space-3);justify-self:center;padding:var(--space-2) 0 0}.auth-brand{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-deep-plum);font-size:var(--text-base);font-weight:800}.auth-brand__mark{width:38px;height:38px;display:grid;flex:0 0 auto;place-items:center;border-radius:10px;background:var(--color-learning-purple);color:var(--color-surface);font-size:var(--text-sm)}.auth-visual h1{max-width:420px;margin:0;font-size:var(--text-xl)}.auth-visual p{max-width:440px;color:var(--color-charcoal);font-size:var(--text-base)}.auth-panel{width:min(100%,560px);justify-self:center}.auth-tabs{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-2);margin-bottom:var(--space-5);padding:var(--space-2);border:1px solid var(--color-border);border-radius:14px;background:#ffffffdb;box-shadow:0 12px 28px #34383814}.auth-tabs--single{grid-template-columns:1fr;padding:8px}.auth-tab{min-width:0;min-height:48px;display:inline-flex;align-items:center;justify-content:center;padding:0 var(--space-4);border:1px solid transparent;border-radius:10px;color:var(--color-muted);font-size:var(--text-sm);font-weight:800;text-align:center;white-space:nowrap;transition:background .16s ease,border-color .16s ease,box-shadow .16s ease,color .16s ease,transform .16s ease}.auth-tabs--single .auth-tab{justify-content:flex-start;padding-inline:var(--space-5);min-height:50px}.auth-tab:hover{background:var(--color-teal-soft);color:var(--color-charcoal)}.auth-tab--active,.auth-tab[aria-current=page]{border-color:#c3312f2e;background:var(--color-smart-red);color:var(--color-surface);box-shadow:0 8px 18px #c3312f2e;transform:translateY(-1px)}.login-form{width:100%;display:grid;gap:var(--space-4);padding:var(--space-5);border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);box-shadow:0 18px 44px #3438381c}.form-heading{display:grid;gap:var(--space-2)}.form-heading .eyebrow{display:none}.form-heading h2{margin:0;color:var(--color-charcoal);font-size:var(--text-xl);line-height:1.15}.form-heading p{font-size:var(--text-sm)}.field{display:grid;gap:var(--space-2);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:800}.input-control{position:relative;display:block}.field input{width:100%;min-height:48px;padding:0 var(--space-4);border:1px solid var(--color-border-strong);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-charcoal);font-size:16px;font-weight:600}.input-control--password input{padding-right:58px}.password-toggle{position:absolute;top:50%;right:var(--space-2);width:40px;height:34px;display:inline-grid;place-items:center;padding:0;border:1px solid var(--color-border);border-radius:8px;background:var(--color-page-soft);color:var(--color-deep-plum);cursor:pointer;transform:translateY(-50%);transition:background .16s ease,border-color .16s ease,color .16s ease,transform .16s ease,box-shadow .16s ease}.password-toggle:hover{border-color:var(--color-brain-teal);background:var(--color-teal-soft);color:var(--color-charcoal)}.password-toggle:active{transform:translateY(-50%) scale(.94)}.password-toggle__icon{display:block;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}.password-toggle__eye,.password-toggle__pupil,.password-toggle__slash{transition:opacity .16s ease,transform .16s ease,stroke-dashoffset .18s ease;transform-origin:center}.password-toggle__slash{stroke-dasharray:22;stroke-dashoffset:0;opacity:1}.password-toggle__slash[data-visible=true]{stroke-dashoffset:22;opacity:0}.password-toggle[aria-pressed=true] .password-toggle__pupil{transform:scale(1.08)}.field input[inputmode=numeric]{letter-spacing:.05em}.field input:focus,.password-toggle:focus-visible{border-color:var(--color-brain-teal);box-shadow:0 0 0 3px #2ebccb2e;outline:0}.checkbox-field{display:flex;align-items:flex-start;gap:var(--space-3);color:var(--color-charcoal);cursor:pointer;font-size:var(--text-sm)}.checkbox-field input{width:18px;height:18px;flex:0 0 auto;margin:3px 0 0;accent-color:var(--color-smart-red)}.checkbox-field span{display:grid;gap:2px}.checkbox-field strong{font-weight:800}.checkbox-field small{color:var(--color-muted);font-size:var(--text-xs);line-height:1.45}.form-error,.form-note{padding:var(--space-3) var(--space-4);border-radius:var(--radius-input);font-size:var(--text-sm);font-weight:700}.form-error{border:1px solid rgba(195,49,47,.25);background:var(--color-danger-soft);color:var(--color-smart-red)}.form-note{border:1px solid rgba(46,188,203,.26);background:var(--color-teal-soft);color:var(--color-charcoal)}.login-form .primary-action{width:100%;min-height:48px}.auth-helper{margin-top:var(--space-4);text-align:center;font-size:var(--text-sm)}.auth-helper a{color:var(--color-deep-plum);font-weight:800}.google-signin{margin-top:var(--space-4);display:flex;flex-direction:column;align-items:center;gap:var(--space-3)}.google-signin__divider{width:100%;display:flex;align-items:center;gap:var(--space-3);color:var(--color-ink-soft, #6b6577);font-size:var(--text-sm)}.google-signin__divider:before,.google-signin__divider:after{content:"";flex:1;height:1px;background:var(--color-border, #e3e0e8)}.google-signin__button{display:flex;justify-content:center;min-height:40px}.dashboard-shell{min-height:100vh;padding:var(--space-8);background:var(--color-page-soft)}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin:0 auto var(--space-6);max-width:1100px}.dashboard-header h1{font-size:var(--text-2xl)}.dashboard-summary{max-width:1100px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-4);margin:0 auto}.dashboard-summary div,.linked-child{min-width:0;padding:var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-surface)}.dashboard-summary dt{margin-bottom:var(--space-1);color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.dashboard-summary dd{margin:0;overflow-wrap:anywhere;color:var(--color-charcoal);font-weight:700}.linked-child-list{max-width:1100px;display:grid;gap:var(--space-3);margin:var(--space-6) auto 0}.linked-child-list h2{margin:0;font-size:var(--text-lg)}.linked-child{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.dashboard-header__actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.setup-shell{min-height:100vh;background:var(--color-page-soft)}.setup-topbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border);background:var(--color-surface)}.setup-topbar__brand{display:flex;align-items:center;gap:var(--space-3)}.setup-topbar__brand strong{display:block;color:var(--color-deep-plum);font-size:var(--text-md)}.setup-topbar__sub{color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.setup-topbar__actions{display:flex;gap:var(--space-2)}.setup-topbar__actions .secondary-action{min-height:38px;padding:0 var(--space-4)}.setup-body{display:grid;grid-template-columns:1fr;gap:var(--space-4);max-width:1180px;margin:0 auto;padding:var(--space-5) var(--space-4)}.setup-nav{display:flex;flex-wrap:wrap;gap:var(--space-2)}.setup-nav__link{min-height:40px;display:inline-flex;align-items:center;padding:0 var(--space-4);border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:800}.setup-nav__link:hover{background:var(--color-teal-soft)}.setup-nav__link--active,.setup-nav__link[aria-current=page]{border-color:#92278f40;background:var(--color-learning-purple);color:var(--color-surface)}.setup-content{display:grid;gap:var(--space-5);min-width:0}.setup-page__header h1{margin-bottom:var(--space-1);font-size:var(--text-xl)}.setup-page__header p{font-size:var(--text-sm)}.setup-note{color:var(--color-muted);font-size:var(--text-sm)}.setup-form{display:grid;gap:var(--space-4);padding:var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:0 12px 30px #34383812}.setup-form h2{margin:0;font-size:var(--text-md)}.setup-form__grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.setup-field{display:grid;gap:var(--space-2);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:800}.setup-field input,.setup-field select{width:100%;min-height:44px;padding:0 var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-charcoal);font-size:16px;font-weight:600}.setup-field input:focus,.setup-field select:focus{border-color:var(--color-brain-teal);box-shadow:0 0 0 3px #2ebccb2e;outline:0}.setup-hint{color:var(--color-muted);font-size:var(--text-xs);font-weight:600}.setup-checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:800}.setup-checkbox input{width:18px;height:18px;accent-color:var(--color-smart-red)}.setup-form .primary-action{justify-self:start;min-width:180px}.setup-table{width:100%;border-collapse:collapse;border:1px solid var(--color-border);border-radius:var(--radius-card);overflow:hidden;background:var(--color-surface);font-size:var(--text-sm)}.setup-table th,.setup-table td{padding:var(--space-3) var(--space-4);text-align:left;border-bottom:1px solid var(--color-border);vertical-align:middle}.setup-table th{background:var(--color-page-soft);color:var(--color-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em}.setup-table tbody tr:last-child td{border-bottom:0}.setup-table__mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:var(--text-xs);color:var(--color-muted);overflow-wrap:anywhere}.setup-table__actions{display:flex;flex-wrap:wrap;gap:var(--space-2)}.setup-table__actions .secondary-action{min-height:36px;padding:0 var(--space-3)}.setup-danger{min-height:36px;padding:0 var(--space-3);border:1px solid rgba(195,49,47,.4);border-radius:var(--radius-input);background:var(--color-danger-soft);color:var(--color-smart-red);font-weight:800;cursor:pointer}.setup-danger:disabled{opacity:.6;cursor:not-allowed}.setup-badge{display:inline-flex;align-items:center;padding:2px var(--space-2);border-radius:999px;font-size:var(--text-xs);font-weight:800}.setup-badge--ok{background:#9acd3d33;color:#4a6b00}.setup-badge--muted{background:var(--color-page-soft);color:var(--color-muted)}.setup-state{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);border:1px dashed var(--color-border-strong);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.setup-state--error{border-style:solid;border-color:#c3312f4d;background:var(--color-danger-soft);color:var(--color-smart-red)}.setup-state--empty{justify-content:center;text-align:center}.setup-state--denied{flex-direction:column;align-items:flex-start;gap:var(--space-1);border-color:#c3312f4d;background:var(--color-danger-soft);color:var(--color-smart-red)}.setup-spinner{width:18px;height:18px;border-radius:50%;border:3px solid rgba(46,188,203,.3);border-top-color:var(--color-brain-teal);animation:setup-spin .8s linear infinite}@keyframes setup-spin{to{transform:rotate(360deg)}}@media(prefers-reduced-motion:reduce){.setup-spinner{animation-duration:0s}}@media(min-width:768px){.setup-form__grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(min-width:768px){.auth-page{align-content:center;padding:var(--space-8)}.auth-visual{text-align:center}.auth-brand{justify-content:center}.auth-visual h1,.auth-visual p{margin-inline:auto}.auth-tabs{grid-template-columns:repeat(4,minmax(0,1fr))}.login-form{padding:var(--space-8)}}@media(min-width:1100px){.auth-page{grid-template-columns:minmax(360px,460px) minmax(460px,560px);align-content:center;justify-content:center;align-items:center;column-gap:clamp(56px,7vw,112px);padding:var(--space-8)}.auth-visual{justify-self:end;text-align:left;padding:var(--space-10);border:1px solid rgba(46,188,203,.22);border-radius:18px;background:linear-gradient(135deg,#2ebccb29,#ffd33d33),var(--color-surface);box-shadow:0 20px 48px #34383814}.auth-brand{justify-content:flex-start}.auth-visual h1,.auth-visual p{margin-inline:0}.auth-visual h1{font-size:var(--text-3xl)}.auth-panel{justify-self:start}}@media(max-width:767px){h1{font-size:var(--text-xl)}.auth-page{padding:var(--space-4)}.login-form{padding:var(--space-5)}.dashboard-shell{padding:var(--space-4)}.dashboard-header{display:grid}.dashboard-summary{grid-template-columns:1fr}}html[data-theme=dark]{--color-charcoal: #e7ebf0;--color-deep-plum: #f0c6da;--color-page-soft: #0f141b;--color-surface: #1a212b;--color-border: #2b3543;--color-border-strong: #3a4658;--color-muted: #9aa7b8;--color-shadow: rgba(0, 0, 0, .5);--color-danger-soft: #3a1f1f;--color-teal-soft: #10303400;--color-purple-soft: #2a1c2a;--color-yellow-soft: #2e2a12;--color-info-text: #8fd6df;color-scheme:dark}html[data-theme=dark] body{background:var(--color-page-soft);color:var(--color-charcoal)}html[data-theme=dark] .app-sidebar{background:linear-gradient(180deg,#161d26,#1a212b)}html[data-theme=dark] .app-topbar{background:#141a22d1}html[data-theme=dark] .app-shell{background:radial-gradient(1200px 480px at 100% -10%,rgba(46,188,203,.1),transparent 60%),radial-gradient(1000px 420px at -10% 0%,rgba(146,39,143,.1),transparent 55%),var(--color-page-soft)}html[data-theme=dark] .card,html[data-theme=dark] .kpi-card,html[data-theme=dark] .modal,html[data-theme=dark] .live-score-card,html[data-theme=dark] .projector-score,html[data-theme=dark] .lobby-tile,html[data-theme=dark] .game-card,html[data-theme=dark] .group-column,html[data-theme=dark] .game-icon-btn,html[data-theme=dark] .rules-row{background:var(--color-surface);color:var(--color-charcoal)}html[data-theme=dark] input,html[data-theme=dark] select,html[data-theme=dark] textarea{background:#11171f;color:var(--color-charcoal);border-color:var(--color-border)}html[data-theme=dark] .dash{background:var(--color-page-soft)}html[data-theme=dark] .projector-page{background:var(--color-page-soft);color:var(--color-charcoal)}.theme-toggle{display:inline-flex;align-items:center;gap:var(--space-2);width:100%;min-height:40px;padding:0 var(--space-3);border:0;border-radius:8px;background:transparent;color:var(--color-charcoal);font:inherit;font-weight:700;text-align:left;cursor:pointer}.theme-toggle:hover{background:var(--color-page-soft)}.dash-theme-toggle{width:auto;min-height:40px;padding:0 var(--space-4);border:1px solid var(--color-border-strong);border-radius:999px;background:var(--color-surface)}.dash-theme-toggle:hover{border-color:var(--color-learning-purple);background:var(--color-surface)}html[data-theme=dark] .data-table thead th{background:#141a22;color:var(--color-muted)}html[data-theme=dark] .data-table tbody tr:nth-child(2n){background:#ffffff08}html[data-theme=dark] .data-table tbody tr:hover{background:#2ebccb1f}html[data-theme=dark] .data-table th,html[data-theme=dark] .data-table td{border-bottom-color:var(--color-border);color:var(--color-charcoal)}html[data-theme=dark] .input,html[data-theme=dark] .field__input,html[data-theme=dark] input,html[data-theme=dark] select,html[data-theme=dark] textarea{background:#11171f;color:var(--color-charcoal);border-color:var(--color-border-strong)}html[data-theme=dark] input::placeholder,html[data-theme=dark] textarea::placeholder{color:#6b7787}html[data-theme=dark] .field__label{color:var(--color-charcoal)}html[data-theme=dark] .field__hint{color:var(--color-muted)}html[data-theme=dark] .btn--secondary{background:#222b37;color:var(--color-charcoal);border-color:var(--color-border-strong)}html[data-theme=dark] .btn--ghost{color:var(--color-charcoal)}html[data-theme=dark] .board-author-steps__item{background:var(--color-surface);color:var(--color-charcoal)}html[data-theme=dark] .board-author-steps__item--active{background:#92278f38}html[data-theme=dark] .subst-panel,html[data-theme=dark] .table-wrap,html[data-theme=dark] .table-foot,html[data-theme=dark] .tt-view-table-wrap,html[data-theme=dark] .profile-dropdown,html[data-theme=dark] .year-switch__menu,html[data-theme=dark] .icon-btn,html[data-theme=dark] .profile-btn,html[data-theme=dark] .live-projector-panel,html[data-theme=dark] .projector-turn,html[data-theme=dark] .projector-roll,html[data-theme=dark] .projector-actions,html[data-theme=dark] .projector-sidebar h2,html[data-theme=dark] .game-store-card,html[data-theme=dark] .token-mode-card,html[data-theme=dark] .group-section-chip,html[data-theme=dark] .group-setup__controls,html[data-theme=dark] .live-dice-panel{background:var(--color-surface);color:var(--color-charcoal)}html[data-theme=dark] .notice-success{background:#12352a;color:#b6f0d4}html[data-theme=dark] .form-banner{background:#3a1f1f;color:#ffc9c9}html[data-theme=dark] .projector-board,html[data-theme=dark] .live-board{background:#0f141b}.app-topbar__search-clear{border:0;background:transparent;color:var(--color-muted);font-size:var(--text-lg);line-height:1;cursor:pointer;padding:0 var(--space-1)}html[data-theme=dark]{--color-success-bg: #143626;--color-success-text: #57e3a0;--color-warning-bg: #3a2f12;--color-warning-text: #ffd66b;--color-info-bg: #10303a;--color-info-text: #6fd2e6;--color-purple-bg: #2c1c3a;--color-purple-text: #d9a7f5}html[data-theme=dark] input{color-scheme:dark}html[data-theme=dark] .tab-nav__link,html[data-theme=dark] .tab-nav a{color:var(--color-charcoal)}html[data-theme=dark] .data-table__actions button,html[data-theme=dark] .live-icon-button{background:#222b37;border-color:var(--color-border-strong);color:var(--color-charcoal)}.search-no-results{padding:var(--space-4);color:var(--color-muted);font-weight:700}.settings-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.settings-info__item{display:grid;gap:4px;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:12px;background:var(--color-page-soft)}.settings-info__item span{font-size:var(--text-xs);font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted)}.settings-info__item strong{font-size:var(--text-md);color:var(--color-charcoal);word-break:break-word}:root{--color-success-text: #4a6b00;--color-success-bg: rgba(154, 205, 61, .18);--color-warning-text: #8a6d00;--color-warning-bg: rgba(255, 211, 61, .22);--color-info-text: #0f6c78;--color-info-bg: var(--color-teal-soft);--color-purple-text: var(--color-learning-purple);--color-purple-bg: rgba(146, 39, 143, .12);--shadow-sm: 0 1px 2px rgba(52, 56, 56, .06), 0 1px 3px rgba(52, 56, 56, .08);--shadow-md: 0 8px 24px rgba(52, 56, 56, .08);--shadow-lg: 0 18px 44px rgba(52, 56, 56, .12);--sidebar-width: 264px;--topbar-height: 66px;--content-max: 1280px;--radius-pill: 999px}.btn{position:relative;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);min-height:44px;padding:0 var(--space-5);border:1px solid transparent;border-radius:var(--radius-input);background:transparent;color:var(--color-charcoal);font-size:var(--text-base);font-weight:700;line-height:1;white-space:nowrap;cursor:pointer;text-decoration:none}.btn:disabled,.btn[aria-disabled=true]{opacity:.6;cursor:not-allowed}.btn--sm{min-height:36px;padding:0 var(--space-3);font-size:var(--text-sm)}.btn--block{width:100%}.btn--primary{border-color:var(--color-smart-red);background:var(--color-smart-red);color:#fff}.btn--primary:hover:not(:disabled){background:#ad2b29}.btn--secondary{border-color:var(--color-border-strong);background:var(--color-surface);color:var(--color-charcoal)}.btn--secondary:hover:not(:disabled){border-color:var(--color-sky-blue);color:var(--color-sky-blue)}.btn--success{border-color:#7bb024;background:var(--color-growth-lime);color:#21340a}.btn--success:hover:not(:disabled){background:#8dc132}.btn--warning{border-color:#e6bd1f;background:var(--color-spark-yellow);color:var(--color-charcoal)}.btn--ghost{border-color:transparent;background:transparent;color:var(--color-muted)}.btn--ghost:hover:not(:disabled){background:var(--color-page-soft);color:var(--color-charcoal)}.btn--danger{border-color:#c3312f66;background:var(--color-danger-soft);color:var(--color-smart-red)}.btn--danger:hover:not(:disabled){border-color:var(--color-smart-red)}.btn--icon{min-width:38px;padding:0 var(--space-2)}.btn__spinner{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.45);border-top-color:currentColor;animation:ui-spin .7s linear infinite}.btn--secondary .btn__spinner,.btn--ghost .btn__spinner,.btn--danger .btn__spinner{border-color:#34383840;border-top-color:currentColor}.ui-spinner{display:inline-block;width:22px;height:22px;border-radius:50%;border:3px solid rgba(46,188,203,.3);border-top-color:var(--color-brain-teal);animation:ui-spin .8s linear infinite}@keyframes ui-spin{to{transform:rotate(360deg)}}.card{position:relative;display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-sm);overflow:hidden}.card--accent:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--card-accent, var(--color-brain-teal))}.card--accent{padding-top:4px}.card__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);padding:var(--space-5) var(--space-6) 0}.card__heading{display:flex;align-items:center;gap:var(--space-3)}.card__icon{width:40px;height:40px;display:grid;place-items:center;flex:0 0 auto;border-radius:12px;background:var(--color-purple-soft);color:var(--color-learning-purple)}.card__title{margin:0;font-size:var(--text-md);font-weight:700;color:var(--color-charcoal)}.card__subtitle{margin:2px 0 0;font-size:var(--text-sm);color:var(--color-muted)}.card__body{padding:var(--space-5) var(--space-6) var(--space-6)}.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.kpi-card{position:relative;padding:var(--space-5);padding-top:calc(var(--space-5) + 4px);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-sm);overflow:hidden}.kpi-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:var(--kpi-accent, var(--color-brain-teal))}.kpi-card__label{margin:0 0 var(--space-2);font-size:var(--text-xs);font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted)}.kpi-card__value{font-size:var(--text-2xl);font-weight:800;color:var(--color-charcoal);overflow-wrap:anywhere}.kpi-card__hint{margin-top:var(--space-1);font-size:var(--text-sm);color:var(--color-muted)}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px var(--space-2);border-radius:var(--radius-pill);font-size:var(--text-xs);font-weight:800;line-height:1.4}.badge--neutral{background:var(--color-page-soft);color:var(--color-muted)}.badge--success{background:var(--color-success-bg);color:var(--color-success-text)}.badge--warning{background:var(--color-warning-bg);color:var(--color-warning-text)}.badge--danger{background:var(--color-danger-soft);color:var(--color-smart-red)}.badge--info{background:var(--color-info-bg);color:var(--color-info-text)}.badge--purple{background:var(--color-purple-bg);color:var(--color-purple-text)}.tabs{display:flex;gap:var(--space-1);padding:var(--space-1);border:1px solid var(--color-border);border-radius:14px;background:var(--color-surface);box-shadow:var(--shadow-sm);overflow-x:auto;scrollbar-width:thin}.tabs__tab{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);min-height:40px;padding:0 var(--space-4);border:none;border-radius:10px;background:transparent;color:var(--color-muted);font-size:var(--text-sm);font-weight:800;white-space:nowrap;cursor:pointer}.tabs__tab:hover{background:var(--color-page-soft);color:var(--color-charcoal)}.tabs__tab--active,.tabs__tab[aria-current=page]{background:var(--color-learning-purple);color:#fff}.tabs__tab--disabled{opacity:.5;cursor:not-allowed}.field{display:grid;gap:var(--space-2);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700}.field__label{display:inline-flex;align-items:center;gap:4px}.field__req{color:var(--color-smart-red)}.field__control,.field__control select,.field__control input{width:100%}.field input,.field select,.field textarea{width:100%;min-height:46px;padding:0 var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-charcoal);font-size:16px;font-weight:600}.field select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--color-muted) 50%),linear-gradient(135deg,var(--color-muted) 50%,transparent 50%);background-position:calc(100% - 18px) center,calc(100% - 13px) center;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:var(--space-8)}.field input::placeholder{color:#98a2b3}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--color-brain-teal);box-shadow:0 0 0 3px #2ebccb2e;outline:0}.field--error input,.field--error select{border-color:var(--color-smart-red)}.field__hint{font-size:var(--text-xs);font-weight:600;color:var(--color-muted)}.field__error{font-size:var(--text-xs);font-weight:700;color:var(--color-smart-red)}.checkbox{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);font-weight:700;cursor:pointer}.checkbox input{width:18px;height:18px;accent-color:var(--color-smart-red)}.checkbox-group{display:flex;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-2) 0}.map-block{margin-top:var(--space-5);padding:var(--space-4);border:1px dashed var(--color-border-strong);border-radius:var(--radius-card);background:var(--color-page-soft)}.map-block__title{margin:0 0 var(--space-3);font-size:var(--text-sm);font-weight:800;letter-spacing:.02em;text-transform:uppercase;color:var(--color-muted)}.map-grades{display:grid;gap:var(--space-3);margin-top:var(--space-3)}.map-picker{display:grid;gap:var(--space-4);margin-top:var(--space-3)}.map-picker__row{display:grid;grid-template-columns:120px 1fr;gap:var(--space-3);align-items:start}.map-picker__label{font-size:var(--text-sm);font-weight:800;color:var(--color-muted);padding-top:6px}.map-checklist{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-2) var(--space-4)}@media(max-width:640px){.map-picker__row{grid-template-columns:1fr;gap:var(--space-2)}}.map-note{margin:0;padding:var(--space-2) var(--space-3);border-radius:var(--radius-input);background:var(--color-teal-soft);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700}.map-note--muted{background:var(--color-surface);color:var(--color-muted)}.multiselect{position:relative}.multiselect__btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:46px;padding:0 var(--space-3);border:1px solid var(--color-border-strong);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-charcoal);font-size:15px;font-weight:600;cursor:pointer;text-align:left}.multiselect__btn:hover{border-color:var(--color-brain-teal)}.multiselect__btn[aria-expanded=true]{border-color:var(--color-brain-teal);box-shadow:0 0 0 3px #2ebccb2e}.multiselect__menu{position:absolute;left:0;right:0;top:calc(100% + 6px);max-height:260px;overflow-y:auto;z-index:30;padding:var(--space-3);border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-lg);display:grid;gap:var(--space-2)}.multiselect__chips{display:flex;flex-wrap:wrap;gap:var(--space-2);margin-top:var(--space-2)}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px var(--space-2);border-radius:var(--radius-pill);background:var(--color-purple-soft);color:var(--color-learning-purple);font-size:var(--text-xs);font-weight:800}.chip button{border:0;background:transparent;color:inherit;cursor:pointer;font-size:14px;line-height:1;padding:0}.chip-list{display:flex;flex-wrap:wrap;gap:6px}.notice-success{margin-top:var(--space-3);padding:var(--space-3) var(--space-4);border-radius:var(--radius-input);border:1px solid rgba(154,205,61,.45);background:var(--color-success-bg);color:var(--color-success-text);font-size:var(--text-sm);font-weight:700}.notice-success code,.result-list code{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-weight:800}.result-list{display:grid;gap:var(--space-2);margin-top:var(--space-3)}.result-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-input);font-size:var(--text-sm);font-weight:600}.result-row--ok{background:var(--color-success-bg);color:var(--color-success-text)}.result-row--err{background:var(--color-danger-soft);color:var(--color-smart-red)}.form-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.form-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-5)}.form-banner{margin-top:var(--space-4);padding:var(--space-3) var(--space-4);border-radius:var(--radius-input);border:1px solid rgba(195,49,47,.25);background:var(--color-danger-soft);color:var(--color-smart-red);font-size:var(--text-sm);font-weight:700}.table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-sm);overflow:hidden}.table-scroll{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.data-table th,.data-table td{padding:var(--space-3) var(--space-4);text-align:left;vertical-align:middle;border-bottom:1px solid var(--color-border)}.data-table thead th{position:sticky;top:0;background:var(--color-page-soft);color:var(--color-muted);font-size:var(--text-xs);font-weight:800;letter-spacing:.04em;text-transform:uppercase}.data-table tbody tr:nth-child(2n){background:#f6f8fb99}.data-table tbody tr:hover{background:var(--color-teal-soft)}.data-table tbody tr:last-child td{border-bottom:0}.data-table__sort{display:inline-flex;align-items:center;gap:var(--space-1);border:0;padding:0;background:transparent;color:inherit;font:inherit;letter-spacing:inherit;text-transform:inherit;cursor:pointer}.data-table__sort:hover{color:var(--color-charcoal)}.data-table__sort-icon{font-size:9px;opacity:.7}.generation-warning-table td{vertical-align:top}.generation-accordion{margin-top:var(--space-3);border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);overflow:hidden}.generation-accordion__trigger{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:0;background:var(--color-page-soft);color:var(--color-text);font:inherit;font-weight:900;text-align:left;cursor:pointer}.generation-accordion__trigger>span:first-child{flex:1}.generation-accordion__chevron{color:var(--color-muted);transition:transform .16s ease}.generation-accordion__chevron--open{transform:rotate(180deg)}.generation-accordion__body{padding:var(--space-3)}.generation-warning-row td{background:var(--color-danger-soft);color:var(--color-smart-red)}.empty-period-table td{vertical-align:top}.period-chip-list{display:flex;flex-wrap:wrap;gap:var(--space-1)}.period-chip{display:inline-flex;align-items:center;min-height:24px;padding:2px 8px;border-radius:999px;background:var(--color-warning-bg);color:var(--color-warning-text);font-size:var(--text-xs);font-weight:800}.muted-dash{color:var(--color-muted)}.data-table__mono{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:var(--text-xs);color:var(--color-muted);overflow-wrap:anywhere}.data-table__actions{display:flex;gap:var(--space-2);justify-content:flex-end}.table-foot{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.subst-page{display:grid;gap:var(--space-5)}.subst-tabs{display:flex;flex-wrap:wrap;gap:var(--space-2);padding:var(--space-1);margin-bottom:var(--space-5);border:1px solid var(--color-border);border-radius:14px;background:var(--color-page-soft)}.subst-tabs button{min-height:38px;padding:0 var(--space-4);border:1px solid transparent;border-radius:10px;background:transparent;color:var(--color-muted);font-size:var(--text-sm);font-weight:800;cursor:pointer}.subst-tabs button.is-active{border-color:var(--color-border);background:var(--color-surface);color:var(--color-charcoal);box-shadow:var(--shadow-sm)}.subst-workspace,.subst-absence-list,.subst-run-list{display:grid;gap:var(--space-4)}.subst-panel{padding:var(--space-5);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-sm)}.subst-panel--flush{padding-bottom:var(--space-4)}.subst-panel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-4)}.subst-panel__head h3{margin:0;font-size:var(--text-md);line-height:1.25}.subst-panel__head p{margin:var(--space-1) 0 0;color:var(--color-muted);font-size:var(--text-sm);font-weight:600}.subst-spacer,.subst-table-offset{margin-top:var(--space-4)}.result-page{display:grid;gap:var(--space-5)}.result-file-input{display:none}.result-dropzone{display:grid;justify-items:center;gap:var(--space-2);min-height:156px;padding:var(--space-5);border:1px dashed var(--color-border-strong);border-radius:8px;background:var(--color-page-soft);color:var(--color-muted);text-align:center;cursor:pointer}.result-dropzone strong{color:var(--color-charcoal);font-size:var(--text-md)}.result-upload-summary{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3);padding:var(--space-4);border:1px solid rgba(46,188,203,.28);border-radius:8px;background:var(--color-teal-soft)}.result-upload-summary strong{color:var(--color-charcoal)}.result-upload-summary span:last-child{color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.result-filter-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-4);align-items:end}.result-action-panel{display:grid;gap:var(--space-4)}.result-download-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}.result-saved-list{display:grid;gap:var(--space-2)}.result-saved-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--color-border);border-radius:8px;background:var(--color-page-soft)}.result-saved-row>button:first-child{display:grid;gap:2px;min-width:0;border:0;background:transparent;color:var(--color-charcoal);text-align:left;cursor:pointer}.result-saved-row strong,.result-saved-row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-saved-row span{color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.result-dashboard-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-5)}.result-bars{display:grid;gap:var(--space-3)}.result-bar{display:grid;gap:6px}.result-bar__meta,.result-band-chart__row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:var(--space-3);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:800}.result-bar__meta span,.result-band-chart__row span{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.result-bar__track,.result-band-chart__track{height:10px;overflow:hidden;border-radius:999px;background:var(--color-page-soft)}.result-bar__track span,.result-band-chart__track i{display:block;height:100%;border-radius:inherit}.result-band-chart{display:grid;gap:var(--space-3)}.result-band-chart__row{grid-template-columns:minmax(130px,190px) minmax(0,1fr) 40px}.result-band-chart__row strong{text-align:right}.result-trend{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));gap:var(--space-3);min-height:220px;align-items:end}.result-trend__item{display:grid;justify-items:center;gap:6px;min-width:0;color:var(--color-muted);font-size:var(--text-xs);font-weight:800;text-align:center}.result-trend__item strong{color:var(--color-charcoal)}.result-trend__stem{width:min(52px,70%);height:140px;display:flex;align-items:end;border-radius:999px;background:var(--color-page-soft);overflow:hidden}.result-trend__stem span{width:100%;border-radius:inherit;background:var(--color-brain-teal)}.subst-muted{color:var(--color-muted)}.subst-grid-meta{font-size:var(--text-xs);color:var(--color-muted);margin-top:2px}.subst-duty{display:flex;flex-direction:column;gap:1px;line-height:1.2}.subst-duty strong{font-size:var(--text-sm)}.subst-duty span{font-size:var(--text-xs);color:var(--color-muted)}.subst-duty em{font-size:var(--text-xs);font-style:normal;color:var(--color-text)}.subst-duty--bad{opacity:.95}.subst-cell-edit{cursor:pointer}.subst-cell-edit:hover{background:var(--color-page-soft)}.subst-save-bar{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-4)}.subst-save-bar>.field{flex:1 1 260px;margin-bottom:0}.subst-save-bar__actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.subst-absence-row{position:relative;display:grid;grid-template-columns:32px minmax(0,1fr) auto;gap:var(--space-3);align-items:end;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-input);background:linear-gradient(180deg,var(--color-surface),var(--color-page-soft))}.subst-absence-row__index{width:32px;height:32px;display:grid;place-items:center;align-self:center;border-radius:999px;background:var(--color-teal-soft);color:var(--color-brain-teal);font-size:var(--text-sm);font-weight:900}.subst-absence-row__remove{align-self:end}.subst-period-picks{grid-column:2 / -1;display:flex;flex-wrap:wrap;gap:var(--space-3);padding-top:var(--space-1)}.subst-actionbar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);padding:var(--space-4);border:1px solid rgba(46,188,203,.28);border-radius:var(--radius-card);background:var(--color-teal-soft)}.subst-actionbar strong,.subst-actionbar span{display:block}.subst-actionbar strong{font-size:var(--text-md)}.subst-actionbar>div:first-child span{color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.subst-actionbar .btn span{color:inherit;font-size:inherit;font-weight:inherit}.subst-actionbar__buttons{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:var(--space-3)}.subst-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-3)}.subst-summary{display:grid;gap:var(--space-1);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-page-soft)}.subst-summary span{color:var(--color-muted);font-size:var(--text-xs);font-weight:800;text-transform:uppercase}.subst-summary strong{font-size:var(--text-xl);line-height:1}.subst-summary--success{border-color:#2da44e40;background:var(--color-success-bg);color:var(--color-success-text)}.subst-summary--warning{border-color:#b9800040;background:var(--color-warning-bg);color:var(--color-warning-text)}.subst-run{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);width:100%;padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-surface);color:var(--color-charcoal);text-align:left;cursor:pointer}.subst-run:hover{border-color:var(--color-brain-teal);background:var(--color-teal-soft)}.subst-run strong,.subst-run small{display:block}.subst-run small{margin-top:var(--space-1);color:var(--color-muted);font-size:var(--text-xs);font-weight:800}.subst-empty{min-height:112px;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);border:1px dashed var(--color-border-strong);border-radius:var(--radius-input);background:var(--color-page-soft);color:var(--color-muted)}.subst-empty__icon{width:42px;height:42px;display:grid;place-items:center;flex:0 0 auto;border-radius:12px;background:var(--color-surface);color:var(--color-brain-teal)}.subst-empty strong{display:block;color:var(--color-charcoal);font-size:var(--text-sm)}.subst-empty p{margin:var(--space-1) 0 0;font-size:var(--text-sm)}.subst-field-action{align-self:end}.subst-danger-text{color:var(--color-smart-red);font-weight:800}.tt-generate-actions{display:flex;align-items:center;justify-content:flex-end;flex-wrap:wrap;gap:var(--space-2)}.tt-view-loadbar{display:grid;grid-template-columns:minmax(220px,320px) auto 1fr;align-items:end;gap:var(--space-3);margin-bottom:var(--space-4)}.tt-view-export-actions{display:flex;justify-content:flex-end;flex-wrap:wrap;gap:var(--space-2)}.manual-load-actions{display:grid;grid-template-columns:minmax(220px,320px) auto auto;align-items:end;gap:var(--space-2)}.manual-editor-teacher{display:grid;gap:var(--space-1);padding:var(--space-3);border:1px solid var(--color-border);border-radius:8px;background:var(--color-page-soft)}.manual-editor-teacher span,.manual-editor-teacher small{color:var(--color-muted);font-size:var(--text-sm)}.manual-editor-teacher strong{font-size:var(--text-lg)}.manual-editor-entry{display:grid;grid-template-columns:1fr 1fr auto;gap:var(--space-3);align-items:end;padding:var(--space-3);border:1px solid var(--color-border);border-radius:8px}.manual-editor-entry>.field,.manual-editor-conflict__reassign>.field{min-width:0}.manual-editor-entry select,.manual-editor-conflict__reassign select{width:100%;min-width:0}.manual-editor-days,.manual-editor-warnings{grid-column:1 / -1}.manual-editor-days{display:flex;flex-wrap:wrap;gap:var(--space-3)}.manual-editor-warnings{display:grid;gap:var(--space-1);padding:var(--space-2) var(--space-3);border-radius:8px;background:var(--color-warning-bg);color:var(--color-warning-text);font-size:var(--text-sm);font-weight:800}.tt-generate-strip{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2);color:var(--color-muted);font-size:var(--text-sm)}.tt-generate-strip span{padding:6px 10px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);font-weight:800}.tt-result-head>div:first-child{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.tt-result-line{color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.tt-validation-chips{display:flex;gap:var(--space-2);flex-wrap:wrap;margin-top:var(--space-4)}.grid-cell-stack{display:grid;gap:var(--space-2);min-width:180px}.grid-entry{width:100%;display:grid;gap:2px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-charcoal);text-align:left}button.grid-entry{cursor:pointer}.grid-entry--warn{background:#c3312f14;border-color:#c3312f3d}.grid-entry__scope{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;text-transform:uppercase}.grid-entry strong{font-size:var(--text-sm)}.grid-entry small{color:var(--color-muted);font-size:var(--text-xs);font-weight:700}.tt-view-card .card__body{display:grid;gap:var(--space-3)}.tt-view-controls{display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,1fr) auto;gap:var(--space-3);align-items:end}.tt-view-tabs-shell{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:stretch;gap:var(--space-2);min-width:0}.tt-view-tabs{display:flex;flex-wrap:nowrap;gap:6px;min-width:0;overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;scrollbar-width:none}.tt-view-tabs::-webkit-scrollbar{display:none}.tt-view-tab{flex:0 0 auto;min-height:40px;padding:8px 16px;border:1px solid var(--color-border-strong);border-radius:8px 8px 0 0;background:var(--color-page-soft);color:var(--color-muted);cursor:pointer;font-weight:900;white-space:nowrap}.tt-view-tab--active{background:var(--color-brain-teal);border-color:var(--color-brain-teal);color:#fff}.tt-view-tab-arrows{display:inline-flex;align-items:stretch;gap:4px}.tt-view-tab-arrows button{width:34px;min-height:40px;display:grid;place-items:center;border:1px solid var(--color-border-strong);border-radius:8px;background:var(--color-surface);color:var(--color-muted);cursor:pointer}.tt-view-tab-arrows button:first-child svg{transform:rotate(90deg)}.tt-view-tab-arrows button:last-child svg{transform:rotate(-90deg)}.tt-view-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface)}.tt-view-table{min-width:980px}.tt-view-table td{vertical-align:top;min-height:84px}.tt-view-cell-stack{display:grid;gap:6px}.tt-view-cell{width:100%;display:grid;gap:2px;min-height:64px;padding:8px;border:0;border-radius:6px;background:var(--color-teal-soft);color:var(--color-charcoal);text-align:left}button.tt-view-cell{cursor:pointer}.tt-view-cell strong{font-size:var(--text-sm);text-transform:uppercase}.tt-view-cell em{color:var(--color-muted);font-size:var(--text-xs);font-style:normal;font-weight:900}.tt-view-cell span{color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.tt-view-break{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;letter-spacing:.14em;text-align:center;vertical-align:middle!important;writing-mode:vertical-rl}.tt-load-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--space-4)}.manual-import-card .card__body{padding-top:0}.manual-import-toggle{width:100%;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:var(--space-3);padding:var(--space-4);border:0;background:transparent;color:var(--color-charcoal);cursor:pointer;text-align:left}.manual-import-toggle__icon{width:42px;height:42px;display:grid;place-items:center;border-radius:14px;background:var(--color-teal-soft);color:var(--color-brain-teal)}.manual-import-toggle strong,.manual-tip strong{display:block}.manual-import-toggle small{display:block;margin-top:2px;color:var(--color-muted);font-weight:700}.manual-import-toggle__chevron{color:var(--color-muted);transition:transform .16s ease}.manual-import-toggle__chevron--open{transform:rotate(180deg)}.manual-actions{display:flex;flex-wrap:wrap;gap:var(--space-3);margin-top:var(--space-3)}.manual-stat-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-4)}.manual-stat-tile{display:grid;gap:var(--space-1);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card)}.manual-stat-tile span{color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.manual-stat-tile strong{font-size:var(--text-xl);line-height:1}.manual-meta{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-3) var(--space-4);margin-top:var(--space-3);color:var(--color-muted);font-size:var(--text-sm)}.manual-grid-toolbar{display:flex;flex-wrap:wrap;gap:var(--space-3);align-items:flex-end;justify-content:space-between;margin-bottom:var(--space-3)}.manual-grid-toolbar>.field{min-width:220px;max-width:340px;flex:1 1 220px}.manual-grid-toolbar .field__label{font-size:0;line-height:0}.manual-toolbar-actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-3)}.manual-export-group{display:inline-flex;flex-wrap:wrap;gap:var(--space-2);padding:4px;border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-page-soft)}.manual-draft-bar{display:grid;grid-template-columns:minmax(180px,1fr) minmax(200px,1.4fr) auto auto auto;gap:var(--space-3);align-items:end}.manual-dirty-flag{padding:2px 10px;border-radius:999px;background:var(--color-warning-bg);color:var(--color-warning-text);font-weight:800}.manual-period-cell--readonly{cursor:default;white-space:pre-line;text-align:left;min-height:40px}.import-source-grid{display:grid;grid-template-columns:minmax(220px,1fr) minmax(220px,1fr) minmax(220px,1fr);gap:var(--space-4);align-items:end}.import-source-block{display:grid;grid-template-columns:1fr auto;gap:var(--space-2);align-items:end}.import-issues{margin-top:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-input);overflow:hidden}.import-issues__head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-warning-bg);color:var(--color-warning-text);font-weight:800}.import-issue{padding:6px var(--space-3);font-size:var(--text-sm);border-top:1px solid var(--color-border);color:var(--color-charcoal)}.import-issue--conflict{color:var(--color-smart-red);font-weight:700}.manual-grid-legend,.manual-grid-legend span{display:inline-flex;align-items:center}.manual-grid-legend{justify-content:flex-end;gap:var(--space-3);color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.manual-grid-legend span{gap:6px}.manual-legend-dot{width:12px;height:12px;border-radius:999px;background:var(--color-success-text);opacity:.45}.manual-legend-empty{width:16px;height:16px;border:1px dashed var(--color-border-strong);border-radius:4px}.manual-save-result{display:inline-flex;align-items:center;gap:var(--space-2)}.manual-grid-count{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.manual-grid-shell{position:relative;max-height:620px;overflow-x:hidden;overflow-y:auto;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface)}.manual-grid-shell .data-table thead th{z-index:2}.manual-period-cell{width:100%;min-width:0;min-height:84px;display:grid;place-items:center;gap:2px;padding:var(--space-2);border:1px dashed var(--color-border-strong);border-radius:8px;background:var(--color-surface);color:var(--color-brain-teal);cursor:pointer;font-weight:800;text-align:center;white-space:pre-wrap}.manual-period-cell--filled{display:block;align-content:start;border:none;padding:0;background:transparent;color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700;text-align:left}.manual-chip-wrap{display:flex;flex-direction:column;gap:3px;width:100%;min-width:0}.manual-chip{display:block;width:100%;min-width:0;box-sizing:border-box;padding:6px 10px;border:1px solid;border-left-width:4px;border-radius:8px;font-size:var(--text-xs);font-weight:800;line-height:1.35;white-space:normal;overflow-wrap:anywhere;word-break:break-word}.manual-cell-empty{color:var(--color-muted);font-weight:700}.manual-editor-conflict{display:flex;flex-direction:column;gap:var(--space-2);margin-top:6px;padding:var(--space-3);border:1px solid var(--color-smart-red);border-radius:var(--radius-input);background:var(--color-danger-soft);font-size:var(--text-sm)}.manual-editor-conflict__reassign{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}.manual-editor-conflict__days{display:grid;gap:4px}.manual-editor-conflict__days .field__label{color:var(--color-charcoal)}.manual-editor-conflict__actions{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.manual-period-cell:disabled{cursor:not-allowed;opacity:.7}.manual-row-actions{display:flex;align-items:center;justify-content:center;gap:var(--space-2)}.manual-tip{display:flex;align-items:center;gap:var(--space-3);color:var(--color-muted);font-size:var(--text-sm)}.manual-tip__icon{width:38px;height:38px;display:grid;place-items:center;flex:0 0 auto;border-radius:14px;background:var(--color-teal-soft);color:var(--color-brain-teal)}.gen-setup{margin-top:var(--space-4)}.gen-setup .field__hint{margin-bottom:var(--space-3)}.gen-accordion{border:1px solid var(--color-border);border-radius:var(--radius-input);margin-bottom:var(--space-2);overflow:hidden}.gen-accordion__summary{width:100%;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);border:0;background:var(--color-page-soft);color:var(--color-charcoal);font-weight:800;cursor:pointer}.gen-accordion__count{margin-left:auto;font-size:var(--text-sm);font-weight:700;color:var(--color-muted)}.gen-accordion__chevron{transition:transform .16s ease}.gen-accordion__chevron--open{transform:rotate(180deg)}.gen-accordion__body{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border)}.gen-check-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-2) var(--space-4)}.gen-check-list{display:grid;gap:var(--space-2);max-height:320px;overflow-y:auto}.gen-check-row{align-items:flex-start}.gen-meta{color:var(--color-muted);font-weight:600;font-size:var(--text-sm)}.teacher-settings-filters{display:grid;grid-template-columns:minmax(200px,1.4fr) minmax(160px,1fr) minmax(160px,1fr);gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-page-soft)}.teacher-accordion-list{display:grid;gap:var(--space-3)}.teacher-accordion{border:1px solid var(--color-border);border-left:4px solid var(--color-learning-purple);border-radius:var(--radius-card);background:var(--color-surface);overflow:hidden}.teacher-accordion__summary{width:100%;display:grid;grid-template-columns:44px minmax(160px,1fr) minmax(220px,1.4fr) minmax(160px,1fr) minmax(180px,auto) auto;align-items:center;gap:var(--space-3);padding:var(--space-4);border:0;background:var(--color-page-soft);color:var(--color-charcoal);text-align:left;cursor:pointer}.teacher-accordion__summary:hover{background:var(--color-purple-soft)}.teacher-accordion__serial{width:32px;height:32px;display:grid;place-items:center;border-radius:10px;background:var(--color-purple-soft);color:var(--color-learning-purple);font-weight:900}.teacher-accordion__identity,.teacher-accordion__meta,.teacher-accordion__limits{display:grid;gap:2px}.teacher-accordion__identity strong{font-size:var(--text-base)}.teacher-accordion__identity small,.teacher-accordion__meta small,.teacher-accordion__limits span{color:var(--color-muted);font-size:var(--text-sm);font-weight:700}.teacher-accordion__meta strong{color:var(--color-muted);font-size:var(--text-xs);font-weight:900;text-transform:uppercase}.teacher-accordion__limits{grid-template-columns:repeat(2,auto);gap:var(--space-2)}.teacher-accordion__limits span{padding:6px 10px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-page-soft)}.teacher-accordion__chevron{color:var(--color-muted);transition:transform .16s ease}.teacher-accordion__chevron--open{transform:rotate(180deg)}.teacher-accordion__body{display:grid;gap:var(--space-4);padding:0 var(--space-4) var(--space-4);border-top:1px solid var(--color-border)}.teacher-settings-form-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:var(--space-3);margin-top:var(--space-4);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-input);background:var(--color-page-soft)}.teacher-settings-panel-row{display:grid;grid-template-columns:minmax(180px,.8fr) minmax(220px,1fr) minmax(260px,1.2fr);gap:var(--space-4)}.teacher-settings-panel-row>.field{padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-input)}.teacher-settings-panel-row>.field:nth-child(1){background:var(--color-purple-soft)}.teacher-settings-panel-row>.field:nth-child(2){background:var(--color-teal-soft)}.teacher-settings-panel-row>.field:nth-child(3){background:var(--color-yellow-soft)}.teacher-settings-panel-row>.field>.field__label{color:var(--color-charcoal);font-weight:900;text-transform:uppercase;font-size:var(--text-xs);letter-spacing:.03em}.teacher-settings-checks,.teacher-settings-periods{display:flex;flex-wrap:wrap;gap:var(--space-2)}.teacher-settings-checks{flex-direction:column;align-items:flex-start}.teacher-accordion__actions{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-2);border-top:1px dashed var(--color-border)}.notice-success--inline{margin:0;font-weight:700}.state-block{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-10) var(--space-6);text-align:center;color:var(--color-muted)}.state-block--error{color:var(--color-smart-red)}.empty-illu{width:92px;height:92px;display:grid;place-items:center;border-radius:24px;background:var(--color-teal-soft);color:var(--color-brain-teal)}.empty-title{margin:0;font-size:var(--text-md);font-weight:800;color:var(--color-charcoal)}.empty-message{margin:0;max-width:38ch;font-size:var(--text-sm)}.permission-card{display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-6);border:1px solid rgba(195,49,47,.3);border-radius:var(--radius-card);background:var(--color-danger-soft)}.permission-card strong{color:var(--color-smart-red);font-size:var(--text-md)}.permission-card span{color:var(--color-charcoal);font-size:var(--text-sm)}.skeleton{position:relative;overflow:hidden;border-radius:8px;background:#ffd33d2e}.skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;transform:translate(-100%);background:linear-gradient(90deg,transparent,rgba(255,255,255,.6),transparent);animation:ui-shimmer 1.5s infinite}@keyframes ui-shimmer{to{transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none}.ui-spinner,.btn__spinner{animation-duration:0s}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;display:grid;place-items:center;padding:var(--space-4);background:#34383873}.modal{width:min(100%,560px);max-height:calc(100vh - 2 * var(--space-4));display:flex;flex-direction:column;border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-lg);overflow:hidden}.modal--wide{width:min(100%,920px)}.modal__header{flex:0 0 auto;padding:var(--space-5) var(--space-6) 0}.modal__title{margin:0;font-size:var(--text-lg);font-weight:700}.modal__body{flex:1 1 auto;min-height:0;overflow-y:auto;padding:var(--space-4) var(--space-6);color:var(--color-muted);font-size:var(--text-sm)}.modal__footer{flex:0 0 auto;display:flex;justify-content:flex-end;gap:var(--space-3);padding:var(--space-4) var(--space-6) var(--space-6)}.app-shell{min-height:100vh;background:radial-gradient(1200px 480px at 100% -10%,rgba(46,188,203,.1),transparent 60%),radial-gradient(1000px 420px at -10% 0%,rgba(146,39,143,.07),transparent 55%),var(--color-page-soft)}.app-sidebar{position:fixed;top:0;left:0;z-index:40;width:var(--sidebar-width);height:100vh;display:flex;flex-direction:column;border-right:1px solid var(--color-border);background:linear-gradient(180deg,#fff,#fcfdff);box-shadow:1px 0 #dbe4ee99,8px 0 24px -18px #0f172a40;transform:translate(0);transition:transform .2s ease}.app-sidebar__brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-5) var(--space-4)}.app-sidebar__brand .auth-brand__mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--color-learning-purple),var(--color-brain-teal));color:#fff;font-weight:900;font-size:var(--text-sm);box-shadow:0 6px 16px -6px #92278f99}.app-sidebar__brand-name{font-size:var(--text-md);font-weight:800;color:var(--color-deep-plum);letter-spacing:-.01em}.app-sidebar__context{margin:0 var(--space-4) var(--space-4);padding:var(--space-3) var(--space-4);border-radius:14px;background:linear-gradient(135deg,var(--color-learning-purple),var(--color-deep-plum));color:#fff;box-shadow:0 10px 24px -14px #6e2144cc}.app-sidebar__context-name{font-size:var(--text-sm);font-weight:800}.app-sidebar__context-sub{font-size:var(--text-xs);opacity:.85}.app-nav{flex:1;overflow-y:auto;padding:0 var(--space-3) var(--space-4)}.app-nav__group{margin-top:var(--space-5)}.app-nav__group-label{padding:0 var(--space-3) var(--space-2);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:var(--color-muted)}.app-nav__link{position:relative;display:flex;align-items:center;gap:var(--space-3);min-height:44px;padding:0 var(--space-3);margin-bottom:3px;border-radius:12px;color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700;transition:background .16s ease,color .16s ease,transform .16s ease}.app-nav__link:hover{background:var(--color-page-soft);transform:translate(2px)}.app-nav__link--active{background:linear-gradient(135deg,#92278f1f,#2ebccb14);color:var(--color-learning-purple)}.app-nav__link--active:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:3px;height:20px;border-radius:3px;background:linear-gradient(180deg,var(--color-learning-purple),var(--color-brain-teal))}.app-nav__link--active .app-nav__icon{color:var(--color-learning-purple)}.app-nav__icon{flex:0 0 auto;color:var(--color-muted);display:inline-flex;transition:color .16s ease}.app-nav__link:hover .app-nav__icon{color:var(--color-charcoal)}.app-nav__link--disabled{color:#aab4c0;cursor:not-allowed}.app-nav__soon{margin-left:auto;padding:1px 6px;border-radius:var(--radius-pill);background:var(--color-page-soft);font-size:9px;font-weight:800;letter-spacing:.04em;color:var(--color-muted)}.app-sidebar__foot{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-top:1px solid var(--color-border)}.avatar{width:38px;height:38px;flex:0 0 auto;display:grid;place-items:center;border-radius:50%;background:var(--color-smart-red);color:#fff;font-size:var(--text-sm);font-weight:800}.app-sidebar__foot-name{font-size:var(--text-sm);font-weight:800}.app-sidebar__foot-role{font-size:var(--text-xs);color:var(--color-growth-lime);font-weight:700}.app-main{margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.app-topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:var(--space-4);min-height:var(--topbar-height);padding:0 var(--space-6);border-bottom:1px solid rgba(219,228,238,.7);background:#ffffffc7;backdrop-filter:blur(14px) saturate(140%);-webkit-backdrop-filter:blur(14px) saturate(140%)}.app-topbar__menu{display:none;width:40px;height:40px;align-items:center;justify-content:center;border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface);cursor:pointer}.app-topbar__search{flex:1;max-width:420px;display:flex;align-items:center;gap:var(--space-2);height:40px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-page-soft);color:var(--color-muted)}.app-topbar__search input{flex:1;border:0;background:transparent;font-size:var(--text-sm);color:var(--color-charcoal)}.app-topbar__search input:focus{outline:0}.app-topbar__spacer{flex:1}.year-switch{position:relative}.year-switch__btn{display:flex;align-items:center;gap:var(--space-2);height:40px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-deep-plum);font-size:var(--text-sm);font-weight:800;cursor:pointer}.year-switch__btn:hover{border-color:var(--color-learning-purple)}.year-switch__menu{position:absolute;right:0;top:calc(100% + 8px);min-width:220px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-lg);display:grid;gap:2px;z-index:40}.year-switch__title{padding:var(--space-1) var(--space-3) var(--space-2);font-size:10px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--color-muted)}.year-switch__menu a,.year-switch__menu button{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);width:100%;min-height:38px;padding:0 var(--space-3);border:0;border-radius:8px;background:transparent;color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700;text-align:left;cursor:pointer}.year-switch__menu a:hover,.year-switch__menu button:hover{background:var(--color-page-soft)}.year-switch__menu .is-current{color:var(--color-learning-purple)}.year-switch__error{padding:var(--space-1) var(--space-3);color:var(--color-smart-red);font-size:var(--text-xs);font-weight:700}@media(max-width:767px){.year-switch__btn span:not([aria-hidden]){display:none}}.app-topbar__actions{display:flex;align-items:center;gap:var(--space-3);margin-left:auto}.icon-btn{position:relative;width:40px;height:40px;display:grid;place-items:center;border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface);color:var(--color-muted);cursor:pointer}.icon-btn:hover{color:var(--color-charcoal)}.profile-menu{position:relative}.profile-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-2);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);cursor:pointer}.profile-btn__name{font-size:var(--text-sm);font-weight:800}.profile-btn__role{font-size:var(--text-xs);color:var(--color-muted)}.profile-dropdown{position:absolute;right:0;top:calc(100% + 8px);min-width:200px;padding:var(--space-2);border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);box-shadow:var(--shadow-lg);display:grid;gap:2px}.profile-dropdown a,.profile-dropdown button{display:flex;align-items:center;gap:var(--space-2);width:100%;min-height:40px;padding:0 var(--space-3);border:0;border-radius:8px;background:transparent;color:var(--color-charcoal);font-size:var(--text-sm);font-weight:700;text-align:left;cursor:pointer}.profile-dropdown a:hover,.profile-dropdown button:hover{background:var(--color-page-soft)}.app-content{flex:1;width:100%;max-width:var(--content-max);margin:0 auto;padding:var(--space-4) var(--space-6) var(--space-6);display:grid;gap:var(--space-5);align-content:start}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.breadcrumb{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2);font-size:var(--text-xs);font-weight:700;color:var(--color-muted)}.breadcrumb span[aria-current]{color:var(--color-charcoal)}.page-head h1{margin:0;font-size:var(--text-2xl);letter-spacing:-.02em}.page-head--tight h1{font-size:var(--text-xl)}.page-head--tight p{font-size:var(--text-xs)}.page-head p{margin:var(--space-1) 0 0;font-size:var(--text-sm)}.section-stack{display:grid;gap:var(--space-5)}.section-stack--tight{gap:var(--space-4)}.form-actions--compact{margin-top:var(--space-3);gap:var(--space-2)}.dev-onboarding-grid{display:grid;grid-template-columns:minmax(0,1fr) 260px;gap:var(--space-4);align-items:start}.dev-qr-card{display:grid;justify-items:center;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-page-soft)}.dev-qr-card img{width:min(220px,100%);height:auto;border-radius:var(--radius-input);background:#fff}.email-preview{display:grid;gap:var(--space-3)}.email-preview__head{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);flex-wrap:wrap;font-size:var(--text-sm);font-weight:800}.email-preview textarea{width:100%;min-height:260px;resize:vertical;border:1px solid var(--color-border);border-radius:var(--radius-input);padding:var(--space-3);color:var(--color-text);background:var(--color-surface);font:600 var(--text-sm) / 1.55 ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace}@media(max-width:760px){.dev-onboarding-grid{grid-template-columns:1fr}}.live-game-page{--live-border: #d9e2ef}.live-hero-grid,.live-action-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap}.live-action-row{margin-top:var(--space-4);justify-content:flex-start}.live-action-row--right{margin-top:0;justify-content:flex-end}.live-current-turn{display:grid;gap:2px}.live-current-turn span,.live-last-roll{margin:0;font-size:var(--text-sm);color:var(--color-muted)}.live-current-turn strong{font-size:var(--text-2xl);color:var(--color-charcoal)}.live-setup-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-4)}.live-group-card{display:grid;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--live-border);border-radius:12px;background:var(--color-page-soft)}.live-group-card__top{display:flex;align-items:center;gap:var(--space-2)}.live-group-card__swatch,.live-score-card__swatch{width:16px;height:16px;border-radius:50%;border:2px solid #fff;box-shadow:0 0 0 1px var(--live-border)}.live-icon-button{margin-left:auto;display:inline-grid;place-items:center;width:32px;height:32px;border:1px solid var(--live-border);border-radius:8px;background:#fff;color:var(--color-smart-red);cursor:pointer}.live-score-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.live-score-card{display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:2px solid var(--live-border);border-radius:16px;background:linear-gradient(135deg,#fff 60%,#2ebccb0a);box-shadow:0 2px 8px #0f172a12;transition:box-shadow .2s,border-color .2s,transform .2s}.live-score-card--current{border-color:var(--color-brain-teal);background:linear-gradient(135deg,#2ebccb14,#fff 60%);box-shadow:0 0 0 4px #2ebccb2e,0 4px 18px #2ebccb26;transform:translateY(-1px)}.live-score-card strong,.live-score-card small{display:block}.live-score-card small{color:var(--color-muted);margin-top:2px;font-size:var(--text-xs)}.live-score-card b{font-size:var(--text-2xl);font-weight:900;background:linear-gradient(135deg,var(--color-brain-teal),var(--color-learning-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.live-score-rank{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;font-size:var(--text-sm);font-weight:900;background:var(--color-page-soft);color:var(--color-muted);border:2px solid var(--live-border);flex-shrink:0}.live-score-rank--1{background:linear-gradient(135deg,gold,#ffb300);color:#7a4f00;border-color:gold;box-shadow:0 2px 8px #ffc10766}.live-score-rank--2{background:linear-gradient(135deg,#e0e0e0,#b0b0b0);color:#444;border-color:silver}.live-score-rank--3{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff;border-color:#cd7f32}.live-board{position:relative;container-type:inline-size;min-height:560px;border:1px solid var(--live-border);border-radius:16px;overflow:hidden;background:#f7fafc;box-shadow:var(--shadow-sm)}.live-board__image{width:100%;height:100%;min-height:560px;object-fit:contain;display:block;background:#fff}.live-board__placeholder{min-height:560px;display:grid;place-items:center;color:var(--color-muted);font-size:var(--text-2xl);font-weight:800}.live-board__tile{position:absolute;transform:translate(-50%,-50%);z-index:2;width:clamp(20px,4.5cqw,36px);height:clamp(20px,4.5cqw,36px);display:grid;place-items:center;border:2px solid #fff;border-radius:50%;background:#e9f7fb;color:var(--color-charcoal);font-size:clamp(8px,1.6cqw,12px);font-weight:900;box-shadow:0 2px 8px #0f172a33}.live-board__tile--question{background:#f3e8ff}.live-board__tile--fact{background:#dcfce7}.live-board__tile--finish{background:#fff3bf}.live-board__token{position:absolute;transform:translate(-50%,-50%);z-index:4;width:clamp(22px,5.5cqw,44px);height:clamp(22px,5.5cqw,44px);display:grid;place-items:center;border:clamp(2px,.5cqw,3px) solid #fff;border-radius:50%;color:#fff;font-size:clamp(9px,2cqw,16px);font-weight:900;box-shadow:0 8px 20px #0f172a59;transition:left .26s ease,top .26s ease,transform .18s ease}.live-board__token:disabled,.projector-board__token:disabled{cursor:default}.live-board__token--selectable,.projector-board__token--selectable{cursor:pointer;box-shadow:0 0 0 4px #ffc1078c,0 0 0 8px #ffc10733,0 12px 32px #0f172a7a;transform:translate(-50%,-50%) scale(1.14);animation:token-pulse 1s ease-in-out infinite}@keyframes token-pulse{0%,to{box-shadow:0 0 0 4px #ffc1078c,0 0 0 8px #ffc10733,0 12px 32px #0f172a7a}50%{box-shadow:0 0 0 6px #ffc107b3,0 0 0 14px #ffc1071f,0 12px 32px #0f172a7a}}.live-play-shell{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:var(--space-4);align-items:start}.live-projector-panel{order:1}.live-play-controls{order:2}.live-play-controls,.live-projector-panel{display:grid;gap:var(--space-4);min-width:0}.live-game-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}.live-projector-panel{position:sticky;top:var(--space-4);padding:var(--space-4);border:2px solid var(--color-border);border-radius:20px;background:linear-gradient(160deg,#fff 70%,#2ebccb0d);box-shadow:0 6px 24px #0f172a1a}.live-projector-toolbar{display:grid;grid-template-columns:minmax(0,1fr) auto auto;gap:var(--space-3);align-items:center}.live-projector-toolbar span,.live-projector-toolbar small{display:block;color:var(--color-muted)}.live-projector-toolbar strong{display:block;font-size:var(--text-xl)}.dice-flat-wrap{--dice-px: 92px;display:inline-grid;place-items:center;justify-self:end;width:var(--dice-px);height:var(--dice-px);perspective:600px}.dice-flat-wrap--store{--dice-px: 66px;justify-self:center}.dice-flat{width:100%;height:100%;transform-style:preserve-3d;transition:transform .4s cubic-bezier(.34,1.56,.64,1)}.dice-flat-wrap--rolling .dice-flat{animation:dice-flat-tumble .7s cubic-bezier(.36,.07,.19,.97) infinite}@keyframes dice-flat-tumble{0%{transform:rotate(0) rotateX(0) rotateY(0) scale(1)}20%{transform:rotate(75deg) rotateX(-26deg) rotateY(18deg) scale(1.12) translateY(-7px)}40%{transform:rotate(160deg) rotateX(22deg) rotateY(-20deg) scale(.9) translateY(3px)}60%{transform:rotate(245deg) rotateX(-30deg) rotateY(16deg) scale(1.1) translateY(-6px)}80%{transform:rotate(310deg) rotateX(18deg) rotateY(-14deg) scale(.95) translateY(2px)}to{transform:rotate(360deg) rotateX(0) rotateY(0) scale(1) translateY(0)}}.dice-face{width:100%;height:100%;display:grid;grid-template-columns:repeat(3,1fr);grid-template-rows:repeat(3,1fr);padding:14%;box-sizing:border-box;border-radius:22%;background:#fff;box-shadow:inset 0 4px 8px #ffffffb3,inset 0 -6px 12px #0000001f,inset 0 0 0 1.5px #00000014,0 8px 18px #0f172a52,0 2px 4px #0f172a33}.dice-face__cell{display:grid;place-items:center}.dice-face__pip{width:64%;height:64%;border-radius:50%;background:#1a1a2e;box-shadow:inset 0 2px 2px #ffffff40,inset 0 -2px 3px #00000080}.live-projector-stage,.projector-stage{position:relative;display:grid;border-radius:18px}.token-shape--circle{border-radius:50%;clip-path:none}.token-shape--square{border-radius:12px;clip-path:none}.token-shape--diamond{border-radius:8px;clip-path:polygon(50% 0%,100% 50%,50% 100%,0% 50%)}.token-shape--hex{border-radius:6px;clip-path:polygon(25% 5%,75% 5%,100% 50%,75% 95%,25% 95%,0% 50%)}.token-shape--star{border-radius:6px;clip-path:polygon(50% 0%,61% 34%,98% 35%,68% 56%,79% 91%,50% 70%,21% 91%,32% 56%,2% 35%,39% 34%)}.token-shape--shield{border-radius:8px 8px 16px 16px;clip-path:polygon(50% 0%,92% 16%,84% 72%,50% 100%,16% 72%,8% 16%)}.lobby-step-label{margin:var(--space-2) 0 calc(var(--space-1) * -1);font-size:11px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.lobby-crumb{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.lobby-back{display:inline-flex;align-items:center;gap:var(--space-2);min-height:38px;padding:0 var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-deep-plum);font-size:var(--text-sm);font-weight:800;cursor:pointer;transition:border-color .16s ease,background .16s ease}.lobby-back:hover{border-color:var(--color-learning-purple);background:var(--color-purple-soft)}.lobby-crumb__current{font-size:var(--text-md);font-weight:800;color:var(--color-charcoal);letter-spacing:-.01em}.board-lobby-grid{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.board-lobby-grid--classes{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.board-lobby-grid--subjects{grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.lobby-tile{display:grid;gap:var(--space-1);align-content:center;justify-items:start;min-height:84px;padding:var(--space-4);border:2px solid var(--color-border);border-radius:16px;background:linear-gradient(135deg,#fff 60%,#2ebccb0a);color:var(--color-charcoal);font:inherit;text-align:left;cursor:pointer;transition:border-color .16s ease,box-shadow .16s ease,transform .16s ease}.lobby-tile:hover{border-color:var(--color-brain-teal);transform:translateY(-2px);box-shadow:0 8px 22px -12px #0f172a66}.lobby-tile--active{border-color:var(--color-learning-purple);background:linear-gradient(135deg,#92278f1a,#2ebccb0f);box-shadow:0 0 0 3px #92278f24}.lobby-tile__title{font-size:var(--text-md);font-weight:800;letter-spacing:-.01em}.lobby-tile--subject .lobby-tile__title{font-size:var(--text-sm)}.lobby-tile__meta{font-size:var(--text-xs);font-weight:700;color:var(--color-muted)}.lobby-tile--active .lobby-tile__meta{color:var(--color-learning-purple)}.analytics-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:var(--space-3)}.analytics-summary>div{display:grid;gap:2px;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:14px;background:linear-gradient(135deg,#fff 55%,#2ebccb0d)}.analytics-summary span{font-size:var(--text-xs);font-weight:800;letter-spacing:.04em;text-transform:uppercase;color:var(--color-muted)}.analytics-summary strong{font-size:var(--text-2xl);font-weight:900;background:linear-gradient(135deg,var(--color-brain-teal),var(--color-learning-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.analytics-board-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:var(--space-3)}.analytics-board{border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface);overflow:hidden;box-shadow:0 2px 10px -6px #0f172a2e}.analytics-board__head{display:grid;gap:2px;padding:var(--space-3) var(--space-4);background:linear-gradient(135deg,var(--color-learning-purple),var(--color-brain-teal));color:#fff}.analytics-board__head strong{font-size:var(--text-md);font-weight:800}.analytics-board__tags{font-size:var(--text-xs);font-weight:700;opacity:.9}.analytics-board__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--color-border)}.analytics-board__stats>div{display:grid;gap:2px;padding:var(--space-3) var(--space-2);background:var(--color-surface);text-align:center}.analytics-board__stats strong{font-size:var(--text-lg);font-weight:900;color:var(--color-deep-plum)}.analytics-board__stats span{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;color:var(--color-muted)}.board-lobby-grid--games{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.game-card{display:flex;flex-direction:column;overflow:hidden;border:1px solid var(--color-border);border-radius:18px;background:var(--color-surface);box-shadow:0 2px 10px -4px #0f172a29;transition:transform .18s ease,box-shadow .18s ease,border-color .18s ease}.game-card:hover{transform:translateY(-3px);border-color:var(--color-brain-teal);box-shadow:0 16px 32px -16px #0f172a66}.game-card__media{position:relative;aspect-ratio:16 / 10;background:linear-gradient(135deg,#eef4fb,#f7eef7)}.game-card__img{width:100%;height:100%;aspect-ratio:16 / 10;object-fit:contain;background:#fff;display:block}.game-card__img--empty{display:grid;place-items:center;aspect-ratio:16 / 10;background:linear-gradient(135deg,#eef4fb,#f7eef7);color:var(--color-muted)}.game-card__chips{position:absolute;top:var(--space-2);left:var(--space-2);display:flex;gap:var(--space-1);flex-wrap:wrap}.game-card__chip{padding:3px 10px;border-radius:var(--radius-pill);background:#0f172ac7;color:#fff;font-size:11px;font-weight:800;letter-spacing:.01em;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);box-shadow:0 2px 6px #0f172a4d}.game-card__chip--alt{background:linear-gradient(135deg,var(--color-learning-purple),var(--color-brain-teal))}.game-card__body{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-4);flex:1}.game-card__title{margin:0;font-size:var(--text-md);font-weight:800;letter-spacing:-.01em;line-height:1.25}.game-card__sub{margin:0;font-size:var(--text-xs);font-weight:700;color:var(--color-muted);text-transform:capitalize}.game-card__stats{display:flex;gap:var(--space-2);margin-top:var(--space-1)}.game-card__stat{flex:1;display:flex;align-items:baseline;gap:4px;padding:var(--space-2) var(--space-3);border-radius:12px;background:var(--color-page-soft);font-size:var(--text-xs);font-weight:700;color:var(--color-muted)}.game-card__stat b{font-size:var(--text-md);font-weight:900;color:var(--color-deep-plum)}.game-card__actions{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2);margin-top:auto;padding-top:var(--space-2)}.game-card__actions .btn{width:100%;justify-content:center}.group-setup-modal{width:min(100%,880px)}.group-setup-modal .modal__body{background:var(--color-page-soft)}.group-setup{display:grid;gap:var(--space-5)}.group-setup__center{display:grid;place-items:center;gap:var(--space-3);padding:var(--space-8) var(--space-6)}.group-setup__sections{display:flex;flex-wrap:wrap;gap:var(--space-2)}.group-section-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border:2px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:800;cursor:pointer;transition:border-color .16s ease,background .16s ease,transform .16s ease,box-shadow .16s ease}.group-section-chip span{color:var(--color-muted);font-weight:700}.group-section-chip:hover{border-color:var(--color-brain-teal);transform:translateY(-1px)}.group-section-chip--active{border-color:transparent;background:linear-gradient(135deg,var(--color-learning-purple),var(--color-brain-teal));color:#fff;box-shadow:0 8px 20px -10px #92278fcc}.group-section-chip--active span{color:#ffffffd9}.group-setup__controls{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface);box-shadow:0 2px 10px -6px #0f172a33}.group-setup__count{display:flex;align-items:center;gap:var(--space-3);font-size:var(--text-xs);font-weight:800;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted)}.group-setup__count-input{display:inline-flex;align-items:center;gap:var(--space-1);padding:3px;border-radius:var(--radius-pill);background:var(--color-page-soft)}.group-setup__count-input button{width:30px;height:30px;display:grid;place-items:center;border:0;border-radius:50%;background:var(--color-surface);color:var(--color-deep-plum);font-size:var(--text-lg);font-weight:900;cursor:pointer;box-shadow:0 1px 3px #0f172a26;transition:background .14s ease,color .14s ease}.group-setup__count-input button:hover{background:var(--color-learning-purple);color:#fff}.group-setup__count-input strong{min-width:26px;text-align:center;font-size:var(--text-lg);color:var(--color-charcoal)}.group-setup__stat{display:flex;align-items:baseline;gap:4px;padding:var(--space-1) var(--space-3);border-radius:var(--radius-pill);background:var(--color-page-soft)}.group-setup__stat strong{font-size:var(--text-md);font-weight:900;color:var(--color-deep-plum)}.group-setup__stat span{font-size:var(--text-xs);color:var(--color-muted);font-weight:700}.group-setup__hint{margin:0 0 0 auto;font-size:var(--text-xs);color:var(--color-muted);font-weight:600}.group-setup-modal{width:min(98vw,1240px)}.group-setup__columns{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--space-2)}.group-setup__columns .group-student__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dev-cap-chip{padding:3px 10px;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-muted);font-size:var(--text-xs);font-weight:800;cursor:pointer}.dev-cap-chip[data-on=true]{border-color:var(--color-learning-purple);background:var(--color-learning-purple);color:#fff}.dev-cap-chip:disabled{opacity:.5;cursor:not-allowed}.dev-activity-bars{display:flex;align-items:flex-end;gap:var(--space-2);height:140px;padding:var(--space-3);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);overflow-x:auto}.dev-activity-bar{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;gap:4px;min-width:26px;height:100%}.dev-activity-bar__fill{width:18px;min-height:3px;border-radius:6px 6px 0 0;background:linear-gradient(180deg,var(--color-learning-purple),var(--color-brain-teal))}.dev-activity-bar__label{font-size:10px;color:var(--color-muted);font-weight:700}.dev-school-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4)}.dev-school-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-2);margin-bottom:var(--space-3)}.dev-school-stats>div{display:flex;flex-direction:column;align-items:center;padding:var(--space-2);border:1px solid var(--color-border);border-radius:10px;background:var(--color-surface)}.dev-school-stats strong{font-size:var(--text-lg);font-weight:800}.dev-school-stats span{font-size:10px;color:var(--color-muted);font-weight:700;text-align:center}@media(max-width:520px){.dev-school-stats{grid-template-columns:repeat(2,1fr)}}.group-column{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:16px;background:var(--color-surface);overflow:hidden;box-shadow:0 2px 10px -6px #0f172a2e}.group-column__head{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);color:#fff;font-size:var(--text-sm);background:linear-gradient(135deg,var(--team-color, var(--color-brain-teal)),color-mix(in srgb,var(--team-color, var(--color-brain-teal)) 70%,#000 30%))}.group-column__dot{width:10px;height:10px;border-radius:50%;background:#ffffffe6}.group-column__count{margin-left:auto;display:grid;place-items:center;min-width:22px;height:22px;padding:0 6px;border-radius:var(--radius-pill);background:#ffffff40;font-size:var(--text-xs);font-weight:800}.group-column__list{display:flex;flex-direction:column;gap:5px;padding:var(--space-2);background:linear-gradient(180deg,color-mix(in srgb,var(--team-color, #fff) 6%,#fff),#fff)}.group-student{display:flex;align-items:center;gap:var(--space-2);padding:5px 8px 5px 5px;border:1.5px solid transparent;border-radius:10px;background:var(--color-surface);color:var(--color-charcoal);font-size:var(--text-sm);font-weight:600;text-align:left;cursor:pointer;box-shadow:0 1px 3px #0f172a14;transition:border-color .14s ease,transform .14s ease,box-shadow .14s ease}.group-student:hover{transform:translateY(-1px);box-shadow:0 4px 10px -4px #0f172a40}.group-student__avatar{flex:0 0 auto;width:26px;height:26px;display:grid;place-items:center;border-radius:50%;color:#fff;font-size:10px;font-weight:800}.group-student__name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.group-student--active{border-color:var(--color-learning-purple);box-shadow:0 0 0 3px #92278f33;transform:translateY(-1px) scale(1.02)}.group-column__empty{padding:var(--space-3) var(--space-2);text-align:center;font-size:var(--text-xs);color:var(--color-muted);font-style:italic}.game-flash{position:absolute;top:50%;left:50%;z-index:14;transform:translate(-50%,-50%);display:grid;justify-items:center;gap:4px;padding:var(--space-4) var(--space-6);border-radius:18px;color:#fff;text-align:center;box-shadow:0 18px 44px -16px #0f172a99;animation:game-flash-pop .25s cubic-bezier(.34,1.56,.64,1);pointer-events:none}.game-flash strong{font-size:clamp(24px,4vw,40px);line-height:1}.game-flash span{font-size:var(--text-lg);font-weight:800}.game-flash--success{background:linear-gradient(135deg,#22b07d,#16916a)}.game-flash--danger{background:linear-gradient(135deg,#e8590c,#c92a2a)}.game-move-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:16;display:grid;place-items:center;background:#0f172a52;border-radius:inherit}.game-move-card{display:grid;justify-items:center;gap:6px;padding:var(--space-5) var(--space-8);border-radius:20px;color:#fff;text-align:center;box-shadow:0 22px 50px -18px #0f172ab3;animation:game-flash-pop .25s cubic-bezier(.34,1.56,.64,1)}.game-move-card strong{font-size:clamp(26px,4vw,44px);line-height:1}.game-move-card span{font-size:var(--text-xl);font-weight:800}.game-move-card--success{background:linear-gradient(135deg,#22b07d,#16916a)}.game-move-card--danger{background:linear-gradient(135deg,#e8590c,#c92a2a)}@keyframes game-flash-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.7)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.store-section-title{margin:var(--space-2) 0 var(--space-3);font-size:var(--text-lg)}.game-store-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:var(--space-3);margin-bottom:var(--space-5)}.game-store-card{display:grid;justify-items:center;gap:var(--space-2);min-height:154px;padding:var(--space-4);border:1px solid var(--color-border);border-radius:8px;background:#fff;color:var(--color-text);font:inherit;text-align:center;cursor:pointer}.game-store-card--selected{border-color:var(--color-learning-purple);box-shadow:0 0 0 3px #92278f24}.game-store-card small{color:var(--color-muted);font-size:var(--text-xs)}.game-store-token-preview{width:58px;height:58px;display:grid;place-items:center;border:3px solid #fff;background:var(--color-brain-teal);color:#fff;font-weight:900;box-shadow:0 8px 18px #0f172a38}.game-celebration{position:absolute;top:0;right:0;bottom:0;left:0;z-index:12;display:grid;place-items:center;align-content:center;gap:var(--space-3);overflow:hidden;border-radius:inherit;background:radial-gradient(ellipse at 50% 40%,#fffffff7,#2ebccb2e 60%,#92278f1f);color:var(--color-charcoal);text-align:center;animation:celebration-enter .4s cubic-bezier(.34,1.56,.64,1)}@keyframes celebration-enter{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.game-celebration__burst{position:absolute;top:-20%;right:-20%;bottom:-20%;left:-20%;background:conic-gradient(from 0deg,transparent 0 6deg,rgba(255,193,7,.95) 6deg 12deg,transparent 12deg 28deg),conic-gradient(from 22deg,transparent 0 6deg,rgba(146,39,143,.85) 6deg 12deg,transparent 12deg 30deg),conic-gradient(from 44deg,transparent 0 5deg,rgba(46,188,203,.9) 5deg 10deg,transparent 10deg 28deg),conic-gradient(from 68deg,transparent 0 6deg,rgba(255,138,42,.85) 6deg 12deg,transparent 12deg 30deg),conic-gradient(from 90deg,transparent 0 5deg,rgba(76,175,80,.85) 5deg 10deg,transparent 10deg 28deg);border-radius:50%;animation:celebration-spin 3.5s linear infinite;opacity:.75;filter:blur(1px)}.game-celebration__burst:after{content:"";position:absolute;top:18%;right:18%;bottom:18%;left:18%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.95) 60%,transparent 100%)}.game-celebration span,.game-celebration strong,.game-celebration p{position:relative;z-index:1;margin:0}.game-celebration span{font-size:var(--text-sm);font-weight:900;text-transform:uppercase;letter-spacing:.15em;color:var(--color-learning-purple);animation:celebration-badge-pop .6s .1s cubic-bezier(.34,1.56,.64,1) both}.game-celebration strong{font-size:clamp(44px,8vw,96px);line-height:1;background:linear-gradient(135deg,#ffd700 0%,var(--color-learning-purple) 60%,var(--color-brain-teal) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:celebration-name-pop .7s .2s cubic-bezier(.34,1.56,.64,1) both}.game-celebration p{font-size:var(--text-xl);font-weight:800;color:var(--color-muted);animation:celebration-badge-pop .6s .35s cubic-bezier(.34,1.56,.64,1) both}.game-celebration__actions{position:relative;z-index:1;display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center;animation:celebration-badge-pop .5s .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes celebration-spin{0%{transform:rotate(0) scale(.88)}50%{transform:rotate(180deg) scale(1.04)}to{transform:rotate(360deg) scale(.88)}}@keyframes celebration-name-pop{0%{opacity:0;transform:scale(.5) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes celebration-badge-pop{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@media(max-width:1100px){.live-play-shell,.live-projector-toolbar{grid-template-columns:1fr}.live-projector-panel{position:static}}.live-popup{display:grid;gap:var(--space-4)}.live-popup h3{margin:0;font-size:var(--text-xl)}.live-popup__image,.projector-popup__image{width:100%;max-height:320px;object-fit:contain;border-radius:8px;background:#f8fafc}.live-popup__hint{margin:0;color:var(--color-muted)}.board-author-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:var(--space-2)}.board-author-steps__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);min-height:44px;padding:8px 10px;border:1px solid var(--color-border);border-radius:8px;background:#fff;color:var(--color-text);font:inherit;font-weight:700;text-align:left;cursor:pointer}.board-author-steps__item--active{border-color:var(--color-learning-purple);box-shadow:0 0 0 3px #92278f1f}.board-point-modal{max-width:520px}.board-point-modal__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.board-point-modal__close{min-height:36px;padding:6px 12px;border:1px solid var(--color-border);border-radius:8px;background:#fff;color:var(--color-text);font:inherit;font-weight:700;cursor:pointer}.board-point-modal__close:hover{border-color:var(--color-learning-purple);color:var(--color-learning-purple)}.board-point-modal__number{margin-left:8px;color:var(--color-learning-purple);font-size:1.35em}.learning-bubble-marker{position:absolute;transform:translate(-50%,-50%);width:32px;height:32px;display:grid;place-items:center;border:2px solid #fff;border-radius:50%;background:#2ebccb;color:#fff;font-size:var(--text-xs);font-weight:900;box-shadow:0 2px 8px #0f172a40}.board-image-preview{width:100%;max-height:70vh;object-fit:contain;border-radius:8px;background:#f8fafc}.image-editor-modal{max-width:920px}.image-editor{display:grid;gap:var(--space-3)}.image-editor__toolbar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.image-editor__brush{display:inline-flex;align-items:center;gap:var(--space-2);color:var(--color-muted);font-size:var(--text-sm);font-weight:800}.image-editor__canvas{width:100%;max-height:65vh;object-fit:contain;border:1px solid var(--color-border);border-radius:8px;background:linear-gradient(45deg,#e2e8f0 25%,transparent 25%),linear-gradient(-45deg,#e2e8f0 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#e2e8f0 75%),linear-gradient(-45deg,transparent 75%,#e2e8f0 75%);background-color:#fff;background-position:0 0,0 10px,10px -10px,-10px 0;background-size:20px 20px;touch-action:none}.image-editor__canvas--crop{cursor:crosshair}.image-editor__canvas--erase{cursor:cell}@media(max-width:760px){.board-author-steps{grid-template-columns:1fr}}.live-answer-list{display:grid;gap:var(--space-2)}.live-answer-option{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--live-border);border-radius:10px;background:var(--color-page-soft)}.live-answer-option span{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#fff;font-weight:900}.live-answer-option--selected{border-color:var(--color-brain-teal);background:#2ebccb1f}.question-reveal{display:grid;gap:var(--space-3)}.question-reveal h2,.question-reveal h3,.question-reveal p{margin:0}.question-reveal__meta{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.question-reveal__options{display:grid;gap:var(--space-2)}.question-reveal__option{display:grid;grid-template-columns:36px minmax(0,1fr);align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);border:1px solid var(--live-border);border-radius:10px;background:#fff;color:var(--color-text);font:inherit;text-align:left;cursor:pointer}.question-reveal__option span{display:grid;place-items:center;width:28px;height:28px;border-radius:50%;background:#2ebccb24;color:var(--color-info-text);font-weight:900}.question-reveal__option--selected{border-color:var(--color-learning-purple);background:#92278f14}.question-reveal__option--correct{border-color:#15803d;background:#dcfce7}.question-reveal__option--correct span{background:#15803d;color:#fff}.question-reveal__option--wrong{border-color:#c92a2a;background:#fee2e2}.question-reveal__option--wrong span{background:#c92a2a;color:#fff}.question-reveal--projector .question-reveal__option{padding:var(--space-4);font-size:var(--text-lg)}.live-popup__meta,.live-copy-status{margin:0;color:var(--color-muted);font-size:var(--text-sm)}.live-access-grid,.live-student-review{display:grid;grid-template-columns:minmax(220px,1fr) auto;gap:var(--space-4);align-items:center}.live-join-code{display:grid;gap:4px;padding:var(--space-4);border:1px dashed var(--color-brain-teal);border-radius:12px;background:#2ebccb14}.live-join-code span,.live-student-review span{color:var(--color-muted);font-size:var(--text-xs);font-weight:800;text-transform:uppercase}.live-join-code strong{letter-spacing:.08em;font-size:var(--text-3xl)}.live-access-actions{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:flex-end}.live-student-review{grid-template-columns:repeat(3,minmax(0,1fr));margin-bottom:var(--space-4)}.live-student-review>div{display:grid;gap:4px;padding:var(--space-4);border:1px solid var(--live-border);border-radius:12px;background:#fff}.live-student-list{display:grid;gap:var(--space-2)}.live-student-row{display:grid;grid-template-columns:minmax(0,1fr) minmax(120px,180px) auto;align-items:center;gap:var(--space-3);padding:var(--space-3);border:1px solid var(--live-border);border-radius:10px}.live-student-row span{color:var(--color-muted)}.board-rule-toggles,.live-control-grid{display:grid;gap:var(--space-3);margin-top:var(--space-4)}.board-rule-toggles{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}.live-control-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.live-control-card{display:grid;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--live-border);border-radius:12px;background:#fff}.live-summary-table{display:grid;border:1px solid var(--live-border);border-radius:12px;overflow:hidden}.live-summary-row{display:grid;grid-template-columns:52px minmax(0,1fr) 100px;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--live-border)}.live-summary-row:last-child{border-bottom:0}.live-summary-row b{text-align:right;font-size:var(--text-lg)}.student-game-shell{min-height:100vh;display:grid;place-items:center;padding:var(--space-5);background:linear-gradient(180deg,#2ebccb1f,#f6f8fb00 260px),var(--color-page-soft)}.student-game-shell>.card{width:min(760px,100%)}.student-game-shell--join>.card{width:min(560px,100%)}.student-game-error{position:fixed;top:var(--space-4);left:50%;z-index:10;width:min(640px,calc(100% - 32px));transform:translate(-50%)}.student-join-form,.student-question{display:grid;gap:var(--space-4)}.student-preview{display:grid;gap:4px;padding:var(--space-3);border:1px solid var(--live-border);border-radius:12px;background:#fff}.student-preview span:last-child{color:var(--color-muted)}.student-status-card{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:var(--space-3)}.student-status-card>div{display:grid;gap:4px;padding:var(--space-4);border:1px solid var(--live-border);border-radius:12px;background:#fff}.student-status-card span{color:var(--color-muted);font-size:var(--text-xs);font-weight:800;text-transform:uppercase}.student-waiting-message{display:grid;justify-items:center;gap:var(--space-2);margin:var(--space-5) 0;padding:var(--space-5);border-radius:16px;background:#2ebccb14;text-align:center}.student-waiting-message h2,.student-waiting-message p,.student-question h1{margin:0}.student-waiting-message p{color:var(--color-muted)}.student-options{display:grid;gap:var(--space-3)}.student-option{display:grid;grid-template-columns:42px minmax(0,1fr);align-items:center;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--live-border);border-radius:14px;background:#fff;color:var(--color-charcoal);text-align:left;cursor:pointer}.student-option span{display:grid;place-items:center;width:36px;height:36px;border-radius:50%;background:var(--color-page-soft);font-weight:900}.student-option--selected{border-color:var(--color-deep-blue);background:#2f80ed14}.projector-page{min-height:100vh;padding:clamp(16px,2vw,32px);background:#f6f8fb;color:var(--color-charcoal)}.live-fullscreen{padding-top:var(--space-3)}.live-fullscreen .live-fullscreen-actions{margin:0 0 var(--space-3);flex-wrap:wrap}.live-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);flex-wrap:wrap;margin-bottom:var(--space-3)}.live-bar__title{display:flex;align-items:center;gap:var(--space-4);flex-wrap:wrap}.live-bar__title h1{margin:0;font-size:clamp(22px,2.4vw,34px);letter-spacing:-.02em}.live-bar__turn{display:inline-flex;align-items:center;gap:var(--space-2);padding:6px 14px;border-radius:var(--radius-pill);background:color-mix(in srgb,var(--turn-color, #2ebccb) 14%,#fff);border:2px solid var(--turn-color, #2ebccb);font-size:var(--text-md)}.live-bar__turn strong{color:var(--color-charcoal)}.live-bar__turn small{color:var(--color-muted)}.live-bar__dot{width:12px;height:12px;border-radius:50%;background:var(--turn-color, #2ebccb);box-shadow:0 0 0 3px color-mix(in srgb,var(--turn-color, #2ebccb) 25%,transparent)}.live-bar__actions{display:flex;align-items:center;gap:var(--space-2)}.game-icon-btn{display:grid;place-items:center;width:44px;height:44px;border:1px solid var(--color-border);border-radius:12px;background:var(--color-surface);color:var(--color-deep-plum);cursor:pointer;transition:border-color .14s ease,background .14s ease,transform .14s ease}.game-icon-btn:hover:not(:disabled){filter:brightness(.96);transform:translateY(-1px)}.game-icon-btn:disabled{opacity:.5;cursor:default}.game-icon-btn--primary{background:var(--color-brain-teal);border-color:var(--color-brain-teal);color:#fff}.game-icon-btn--danger{background:var(--color-smart-red);border-color:var(--color-smart-red);color:#fff}.game-icon-btn--slate{background:#475569;border-color:#475569;color:#fff}.game-icon-btn--purple{background:var(--color-learning-purple);border-color:var(--color-learning-purple);color:#fff}.game-icon-btn--teal{background:var(--color-brain-teal);border-color:var(--color-brain-teal);color:#fff}.game-icon-btn--amber{background:#f59e0b;border-color:#f59e0b;color:#fff}.live-dice-btn{display:grid;place-items:center;padding:6px;border:0;border-radius:16px;background:transparent;cursor:pointer}.live-dice-btn:disabled{cursor:default;opacity:.85}.live-dice-btn--ready{animation:dice-btn-pulse 1.6s ease-in-out infinite;border-radius:18px}@keyframes dice-btn-pulse{0%,to{box-shadow:0 0 #2ebccb00}50%{box-shadow:0 0 0 6px #2ebccb2e}}.live-dice-panel{display:grid;justify-items:center;gap:var(--space-3);padding:var(--space-5) var(--space-4);border:2px solid var(--turn-color, var(--color-border));border-radius:18px;background:linear-gradient(160deg,color-mix(in srgb,var(--turn-color, #2ebccb) 8%,#fff),#fff);box-shadow:0 6px 22px -12px #0f172a4d}.live-dice-panel__turn{display:inline-flex;align-items:center;gap:var(--space-2);font-size:var(--text-md);font-weight:800;color:var(--color-charcoal)}.live-dice-panel__turn small{color:var(--color-muted);font-weight:700}.live-dice-panel__hint{font-size:var(--text-xs);color:var(--color-muted);font-weight:700}.live-dice-btn--big{padding:var(--space-2)}.live-dice-btn--big .dice-flat-wrap{--dice-px: 120px}.rules-list{display:grid;gap:var(--space-2)}.rules-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border);border-radius:10px;background:var(--color-page-soft);font-size:var(--text-sm)}.rules-row span{color:var(--color-muted);font-weight:700}.rules-row strong{text-align:right}.projector-page--center{display:grid;place-items:center}.projector-header{display:grid;grid-template-columns:minmax(0,1fr) auto auto auto;gap:var(--space-4);align-items:center;margin-bottom:var(--space-4)}.projector-header h1,.projector-header span,.projector-turn span,.projector-roll span{margin:0}.projector-header h1{font-size:clamp(28px,3vw,48px)}.projector-header span,.projector-turn span,.projector-roll span{color:var(--color-muted);font-size:var(--text-sm);font-weight:800;text-transform:uppercase}.projector-turn,.projector-roll,.projector-actions{display:grid;gap:4px;min-width:160px;padding:var(--space-4);border:2px solid var(--live-border);border-radius:16px;background:linear-gradient(145deg,#fff 60%,#2ebccb0a);box-shadow:0 4px 14px #0f172a17}.projector-turn{border-color:#2ebccb59;background:linear-gradient(145deg,#2ebccb12,#fff 60%)}.projector-actions{grid-template-columns:repeat(3,max-content);align-items:center}.projector-roll .dice-flat-wrap{justify-self:start}.projector-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:var(--space-4);align-items:start}.projector-board{position:relative;container-type:inline-size;min-height:660px;overflow:hidden;border:1px solid var(--live-border);border-radius:18px;background:#fff;box-shadow:var(--shadow-md)}.projector-board__image{width:100%;height:100%;min-height:660px;object-fit:contain;display:block}.projector-board__placeholder{min-height:660px;display:grid;place-items:center;color:var(--color-muted);font-size:clamp(32px,5vw,72px);font-weight:900}.projector-board__tile{position:absolute;z-index:2;display:grid;place-items:center;width:clamp(22px,5cqw,42px);height:clamp(22px,5cqw,42px);transform:translate(-50%,-50%);border:clamp(2px,.5cqw,3px) solid #fff;border-radius:50%;background:#e9f7fb;font-size:clamp(8px,1.6cqw,13px);font-weight:900;box-shadow:0 4px 12px #0f172a40}.projector-board__tile--question{background:#f3e8ff}.projector-board__tile--fact{background:#dcfce7}.projector-board__tile--finish{background:#fff3bf}.projector-board__token{position:absolute;z-index:4;display:grid;place-items:center;width:clamp(26px,7cqw,58px);height:clamp(26px,7cqw,58px);transform:translate(-50%,-50%);border:clamp(2px,.6cqw,4px) solid #fff;border-radius:50%;color:#fff;font-size:clamp(11px,2.6cqw,22px);font-weight:900;box-shadow:0 10px 26px #0f172a59;transition:left .26s ease,top .26s ease,transform .18s ease}.projector-sidebar{display:grid;gap:var(--space-4)}.projector-sidebar h2{margin:0;font-size:clamp(22px,2.5vw,32px);background:linear-gradient(135deg,var(--color-brain-teal),var(--color-learning-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.projector-mini-stats{display:flex;gap:var(--space-2);flex-wrap:wrap}.projector-mini-stats span{padding:6px 14px;border-radius:var(--radius-pill);background:linear-gradient(135deg,#2ebccb26,#2ebccb12);border:1px solid rgba(46,188,203,.22);color:var(--color-info-text);font-weight:800;font-size:var(--text-sm)}.projector-score-list,.projector-options{display:grid;gap:var(--space-3)}.projector-score,.projector-option{display:grid;grid-template-columns:auto auto minmax(0,1fr) auto;align-items:center;gap:var(--space-3);padding:var(--space-4);border:2px solid var(--live-border);border-radius:16px;background:linear-gradient(135deg,#fff 55%,#2ebccb08);transition:box-shadow .2s,border-color .2s,transform .2s}.projector-score--current{border-color:var(--color-brain-teal);background:linear-gradient(135deg,#2ebccb1a,#fff 55%);box-shadow:0 0 0 4px #2ebccb2e,0 6px 24px #2ebccb26;transform:translate(4px)}.projector-option--selected{border-color:var(--color-learning-purple);background:#92278f14;box-shadow:0 0 0 3px #92278f1a}.projector-score-rank{display:grid;place-items:center;width:32px;height:32px;border-radius:50%;font-size:var(--text-sm);font-weight:900;background:var(--color-page-soft);color:var(--color-muted);border:2px solid var(--live-border)}.projector-score-rank--1{background:linear-gradient(135deg,gold,#ffb300);color:#7a4f00;border-color:gold;box-shadow:0 2px 10px #ffc10773;font-size:var(--text-base)}.projector-score-rank--2{background:linear-gradient(135deg,#e8e8e8,#b8b8b8);color:#444;border-color:silver}.projector-score-rank--3{background:linear-gradient(135deg,#cd7f32,sienna);color:#fff;border-color:#cd7f32}.projector-score span{width:20px;height:20px;border-radius:50%;border:2px solid rgba(255,255,255,.7);box-shadow:0 2px 6px #0003}.projector-score b{font-size:clamp(28px,3.5vw,44px);font-weight:900;background:linear-gradient(135deg,var(--color-brain-teal),var(--color-learning-purple));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;line-height:1}.projector-popup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:80;display:grid;place-items:center;padding:clamp(16px,4vw,64px);background:#1e25296b}.projector-popup{display:grid;gap:var(--space-3);width:min(720px,100%);max-height:calc(100vh - 64px);overflow:auto;padding:var(--space-5);border-radius:18px;background:#fff;box-shadow:var(--shadow-md)}.projector-popup h2,.projector-popup p{margin:0}.projector-popup h2{font-size:clamp(24px,2.5vw,38px)}.projector-popup .btn{min-height:54px}.projector-popup__actions{display:flex;justify-content:flex-end;gap:var(--space-3);flex-wrap:wrap}.token-mode-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:var(--space-3)}.token-mode-card{display:grid;gap:var(--space-2);min-height:130px;padding:var(--space-4);border:1px solid var(--color-border);border-radius:8px;background:#fff;color:var(--color-text);font:inherit;text-align:left;cursor:pointer}.token-mode-card:hover{border-color:var(--color-learning-purple);box-shadow:0 0 0 3px #92278f1f}.token-mode-card strong{font-size:var(--text-lg)}.token-mode-card span{color:var(--color-muted)}.projector-option{grid-template-columns:42px minmax(0,1fr)}.projector-option span{display:grid;place-items:center;width:34px;height:34px;border-radius:50%;background:var(--color-page-soft);font-weight:900}.projector-error{padding:var(--space-5);border-radius:16px;background:#fff1f2;color:var(--color-smart-red);font-weight:800}.app-sidebar__backdrop{display:none}@media(max-width:1023px){.app-sidebar{transform:translate(-100%);box-shadow:var(--shadow-lg)}.app-shell--nav-open .app-sidebar{transform:translate(0)}.app-shell--nav-open .app-sidebar__backdrop{display:block;position:fixed;top:0;right:0;bottom:0;left:0;z-index:35;background:#34383866}.app-main{margin-left:0}.app-topbar__menu{display:inline-flex}}@media(max-width:767px){.app-content{padding:var(--space-4)}.app-topbar{padding:0 var(--space-4)}.app-topbar__search,.profile-btn__name,.profile-btn__role{display:none}.page-head h1{font-size:var(--text-xl)}.subst-panel{padding:var(--space-4)}.subst-panel__head,.subst-actionbar{align-items:stretch;flex-direction:column}.subst-actionbar__buttons{justify-content:stretch}.subst-actionbar__buttons .btn{flex:1 1 160px}.subst-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.subst-absence-row{grid-template-columns:32px minmax(0,1fr)}.subst-absence-row__remove{grid-column:2;justify-self:start}.subst-period-picks{grid-column:1 / -1}.subst-run{align-items:flex-start;flex-direction:column}.manual-stat-grid,.manual-grid-toolbar,.manual-draft-bar,.manual-editor-conflict__reassign,.import-source-grid,.import-source-block,.teacher-accordion__summary,.teacher-settings-filters,.teacher-settings-form-grid,.teacher-settings-panel-row,.tt-view-controls,.tt-load-grid,.result-filter-grid,.result-download-grid,.result-dashboard-grid,.live-hero-grid,.live-action-row,.live-access-grid,.live-student-review,.live-student-row,.student-status-card,.projector-header,.projector-layout{grid-template-columns:1fr}.live-action-row,.live-action-row--right{align-items:stretch;flex-direction:column}.live-action-row .btn{width:100%}.live-board,.live-board__image,.projector-board,.projector-board__image{min-height:0;height:auto}.live-board__placeholder{min-height:240px}.projector-board__placeholder{min-height:260px}.projector-page{padding:var(--space-3)}.projector-header{gap:var(--space-3);margin-bottom:var(--space-3)}.projector-actions{grid-template-columns:1fr 1fr;gap:var(--space-2)}.projector-actions .btn{width:100%}.projector-turn,.projector-roll{grid-template-columns:1fr;text-align:left}.projector-roll{grid-template-columns:auto 1fr;align-items:center;gap:var(--space-3)}.projector-roll .dice-flat-wrap{--dice-px: 64px}.projector-sidebar{grid-template-columns:1fr}.projector-score b{font-size:var(--text-xl)}.projector-popup{padding:var(--space-4)}.projector-popup h2{font-size:var(--text-xl)}.live-projector-toolbar .dice-flat-wrap{--dice-px: 64px}.live-fullscreen .projector-layout{display:flex;flex-direction:column;gap:var(--space-3)}.live-fullscreen .projector-sidebar{display:contents}.live-fullscreen .projector-sidebar h2,.live-fullscreen .projector-sidebar .projector-mini-stats,.live-fullscreen .live-score-grid{order:1}.live-fullscreen .projector-stage{order:2;width:100%}.live-fullscreen .live-dice-panel{order:3}.live-fullscreen .live-score-grid{grid-template-columns:1fr 1fr;gap:var(--space-2)}.live-fullscreen .live-score-card{padding:var(--space-2) var(--space-3)}.live-fullscreen .live-score-card b{font-size:var(--text-lg)}.live-fullscreen .projector-sidebar h2{margin-bottom:calc(var(--space-2) * -1)}.live-fullscreen .projector-board{height:62vh;min-height:320px;width:100%}.live-fullscreen .projector-board__image{height:100%;min-height:0;object-fit:contain}.live-bar{gap:var(--space-2)}.live-bar__title h1{font-size:var(--text-lg)}.live-bar__turn{padding:4px 10px;font-size:var(--text-sm)}.projector-sidebar h2{font-size:var(--text-lg)}.projector-score{padding:var(--space-2) var(--space-3);border-radius:12px}.live-dice-panel{padding:var(--space-3);gap:var(--space-2)}.live-dice-panel__turn{font-size:var(--text-sm)}.live-dice-btn--big .dice-flat-wrap{--dice-px: 72px}.game-icon-btn{width:38px;height:38px;border-radius:10px}.manual-grid-legend{justify-content:flex-start}.teacher-accordion__limits{grid-template-columns:1fr}}@media(min-width:768px){.form-grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}}.dash{min-height:100vh;background:linear-gradient(180deg,#2ebccb1f,#f6f8fb00 220px),var(--color-page-soft)}.dash__inner{width:100%;max-width:1100px;margin:0 auto;padding:var(--space-8) var(--space-6);display:grid;gap:var(--space-6)}.dash__head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-4)}.dash__id{display:flex;align-items:center;gap:var(--space-4)}.dash__id .avatar{width:52px;height:52px;font-size:var(--text-md)}.dash__eyebrow{margin:0;font-size:var(--text-xs);font-weight:800;letter-spacing:.06em;text-transform:uppercase;color:var(--color-learning-purple)}.dash__title{margin:2px 0;font-size:var(--text-2xl)}.dash__name{margin:0;font-size:var(--text-sm);color:var(--color-muted)}.dash__actions{display:flex;flex-wrap:wrap;gap:var(--space-3)}.child-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:var(--space-4)}.child-card{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-sm)}.child-card strong{font-size:var(--text-md)}.child-card span{font-size:var(--text-xs);color:var(--color-muted)}.dash-info-list{display:grid;gap:var(--space-3)}.dash-info-row{display:flex;gap:var(--space-3);align-items:flex-start}.dash-info-row__icon{display:grid;place-items:center;flex:0 0 auto;width:36px;height:36px;border-radius:10px;background:var(--color-page-soft);color:var(--color-learning-purple)}.dash-info-row strong{display:block;font-size:var(--text-sm)}.dash-info-row p{margin:2px 0 0;font-size:var(--text-xs);color:var(--color-muted)}.audit-pager{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);margin-top:var(--space-3);flex-wrap:wrap}.no-capture{-webkit-user-select:none;user-select:none;-webkit-touch-callout:none}.no-capture img{-webkit-user-drag:none;pointer-events:none}.skip-link{position:absolute;left:-9999px;top:0;z-index:100;padding:var(--space-2) var(--space-4);background:var(--color-learning-purple);color:#fff;font-weight:800;border-radius:0 0 8px}.skip-link:focus{left:0}.app-content:focus{outline:none}.notif,.notif__btn{position:relative}.notif__badge{position:absolute;top:-4px;right:-4px;min-width:16px;height:16px;padding:0 4px;display:grid;place-items:center;border-radius:999px;background:var(--color-smart-red);color:#fff;font-size:10px;font-weight:800;line-height:1}.notif__menu{position:absolute;top:calc(100% + 8px);right:0;width:min(92vw,340px);max-height:60vh;display:flex;flex-direction:column;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-lg);z-index:60;overflow:hidden}.notif__head{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--color-border)}.notif__readall{border:none;background:none;color:var(--color-learning-purple);font-size:var(--text-xs);font-weight:800;cursor:pointer}.notif__list{overflow-y:auto}.notif__empty{padding:var(--space-5);margin:0;text-align:center;color:var(--color-muted);font-size:var(--text-sm)}.notif__item{display:grid;gap:2px;width:100%;text-align:left;padding:var(--space-3) var(--space-4);border:none;border-bottom:1px solid var(--color-border);background:none;cursor:pointer}.notif__item:hover{background:var(--color-page-soft)}.notif__item--unread{background:var(--color-teal-soft)}.notif__title{font-size:var(--text-sm);font-weight:800;color:var(--color-charcoal)}.notif__body{font-size:var(--text-xs);color:var(--color-muted)}.notif__time{font-size:10px;color:var(--color-muted)}.my-tt-table th,.my-tt-table td{text-align:center;vertical-align:middle}.my-tt-table td:first-child,.my-tt-table th:first-child{text-align:left}.my-tt-cell{display:grid;gap:1px}.my-tt-cell strong{font-size:var(--text-xs);font-weight:800}.my-tt-cell span{font-size:10px;color:var(--color-muted)}@media(max-width:767px){.dash__inner{padding:var(--space-5) var(--space-4)}.dash__title{font-size:var(--text-xl)}}.dash-quick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--space-3)}.dash-quick{display:grid;justify-items:start;gap:var(--space-1);padding:var(--space-4);border:1px solid var(--color-border);border-radius:16px;background:linear-gradient(150deg,var(--color-surface) 60%,rgba(46,188,203,.05));color:var(--color-charcoal);text-align:left;cursor:pointer;transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.dash-quick:hover{transform:translateY(-2px);border-color:var(--color-brain-teal);box-shadow:0 10px 26px -14px #0f172a66}.dash-quick__icon{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;margin-bottom:var(--space-1);background:linear-gradient(135deg,var(--color-learning-purple),var(--color-brain-teal));color:#fff}.dash-quick__title{font-size:var(--text-md);font-weight:800;letter-spacing:-.01em}.dash-quick__hint{font-size:var(--text-xs);color:var(--color-muted);font-weight:600}.app-nav__sub{display:grid;gap:2px;margin:2px 0 6px var(--space-6);padding-left:var(--space-2);border-left:2px solid var(--color-border)}.app-nav__sub .app-nav__link{min-height:34px;font-size:var(--text-xs);font-weight:700;padding-left:var(--space-3)}.app-sidebar__collapse{margin-left:auto;width:26px;height:26px;display:grid;place-items:center;border:1px solid var(--color-border);border-radius:8px;background:var(--color-surface);color:var(--color-muted);font-size:var(--text-md);line-height:1;cursor:pointer}.app-sidebar__collapse:hover{color:var(--color-charcoal);border-color:var(--color-learning-purple)}.app-sidebar,.app-nav{overflow-x:hidden}.app-nav__link{white-space:nowrap;overflow:hidden}.app-nav__text{overflow:hidden;text-overflow:ellipsis}.app-nav__caret{margin-left:auto;flex:0 0 auto;font-size:var(--text-lg);line-height:1;color:var(--color-muted);transition:transform .16s ease}.app-nav__caret--open{transform:rotate(90deg)}.app-shell--collapsed{--sidebar-width: 72px}.app-shell--collapsed .app-sidebar__brand-name,.app-shell--collapsed .app-sidebar__context,.app-shell--collapsed .app-nav__group-label,.app-shell--collapsed .app-nav__text,.app-shell--collapsed .app-nav__caret,.app-shell--collapsed .app-nav__sub,.app-shell--collapsed .app-sidebar__foot>div{display:none}.app-shell--collapsed .app-nav__link{justify-content:center;padding:0;gap:0}.app-shell--collapsed .app-sidebar__brand{justify-content:center;gap:0;padding:var(--space-4) 0}.app-shell--collapsed .app-sidebar__collapse{margin:0}.app-shell--collapsed .app-sidebar__foot{justify-content:center}@media(max-width:1023px){.app-shell--collapsed{--sidebar-width: 264px}}.toast-region{position:fixed;z-index:90;right:max(var(--space-4),env(safe-area-inset-right));bottom:max(var(--space-4),env(safe-area-inset-bottom));display:flex;flex-direction:column;gap:var(--space-2);width:min(360px,calc(100vw - 2 * var(--space-4)));pointer-events:none}.toast{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-3) var(--space-4);border:1px solid var(--color-border);border-left-width:4px;border-radius:12px;background:var(--color-surface);color:var(--color-charcoal);box-shadow:var(--shadow-lg);font-size:var(--text-sm);font-weight:700;pointer-events:auto;animation:toast-in .2s ease}.toast--success{border-left-color:var(--color-growth-lime)}.toast--error{border-left-color:var(--color-smart-red)}.toast--warning{border-left-color:var(--color-spark-yellow)}.toast--info{border-left-color:var(--color-brain-teal)}.toast__msg{flex:1 1 auto}.toast__close{flex:0 0 auto;border:0;background:transparent;color:var(--color-muted);font-size:var(--text-lg);line-height:1;cursor:pointer;padding:0}@keyframes toast-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.toast{animation:none}}.error-boundary{min-height:60vh;display:grid;place-items:center;padding:var(--space-6)}.error-boundary__card{width:min(100%,460px);display:grid;gap:var(--space-3);padding:var(--space-6);border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-lg);text-align:center}.error-boundary__card h1{margin:0;font-size:var(--text-xl)}.error-boundary__actions{display:flex;justify-content:center;gap:var(--space-3);margin-top:var(--space-2)}.app-sidebar{padding-left:env(safe-area-inset-left)}.app-topbar{padding-right:max(var(--space-4),env(safe-area-inset-right))}
