:root{--cream:#fff6e5;--cream-2:#ffefcf;--paper:#fff;--ink:#1b1733;--ink-2:#3b3458;--ink-3:#6b6486;--line:#e9e1cc;--surface:#fff;--surface-2:#f3f4f6;--surface-hover:var(--cream-2);--sidebar-bg:linear-gradient(180deg, #fff 0%, #fff8e8 100%);--red:#ff4d5e;--red-deep:#c8313f;--blue:#2d74ff;--blue-deep:#1b4fcc;--green:#1fb573;--green-deep:#138756;--orange:#ff8a1f;--orange-deep:#cc6a0f;--purple:#7b3ff2;--purple-deep:#5826bf;--yellow:#ffc845;--shadow-sm:0 2px 0 #1b173314;--shadow-btn:0 4px 0 #1b17332e;--shadow-card:0 6px 0 #1b17330f, 0 12px 28px #1b17330f;--shadow-pop:0 14px 40px #1b17332e;--radius-sm:12px;--radius:18px;--radius-lg:26px;--radius-xl:36px;--font-display:"Outfit", system-ui, -apple-system, sans-serif;--font-body:"Inter", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, SFMono-Regular, monospace;--bg-cream:var(--cream);--bg-card:var(--paper);--bg-overlay:#1b17338c;--text-dark:var(--ink);--text-medium:var(--ink-2);--text-light:var(--ink-3);--text-white:#fff;--z-base:1;--z-dropdown:10;--z-modal:100;--z-overlay:200;--z-toast:300}[data-theme=dark]{--cream:#13111c;--cream-2:#1c192a;--paper:#1a1726;--ink:#f0ecf9;--ink-2:#c2bad6;--ink-3:#8a82a0;--line:#2e2943;--surface:#201d2e;--surface-2:#1c192a;--surface-hover:#2a2640;--sidebar-bg:linear-gradient(180deg, #1a1726 0%, #13111c 100%);--red:#ff6573;--red-deep:#ff4d5e;--blue:#4d8aff;--blue-deep:#2d74ff;--green:#30d68a;--green-deep:#1fb573;--orange:#ffa04d;--orange-deep:#ff8a1f;--purple:#96f;--purple-deep:#7b3ff2;--yellow:#ffd466;--shadow-sm:0 2px 0 #0003;--shadow-btn:0 4px 0 #0000004d;--shadow-card:0 6px 0 #00000026, 0 12px 28px #00000026;--shadow-pop:0 14px 40px #00000059;--bg-cream:var(--cream);--bg-card:var(--paper);--bg-overlay:#0009;--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark}*{box-sizing:border-box}html,body{font-family:var(--font-body);color:var(--ink);background:var(--cream);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;margin:0;padding:0}body{background:radial-gradient(1200px 600px at 90% -10%, #ffe3b8 0%, transparent 50%), radial-gradient(900px 500px at -10% 100%, #ffd4da 0%, transparent 55%), var(--cream);min-height:100vh}#root{z-index:var(--z-base);min-height:100vh;position:relative}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,textarea,select{font-family:inherit}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--cream)}::-webkit-scrollbar-thumb{background:var(--line);border-radius:100px}::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}::selection{color:var(--ink);background:#ff4d5e33}:focus-visible{outline:3px solid var(--blue);outline-offset:2px;border-radius:var(--radius-sm)}a{color:var(--blue);font-weight:600;text-decoration:none}a:hover{color:var(--blue-deep)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--ink);margin:0;font-weight:700;line-height:1.2}.btn{white-space:nowrap;border-radius:14px;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:600;transition:transform .1s,box-shadow .1s;display:inline-flex}.btn:active{transform:translateY(2px)}.btn-primary{background:var(--ink);color:var(--cream);box-shadow:var(--shadow-btn)}.btn-primary:active{box-shadow:0 2px #1b17332e}.btn-accent{background:var(--red);color:#fff;box-shadow:0 4px 0 var(--red-deep)}.btn-accent:active{box-shadow:0 2px 0 var(--red-deep)}.btn-green{background:var(--green);color:#fff;box-shadow:0 4px 0 var(--green-deep)}.btn-green:active{box-shadow:0 2px 0 var(--green-deep)}.btn-ghost{color:var(--ink);border:1px solid var(--line);background:#fff}.btn-ghost:hover{background:var(--cream-2)}.btn-lg{border-radius:16px;padding:16px 28px;font-size:16px}.icon-btn{border:1px solid var(--line);background:#fff;border-radius:12px;place-items:center;width:42px;height:42px;font-size:18px;display:grid}.icon-btn:hover{background:var(--cream-2)}.tag{background:var(--cream-2);color:var(--ink-2);border-radius:100px;align-items:center;gap:6px;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.tag.math{color:var(--blue-deep);background:#e5eeff}.tag.sci{color:var(--green-deep);background:#ddf5e8}.tag.ela{color:var(--red-deep);background:#ffe3e6}.tag.soc{color:var(--purple-deep);background:#f0e5ff}.tag.art{color:var(--orange-deep);background:#ffeacc}.dot{background:var(--green);border-radius:50%;width:8px;height:8px;display:inline-block}.badge{border-radius:100px;align-items:center;padding:4px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-green{color:var(--green-deep);background:#1fb5731f}.badge-red{color:var(--red-deep);background:#ff4d5e1f}.badge-blue{color:var(--blue-deep);background:#2d74ff1f}.badge-orange{color:var(--orange-deep);background:#ff8a1f1f}.badge-purple{color:var(--purple-deep);background:#7b3ff21f}.input,.select{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:14px;padding:14px 16px;font-size:14px;font-weight:500;transition:border-color .1s,box-shadow .1s}.input:focus,.select:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 4px #1b173314}input,select,textarea{font-family:var(--font-body);border:1px solid var(--line);color:var(--ink);background:#fff;border-radius:14px;width:100%;padding:14px 16px;font-size:14px;transition:border-color .1s,box-shadow .1s}input:focus,select:focus,textarea:focus{border-color:var(--ink);outline:none;box-shadow:0 0 0 4px #1b173314}input::placeholder,textarea::placeholder{color:var(--ink-3)}select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236B6486' d='M6 8.825L1.175 4 2.238 2.938 6 6.7 9.763 2.938 10.825 4z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}select option{color:var(--ink);background:#fff}.loading-spinner{border:4px solid var(--line);border-top-color:var(--ink);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes popIn{0%{opacity:0;transform:translateY(20px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}@keyframes wiggle{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes pop{0%{opacity:0;transform:scale(.8)}50%{transform:scale(1.05)}to{opacity:1;transform:scale(1)}}@keyframes shake{0%,to{transform:translate(0)}20%,60%{transform:translate(-6px)}40%,80%{transform:translate(6px)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes confettiFall{0%{opacity:1;transform:translateY(-20px)rotate(0)}to{opacity:0;transform:translateY(420px)rotate(540deg)}}@keyframes scorePopup{0%{opacity:0;transform:translateY(0)scale(.5)}30%{opacity:1;transform:translateY(-20px)scale(1.2)}to{opacity:0;transform:translateY(-50px)scale(1)}}.mobile-menu-btn{z-index:201;background:var(--surface);border:1px solid var(--line);width:44px;height:44px;box-shadow:var(--shadow-sm);cursor:pointer;border-radius:12px;justify-content:center;align-items:center;font-size:20px;transition:background .2s;display:none;position:fixed;top:14px;left:14px}.mobile-menu-btn:hover{background:var(--cream-2)}@media (width<=820px){.app-shell{grid-template-columns:1fr}.sidebar{z-index:300;width:280px;height:100vh;box-shadow:none;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0);box-shadow:16px 0 48px #00000026}.mobile-backdrop{z-index:299;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0006;animation:.2s fadeIn;display:none;position:fixed;inset:0}.mobile-backdrop.show{display:block}.mobile-menu-btn{display:flex}.main{padding-top:64px}.topbar{padding-left:54px}}html,body,.sidebar,.btn-ghost,.icon-btn,.section,input,select,textarea,.modal,.data-table,.tag{transition:background .3s,color .3s,border-color .3s,box-shadow .3s}[data-theme=dark] body{background:radial-gradient(1200px 600px at 90% -10%, #7b3ff214 0%, transparent 50%), radial-gradient(900px 500px at -10% 100%, #2d74ff0f 0%, transparent 55%), var(--cream)}[data-theme=dark] .btn-ghost{background:var(--surface);border-color:var(--line);color:var(--ink)}[data-theme=dark] .btn-ghost:hover{background:var(--surface-hover)}[data-theme=dark] .btn-primary{background:var(--purple);color:#fff;box-shadow:0 4px 0 var(--purple-deep)}[data-theme=dark] .icon-btn{background:var(--surface);border-color:var(--line)}[data-theme=dark] .icon-btn:hover{background:var(--surface-hover)}[data-theme=dark] input,[data-theme=dark] select,[data-theme=dark] textarea{background:var(--surface);border-color:var(--line);color:var(--ink)}[data-theme=dark] input:focus,[data-theme=dark] select:focus,[data-theme=dark] textarea:focus{border-color:var(--purple);box-shadow:0 0 0 4px #7b3ff226}[data-theme=dark] select option{background:var(--surface);color:var(--ink)}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--cream)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--line)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--ink-3)}[data-theme=dark] ::selection{color:var(--ink);background:#7b3ff24d}[data-theme=dark] .loading-spinner{border-color:var(--line);border-top-color:var(--purple)}.app-shell{grid-template-columns:260px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);background:linear-gradient(#fff 0%,#fff8e8 100%);flex-direction:column;gap:18px;height:100vh;padding:22px 18px;display:flex;position:sticky;top:0;overflow:hidden}.brand{border-bottom:1px dashed var(--line);align-items:center;gap:12px;padding:6px 8px 14px;display:flex}.brand-mark{background:var(--ink);width:44px;height:44px;color:var(--cream);font-family:var(--font-display);box-shadow:var(--shadow-btn);border-radius:14px;place-items:center;font-size:22px;font-weight:800;display:grid;position:relative;transform:rotate(-4deg)}.brand-mark:after{content:"";border:2px dashed #ffffff40;border-radius:10px;position:absolute;inset:4px}.brand-text{font-family:var(--font-display);letter-spacing:-.02em;font-size:20px;font-weight:800;line-height:1}.brand-text small{font-family:var(--font-body);color:var(--ink-3);letter-spacing:.06em;text-transform:uppercase;margin-top:4px;font-size:11px;font-weight:500;display:block}.nav{flex-direction:column;flex:1;gap:4px;min-height:0;display:flex;overflow-y:auto}.nav-section{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:14px 10px 6px;font-size:11px;font-weight:600}.nav-item{color:var(--ink-2);text-align:left;border-radius:12px;align-items:center;gap:12px;width:100%;padding:10px 12px;font-size:14px;font-weight:500;transition:background .15s,color .15s;display:flex}.nav-item:hover{background:#1b17330a}.nav-item.active{background:var(--ink);color:var(--cream);font-weight:600}.nav-icon{place-items:center;width:22px;height:22px;font-size:16px;display:grid}.sidebar-footer{flex-direction:column;gap:10px;margin-top:auto;display:flex}.classroom-card{background:var(--cream-2);border:1px solid var(--line);border-radius:var(--radius);padding:14px}.classroom-card .label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:10px;font-weight:700}.classroom-card .name{font-family:var(--font-display);margin:4px 0 8px;font-size:16px;font-weight:700}.classroom-card .meta{color:var(--ink-2);gap:8px;font-size:12px;display:flex}.classroom-card .meta span{background:#fff;border-radius:100px;padding:3px 8px;font-weight:500}.user-row{cursor:pointer;border-radius:12px;align-items:center;gap:10px;padding:8px;display:flex}.user-row:hover{background:#1b17330a}.user-avatar{background:linear-gradient(135deg, var(--purple), var(--blue));color:#fff;width:36px;height:36px;font-family:var(--font-display);border-radius:12px;place-items:center;font-size:14px;font-weight:700;display:grid}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--ink-3);font-size:11px}.main{min-width:0;padding:28px 36px 80px}.topbar{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.topbar h1{font-family:var(--font-display);letter-spacing:-.02em;margin:0;font-size:32px;font-weight:800;line-height:1.1}.topbar .greeting{color:var(--ink-3);margin-top:4px;font-size:14px}.hero-grid{grid-template-columns:1.5fr 1fr 1fr;gap:18px;margin-bottom:28px;display:grid}.hero-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:#fff;padding:24px;position:relative;overflow:hidden}.hero-card.dark{background:var(--ink);color:var(--cream);border:none}.hero-card .eyebrow{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.hero-card.dark .eyebrow{color:#fff6e599}.hero-card .stat{font-family:var(--font-display);letter-spacing:-.04em;margin:14px 0 6px;font-size:56px;font-weight:800;line-height:1}.hero-card .stat-sub{color:var(--ink-3);font-size:13px}.hero-card.dark .stat-sub{color:#fff6e5b3}.hero-card .delta{color:var(--green-deep);background:#1fb5731f;border-radius:100px;align-items:center;gap:4px;margin-top:6px;padding:4px 10px;font-size:12px;font-weight:600;display:inline-flex}.hero-card .corner-badge{border-radius:12px;place-items:center;width:38px;height:38px;font-size:18px;display:grid;position:absolute;top:18px;right:18px}.hero-card.feature{background:linear-gradient(135deg, var(--red) 0%, var(--orange) 100%);color:#fff;border:none;flex-direction:column;justify-content:space-between;min-height:200px;display:flex}.hero-card.feature .eyebrow{color:#fffc}.hero-card.feature h3{font-family:var(--font-display);letter-spacing:-.02em;max-width:280px;margin:12px 0 0;font-size:28px;font-weight:800;line-height:1.1}.hero-card.feature .pattern{background:radial-gradient(circle,#ffffff2e 0%,#0000 60%);border-radius:50%;width:220px;height:220px;position:absolute;bottom:-40px;right:-40px}.feature-cta{color:var(--red-deep);background:#fff;border-radius:14px;align-self:flex-start;align-items:center;gap:8px;padding:12px 20px;font-size:14px;font-weight:700;display:inline-flex;box-shadow:0 4px #0000002e}.section{margin-bottom:36px}.section-head{justify-content:space-between;align-items:baseline;margin-bottom:16px;display:flex}.section-title{font-family:var(--font-display);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.section-link{color:var(--ink-2);font-size:13px;font-weight:600}.tile-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;display:grid}.game-tile{border-radius:var(--radius-lg);cursor:pointer;color:#fff;text-align:left;border:none;flex-direction:column;justify-content:space-between;min-height:200px;padding:20px;transition:transform .15s,box-shadow .15s;display:flex;position:relative;overflow:hidden}.game-tile:hover{box-shadow:var(--shadow-pop);transform:translateY(-3px)}.game-tile .tile-emoji{font-size:44px;line-height:1}.game-tile h3{font-family:var(--font-display);letter-spacing:-.02em;color:inherit;margin:0 0 4px;font-size:22px;font-weight:800}.game-tile p{opacity:.85;color:inherit;margin:0;font-size:13px;line-height:1.4}.game-tile .tile-bottom{justify-content:space-between;align-items:center;margin-top:14px;display:flex}.game-tile .tile-pill{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffff38;border-radius:100px;padding:4px 10px;font-size:11px;font-weight:600}.game-tile .tile-arrow{background:#ffffff38;border-radius:50%;place-items:center;width:32px;height:32px;transition:transform .15s;display:grid}.game-tile:hover .tile-arrow{transform:translate(2px)}.tile-action-btn{cursor:pointer;opacity:0;background:#fff3;border:none;border-radius:8px;place-items:center;width:28px;height:28px;font-size:13px;transition:all .15s;display:grid}.game-tile:hover .tile-action-btn{opacity:1}.tile-action-btn:hover{background:#ffffff73;transform:scale(1.15)}.lib-menu-item{text-align:left;cursor:pointer;width:100%;color:var(--ink);background:0 0;border:none;padding:10px 14px;font-size:13px;font-weight:600;transition:background .1s;display:block}.lib-menu-item:hover{background:var(--surface-2,#f3f4f6)}.tile-quiz{background:linear-gradient(140deg,#ff4d5e,#ff7a6b)}.tile-memory{background:linear-gradient(140deg,#2d74ff,#5ba0ff)}.tile-boss{background:linear-gradient(140deg,#7b3ff2,#b47bff)}.tile-scramble{background:linear-gradient(140deg,#ff8a1f,#ffb04a)}.tile-speed{background:linear-gradient(140deg,#1fb573,#4fd89a)}.tile-spin{color:var(--ink);background:linear-gradient(140deg,#ffc845,#ff8a1f)}.tile-spin p{color:#1b1733a6}.tile-spin .tile-pill,.tile-spin .tile-arrow{color:var(--ink);background:#1b17331f}.tile-board{background:linear-gradient(140deg,#1b1733,#3f3666)}.tile-trivia{background:linear-gradient(140deg,#5826bf,#7b3ff2)}.tile-pattern{pointer-events:none;background:radial-gradient(circle,#ffffff29 0%,#0000 65%);border-radius:50%;width:160px;height:160px;position:absolute;top:-30px;right:-30px}.list-card{border-radius:var(--radius-lg);border:1px solid var(--line);background:#fff;overflow:hidden}.list-row{border-bottom:1px solid var(--line);grid-template-columns:50px 1.5fr 1fr 1fr 1fr auto;align-items:center;gap:16px;padding:14px 20px;transition:background .1s;display:grid}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--cream)}.list-row.list-head{letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);background:var(--cream-2);font-size:11px;font-weight:700}.list-row.list-head:hover{background:var(--cream-2)}.list-icon{border-radius:12px;place-items:center;width:40px;height:40px;font-size:20px;display:grid}.list-game{font-size:14px;font-weight:600}.list-meta{color:var(--ink-3);margin-top:2px;font-size:12px}.list-cell{color:var(--ink-2);font-size:13px}.list-cell.num{font-family:var(--font-display);color:var(--ink);font-size:16px;font-weight:700}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:100;background:#1b17338c;place-items:center;padding:24px;animation:.2s fadeIn;display:grid;position:fixed;inset:0}.modal{background:var(--cream);border-radius:var(--radius-xl);width:min(960px,100%);max-height:90vh;box-shadow:var(--shadow-pop);flex-direction:column;animation:.25s popIn;display:flex;overflow:hidden}.modal-head{border-bottom:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;padding:20px 28px;display:flex}.modal-head h2{font-family:var(--font-display);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:800}.close-btn{background:var(--cream-2);cursor:pointer;border:none;border-radius:12px;place-items:center;width:38px;height:38px;font-size:16px;font-weight:700;display:grid}.modal-body{flex:1;padding:28px;overflow-y:auto}.modal-foot{border-top:1px solid var(--line);background:#fff;justify-content:space-between;align-items:center;padding:18px 28px;display:flex}.data-table-wrap{border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;overflow:hidden}.data-table-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:18px 24px;display:flex}.data-table-header h3{font-family:var(--font-display);font-size:18px;font-weight:700}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--ink-3);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--line);background:var(--cream-2);padding:12px 24px;font-size:11px;font-weight:700}.data-table td{border-bottom:1px solid var(--line);color:var(--ink-2);padding:12px 24px;font-size:14px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--cream)}.form-group{margin-bottom:18px}.form-group label{letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);margin-bottom:8px;font-size:12px;font-weight:700;display:block}.form-row{grid-template-columns:1fr 1fr;gap:18px;display:grid}.stat-card{border:1px solid var(--line);border-radius:var(--radius-lg);background:#fff;padding:24px;position:relative;overflow:hidden}.stat-card:before{content:"";border-radius:var(--radius-lg) var(--radius-lg) 0 0;height:4px;position:absolute;top:0;left:0;right:0}.stat-card.red:before{background:linear-gradient(90deg, var(--red), var(--orange))}.stat-card.green:before{background:linear-gradient(90deg, var(--green), #4fd89a)}.stat-card.blue:before{background:linear-gradient(90deg, var(--blue), #5ba0ff)}.stat-card.orange:before{background:linear-gradient(90deg, var(--orange), var(--yellow))}.stat-card.purple:before{background:linear-gradient(90deg, var(--purple), #b47bff)}.stat-card .stat-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:48px;height:48px;margin-bottom:14px;font-size:22px;display:flex}.stat-card.red .stat-icon{background:#ff4d5e1a}.stat-card.green .stat-icon{background:#1fb5731a}.stat-card.blue .stat-icon{background:#2d74ff1a}.stat-card.orange .stat-icon{background:#ff8a1f1a}.stat-card.purple .stat-icon{background:#7b3ff21a}.stat-card .stat-value{font-family:var(--font-display);margin-bottom:4px;font-size:36px;font-weight:800;line-height:1}.stat-card .stat-label{color:var(--ink-3);font-size:13px}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 24px;display:flex}.empty-state .empty-icon{margin-bottom:18px;font-size:56px}.empty-state .empty-title{font-family:var(--font-display);margin-bottom:8px;font-size:22px;font-weight:800}.empty-state .empty-desc{color:var(--ink-3);max-width:360px;margin-bottom:24px;font-size:14px}.lang-selector{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:100px;align-items:center;gap:8px;padding:6px 14px;font-size:13px;font-weight:600;display:flex}.lang-selector:hover{background:var(--cream-2)}.fab{z-index:50;background:var(--red);color:#fff;box-shadow:0 8px 0 var(--red-deep), 0 12px 30px #ff4d5e66;border-radius:100px;align-items:center;gap:10px;padding:16px 24px;font-size:15px;font-weight:700;display:inline-flex;position:fixed;bottom:28px;right:28px}.fab:active{box-shadow:0 2px 0 var(--red-deep), 0 6px 16px #ff4d5e66}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:18px;margin-bottom:28px;display:grid}.page-header{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:var(--z-dropdown);background:#fff6e5d9;justify-content:space-between;align-items:center;padding:20px 28px;display:flex;position:sticky;top:0}.page-header h1{font-family:var(--font-display);font-size:24px;font-weight:800}.page-header .header-subtitle{color:var(--ink-3);margin-top:2px;font-size:13px}.page-header .header-actions{align-items:center;gap:10px;display:flex}.page-body{padding:28px 36px}.main-content{flex:1;min-height:100vh;margin-left:260px}.app-layout{min-height:100vh;display:flex}@media (width<=1100px){.hero-grid{grid-template-columns:1fr 1fr}.hero-card.feature{grid-column:span 2}}@media (width<=820px){.app-shell{grid-template-columns:1fr}.sidebar{display:none}.hero-grid{grid-template-columns:1fr}.hero-card.feature{grid-column:auto}}@media (width<=1024px){.sidebar{z-index:var(--z-dropdown);transition:transform .3s;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0}}@media (width<=768px){.page-body{padding:18px}.page-header{padding:16px 18px}.form-row{grid-template-columns:1fr}.main{padding:16px 14px 60px}.topbar h1{font-size:24px}.stats-grid{grid-template-columns:1fr 1fr;gap:10px}.stat-card{padding:16px}.stat-card .stat-value{font-size:28px}.stat-card .stat-icon{width:38px;height:38px;margin-bottom:10px;font-size:18px}.data-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.data-table{min-width:520px}.data-table th,.data-table td{padding:10px 14px;font-size:12px}.tile-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}.game-tile{min-height:160px;padding:14px}.game-tile h3{font-size:17px}.game-tile .tile-emoji{font-size:32px}.list-row{grid-template-columns:40px 1fr auto;gap:10px;padding:10px 14px}.list-row .list-cell:nth-child(n+4){display:none}.modal{border-radius:16px;width:min(100%,100vw);max-height:100vh}.modal-head{padding:14px 18px}.modal-body{padding:18px}.modal-foot{padding:14px 18px}.fab{padding:12px 18px;font-size:14px;bottom:16px;right:16px}}@media (width<=480px){.stats-grid{grid-template-columns:1fr}.hero-card .stat{font-size:40px}.topbar{flex-direction:column;align-items:flex-start;gap:8px}}[data-theme=dark] .sidebar{background:var(--sidebar-bg);border-right-color:var(--line)}[data-theme=dark] .brand-mark{background:var(--purple)}[data-theme=dark] .nav-item:hover{background:var(--surface-hover)}[data-theme=dark] .nav-item.active{background:var(--surface)}[data-theme=dark] .section,[data-theme=dark] .stat-card,[data-theme=dark] .hero-card,[data-theme=dark] .game-tile{background:var(--surface);border-color:var(--line)}[data-theme=dark] .game-tile:hover{border-color:var(--purple)}[data-theme=dark] .data-table th{background:var(--cream-2);border-color:var(--line)}[data-theme=dark] .data-table td{border-color:var(--line)}[data-theme=dark] .data-table tr:hover td{background:var(--surface-hover)}[data-theme=dark] .modal-backdrop{background:var(--bg-overlay)}[data-theme=dark] .modal{background:var(--paper);border:1px solid var(--line)}[data-theme=dark] .modal-head{border-bottom-color:var(--line)}[data-theme=dark] .modal-foot{border-top-color:var(--line)}[data-theme=dark] .list-row{background:var(--surface);border-color:var(--line)}[data-theme=dark] .list-row:hover{background:var(--surface-hover)}[data-theme=dark] .empty-state{background:var(--surface);border-color:var(--line)}[data-theme=dark] .tab-bar button{color:var(--ink-3)}[data-theme=dark] .tab-bar button.active{color:var(--ink);border-bottom-color:var(--purple)}[data-theme=dark] .form-group label{color:var(--ink-2)}[data-theme=dark] .fab{background:var(--purple);box-shadow:0 6px 0 var(--purple-deep)}.gm-screen{z-index:200;color:var(--ink);background:radial-gradient(1200px 600px at 90% -10%, #ffe3b8 0%, transparent 50%), radial-gradient(900px 500px at -10% 100%, #ffd4da 0%, transparent 55%), var(--cream);flex-direction:column;padding:18px 28px 28px;display:flex;position:fixed;inset:0;overflow:hidden}.gm-screen.dark{color:#fff;background:radial-gradient(1400px 700px at 50% -10%,#2d74ff 0%,#1b1733 60%)}.gm-screen.purple{color:#fff;background:radial-gradient(1400px 700px at 50% -10%,#7b3ff2 0%,#1b1733 60%)}.gm-screen.crimson{color:#fff;background:radial-gradient(1400px 700px at 50% -10%,#ff4d5e 0%,#1b1733 60%)}.gm-screen.green{color:#fff;background:radial-gradient(1400px 700px at 50% -10%,#1fb573 0%,#0e3d2a 60%)}.gm-screen.gold{color:var(--ink);background:radial-gradient(1400px 700px at 50% -10%,#ffc845 0%,#ff8a1f 60%)}.gm-top{flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.gm-top .live-pill{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:inherit;background:#ffffff1f;border:1px solid #ffffff2e}.gm-screen:not(.dark):not(.purple):not(.crimson):not(.green):not(.gold) .gm-top .live-pill{color:var(--ink);border:1px solid var(--line);-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff}.gm-stat{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff1f;border:1px solid #ffffff2e;border-radius:100px;align-items:center;gap:8px;padding:8px 14px;font-size:13px;font-weight:600;display:inline-flex}.gm-screen:not(.dark):not(.purple):not(.crimson):not(.green):not(.gold) .gm-stat{border:1px solid var(--line);color:var(--ink-2);-webkit-backdrop-filter:none;backdrop-filter:none;background:#fff}.gm-stat strong{font-family:var(--font-display);font-size:16px;font-weight:800}.gm-stage{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:24px;min-height:0;display:flex}.mm-board{grid-template-columns:repeat(4,minmax(120px,180px));grid-auto-rows:minmax(100px,160px);gap:12px;width:100%;max-width:800px;padding:0 12px;display:grid}.mm-card{perspective:1000px;cursor:pointer}.mm-inner{width:100%;height:100%;transform-style:preserve-3d;border-radius:18px;transition:transform .5s;position:relative}.mm-card.flipped .mm-inner,.mm-card.matched .mm-inner{transform:rotateY(180deg)}.mm-face{backface-visibility:hidden;text-align:center;word-break:break-word;border-radius:18px;flex-direction:column;justify-content:center;align-items:center;padding:8px;font-size:12px;font-weight:700;display:flex;position:absolute;inset:0;overflow:hidden;box-shadow:0 6px #0000002e}.mm-face.back{background:linear-gradient(135deg, var(--purple), var(--blue));color:#fff;font-family:var(--font-display);font-size:36px}.mm-face.front{color:var(--ink);font-family:var(--font-display);background:#fff;gap:4px;font-size:11px;line-height:1.3;transform:rotateY(180deg)}.mm-card.matched .mm-face.front{border:2px solid var(--green);background:linear-gradient(135deg,#ddf5e8,#b8e8c8)}.mm-q{color:var(--ink-3);text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;font-size:9px;font-weight:600}.bb-arena{grid-template-columns:1fr 1fr;align-items:end;gap:28px;width:100%;max-width:980px;display:grid}.bb-fighter{text-align:center}.bb-portrait{border-radius:36px;place-items:center;width:220px;height:220px;margin:0 auto;font-size:120px;transition:transform .2s;display:grid;position:relative;box-shadow:0 12px #0000004d}.bb-portrait.player{background:linear-gradient(135deg,#2d74ff,#5ba0ff)}.bb-portrait.boss{background:linear-gradient(135deg,#c8313f,#ff4d5e)}.bb-portrait.hit{animation:.4s hitShake}@keyframes hitShake{0%,to{transform:translate(0)}25%{transform:translate(-12px,4px)rotate(-3deg)}75%{transform:translate(12px,-4px)rotate(3deg)}}.bb-name{font-family:var(--font-display);letter-spacing:-.01em;margin-top:14px;font-size:22px;font-weight:800}.bb-hp{background:#0000004d;border:2px solid #fff3;border-radius:100px;height:20px;margin-top:10px;position:relative;overflow:hidden}.bb-hp-fill{background:linear-gradient(90deg, var(--green), #4fd89a);border-radius:100px;height:100%;transition:width .5s}.bb-hp-fill.boss{background:linear-gradient(90deg, var(--red), #ff8a1f)}.bb-hp-fill.low{background:linear-gradient(90deg, var(--red), #c8313f)}.bb-hp-text{font-family:var(--font-display);color:#fff;text-shadow:0 1px 2px #00000080;place-items:center;font-size:12px;font-weight:800;display:grid;position:absolute;inset:0}.bb-vs{text-align:center;font-family:var(--font-display);color:var(--yellow);text-shadow:0 4px #0000004d;font-size:48px;font-weight:800}.bb-damage{font-family:var(--font-display);color:var(--yellow);text-shadow:0 4px 0 var(--orange-deep);pointer-events:none;z-index:5;font-size:56px;font-weight:800;animation:1s ease-out forwards damageFly;position:absolute}@keyframes damageFly{0%{opacity:0;transform:translateY(0)scale(.5)}30%{opacity:1;transform:translateY(-30px)scale(1.2)}to{opacity:0;transform:translateY(-100px)scale(1)}}.bb-explosion{pointer-events:none;font-size:80px;animation:.6s ease-out forwards explode;position:absolute}@keyframes explode{0%{opacity:1;transform:scale(0)}to{opacity:0;transform:scale(2)}}.ws-prompt{font-family:var(--font-display);text-align:center;max-width:600px;color:inherit;opacity:.92;font-size:22px;font-weight:700;line-height:1.3}.ws-slots{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.ws-slot{width:64px;height:80px;font-family:var(--font-display);color:#fff;text-transform:uppercase;background:#ffffff1a;border:2px dashed #ffffff4d;border-radius:14px;place-items:center;font-size:36px;font-weight:800;display:grid}.ws-slot.filled{color:var(--ink);background:#fff;border:none;box-shadow:0 6px #0003}.ws-slot.correct{background:var(--green);color:#fff;box-shadow:0 6px 0 var(--green-deep);border:none}.ws-slot.wrong{background:var(--red);color:#fff;box-shadow:0 6px 0 var(--red-deep);border:none;animation:.4s shake}.ws-tray{flex-wrap:wrap;justify-content:center;gap:10px;max-width:720px;display:flex}.ws-tile{width:56px;height:64px;color:var(--ink);font-family:var(--font-display);text-transform:uppercase;cursor:pointer;background:linear-gradient(#fff,#fff6e5);border-radius:12px;font-size:28px;font-weight:800;transition:transform .1s;box-shadow:0 5px #0000002e}.ws-tile:hover:not(:disabled){transform:translateY(-2px)}.ws-tile:active:not(:disabled){transform:translateY(2px);box-shadow:0 2px #0000002e}.ws-tile:disabled{opacity:.25;cursor:default}.sm-card-stack{width:360px;height:460px;position:relative}.sm-card{color:var(--ink);background:#fff;border-radius:28px;flex-direction:column;justify-content:space-between;padding:28px;transition:transform .4s,opacity .4s;display:flex;position:absolute;inset:0;box-shadow:0 12px #00000026,0 24px 60px #0003}.sm-card .sm-q-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.sm-card .sm-q-text{font-family:var(--font-display);letter-spacing:-.01em;margin-top:10px;font-size:22px;font-weight:700;line-height:1.3}.sm-divider{background:var(--cream-2);border-radius:2px;height:2px;margin:18px 0}.sm-card .sm-a-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.sm-card .sm-a-text{font-family:var(--font-display);letter-spacing:-.02em;color:var(--ink);margin-top:8px;font-size:36px;font-weight:800;line-height:1.1}.sm-card.swipe-right{opacity:0;transform:translate(420px)rotate(20deg)}.sm-card.swipe-left{opacity:0;transform:translate(-420px)rotate(-20deg)}.sm-stamp{font-family:var(--font-display);letter-spacing:.1em;opacity:0;border:3px solid;border-radius:14px;padding:8px 16px;font-size:14px;font-weight:800;position:absolute;top:24px;right:24px;transform:rotate(-12deg)}.sm-card.choose-right .sm-stamp.match{opacity:1;color:var(--green-deep);border-color:var(--green)}.sm-card.choose-left .sm-stamp.nope{opacity:1;color:var(--red-deep);border-color:var(--red);top:24px;left:24px;right:auto;transform:rotate(12deg)}.sm-controls{gap:24px;margin-top:12px;display:flex}.sm-btn{cursor:pointer;border:none;border-radius:50%;place-items:center;width:84px;height:84px;font-size:36px;transition:transform .1s,box-shadow .1s;display:grid}.sm-btn.no{background:var(--red);color:#fff;box-shadow:0 6px 0 var(--red-deep)}.sm-btn.yes{background:var(--green);color:#fff;box-shadow:0 6px 0 var(--green-deep)}.sm-btn:active{transform:translateY(3px);box-shadow:0 3px}.spin-stage{grid-template-columns:1fr 1fr;align-items:center;gap:36px;width:100%;max-width:1100px;display:grid}.spin-wheel-wrap{width:460px;height:460px;margin:0 auto;position:relative}.spin-pointer{background:var(--ink);clip-path:polygon(50% 100%,0 0,100% 0);z-index:3;filter:drop-shadow(0 4px #0000004d);width:40px;height:60px;position:absolute;top:-8px;left:50%;transform:translate(-50%)}.spin-wheel{width:100%;height:100%;transition:transform 4s cubic-bezier(.16,1,.3,1)}.spin-center{pointer-events:none;place-items:center;display:grid;position:absolute;inset:0}.spin-center-disc{background:var(--ink);width:110px;height:110px;color:var(--cream);font-family:var(--font-display);text-align:center;border-radius:50%;place-items:center;font-size:14px;font-weight:800;line-height:1.1;display:grid;box-shadow:0 0 0 8px #ffffff80}.spin-side{flex-direction:column;gap:16px;display:flex}.spin-multiplier-display{color:var(--ink);text-align:center;background:#fff;border-radius:28px;padding:28px;box-shadow:0 12px #0000002e}.spin-multi-label{letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);font-size:11px;font-weight:700}.spin-multi-val{font-family:var(--font-display);letter-spacing:-.04em;background:linear-gradient(135deg, var(--purple), var(--red));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;margin:8px 0;font-size:96px;font-weight:800;line-height:1}.spin-q-card{color:var(--ink);background:#fff;border-radius:22px;padding:22px 24px;box-shadow:0 8px #00000026}.spin-q-text{font-family:var(--font-display);font-size:18px;font-weight:700;line-height:1.3}.spin-q-options{grid-template-columns:1fr 1fr;gap:10px;margin-top:14px;display:grid}.spin-opt{background:var(--cream);border:2px solid var(--cream-2);text-align:left;cursor:pointer;border-radius:12px;padding:10px 14px;font-size:14px;font-weight:600}.spin-opt:hover{border-color:var(--ink-3)}.spin-opt.correct{background:var(--green);color:#fff;border-color:var(--green-deep)}.spin-opt.wrong{background:var(--red);color:#fff;border-color:var(--red-deep)}.btn-spin{background:var(--ink);width:100%;color:var(--cream);font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;border-radius:18px;padding:18px 22px;font-size:18px;font-weight:800;box-shadow:0 6px #00000080}.btn-spin:disabled{opacity:.4;cursor:not-allowed}.qb-grid{grid-template-columns:repeat(5,1fr);gap:12px;width:100%;max-width:1200px;display:grid}.qb-cat{background:var(--ink);color:var(--yellow);text-align:center;font-family:var(--font-display);letter-spacing:.04em;text-transform:uppercase;border:2px solid #ffc8454d;border-radius:16px;place-items:center;min-height:70px;padding:18px 14px;font-size:15px;font-weight:800;line-height:1.2;display:grid}.qb-cell{color:var(--yellow);text-align:center;font-family:var(--font-display);letter-spacing:-.01em;cursor:pointer;text-shadow:0 2px 4px #0000004d;background:linear-gradient(#2d74ff,#1b4fcc);border:none;border-radius:16px;min-height:90px;padding:22px 12px;font-size:32px;font-weight:800;transition:transform .1s,box-shadow .1s;box-shadow:0 6px #0000004d,inset 0 1px #ffffff26}.qb-cell:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px #0000004d}.qb-cell:active:not(:disabled){transform:translateY(3px);box-shadow:0 3px #0000004d}.qb-cell:disabled{color:#ffffff26;cursor:default;box-shadow:none;text-shadow:none;background:#ffffff0a}.qb-teams{gap:12px;margin-bottom:18px;display:flex}.qb-team{background:#ffffff14;border:1px solid #ffffff26;border-radius:16px;flex:1;align-items:center;gap:14px;padding:14px 18px;display:flex}.qb-team.active{border-color:var(--yellow);background:#ffc8452e;box-shadow:0 0 0 3px #ffc8454d}.qb-team-emoji{font-size:28px}.qb-team-name{font-family:var(--font-display);font-size:14px;font-weight:700}.qb-team-score{font-family:var(--font-display);color:var(--yellow);margin-top:2px;font-size:28px;font-weight:800;line-height:1}.qb-card-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10;background:#1b1733d9;place-items:center;padding:24px;animation:.2s fadeIn;display:grid;position:absolute;inset:0}.qb-card{color:#fff;text-align:center;background:linear-gradient(#2d74ff,#1b4fcc);border-radius:28px;width:min(820px,100%);padding:48px;animation:.3s popIn;box-shadow:0 20px #0006}.qb-card-eyebrow{letter-spacing:.16em;text-transform:uppercase;color:var(--yellow);font-size:13px;font-weight:700}.qb-card-clue{font-family:var(--font-display);letter-spacing:-.02em;margin-top:18px;font-size:40px;font-weight:800;line-height:1.2}.qb-options{grid-template-columns:1fr 1fr;gap:14px;margin-top:30px;display:grid}.qb-points-pill{background:var(--yellow);color:var(--ink);font-family:var(--font-display);border-radius:100px;margin-top:12px;padding:8px 18px;font-size:22px;font-weight:800;display:inline-block}.login-page{background:radial-gradient(1200px 600px at 90% -10%, #ffe3b8 0%, transparent 50%), radial-gradient(900px 500px at -10% 100%, #ffd4da 0%, transparent 55%), var(--cream);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex;position:relative;overflow:hidden}.login-floaters{pointer-events:none;z-index:0;position:absolute;inset:0}.floater{opacity:.12;font-size:40px;animation:3s ease-in-out infinite float;position:absolute}.login-lang-bar{z-index:10;position:fixed;top:18px;right:18px}.login-card{border:1px solid var(--line);border-radius:var(--radius-xl);width:100%;max-width:440px;box-shadow:var(--shadow-pop);text-align:center;z-index:1;background:#fff;padding:40px 32px;animation:.5s popIn;position:relative}.login-logo{margin-bottom:14px}.login-logo-icon{background:var(--ink);width:72px;height:72px;box-shadow:var(--shadow-btn);border-radius:20px;justify-content:center;align-items:center;font-size:36px;animation:2s ease-in-out infinite wiggle;display:inline-flex;position:relative}.login-logo-icon:after{content:"";border:2px dashed #ffffff40;border-radius:16px;position:absolute;inset:4px}.login-title{font-family:var(--font-display);color:var(--ink);letter-spacing:-.02em;margin-bottom:4px;font-size:32px;font-weight:900}.login-subtitle{color:var(--ink-3);margin-bottom:28px;font-size:14px;font-weight:500}.login-divider{align-items:center;gap:14px;margin-bottom:24px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--line);flex:1;height:1px}.login-divider span{color:var(--ink-3);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap;font-size:11px;font-weight:700}.login-roles{flex-direction:column;gap:10px;display:flex}.role-btn{border-radius:var(--radius);border:2px solid var(--line);cursor:pointer;text-align:left;box-shadow:var(--shadow-sm);background:#fff;align-items:center;gap:16px;padding:14px 18px;transition:all .15s;display:flex}.role-btn:hover{box-shadow:var(--shadow-card);transform:translateY(-2px)}.role-btn .role-icon{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:28px;display:flex}.role-btn .role-name{font-family:var(--font-display);color:var(--ink);font-size:15px;font-weight:700;display:block}.role-btn .role-desc{color:var(--ink-3);margin-top:2px;font-size:12px;display:block}.role-admin:hover{border-color:var(--orange)}.role-admin .role-icon{background:#ff8a1f1a}.role-school:hover{border-color:var(--blue)}.role-school .role-icon{background:#2d74ff1a}.role-classroom:hover{border-color:var(--green)}.role-classroom .role-icon{background:#1fb5731a}.login-footer-text{color:var(--ink-3);margin-top:24px;font-size:12px}[data-theme=dark] .login-page{background:radial-gradient(1200px 600px at 90% -10%, #7b3ff21a 0%, transparent 50%), radial-gradient(900px 500px at -10% 100%, #2d74ff14 0%, transparent 55%), var(--cream)}[data-theme=dark] .login-card{background:var(--surface);border-color:var(--line)}[data-theme=dark] .role-btn{background:var(--cream-2);border-color:var(--line)}[data-theme=dark] .login-logo-icon{background:var(--purple)}
