.board-badge{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);letter-spacing:.125px;padding:5px 12px;font-size:12px;font-weight:600;display:inline-block}.dashboard-classroom-row{max-width:var(--container-max-width);margin:0 auto 16px}.dashboard-classroom-link{color:var(--color-accent);font-size:14px;font-weight:500;text-decoration:none;transition:color .15s}.dashboard-classroom-link:hover{color:var(--color-accent-active)}.home-page{background:#fff;min-height:100vh;padding:48px 32px}.home-header{max-width:var(--container-max-width);margin:0 auto 40px}.home-header-top{justify-content:space-between;align-items:center;display:flex}.home-title{font-family:var(--font-display);letter-spacing:var(--font-display-tracking);color:var(--color-text);margin:0 0 8px;font-size:32px;font-weight:700}.home-subtitle{color:var(--color-text-muted);margin:0;font-size:15px}.home-header-actions{align-items:center;gap:12px;display:flex}.board-list{max-width:var(--container-max-width);flex-direction:column;gap:12px;margin:0 auto;display:flex}.board-grid{max-width:var(--container-max-width);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin:0 auto;display:grid}.board-grid-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);color:var(--color-text);text-align:center;min-height:160px;transition:box-shadow var(--t-slow), border-color var(--t-slow), transform var(--t-slow);flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:24px 12px;text-decoration:none;display:flex;position:relative}.board-grid-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover);transform:translateY(-2px)}.board-grid-card--menu-open:hover{transform:none}.board-grid-card-link{width:100%;color:inherit;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;text-decoration:none;display:flex}.board-grid-emoji{font-size:36px}.board-grid-title{font-family:var(--font-display);letter-spacing:-.25px;color:var(--color-text);font-size:16px;font-weight:700;line-height:1.3}.board-grid-meta{color:var(--color-text-muted);font-size:13px}.board-grid-kebab{width:26px;height:26px;color:var(--color-text-faint);cursor:pointer;opacity:.6;transition:background var(--t-normal), color var(--t-normal), opacity var(--t-normal);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:16px;line-height:1;display:flex;position:absolute;top:6px;right:6px}.board-grid-kebab:hover{background:var(--color-surface-alt);color:var(--color-text);opacity:1}.board-grid-kebab-menu{background:var(--color-surface);border:1px solid var(--color-border);min-width:110px;box-shadow:var(--shadow-lift);z-index:10;border-radius:8px;position:absolute;top:34px;right:6px;overflow:hidden}.board-grid-kebab-item{text-align:left;width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:none;padding:10px 14px;font-family:inherit;font-size:13px;display:block}.board-grid-kebab-item:hover{background:var(--color-surface-alt)}.board-grid-kebab-item--danger{color:var(--color-danger)}.board-grid-new{border:2px dashed var(--color-border);box-shadow:none;cursor:pointer;font-family:var(--font-body);background:0 0}.board-grid-new:hover{border-color:var(--color-accent);background:var(--color-accent-tinted-bg);box-shadow:none;transform:none}.board-grid-new-icon{background:var(--color-surface-alt);width:48px;height:48px;color:var(--color-text-faint);border-radius:50%;justify-content:center;align-items:center;font-size:28px;transition:background .15s,color .15s;display:flex}.board-grid-new:hover .board-grid-new-icon{background:var(--color-accent);color:#fff}.board-grid-new-label{color:var(--color-text-muted);font-size:14px;font-weight:500}.board-list-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);color:var(--color-text);align-items:center;gap:18px;padding:20px 24px;text-decoration:none;transition:box-shadow .18s,border-color .18s,transform .18s;display:flex}.board-list-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover);transform:translateY(-2px)}.board-list-emoji{flex-shrink:0;font-size:28px}.board-list-info{flex:1}.board-list-title{font-family:var(--font-display);letter-spacing:-.25px;color:var(--color-text);margin:0 0 4px;font-size:18px;font-weight:700}.board-list-meta{color:var(--color-text-muted);margin:0;font-size:13px}.board-list-new{border:2px dashed var(--color-border);box-shadow:none;cursor:pointer;font-family:var(--font-body);text-align:left;background:0 0}.board-list-new:hover{border-color:var(--color-accent);background:var(--color-accent-tinted-bg);box-shadow:none}.board-list-new .board-list-emoji{color:var(--color-text-faint);font-size:28px}.board-list-new .board-list-title{color:var(--color-text-muted)}.board-list-new .board-list-meta{color:var(--color-text-faint)}.create-board-modal{width:min(94vw,860px)}.layout-grid-picker{grid-template-columns:repeat(3,1fr);gap:10px;margin-top:4px;display:grid}.layout-grid-option{text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-text);font-family:var(--font-body);cursor:pointer;transition:border-color var(--t-normal), box-shadow var(--t-normal), background var(--t-normal);flex-direction:column;justify-content:flex-start;align-items:center;gap:8px;padding:10px;display:flex}.layout-grid-option:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card)}.layout-grid-option:disabled{cursor:default}.layout-grid-option:disabled:hover{border-color:var(--color-border);box-shadow:none}.layout-grid-option-dev{background:color-mix(in srgb, var(--color-surface-alt) 38%, #fff)}.layout-grid-option-preview{aspect-ratio:16/10;background:linear-gradient(#f7fbff 0%,#edf6ff 100%);border:1px solid #184a5c1a;border-radius:7px;width:100%;overflow:hidden}.layout-grid-option-thumb{object-fit:cover;width:100%;height:100%;display:block}.layout-grid-option-placeholder{width:100%;height:100%;color:var(--color-text-muted);opacity:.74;flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex}.layout-grid-option-emoji{font-size:28px;line-height:1}.layout-grid-option-status{border:1px solid var(--color-border);border-radius:var(--radius-pill);color:var(--color-text-muted);background:#ffffffa3;padding:3px 8px;font-size:10px;font-weight:600;line-height:1}.layout-grid-option-label{color:var(--color-text);font-size:13px;font-weight:600}.layout-grid-option-desc{color:var(--color-text-muted);font-size:11px;line-height:1.4}@media (max-width:540px){.layout-grid-picker{grid-template-columns:1fr}.layout-grid-option{padding:9px}.layout-grid-option-preview{aspect-ratio:2}}.layout-picker{flex-direction:column;gap:8px;display:flex}.layout-option{border:1.5px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;font-family:var(--font-body);border-radius:10px;align-items:center;gap:14px;padding:14px 16px;transition:border-color .15s,background .15s;display:flex}.layout-option:hover{border-color:var(--color-border-hover);background:var(--color-bg)}.layout-option-active{border-color:var(--color-accent)!important;background:var(--color-accent-tinted-bg)!important}.layout-option-emoji{text-align:center;flex-shrink:0;width:40px;font-size:28px}.layout-option-label{color:var(--color-text);min-width:80px;font-size:15px;font-weight:600}.layout-option-desc{color:var(--color-text-muted);flex:1;font-size:13px}.create-board-hint{color:var(--color-text-muted);margin:0 0 4px;font-size:13px}.create-board-selected{background:var(--color-accent-tinted-bg);color:var(--color-accent);border-radius:8px;margin-bottom:4px;padding:10px 14px;font-size:14px;font-weight:500}.board-back-link{color:var(--color-text-muted);border-radius:var(--radius-btn);padding:4px 8px;font-size:20px;text-decoration:none;transition:color .15s,background .15s}.board-back-link:hover{color:var(--color-text);background:var(--color-surface-alt)}.board-layout-badge{background:var(--color-surface-alt);color:var(--color-text-faint);border-radius:var(--radius-pill);letter-spacing:.2px;padding:3px 10px;font-size:11px;font-weight:600;display:inline-block}.board-empty-inline{text-align:center;color:var(--color-text-faint);grid-column:1/-1;padding:48px 24px}.board-empty-inline p{margin:0;font-size:14px}
.export-start-btn{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-pill);font-family:var(--font-body);color:var(--color-text-muted);cursor:pointer;z-index:10;padding:8px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s,border-color .15s;position:absolute;top:8px;right:8px}.export-start-btn:hover{background:var(--color-accent-tinted-bg);color:var(--color-accent);border-color:var(--color-accent)}.export-toolbar{background:var(--color-accent);border-radius:var(--radius-card);align-items:center;gap:12px;margin-bottom:16px;padding:12px 20px;animation:.15s fadeIn;display:flex}.export-toolbar-text{color:#fff;flex:1;font-size:14px;font-weight:500}.export-toolbar-btn{color:var(--color-accent);border-radius:var(--radius-pill);font-family:var(--font-body);cursor:pointer;background:#fff;border:none;padding:7px 18px;font-size:13px;font-weight:600;transition:opacity .15s}.export-toolbar-btn:disabled{opacity:.5;cursor:not-allowed}.export-toolbar-cancel{color:#fff;border-radius:var(--radius-pill);font-family:var(--font-body);cursor:pointer;background:#fff3;border:none;padding:7px 14px;font-size:13px;font-weight:500;transition:background .15s}.export-toolbar-cancel:hover{background:#ffffff4d}.export-selectable{border:2px solid #0000;transition:border-color .15s,box-shadow .15s;cursor:pointer!important}.export-selectable:hover{border-color:var(--color-accent)!important}.export-selected{border-color:var(--color-accent)!important;box-shadow:0 0 0 3px #0075de33!important}.export-disabled{opacity:.35;pointer-events:none}.export-checkbox{border:2px solid var(--color-border);background:var(--color-surface);color:#fff;z-index:2;border-radius:6px;justify-content:center;align-items:center;width:22px;height:22px;font-size:14px;font-weight:700;display:flex;position:absolute;top:8px;left:8px}.export-selected .export-checkbox{background:var(--color-accent);border-color:var(--color-accent)}.export-modal{width:560px}.export-summary{color:var(--color-text-muted);margin:0 0 16px;font-size:14px}.export-design-list{flex-direction:column;gap:8px;max-height:320px;display:flex;overflow-y:auto}.export-design-item{border:1px solid var(--color-border);border-radius:8px;align-items:center;gap:12px;padding:10px 12px;transition:border-color .15s;display:flex}.export-design-item.ready{border-color:var(--color-accent)}.export-design-item.error{opacity:.6;border-color:#dc3545}.export-design-thumb{object-fit:cover;border-radius:4px;flex-shrink:0;width:64px;height:40px}.export-design-info{flex:1;min-width:0}.export-design-title{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.export-design-meta{color:var(--color-text-faint);margin-top:2px;font-size:11px}.export-item-check{width:18px;height:18px;accent-color:var(--color-accent);cursor:pointer;flex-shrink:0}.export-design-badge{flex-shrink:0;font-size:16px}.export-hint{color:var(--color-text-faint);margin:12px 0 0;font-size:13px}.export-ready-msg{background:var(--color-accent-tinted-bg);color:var(--color-text);border-radius:8px;margin-top:12px;padding:12px;font-size:13px;line-height:1.5}.export-ids{background:var(--color-surface);border:1px solid var(--color-border);word-break:break-all;-webkit-user-select:all;user-select:all;border-radius:6px;margin-top:8px;padding:8px 12px;font-family:monospace;font-size:12px;display:block}.canva-breadcrumb{flex-wrap:wrap;align-items:center;gap:2px;margin-bottom:12px;display:flex}.canva-breadcrumb-sep{color:var(--color-text-faint);font-size:12px}.canva-breadcrumb-btn{font-family:var(--font-body);color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:13px;transition:background .1s}.canva-breadcrumb-btn:hover{background:var(--color-surface-alt)}.canva-breadcrumb-btn.active{color:var(--color-text);font-weight:600}.canva-folder-item{border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;width:100%;font-family:var(--font-body);color:var(--color-text);text-align:left;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;transition:background .1s,border-color .1s;display:flex}.canva-folder-item:hover{background:var(--color-accent-tinted-bg);border-color:var(--color-accent)}.canva-folder-icon{flex-shrink:0;font-size:18px}
.add-card-fab{right:32px;bottom:var(--fab-bottom-safe,32px);background:var(--color-accent);color:#fff;cursor:pointer;width:56px;height:56px;box-shadow:var(--shadow-accent);z-index:30;border:none;border-radius:50%;justify-content:center;align-items:center;transition:background .16s,transform .16s,box-shadow .16s;display:flex;position:fixed}.add-card-fab:hover{background:var(--color-accent-active);box-shadow:var(--shadow-accent-hover);transform:translateY(-2px)}.add-card-fab:active{transform:scale(.95)}.ctx-menu-wrap{display:inline-flex;position:relative}.ctx-menu-trigger{width:28px;height:28px;color:var(--color-text-faint);cursor:pointer;letter-spacing:1px;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:0;font-size:18px;font-weight:700;line-height:1;transition:background .15s,color .15s;display:flex}@media (pointer:coarse){.ctx-menu-trigger{width:var(--tap-min);height:var(--tap-min);font-size:22px}}.ctx-menu-trigger:hover{color:var(--color-text);background:#00000014}.ctx-menu-dropdown{box-sizing:border-box;background:var(--color-surface);border:var(--border-card);z-index:50;border-radius:10px;width:max-content;min-width:140px;max-width:min(220px,100vw - 16px);margin-top:4px;padding:4px;position:absolute;top:100%;right:0;box-shadow:0 8px 30px #0000001f,0 2px 8px #00000014}.ctx-menu-dropdown-portal{z-index:70;margin-top:0;animation:.12s menuIn}@keyframes menuIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.ctx-menu-item{width:100%;min-width:0;color:var(--color-text);font-family:var(--font-body);cursor:pointer;text-align:left;white-space:nowrap;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;transition:background .1s;display:flex}.ctx-menu-item:hover{background:var(--color-surface-alt)}.ctx-menu-item-danger{color:#dc3545}.ctx-menu-item-danger:hover{background:#dc354514}.ctx-menu-icon{flex-shrink:0;font-size:14px}.ctx-menu-label{letter-spacing:.1px;color:var(--color-text-faint);text-transform:none;padding:6px 12px 2px;font-size:11px;font-weight:600}.ctx-menu-sep{background:var(--color-border);height:1px;margin:4px 6px}.ctx-menu-item-radio{padding-left:8px}.ctx-menu-item-radio .ctx-menu-check{width:16px;color:var(--color-accent);flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:inline-flex}.ctx-menu-item-radio.is-selected{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text)}.ctx-menu-item-radio.is-selected:hover{background:var(--color-accent-tinted-bg)}.forbidden-card{text-align:center;background:var(--color-surface);border-radius:var(--radius-card);border:var(--border-card);max-width:420px;box-shadow:var(--shadow-card);margin:80px auto;padding:40px}.forbidden-card h2{font-family:var(--font-display);letter-spacing:-.25px;color:var(--color-text);margin:0 0 8px;font-size:22px;font-weight:700}.forbidden-card p{color:var(--color-text-muted);margin:0}.docs-page{background:var(--color-bg);min-height:100vh;padding:48px 24px}.docs-article{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);max-width:720px;box-shadow:var(--shadow-card);margin:0 auto;padding:40px 48px}.docs-back{color:var(--color-text-muted);margin-bottom:24px;font-size:13px;text-decoration:none;display:inline-block}.docs-back:hover{color:var(--color-accent)}.docs-title{font-family:var(--font-display);color:var(--color-text);margin:0 0 12px;font-size:28px;font-weight:700}.docs-subtitle{color:var(--color-text-muted);margin:0 0 32px;font-size:15px}.docs-section{margin-bottom:24px}.docs-h2{color:var(--color-text);margin:0 0 12px;font-size:18px;font-weight:700}.docs-h3{color:var(--color-text);margin:16px 0 6px;font-size:15px;font-weight:700}.docs-p{color:var(--color-text);margin:0 0 12px;font-size:14px;line-height:1.7}.docs-p.docs-note{background:var(--color-surface-alt);border-left:3px solid var(--color-accent);border-radius:var(--radius-btn);color:var(--color-text-muted);padding:10px 14px;font-size:13px}.docs-p code,.docs-list code{background:var(--color-surface-alt);border-radius:4px;padding:2px 6px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.docs-list{color:var(--color-text);padding-left:20px;font-size:14px;line-height:1.7}.docs-list li{margin-bottom:6px}.docs-link{color:var(--color-accent);font-weight:500;text-decoration:none}.docs-link:hover{text-decoration:underline}.docs-code{font-family:var(--font-mono);background:var(--color-surface-alt);color:var(--color-text);border-radius:4px;padding:2px 6px;font-size:12.5px}.docs-compare-table{border-collapse:collapse;width:100%;margin-top:8px;font-size:14px}.app-footer{border-top:1px solid var(--color-border);background:var(--color-surface);padding:24px}.app-footer-inner{text-align:center;flex-direction:column;align-items:center;gap:12px;max-width:720px;margin:0 auto;display:flex}@media (min-width:640px){.app-footer-inner{text-align:left;flex-direction:row;justify-content:space-between}}.app-footer-copy{color:var(--color-text-muted);margin:0;font-size:13px}.app-footer-links{align-items:center;gap:16px;display:flex}.app-footer-links a{color:var(--color-text-muted);font-size:13px;text-decoration:none;transition:color .15s}.app-footer-links a:hover{color:var(--color-accent)}html,body{min-height:100vh}body{flex-direction:column;display:flex}body>main,body>div{flex:1 0 auto;width:100%}.app-footer{flex-shrink:0}.docs-page{padding-bottom:24px}.docs-compare-table th,.docs-compare-table td{text-align:left;border-bottom:1px solid var(--color-border);vertical-align:top;padding:10px 12px}.docs-compare-table th{color:var(--color-text-muted);font-size:13px;font-weight:600}.docs-compare-table td:first-child{color:var(--color-text)}.llm-key-form{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);flex-direction:column;gap:14px;margin-top:8px;padding:18px;display:flex}.llm-key-status{border-radius:var(--radius-btn);background:var(--color-surface-alt);padding:10px 14px;font-size:13px}.llm-key-status.is-ok{border-left:3px solid var(--color-accent)}.llm-key-status.is-warn{border-left:3px solid var(--color-danger,#dc3545)}.llm-key-status-row{align-items:center;gap:8px;display:flex}.llm-key-status-dot{font-size:14px;line-height:1}.llm-key-status.is-ok .llm-key-status-dot{color:var(--color-accent)}.llm-key-status.is-warn .llm-key-status-dot{color:var(--color-danger,#dc3545)}.llm-key-status-text{color:var(--color-text);flex:1;font-weight:500}.llm-key-delete{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius-btn);cursor:pointer;background:0 0;padding:4px 10px;font-size:12px}.llm-key-delete:hover:not(:disabled){background:var(--color-surface);color:var(--color-text)}.llm-key-error{color:var(--color-danger,#dc3545);word-break:break-word;margin:8px 0 0;font-size:12px}.llm-key-hint-small{color:var(--color-text-muted);margin:6px 0 0;font-size:11px}.llm-key-fields{flex-direction:column;gap:12px;display:flex}.llm-key-field{flex-direction:column;gap:6px;font-size:13px;display:flex}.llm-key-field>span{color:var(--color-text);font-weight:600}.llm-key-select,.llm-key-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.llm-key-input{font-family:var(--font-mono);font-size:13px}.llm-key-select:focus,.llm-key-input:focus{border-color:var(--color-accent)}.llm-key-hint{color:var(--color-text-muted);font-size:11.5px;font-weight:400}.llm-key-submit{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:none;align-self:flex-start;padding:10px 18px;font-size:14px;font-weight:600;transition:background .15s}.llm-key-submit:hover:not(:disabled){background:var(--color-accent-active)}.llm-key-submit:disabled{opacity:.55;cursor:default}.llm-key-msg{color:var(--color-text-muted);margin:0;font-size:13px}.billing-panel{flex-direction:column;gap:18px;margin-top:8px;display:flex}.billing-current{background:var(--color-surface-alt);border-radius:var(--radius-card);align-items:flex-start;gap:14px;padding:14px 16px;display:flex}.billing-badge{letter-spacing:.5px;border-radius:999px;padding:4px 10px;font-size:12px;font-weight:700}.billing-badge.is-pro{background:var(--color-accent);color:#fff}.billing-badge.is-free{background:var(--color-border);color:var(--color-text)}.billing-current-meta{color:var(--color-text);flex-direction:column;gap:4px;font-size:13.5px;display:flex}.billing-muted{color:var(--color-text-muted);font-size:12px}.billing-plans{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.billing-plan-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);cursor:pointer;text-align:left;color:var(--color-text);flex-direction:column;gap:2px;padding:18px 16px;font-family:inherit;transition:border-color .15s,transform .12s;display:flex}.billing-plan-card:hover:not(:disabled){border-color:var(--color-accent);transform:translateY(-1px)}.billing-plan-card.is-highlighted{border-color:var(--color-accent)}.billing-plan-card:disabled{opacity:.55;cursor:default}.billing-plan-title{color:var(--color-text-muted);margin-bottom:6px;font-size:13px;font-weight:600}.billing-plan-price{color:var(--color-text);font-size:22px;font-weight:700}.billing-plan-period{color:var(--color-text-muted);font-size:12px}.billing-plan-note{color:var(--color-accent);margin-top:6px;font-size:12px}.billing-cancel{border:1px solid var(--color-border);color:var(--color-text-muted);border-radius:var(--radius-btn);cursor:pointer;background:0 0;align-self:flex-start;padding:8px 16px;font-size:13px}.billing-cancel:hover:not(:disabled){color:var(--color-danger,#dc3545);border-color:var(--color-danger,#dc3545)}.billing-msg{color:var(--color-text-muted);margin:0;font-size:13px}.billing-callback{color:var(--color-text);padding:24px 0;font-size:14px}.billing-callback-success{color:var(--color-accent)}.billing-callback-failed{color:var(--color-danger,#dc3545)}.event-public-page{background:var(--color-bg);min-height:100vh;padding:32px 16px}.event-public-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);max-width:560px;box-shadow:var(--shadow-card);flex-direction:column;gap:16px;margin:0 auto;padding:32px 28px;display:flex}.event-public-poster{border-radius:var(--radius-card);object-fit:cover;width:100%;height:auto}.event-public-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:24px;font-weight:700}.event-public-desc{color:var(--color-text-muted);white-space:pre-wrap;margin:0;font-size:14px}.event-public-meta{color:var(--color-text);background:var(--color-surface-alt);border-radius:var(--radius-btn);grid-template-columns:auto 1fr;gap:6px 14px;margin:0;padding:12px 16px;font-size:13px;display:grid}.event-public-meta dt{color:var(--color-text-muted);font-weight:600}.event-public-notice{background:var(--color-surface-alt);border-left:3px solid var(--color-accent);border-radius:var(--radius-btn);color:var(--color-text);padding:14px 16px;font-size:14px}.event-public-form{flex-direction:column;gap:14px;display:flex}.event-public-field{flex-direction:column;gap:6px;font-size:14px;display:flex}.event-public-field>span{color:var(--color-text);font-weight:600}.event-public-field em{color:var(--color-danger);font-style:normal;font-weight:700}.event-public-field input[type=text],.event-public-field input[type=number],.event-public-field input[type=url],.event-public-field textarea,.event-public-field select{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-surface);color:var(--color-text);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .15s}.event-public-field input:focus,.event-public-field textarea:focus,.event-public-field select:focus{border-color:var(--color-accent)}.event-public-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.event-public-hint{color:var(--color-text-muted);font-size:12px}.event-public-checkbox-group{flex-direction:column;gap:6px;display:flex}.event-public-checkbox-label{color:var(--color-text);align-items:center;gap:8px;font-size:14px;font-weight:500;display:inline-flex}.event-public-submit{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);cursor:pointer;border:none;margin-top:8px;padding:14px 20px;font-size:15px;font-weight:600;transition:background .15s}.event-public-submit:hover:not(:disabled){background:var(--color-accent-active)}.event-public-submit:disabled{opacity:.6;cursor:default}.event-public-error{background:var(--color-surface-alt);border-left:3px solid var(--color-danger);border-radius:var(--radius-btn);color:var(--color-danger);padding:10px 14px;font-size:13px}.event-public-success{text-align:center;padding:32px 16px}.event-public-success h2{font-family:var(--font-display);color:var(--color-text);margin:0 0 8px;font-size:20px;font-weight:700}.event-public-success p{color:var(--color-text-muted);margin:0;font-size:14px}.settings-section{border-bottom:1px solid var(--color-border-subtle,var(--color-border));padding:20px 0}.settings-section:last-of-type{border-bottom:none}.settings-section-header{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:8px;display:flex}.settings-section-header .docs-h2{margin:0}.settings-help-link{white-space:nowrap;font-size:13px}.settings-status-row{border-radius:var(--radius-btn);background:var(--color-surface-alt);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;font-size:13.5px;display:flex}.settings-status-line{align-items:center;gap:8px;display:flex}.settings-status-dot{font-size:11px;line-height:1}.settings-status-dot.is-on{color:var(--color-positive,#2a9d5a)}.connected-apps-list{flex-direction:column;gap:8px;display:flex}.connected-app-row{border-radius:var(--radius-btn);background:var(--color-surface-alt);justify-content:space-between;align-items:center;gap:12px;padding:12px 14px;display:flex}.connected-app-main{flex-direction:column;gap:4px;display:flex}.connected-app-name{color:var(--color-text);align-items:center;gap:6px;font-size:14px;font-weight:600;display:inline-flex}.connected-app-meta{color:var(--color-text);font-size:12.5px}.connected-app-meta-faint{color:var(--color-text-faint);font-size:11.5px}.connected-apps-error{color:var(--color-danger,#c4302b);background:#c4302b14;border-radius:6px;margin:8px 0 0;padding:8px 10px;font-size:12.5px}.settings-status-row.is-ok .settings-status-dot{color:var(--color-positive,#2a9d5a)}.settings-status-row.is-warn .settings-status-dot{color:var(--color-warning,#c9a227)}.settings-status-row.is-idle .settings-status-dot{color:var(--color-text-muted)}.settings-action-btn{border-radius:var(--radius-btn);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;display:inline-block}.settings-action-btn:hover{background:var(--color-surface-alt)}.settings-action-btn.is-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.settings-action-btn.is-primary:hover{filter:brightness(.95)}.settings-billing-summary{border-radius:var(--radius-btn);background:var(--color-surface-alt);flex-direction:column;gap:6px;padding:14px;display:flex}.settings-billing-line{align-items:center;gap:10px;font-size:14px;display:flex}.settings-billing-muted{color:var(--color-text-muted);font-size:13px}.settings-pill{border-radius:999px;align-items:center;padding:2px 10px;font-size:12px;font-weight:600;display:inline-flex}.settings-pill.is-pro{background:var(--color-accent);color:#fff}.settings-pill.is-free{background:var(--color-surface);color:var(--color-text-muted);border:1px solid var(--color-border)}.settings-billing-summary .settings-action-btn{align-self:flex-start;margin-top:6px}.docs-cta-btn{border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;margin:8px 0 12px;padding:10px 16px;font-size:14px;font-weight:500;text-decoration:none;display:inline-block}.docs-cta-btn:hover{filter:brightness(.95)}.auth-settings-subitem{color:var(--color-text-muted);padding-left:28px;font-size:12.5px}
.login-page{background:#fff;justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);width:100%;max-width:400px;box-shadow:var(--shadow-card);text-align:center;padding:48px 40px}.login-hub-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);width:100%;max-width:720px;box-shadow:var(--shadow-card);text-align:center;padding:48px 40px}.login-hub-grid{grid-template-columns:repeat(3,1fr);gap:16px;margin:24px 0 32px;display:grid}@media (max-width:640px){.login-hub-grid{grid-template-columns:1fr}}.login-role-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);cursor:pointer;font-family:var(--font-body);text-align:center;flex-direction:column;align-items:center;gap:6px;padding:24px 16px;transition:border-color .15s,box-shadow .15s,transform .15s;display:flex}.login-role-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-card-hover);transform:translateY(-2px)}.login-role-card:focus-visible{outline:2px solid var(--color-accent);outline-offset:2px}.login-role-emoji{margin-bottom:4px;font-size:40px;line-height:1}.login-role-title{color:var(--color-text);font-size:16px;font-weight:700}.login-role-desc{color:var(--color-text-muted);min-height:36px;font-size:13px}.login-role-cta{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);margin-top:10px;padding:8px 16px;font-size:13px;font-weight:600}.login-role-card:hover .login-role-cta{background:var(--color-accent-active)}.login-role-card-static{cursor:default}.login-role-card-static:hover{transform:none}.login-role-oauth-actions{gap:6px;width:100%;margin-top:10px;display:grid}.login-role-oauth{border-radius:var(--radius-btn);border:1px solid var(--color-border);cursor:pointer;justify-content:center;align-items:center;gap:6px;height:36px;font-size:12px;font-weight:600;text-decoration:none;transition:background .1s,border-color .1s;display:inline-flex}.login-role-oauth:hover{border-color:var(--color-border-hover)}.login-role-oauth-google{color:#1f1f1f;background:#fff}.login-role-oauth-kakao{background:var(--color-oauth-kakao);color:#181600;border-color:var(--color-oauth-kakao)}.login-role-oauth-kakao:hover{background:#fada0a;border-color:#fada0a}.login-logo{justify-content:center;margin:0 auto 20px;display:flex}.login-title{font-family:var(--font-display);letter-spacing:var(--font-display-tracking);color:var(--color-text);margin:0 0 8px;font-size:24px;font-weight:700}.login-subtitle{color:var(--color-text-muted);margin:0 0 32px;font-size:15px}.login-google-btn{border:1.5px solid var(--color-border);background:var(--color-surface);width:100%;color:var(--color-text);font-family:var(--font-body);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:10px;padding:12px 24px;font-size:15px;font-weight:600;transition:border-color .16s,background .16s,box-shadow .16s;display:inline-flex}.login-google-btn:hover{border-color:var(--color-border-hover);background:var(--color-bg);box-shadow:var(--shadow-lift)}.login-google-icon{flex-shrink:0}.login-divider{color:var(--color-text-faint);align-items:center;gap:16px;margin:28px 0;font-size:13px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.auth-header{align-items:center;gap:8px;display:inline-flex}.auth-avatar{object-fit:cover;border-radius:50%;width:28px;height:28px}.auth-name{color:var(--color-text);font-size:13px;font-weight:500}.auth-logout-btn{border:1px solid var(--color-border);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);border-radius:var(--radius-pill);cursor:pointer;justify-content:center;align-items:center;padding:0;transition:border-color .15s,background .15s,color .15s;display:inline-flex}.auth-logout-btn:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt);color:var(--color-text)}.auth-logout-icon{fill:none;stroke:currentColor;stroke-width:1.9px;stroke-linecap:round;stroke-linejoin:round;width:17px;height:17px}.auth-login-link{color:#fff;background:var(--color-accent);border-radius:var(--radius-pill);align-items:center;padding:6px 16px;font-size:13px;font-weight:600;text-decoration:none;transition:background .15s,box-shadow .15s;display:inline-flex}.auth-login-link:hover{background:var(--color-accent-active);box-shadow:var(--shadow-accent)}.auth-notify{position:relative}.auth-notify-trigger{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:14px;list-style:none;transition:border-color .15s,background .15s;display:inline-flex;position:relative}.auth-notify-trigger::-webkit-details-marker{display:none}.auth-notify-trigger:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt)}.auth-notify[open] .auth-notify-trigger{border-color:var(--color-accent)}.auth-notify-badge{background:var(--color-danger);color:#fff;text-align:center;box-sizing:border-box;border-radius:8px;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:16px;position:absolute;top:-4px;right:-4px}.auth-notify-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);min-width:280px;max-width:340px;max-height:400px;box-shadow:var(--shadow-card-hover);z-index:60;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0;overflow-y:auto}.auth-notify-header{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.4px;padding:8px 12px 6px;font-size:11px;font-weight:700}.auth-notify-empty{color:var(--color-text-muted);text-align:center;padding:16px 12px;font-size:13px}.auth-notify-item{color:var(--color-text);border-radius:var(--radius-btn);padding:8px 12px;text-decoration:none;transition:background .12s;display:block}.auth-notify-item:hover{background:var(--color-surface-alt)}.auth-notify-item-title{font-size:13px;font-weight:600}.auth-notify-item-meta{color:var(--color-text-muted);margin-top:2px;font-size:12px}.auth-settings{text-decoration:none;display:inline-flex;position:relative}.auth-settings-trigger{border:1px solid var(--color-border);border-radius:var(--radius-pill);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:16px;list-style:none;transition:border-color .15s,background .15s;display:inline-flex}.auth-settings-trigger::-webkit-details-marker{display:none}.auth-settings-trigger:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt)}.auth-settings[open] .auth-settings-trigger{border-color:var(--color-accent);color:var(--color-accent)}.auth-settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);min-width:220px;box-shadow:var(--shadow-card-hover);z-index:60;flex-direction:column;gap:2px;padding:6px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.auth-settings-item{color:var(--color-text);border-radius:var(--radius-btn);align-items:center;gap:8px;padding:8px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:background .12s;display:flex}.auth-settings-item:hover{background:var(--color-surface-alt)}.oauth-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:32px 16px;display:flex}.oauth-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);width:100%;max-width:440px;box-shadow:var(--shadow-card);flex-direction:column;gap:20px;padding:32px 28px;display:flex}.oauth-header{align-items:center;gap:12px;display:flex}.oauth-app-icon{font-size:32px;line-height:1}.oauth-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:19px;font-weight:700;line-height:1.35}.oauth-subtitle{color:var(--color-text-muted);margin:0;font-size:14px}.oauth-error-detail{background:var(--color-surface-alt);border-radius:var(--radius-btn);color:var(--color-text-muted);white-space:pre-wrap;word-break:break-all;margin:0;padding:12px;font-family:SF Mono,Fira Code,monospace;font-size:12px}.oauth-identity{background:var(--color-surface-alt);border-radius:var(--radius-btn);padding:12px 14px}.oauth-identity-label{color:var(--color-text-muted);margin-bottom:4px;font-size:12px}.oauth-identity-value{color:var(--color-text);font-size:14px;font-weight:600}.oauth-scopes{flex-direction:column;gap:8px;display:flex}.oauth-scopes-head{color:var(--color-text);margin:0;font-size:13px;font-weight:600}.oauth-scopes-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.oauth-scopes-list li{color:var(--color-text);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-btn);padding:8px 12px;font-size:13px}.oauth-scopes-note{color:var(--color-text-muted);margin:4px 0 0;font-size:12px;line-height:1.5}.oauth-actions{justify-content:flex-end;gap:10px;margin-top:8px;display:flex}.oauth-btn{border-radius:var(--radius-btn);cursor:pointer;font-size:14px;font-weight:600;font-family:var(--font-body);border:1px solid #0000;padding:10px 20px;transition:background .15s,border-color .15s}.oauth-btn-primary{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.oauth-btn-primary:hover{background:var(--color-accent-active)}.oauth-btn-secondary{background:var(--color-surface);color:var(--color-text);border-color:var(--color-border)}.oauth-btn-secondary:hover{border-color:var(--color-border-hover);background:var(--color-surface-alt)}
.quiz-board{flex-direction:column;gap:20px;max-width:800px;margin:0 auto;padding:24px 16px;display:flex}.quiz-upload{border:2px dashed var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:48px 24px;transition:border-color .15s,background .15s;display:flex}.quiz-upload:hover,.quiz-upload.drag-over{border-color:var(--color-accent);background:var(--color-accent-tinted-bg)}.quiz-upload-icon{font-size:40px}.quiz-upload-title{color:var(--color-text);font-size:16px;font-weight:600}.quiz-upload-hint{color:var(--color-text-faint);font-size:13px}.quiz-upload-or{color:var(--color-text-faint);margin:4px 0;font-size:12px}.quiz-text-input{width:100%;max-width:560px;min-height:100px;font-family:var(--font-body);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-bg);resize:vertical;border-radius:8px;outline:none;padding:12px 14px;font-size:14px;transition:border-color .15s}.quiz-text-input:focus{border-color:var(--color-accent)}.quiz-actions{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.quiz-btn{font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;padding:10px 24px;font-size:14px;font-weight:600;transition:background .16s,transform .1s}.quiz-btn:active{transform:scale(.97)}.quiz-btn:disabled{opacity:.5;cursor:not-allowed}.quiz-btn-primary{background:var(--color-accent);color:#fff}.quiz-btn-primary:hover:not(:disabled){background:var(--color-accent-active)}.quiz-btn-secondary{background:var(--color-surface-alt);color:var(--color-text);border:1px solid var(--color-border)}.quiz-btn-secondary:hover:not(:disabled){background:#00000014}.quiz-btn-danger{color:#fff;background:#e21b3c}.quiz-btn-danger:hover:not(:disabled){background:#c0162f}.quiz-btn-success{color:#fff;background:#26890c}.quiz-btn-success:hover:not(:disabled){background:#1e6e09}.quiz-room-code{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;align-items:center;gap:8px;padding:24px;display:flex}.quiz-room-code-label{color:var(--color-text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:13px;font-weight:600}.quiz-room-code-value{letter-spacing:8px;color:var(--color-accent);font-size:48px;font-weight:800;font-family:var(--font-display);cursor:pointer;-webkit-user-select:all;user-select:all;transition:color .15s}.quiz-room-code-value:hover{color:var(--color-accent-active)}.quiz-room-code-copied{color:#26890c;min-height:18px;font-size:12px;font-weight:500}.quiz-room-code-url{color:var(--color-text-faint);word-break:break-all;font-size:12px}.quiz-qr-area{background:var(--color-surface-alt);width:120px;height:120px;color:var(--color-text-faint);border-radius:8px;justify-content:center;align-items:center;font-size:12px;display:flex}.quiz-info-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;gap:12px;padding:20px 24px;display:flex}.quiz-info-title{font-size:18px;font-weight:700;font-family:var(--font-display)}.quiz-info-meta{color:var(--color-text-muted);gap:16px;font-size:13px;display:flex}.quiz-status-badge{border-radius:var(--radius-pill);padding:4px 12px;font-size:12px;font-weight:600;display:inline-block}.quiz-status-waiting{background:var(--color-accent-tinted-bg);color:var(--color-accent)}.quiz-status-active{color:#26890c;background:#e6f9e6}.quiz-status-finished{color:var(--color-text-muted);background:#f5f5f5}.quiz-player-list{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);padding:16px 20px}.quiz-player-list-header{color:var(--color-text);justify-content:space-between;align-items:center;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.quiz-player-count{color:var(--color-text-muted);font-size:12px;font-weight:400}.quiz-player-grid{flex-wrap:wrap;gap:8px;display:flex}.quiz-player-chip{background:var(--color-surface-alt);border-radius:var(--radius-pill);align-items:center;gap:6px;padding:6px 12px;font-size:13px;font-weight:500;display:flex}.quiz-player-score{color:var(--color-accent);font-size:11px;font-weight:700}.quiz-question{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);text-align:center;padding:28px 24px}.quiz-question-number{color:var(--color-text-muted);margin-bottom:12px;font-size:13px;font-weight:600}.quiz-question-text{font-size:20px;font-weight:700;font-family:var(--font-display);margin-bottom:20px;line-height:1.4}.quiz-distribution{flex-direction:column;gap:8px;margin-top:16px;display:flex}.quiz-dist-row{align-items:center;gap:10px;display:flex}.quiz-dist-label{color:#fff;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;font-weight:700;display:flex}.quiz-dist-bar-wrap{background:var(--color-surface-alt);border-radius:4px;flex:1;height:28px;position:relative;overflow:hidden}.quiz-dist-bar{border-radius:4px;min-width:2px;height:100%;transition:width .6s}.quiz-dist-bar.correct{outline:2px solid #0003}.quiz-dist-count{color:var(--color-text-muted);text-align:right;width:32px;font-size:13px;font-weight:600}.quiz-options{grid-template-columns:1fr 1fr;gap:12px;padding:16px;display:grid}.quiz-option-btn{border-radius:var(--radius-card);color:#fff;font-family:var(--font-body);cursor:pointer;text-align:center;border:none;justify-content:center;align-items:center;gap:10px;min-height:80px;padding:24px 16px;font-size:16px;font-weight:700;line-height:1.3;transition:transform .1s,opacity .15s;display:flex}.quiz-option-btn:hover:not(:disabled){transform:scale(1.02)}.quiz-option-btn:active:not(:disabled){transform:scale(.97)}.quiz-option-btn:disabled{opacity:.5;cursor:not-allowed}.quiz-option-btn.selected{outline-offset:-4px;outline:4px solid #fffc}.quiz-option-a{background:#e21b3c}.quiz-option-b{background:#1368ce}.quiz-option-c{background:#d89e00}.quiz-option-d{background:#26890c}.quiz-option-shape{flex-shrink:0;font-size:20px}.quiz-timer-bar{background:var(--color-surface-alt);border-radius:3px;width:100%;height:6px;margin-bottom:8px;overflow:hidden}.quiz-timer-fill{background:var(--color-accent);height:100%;animation:timerCountdown var(--timer-duration,30s) linear forwards;border-radius:3px;transition:background .3s}.quiz-timer-fill.warning{background:#d89e00}.quiz-timer-fill.danger{background:#e21b3c}@keyframes timerCountdown{0%{width:100%}to{width:0%}}.quiz-timer-text{color:var(--color-text-muted);text-align:center;margin-bottom:12px;font-size:14px;font-weight:700}.quiz-result{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;display:flex}.quiz-result-icon{font-size:56px}.quiz-result-text{font-size:24px;font-weight:800;font-family:var(--font-display)}.quiz-result-correct{color:#26890c}.quiz-result-wrong{color:#e21b3c}.quiz-result-points{color:var(--color-text-muted);font-size:16px;font-weight:600}.quiz-result-rank{color:var(--color-accent);font-size:14px;font-weight:500}.quiz-leaderboard{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);padding:24px}.quiz-leaderboard-title{font-size:20px;font-weight:700;font-family:var(--font-display);text-align:center;margin-bottom:20px}.quiz-leaderboard-list{flex-direction:column;gap:6px;display:flex}.quiz-leaderboard-row{background:var(--color-surface-alt);border-radius:8px;align-items:center;gap:12px;padding:10px 14px;transition:background .15s;display:flex}.quiz-leaderboard-row:first-child{background:#fff8e1}.quiz-leaderboard-row:nth-child(2){background:#f0f0f0}.quiz-leaderboard-row:nth-child(3){background:#fbe9e7}.quiz-leaderboard-rank{width:28px;color:var(--color-text);text-align:center;font-size:16px;font-weight:800}.quiz-leaderboard-name{flex:1;font-size:15px;font-weight:600}.quiz-leaderboard-score{color:var(--color-accent);font-size:14px;font-weight:700}.quiz-podium{justify-content:center;align-items:flex-end;gap:8px;padding:24px 0;display:flex}.quiz-podium-slot{flex-direction:column;align-items:center;gap:8px;display:flex}.quiz-podium-bar{color:#fff;border-radius:8px 8px 0 0;flex-direction:column;justify-content:flex-end;align-items:center;width:80px;padding:12px 8px;font-size:24px;font-weight:800;display:flex}.quiz-podium-bar-1{background:#fff;height:120px}.quiz-podium-bar-2{background:#fff;height:90px}.quiz-podium-bar-3{background:#fff;height:70px}.quiz-podium-name{color:var(--color-text);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:14px;font-weight:600;overflow:hidden}.quiz-podium-score{color:var(--color-text-muted);font-size:12px;font-weight:500}.quiz-waiting{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:60vh;padding:24px;display:flex}.quiz-waiting-icon{font-size:48px;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.7;transform:scale(1.1)}}.quiz-waiting-text{color:var(--color-text);font-size:18px;font-weight:600}.quiz-waiting-sub{color:var(--color-text-muted);font-size:14px}.quiz-join{flex-direction:column;justify-content:center;align-items:center;gap:20px;min-height:80vh;padding:24px;display:flex}.quiz-join-title{font-size:28px;font-weight:800;font-family:var(--font-display);letter-spacing:var(--font-display-tracking)}.quiz-join-form{flex-direction:column;gap:12px;width:100%;max-width:320px;display:flex}.quiz-join-input{font-family:var(--font-body);border:1px solid var(--color-border);color:var(--color-text);background:var(--color-surface);text-align:center;border-radius:8px;outline:none;padding:12px 16px;font-size:16px;transition:border-color .15s}.quiz-join-input:focus{border-color:var(--color-accent)}.quiz-join-input.code-input{letter-spacing:6px;font-size:24px;font-weight:700}.quiz-join-btn{background:var(--color-accent);color:#fff;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;padding:14px 24px;font-size:16px;font-weight:700;transition:background .16s}.quiz-join-btn:hover:not(:disabled){background:var(--color-accent-active)}.quiz-join-btn:disabled{opacity:.5;cursor:not-allowed}.quiz-play{flex-direction:column;max-width:600px;min-height:100vh;margin:0 auto;padding:16px;display:flex}.quiz-play-header{justify-content:space-between;align-items:center;margin-bottom:12px;padding:8px 0;display:flex}.quiz-play-nickname{color:var(--color-text-muted);font-size:14px;font-weight:600}.quiz-play-score{color:var(--color-accent);font-size:14px;font-weight:700}.llm-settings-modal{width:440px}.llm-settings-modal .modal-body{gap:16px}.llm-settings-field{flex-direction:column;gap:6px;display:flex}.llm-settings-label{color:var(--color-text-muted);letter-spacing:.2px;font-size:12px;font-weight:600}@media (max-width:600px){.quiz-room-code-value{letter-spacing:4px;font-size:32px}.quiz-options{grid-template-columns:1fr;gap:8px}.quiz-option-btn{min-height:60px;padding:16px 12px;font-size:14px}.quiz-podium-bar{width:60px}.quiz-question-text{font-size:16px}}.quiz-empty{text-align:center;flex-direction:column;align-items:center;gap:12px;padding:40px 16px;display:flex}.quiz-empty-icon{font-size:40px}.quiz-empty-title{color:var(--color-text-muted);font-size:15px}.quiz-empty-hint{color:var(--color-text-faint);font-size:13px}.quiz-modal{z-index:1001;background:var(--color-surface);border-radius:var(--radius-card);width:min(720px,100vw - 32px);max-height:calc(100vh - 48px);box-shadow:var(--shadow-card);flex-direction:column;display:flex;position:fixed;top:50%;left:50%;overflow:hidden;transform:translate(-50%,-50%)}.quiz-report-modal{width:min(840px,100vw - 32px)}.quiz-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.quiz-modal-title{margin:0;font-size:18px;font-weight:600}.quiz-modal-close{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;padding:4px 8px;font-size:24px;line-height:1}.quiz-modal-body{padding:20px;overflow:auto}.quiz-modal-tabs{border-bottom:1px solid var(--color-border);gap:0;margin-bottom:20px;display:flex}.quiz-modal-tab{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:12px 8px;font-size:14px}.quiz-modal-tab.is-active{color:var(--color-text);border-bottom-color:var(--color-accent);font-weight:600}.quiz-modal-label{color:var(--color-text-muted);margin:16px 0 6px;font-size:13px;display:block}.quiz-modal-file-row{align-items:center;gap:8px;margin-top:8px;display:flex}.quiz-modal-file-clear{color:var(--color-text-faint);cursor:pointer;background:0 0;border:none;font-size:12px}.quiz-modal-count{flex-direction:column;gap:8px;display:flex}.quiz-modal-count-row{align-items:center;gap:8px;font-size:14px;display:flex}.quiz-modal-count-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:72px;padding:6px 8px}.quiz-modal-count-input:disabled{opacity:.5}.quiz-modal-count-hint{color:var(--color-text-faint);font-size:12px}.quiz-modal-actions{justify-content:flex-end;gap:8px;margin-top:24px;display:flex}.quiz-modal-error{background:var(--color-status-returned-bg);color:var(--color-status-returned-text);border-radius:var(--radius-btn);margin-top:12px;padding:8px 12px;font-size:13px}.segmented-control{border:1px solid var(--color-border);border-radius:var(--radius-btn);display:inline-flex;overflow:hidden}.segmented-control-item{background:var(--color-surface);color:var(--color-text-muted);cursor:pointer;border:none;border-right:1px solid var(--color-border);padding:8px 16px;font-size:14px}.segmented-control-item:last-child{border-right:none}.segmented-control-item.is-active{background:var(--color-accent);color:#fff;font-weight:600}.quiz-library{flex-direction:column;gap:12px;display:flex}.quiz-library-list{border:1px solid var(--color-border);border-radius:var(--radius-card);max-height:320px;margin:0;padding:0;list-style:none;overflow:auto}.quiz-library-item{border-bottom:1px solid var(--color-border);cursor:pointer;align-items:center;gap:10px;padding:10px 12px;display:flex}.quiz-library-list>li:last-child>.quiz-library-item{border-bottom:none}.quiz-library-item.is-active{background:var(--color-accent-tinted-bg)}.quiz-library-item-main{flex:1;min-width:0}.quiz-library-item-title{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:500;overflow:hidden}.quiz-library-item-meta{color:var(--color-text-muted);font-size:12px}.quiz-library-empty,.quiz-library-error{color:var(--color-text-muted);flex-direction:column;align-items:center;gap:8px;padding:32px 16px;display:flex}.quiz-library-empty-icon{font-size:36px}.quiz-library-more{align-self:center}.quiz-draft-editor{flex-direction:column;gap:12px;display:flex}.quiz-draft-editor-header{justify-content:space-between;align-items:center;gap:8px;padding-bottom:8px;display:flex}.quiz-draft-editor-title{text-align:center;color:var(--color-text-muted);flex:1;margin:0;font-size:14px;font-weight:600}.quiz-draft-editor-back{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;font-size:13px}.quiz-draft-editor-error{background:var(--color-status-returned-bg);color:var(--color-status-returned-text);border-radius:var(--radius-btn);padding:8px 12px;font-size:13px}.quiz-draft-editor-list{flex-direction:column;gap:12px;display:flex}.quiz-draft-question{border:1px solid var(--color-border);border-radius:var(--radius-card);flex-direction:column;gap:8px;padding:12px;display:flex}.quiz-draft-question.has-error{border-color:var(--color-danger);animation:.3s quiz-draft-shake}@keyframes quiz-draft-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}75%{transform:translate(4px)}}.quiz-draft-question-head{justify-content:space-between;align-items:center;display:flex}.quiz-draft-question-num{color:var(--color-text-muted);font-size:13px;font-weight:600}.quiz-draft-question-delete{color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;font-size:16px}.quiz-draft-question-delete:disabled{opacity:.3;cursor:not-allowed}.quiz-draft-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;font-size:14px;font-family:var(--font-body);padding:8px 10px}.quiz-draft-input:focus{outline:2px solid var(--color-accent);outline-offset:-1px}.quiz-draft-options{flex-direction:column;gap:6px;display:flex}.quiz-draft-option{align-items:center;gap:8px;display:flex}.quiz-draft-option-letter{width:16px;color:var(--color-text-muted);font-weight:600}.quiz-draft-option-input{flex:1}.quiz-draft-add{align-self:flex-start}.quiz-report-summary{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:20px;display:grid}.quiz-report-stat{border:1px solid var(--color-border);border-radius:var(--radius-card);text-align:center;padding:12px}.quiz-report-stat-label{color:var(--color-text-muted);font-size:12px}.quiz-report-stat-value{margin-top:4px;font-size:22px;font-weight:700}.quiz-report-matrix-wrap{border:1px solid var(--color-border);border-radius:var(--radius-card);max-height:420px;overflow:auto}.quiz-report-matrix{border-collapse:collapse;width:100%;font-size:13px}.quiz-report-matrix th,.quiz-report-matrix td{text-align:center;border-bottom:1px solid var(--color-border);border-right:1px solid var(--color-border);background:var(--color-surface);padding:6px 10px}.quiz-report-matrix thead th{background:var(--color-bg-alt);z-index:1;font-weight:600;position:sticky;top:0}.quiz-report-matrix-name{text-align:left;background:var(--color-bg-alt);z-index:2;min-width:100px;position:sticky;left:0}.quiz-report-matrix thead th.quiz-report-matrix-name{z-index:3}.quiz-report-cell-correct{background:var(--color-status-reviewed-bg);color:var(--color-status-reviewed-text);font-weight:600}.quiz-report-cell-wrong{background:var(--color-status-returned-bg);color:var(--color-status-returned-text)}.quiz-report-cell-empty{color:var(--color-text-faint)}.quiz-report-footer{justify-content:flex-end;margin-top:16px;display:flex}.quiz-report-skeleton{flex-direction:column;gap:8px;padding:32px;display:flex}.quiz-report-skeleton-row{background:var(--color-surface-alt);border-radius:var(--radius-btn);height:20px}.quiz-report-empty{color:var(--color-text-muted);flex-direction:column;align-items:center;gap:8px;padding:40px 16px;display:flex}.quiz-report-empty-icon{font-size:40px}.quiz-report-error{text-align:center;color:var(--color-status-returned-text);padding:16px}.quiz-difficulty-badge{border-radius:var(--radius-pill);color:#fff;padding:2px 8px;font-size:11px;display:inline-block}.quiz-difficulty-badge-easy{background:var(--color-quiz-difficulty-easy)}.quiz-difficulty-badge-medium{background:var(--color-quiz-difficulty-medium);color:var(--color-text)}.quiz-difficulty-badge-hard{background:var(--color-quiz-difficulty-hard)}@media (max-width:600px){.quiz-modal{border-radius:0;width:100vw;height:100vh;max-height:100vh;top:0;left:0;transform:none}.quiz-report-summary{grid-template-columns:1fr}}
.classroom-page{min-height:100vh;max-width:var(--container-max-width);background:#fff;margin:0 auto;padding:48px 32px}.classroom-page-detail{max-width:1400px}.classroom-back-link{color:var(--color-text-muted);margin-bottom:16px;font-size:14px;text-decoration:none;transition:color .15s;display:inline-block}.classroom-back-link:hover{color:var(--color-text)}.classroom-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.classroom-header h1{font-family:var(--font-display);letter-spacing:-.5px;color:var(--color-text);margin:0;font-size:26px;font-weight:700}.classroom-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;display:grid}.classroom-grid-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);min-height:140px;box-shadow:var(--shadow-card);cursor:pointer;text-align:left;color:inherit;font-family:var(--font-body);transition:box-shadow var(--t-slow), border-color var(--t-slow), transform var(--t-slow);flex-direction:column;gap:10px;padding:24px;display:flex;position:relative}.classroom-grid-card-link{color:inherit;cursor:pointer;flex-direction:column;flex:1;gap:10px;text-decoration:none;display:flex}.classroom-grid-card--menu-open:hover{transform:none}.classroom-grid-card--menu-open{z-index:20}.classroom-grid-kebab{width:28px;height:28px;color:var(--color-text-faint);cursor:pointer;opacity:.6;transition:background var(--t-normal), color var(--t-normal), opacity var(--t-normal);z-index:21;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;font-size:16px;line-height:1;display:flex;position:absolute;top:6px;right:6px}.classroom-grid-kebab:hover{background:var(--color-surface-alt);color:var(--color-text);opacity:1}.classroom-grid-kebab-menu{background:var(--color-surface);border:1px solid var(--color-border);min-width:110px;box-shadow:var(--shadow-lift);z-index:22;border-radius:8px;position:absolute;top:36px;right:6px;overflow:hidden}.classroom-grid-kebab-item{text-align:left;width:100%;color:var(--color-text);cursor:pointer;background:0 0;border:none;padding:10px 14px;font-family:inherit;font-size:13px;display:block}.classroom-grid-kebab-item:hover{background:var(--color-surface-alt)}.classroom-grid-kebab-item--danger{color:var(--color-danger)}.classroom-grid-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover);transform:translateY(-2px)}.classroom-grid-name{letter-spacing:-.25px;color:var(--color-text);font-size:18px;font-weight:700}.classroom-grid-code{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);font-family:var(--font-mono);letter-spacing:2px;text-transform:uppercase;align-self:flex-start;padding:3px 10px;font-size:12px;font-weight:600;display:inline-block}.classroom-grid-stats{color:var(--color-text-muted);align-items:baseline;gap:12px;margin-top:auto;font-size:13px;display:flex}.classroom-stat{align-items:baseline;gap:4px;display:flex}.classroom-stat-num{letter-spacing:-.3px;color:var(--color-text);font-size:22px;font-weight:700}.classroom-stat-label{color:var(--color-text-muted);font-size:13px}.classroom-stat-sep{background:var(--color-border);align-self:center;width:1px;height:14px}.classroom-grid-new{text-align:center;border:2px dashed var(--color-border);box-shadow:none;background:0 0;justify-content:center;align-items:center}.classroom-grid-new:hover{border-color:var(--color-accent);background:var(--color-accent-tinted-bg);box-shadow:none;transform:none}.classroom-grid-new-icon{background:var(--color-surface-alt);width:48px;height:48px;color:var(--color-text-faint);border-radius:50%;justify-content:center;align-items:center;font-size:28px;transition:background .15s,color .15s;display:flex}.classroom-grid-new:hover .classroom-grid-new-icon{background:var(--color-accent);color:#fff}.classroom-grid-new-label{color:var(--color-text-muted);font-size:14px;font-weight:500}.classroom-detail{width:100%}.classroom-detail-header{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:24px;padding-bottom:24px;display:flex}.classroom-detail-header-main{flex:auto;min-width:0}.classroom-detail-name{font-family:var(--font-display);letter-spacing:-.5px;color:var(--color-text);margin:0 0 8px;font-size:32px;font-weight:700}.classroom-detail-meta{color:var(--color-text-muted);margin:0;font-size:15px}.classroom-invite-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);color:inherit;transition:box-shadow var(--t-normal), border-color var(--t-normal);align-items:center;gap:16px;padding:14px 18px;text-decoration:none;display:inline-flex}.classroom-invite-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.classroom-invite-label{letter-spacing:.1px;color:var(--color-text-muted);font-size:12px;font-weight:600}.classroom-invite-cta{letter-spacing:-.2px;color:var(--color-text);margin-top:4px;font-size:15px;font-weight:700}.classroom-invite-badge{border-radius:var(--radius-pill);background:var(--color-warning-tinted-bg);min-width:22px;height:22px;color:var(--color-warning);justify-content:center;align-items:center;padding:0 6px;font-size:12px;font-weight:700;display:inline-flex}.classroom-detail-delete{color:var(--color-danger);border-radius:var(--radius-btn);cursor:pointer;transition:background var(--t-fast), border-color var(--t-fast);background:0 0;border:1px solid #0000;margin-left:auto;padding:6px 10px;font-size:13px;font-weight:500}.classroom-detail-delete:hover{background:#c6282814;border-color:#c628284d}.classroom-action-bar{align-items:center;gap:12px;margin-bottom:24px;display:flex}.classroom-action-badge{color:#fff;background:#e53e3e;border-radius:999px;justify-content:center;align-items:center;min-width:20px;height:20px;margin-left:8px;padding:0 6px;font-size:12px;font-weight:700;line-height:1;display:inline-flex}.classroom-action-btn{font-family:var(--font-body);border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;cursor:pointer;border:none;align-items:center;padding:8px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:background .16s;display:inline-flex}.classroom-action-btn:hover{background:var(--color-accent-active)}.classroom-table-wrap{overflow-x:auto}.classroom-table{border-collapse:separate;border-spacing:0;width:100%}.classroom-th{text-align:left;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);padding:8px 12px;font-size:13px;font-weight:600}.classroom-th-num{width:40px}.classroom-th-actions{text-align:right;width:120px}.classroom-td{border-bottom:1px solid var(--color-border);vertical-align:middle;padding:10px 12px;font-size:14px}.classroom-tr:hover .classroom-td{background:#00000005}.classroom-td-num{color:var(--color-text-faint);font-size:13px}.classroom-td-name{font-weight:600}.classroom-qr-thumb{border-radius:4px;width:40px;height:40px}.classroom-qr-placeholder{background:var(--color-surface-alt);border-radius:4px;width:40px;height:40px;display:inline-block}.classroom-text-code{letter-spacing:1px;color:var(--color-text-muted);font-family:monospace;font-size:13px}.classroom-td-parent{text-align:center}.classroom-parent-chip{min-width:44px;color:var(--color-accent-tinted-text,var(--color-accent));background:var(--color-accent-tinted-bg,var(--color-surface-alt));border-radius:999px;justify-content:center;align-items:center;padding:4px 10px;font-size:13px;font-weight:600;text-decoration:none;transition:background .12s;display:inline-flex}.classroom-parent-chip:hover{background:var(--color-surface-alt)}.classroom-parent-chip.is-empty{color:var(--color-text-faint);background:0 0;font-weight:400}.classroom-td-role{text-align:left}.classroom-role-select{font:inherit;border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);cursor:pointer;border-radius:6px;min-width:90px;padding:4px 8px;font-size:12px}.classroom-role-select:focus-visible{outline:2px solid var(--color-accent-tinted-text);outline-offset:1px}.classroom-td-actions{text-align:right}.classroom-row-actions{opacity:0;justify-content:flex-end;align-items:center;gap:8px;transition:opacity .15s;display:flex}.classroom-tr:hover .classroom-row-actions{opacity:1}.classroom-row-btn{cursor:pointer;font-family:var(--font-body);color:var(--color-text-muted);border-radius:var(--radius-btn);background:0 0;border:none;padding:4px 8px;font-size:12px;font-weight:500;transition:color .15s,background .15s}.classroom-row-btn:hover{background:var(--color-surface-alt)}.classroom-row-btn-reissue:hover{color:var(--color-accent)}.classroom-row-btn-delete:hover{color:#c62828}.classroom-main-grid{grid-template-columns:minmax(0,2fr) minmax(280px,1fr);align-items:stretch;gap:32px;margin-top:24px;display:grid}@media (max-width:1199px){.classroom-main-grid{grid-template-columns:minmax(0,1fr)}}.classroom-boards-section{margin-top:0}.classroom-boards-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.classroom-boards-heading{color:var(--color-text);margin:0;font-size:16px;font-weight:700}.classroom-boards-empty{color:var(--color-text-muted);padding:24px 0;font-size:14px}.classroom-board-picker{background:var(--color-bg);border:1px dashed var(--color-border);border-radius:var(--radius-card);flex-direction:column;gap:8px;margin-bottom:20px;padding:16px;display:flex}.classroom-board-picker-empty{color:var(--color-text-muted);margin:0;font-size:13px}.classroom-board-picker-item{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-btn);cursor:pointer;font-family:var(--font-body);text-align:left;align-items:center;gap:12px;padding:10px 14px;transition:border-color .15s;display:flex}.classroom-board-picker-item:hover{border-color:var(--color-accent)}.classroom-board-link-action{color:var(--color-accent);margin-left:auto;font-size:12px;font-weight:600}.classroom-boards-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.classroom-board-new{color:#166534;background:#dcfce7;border-radius:999px;align-self:flex-start;align-items:center;gap:4px;margin-top:4px;padding:3px 8px;font-size:11px;font-weight:600;line-height:1;display:inline-flex}.classroom-board-new-dot{background:#22c55e;border-radius:999px;flex:none;width:7px;height:7px}.classroom-board-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;transition:box-shadow .18s,border-color .18s;display:flex;position:relative}.classroom-board-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.classroom-board-card-body{cursor:pointer;font-family:var(--font-body);text-align:left;background:0 0;border:none;flex-direction:column;gap:6px;padding:16px;display:flex}.classroom-board-unlink{border-radius:var(--radius-pill);width:22px;height:22px;color:var(--color-text-muted);cursor:pointer;background:#0000000f;border:none;justify-content:center;align-items:center;font-size:12px;transition:background .15s,color .15s;display:none;position:absolute;top:6px;right:6px}.classroom-board-card:hover .classroom-board-unlink{display:flex}.classroom-board-unlink:hover{color:#c62828;background:#fee}.classroom-board-title{color:var(--color-text);font-size:14px;font-weight:600}.classroom-board-layout{color:var(--color-text-faint);font-size:12px}.classroom-empty{text-align:center;padding:48px 0}.classroom-empty-text{color:var(--color-text-muted);margin:0 0 16px;font-size:14px}.classroom-empty-btn{border-radius:var(--radius-btn);background:var(--color-accent);color:#fff;font-family:var(--font-body);cursor:pointer;border:none;padding:8px 20px;font-size:14px;font-weight:600;transition:background .16s}.classroom-empty-btn:hover{background:var(--color-accent-active)}.classroom-copy-toast{background:var(--color-accent);color:#fff;border-radius:var(--radius-pill);z-index:200;padding:8px 16px;font-size:13px;font-weight:500;animation:2s forwards fadeInOut;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}@keyframes fadeInOut{0%{opacity:0;transform:translate(-50%)translateY(8px)}15%{opacity:1;transform:translate(-50%)translateY(0)}75%{opacity:1;transform:translate(-50%)translateY(0)}to{opacity:0;transform:translate(-50%)translateY(-4px)}}:root{--color-bank-positive:var(--color-plant-active,#27a35f);--color-bank-negative:var(--color-danger,#c62828)}.classroom-page-title{font-family:var(--font-display);color:var(--color-text);margin:8px 0 16px;font-size:22px;font-weight:700}.classroom-nav{border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:4px;margin-bottom:20px;display:flex}.classroom-nav-tab{color:var(--color-text-muted);border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;transition:color .12s,border-color .12s;display:inline-flex}.classroom-nav-tab:hover{color:var(--color-text)}.classroom-nav-tab.is-active{color:var(--color-accent);border-bottom-color:var(--color-accent)}.classroom-nav-emoji{font-size:16px}.classroom-dashboard-hero{border:1px solid var(--color-border);border-radius:var(--radius-card);background:linear-gradient(135deg, #0ea5e91a, #22c55e1a), var(--color-surface);justify-content:space-between;align-items:flex-end;gap:24px;margin:24px 0;padding:24px;display:flex}.classroom-dashboard-eyebrow,.classroom-dashboard-panel-head span{letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-muted);font-size:11px;font-weight:800;display:block}.classroom-dashboard-hero h2{letter-spacing:0;margin:4px 0 8px;font-size:28px}.classroom-dashboard-hero p{color:var(--color-text-muted);margin:0;font-size:14px}.classroom-dashboard-hero-stats{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.classroom-dashboard-hero-stats span{border:1px solid var(--color-border);background:#fff;border-radius:999px;padding:7px 10px;font-size:12px;font-weight:700}.classroom-dashboard-kpis{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px;display:grid}.classroom-dashboard-kpi,.classroom-dashboard-panel{border:1px solid var(--color-border);border-radius:var(--radius-card);background:var(--color-surface);box-shadow:var(--shadow-card)}.classroom-dashboard-kpi{gap:6px;padding:16px;display:grid}.classroom-dashboard-kpi span{color:var(--color-text-muted);font-size:12px;font-weight:700}.classroom-dashboard-kpi strong{letter-spacing:0;font-size:22px}.classroom-dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.classroom-dashboard-panel{min-width:0;padding:18px}.classroom-dashboard-panel-wide{grid-column:1/-1}.classroom-dashboard-panel-head{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:14px;display:flex}.classroom-dashboard-panel-head h3{margin:2px 0 0;font-size:17px}.classroom-dashboard-panel-head a{color:var(--color-accent);font-size:12px;font-weight:800;text-decoration:none}.classroom-showcase-strip{grid-template-columns:repeat(6,minmax(0,1fr));gap:10px;display:grid}.classroom-showcase-card{aspect-ratio:1;color:#fff;background:#0f172a;border:1px solid #0f172a14;border-radius:10px;min-height:164px;text-decoration:none;display:block;position:relative;overflow:hidden}.classroom-showcase-card img,.classroom-showcase-fallback{object-fit:cover;place-items:center;width:100%;height:100%;display:grid}.classroom-showcase-fallback{background:linear-gradient(135deg,#0ea5e9,#22c55e);font-weight:800}.classroom-showcase-overlay{background:linear-gradient(#0000,#0f172ae6);gap:3px;padding:32px 10px 10px;display:grid;position:absolute;inset:auto 0 0}.classroom-showcase-overlay strong,.classroom-showcase-overlay small{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.classroom-showcase-overlay strong{font-size:13px}.classroom-showcase-overlay small{color:#ffffffc7;font-size:11px}.classroom-dashboard-list{gap:8px;display:grid}.classroom-dashboard-row{background:var(--color-surface-alt);min-height:42px;color:inherit;border-radius:8px;justify-content:space-between;align-items:center;gap:12px;padding:10px 12px;font-size:13px;text-decoration:none;display:flex}.classroom-dashboard-row strong{white-space:nowrap}.classroom-role-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.classroom-role-mini-card{background:var(--color-surface-alt);border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:2px 8px;padding:10px;font-size:13px;display:grid}.classroom-role-mini-icon{border:1px solid var(--color-border);background:#fff;border-radius:999px;grid-row:span 2;place-items:center;width:30px;height:30px;display:grid}.classroom-role-mini-card strong{color:var(--color-text-muted);font-size:12px}.classroom-dashboard-empty{color:var(--color-text-muted);margin:0;font-size:13px}@media (max-width:960px){.classroom-dashboard-hero{flex-direction:column;align-items:flex-start}.classroom-dashboard-kpis,.classroom-dashboard-grid{grid-template-columns:1fr}.classroom-showcase-strip{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (max-width:640px){.classroom-showcase-strip,.classroom-role-mini-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.classroom-roles-header h2{margin:0 0 4px;font-size:18px;font-weight:700}.classroom-roles-desc{color:var(--color-text-muted);margin:0 0 16px;font-size:13px}.classroom-role-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.classroom-role-card-btn{background:var(--color-surface);border:1px solid var(--color-border);text-align:left;cursor:pointer;border-radius:10px;flex-direction:column;gap:6px;width:100%;padding:16px;transition:border-color .12s,box-shadow .12s;display:flex}.classroom-role-card-btn:hover:not(:disabled){border-color:var(--color-accent);box-shadow:var(--shadow-card-hover,0 4px 16px #00000014)}.classroom-role-card-btn:disabled{opacity:.6;cursor:default}.classroom-role-emoji{font-size:28px}.classroom-role-label{color:var(--color-text);font-size:15px;font-weight:700}.classroom-role-meta{color:var(--color-text-muted);font-size:12px}.classroom-role-meta-faint{color:var(--color-text-faint)}.classroom-role-perms{color:var(--color-text-faint);margin-top:4px;font-size:11px}.classroom-role-badge{background:var(--color-surface-alt);color:var(--color-text-muted);border-radius:999px;padding:2px 8px;font-size:10px;display:inline-block}.role-perm-modal{background:var(--color-surface);border-radius:12px;flex-direction:column;width:calc(100vw - 32px);max-width:520px;max-height:calc(100vh - 80px);display:flex;overflow:auto}.role-perm-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.role-perm-modal-header h3{margin:0;font-size:16px}.role-perm-modal-body{padding:16px 20px}.role-perm-group{margin-bottom:16px}.role-perm-group-title{color:var(--color-text-muted);margin:0 0 8px;font-size:13px;font-weight:700}.role-perm-list{margin:0;padding:0;list-style:none}.role-perm-row{border-bottom:1px solid var(--color-border);padding:8px 0}.role-perm-label{cursor:pointer;align-items:center;gap:8px;display:flex}.role-perm-label-main{color:var(--color-text);font-size:14px;font-weight:600}.role-perm-desc{color:var(--color-text-muted);margin:4px 0 0 24px;font-size:12px}.role-perm-error{color:var(--color-bank-negative);padding:0 20px;font-size:12px}.role-perm-modal-footer{border-top:1px solid var(--color-border);justify-content:flex-end;gap:8px;padding:12px 20px;display:flex}.role-perm-btn-cancel,.role-perm-btn-save{border:1px solid var(--color-border);cursor:pointer;border-radius:4px;padding:8px 16px;font-size:13px;font-weight:600}.role-perm-btn-cancel{color:var(--color-text-muted);background:0 0}.role-perm-btn-save{background:var(--color-accent);border-color:var(--color-accent);color:#fff}.classroom-bank{flex-direction:column;gap:20px;display:flex}.bank-summary-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;display:grid}.bank-summary-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:14px 16px}.bank-summary-label{color:var(--color-text-muted);font-size:12px}.bank-summary-value{font-family:var(--font-display);color:var(--color-text);margin-top:2px;font-size:22px;font-weight:700}.bank-summary-rate{gap:4px;margin-top:6px;display:flex}.bank-rate-input{border:1px solid var(--color-border);border-radius:4px;width:72px;padding:4px 8px;font-size:12px}.bank-rate-save{border:1px solid var(--color-accent);background:var(--color-accent);color:#fff;cursor:pointer;border-radius:4px;padding:4px 10px;font-size:12px}.bank-action-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (max-width:720px){.bank-action-grid{grid-template-columns:1fr}}.bank-student-panel,.bank-action-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:14px}.bank-student-panel h3,.bank-action-panel h3{margin:0 0 10px;font-size:14px}.bank-student-list{max-height:340px;margin:0;padding:0;list-style:none;overflow-y:auto}.bank-student-row{cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:6px;grid-template-columns:32px 1fr auto;align-items:center;gap:8px;width:100%;padding:8px;font-size:13px;display:grid}.bank-student-row:hover{background:var(--color-surface-alt)}.bank-student-row.is-selected{border-color:var(--color-accent);background:var(--color-accent-tinted-bg)}.bank-student-num{color:var(--color-text-faint);font-size:11px}.bank-student-balance{font-weight:600}.bank-field{color:var(--color-text-muted);flex-direction:column;gap:4px;margin-bottom:8px;font-size:12px;display:flex}.bank-field input{border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text);border-radius:6px;padding:8px 10px;font-size:14px}.bank-btn-row{flex-wrap:wrap;gap:6px;margin-top:8px;display:flex}.bank-btn{cursor:pointer;border:1px solid var(--color-border);background:var(--color-surface);border-radius:6px;flex:auto;min-width:90px;padding:10px 12px;font-size:13px;font-weight:600}.bank-btn-deposit{background:var(--color-bank-positive);color:#fff;border-color:var(--color-bank-positive)}.bank-btn-withdraw{background:var(--color-bank-negative);color:#fff;border-color:var(--color-bank-negative)}.bank-btn-fd{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}.bank-btn:disabled{opacity:.4;cursor:not-allowed}.bank-error{color:var(--color-bank-negative);margin:8px 0 0;font-size:12px}.bank-toast{color:var(--color-bank-positive);margin:8px 0 0;font-size:12px}.bank-loading{color:var(--color-text-muted)}.bank-fd-section,.bank-txn-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:14px}.bank-fd-section h3,.bank-txn-section h3{margin:0 0 10px;font-size:14px}.bank-fd-list,.bank-txn-list{flex-direction:column;gap:6px;margin:0;padding:0;list-style:none;display:flex}.bank-fd-row{border:1px solid var(--color-border);border-radius:6px;grid-template-columns:1fr auto auto auto auto;align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:grid}.bank-fd-principal{font-weight:700}.bank-fd-rate{color:var(--color-text-muted)}.bank-fd-due{color:var(--color-accent);font-weight:600}.bank-fd-cancel{border:1px solid var(--color-bank-negative);color:var(--color-bank-negative);cursor:pointer;background:0 0;border-radius:4px;padding:4px 10px;font-size:12px}.bank-txn-row{border-bottom:1px solid var(--color-border);grid-template-columns:auto 64px auto 1fr auto;align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:grid}.bank-txn-time{color:var(--color-text-faint);font-size:11px}.bank-txn-type{background:var(--color-surface-alt);color:var(--color-text-muted);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.bank-txn-amount{font-weight:700}.bank-txn-deposit .bank-txn-amount,.bank-txn-fd_matured .bank-txn-amount,.bank-txn-fd_cancelled .bank-txn-amount{color:var(--color-bank-positive)}.bank-txn-withdraw .bank-txn-amount,.bank-txn-purchase .bank-txn-amount,.bank-txn-fd_open .bank-txn-amount{color:var(--color-bank-negative)}.bank-txn-note{color:var(--color-text-muted);font-size:12px}.bank-txn-by{color:var(--color-text-faint);font-size:11px}.bank-empty{color:var(--color-text-muted);font-size:13px}.classroom-store{flex-direction:column;gap:16px;display:flex}.classroom-store-header{justify-content:space-between;align-items:center;display:flex}.classroom-store-header h2{margin:0;font-size:18px}.classroom-store-header-actions{align-items:center;gap:8px;display:flex}.classroom-store-archive-toggle{color:var(--color-text-muted);border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:6px;padding:8px 14px;font-size:13px;font-weight:500}.classroom-store-archive-toggle:hover{background:var(--color-surface-alt);color:var(--color-text)}.classroom-store-add{background:var(--color-accent);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:8px 16px;font-weight:600}.classroom-store-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin:0;padding:0;list-style:none;display:grid}.store-item-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;flex-direction:column;gap:6px;padding:12px;display:flex}.store-item-image{object-fit:cover;background:var(--color-surface-alt);border-radius:6px;width:100%;height:120px}.store-item-name{font-size:14px;font-weight:700}.store-item-price{color:var(--color-accent);font-weight:700}.store-item-stock{color:var(--color-text-muted);font-size:11px}.store-item-actions{gap:4px;display:flex}.store-item-edit,.store-item-archive,.store-item-restore{border:1px solid var(--color-border);cursor:pointer;background:0 0;border-radius:4px;flex:1;padding:6px;font-size:12px}.store-item-archive{color:var(--color-bank-negative)}.store-item-restore{color:var(--color-accent);font-weight:600}.store-item-restore:disabled{opacity:.5;cursor:not-allowed}.store-item-editor{background:var(--color-surface);border-radius:12px;flex-direction:column;width:calc(100vw - 32px);max-width:460px;max-height:calc(100vh - 80px);display:flex;overflow:auto}.store-item-editor-header,.store-item-editor-footer{justify-content:space-between;align-items:center;padding:14px 20px;display:flex}.store-item-editor-header{border-bottom:1px solid var(--color-border)}.store-item-editor-footer{border-top:1px solid var(--color-border);gap:8px}.store-item-editor-header h3{margin:0;font-size:16px}.store-editor-field{color:var(--color-text-muted);flex-direction:column;gap:4px;padding:10px 20px;font-size:12px;display:flex}.store-editor-field input{border:1px solid var(--color-border);border-radius:6px;padding:8px 10px;font-size:14px}.store-item-editor-footer button{cursor:pointer;border-radius:6px;padding:8px 16px;font-weight:600}.store-item-editor-footer button[type=submit]{background:var(--color-accent);color:#fff;border:1px solid var(--color-accent)}.store-item-editor-footer button[type=button]{border:1px solid var(--color-border);color:var(--color-text-muted);background:0 0}.pay-intro{border:1px solid var(--color-border);background:var(--color-accent-tinted-bg);border-radius:12px;margin-bottom:16px;padding:18px 20px}.pay-intro-eyebrow{color:var(--color-accent);margin:0 0 6px;font-size:12px;font-weight:700}.pay-intro-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:20px;font-weight:700}.pay-intro-copy{color:var(--color-text-muted);margin:8px 0 0;font-size:13px;line-height:1.5}.pay-intro-actions{align-items:center;display:flex}.pay-manage-link{border:1px solid var(--color-border);background:var(--color-surface);min-height:36px;color:var(--color-text);border-radius:999px;justify-content:center;align-items:center;padding:0 14px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.pay-manage-link:hover{border-color:var(--color-accent);color:var(--color-accent)}.pay-grid{grid-template-columns:1fr 340px;gap:16px;display:grid}@media (max-width:900px){.pay-grid{grid-template-columns:1fr}}.pay-catalog{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:14px}.pay-catalog h3{margin:0 0 10px;font-size:14px}.pay-item-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px;margin:0;padding:0;list-style:none;display:grid}.pay-item-btn{border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;text-align:left;border-radius:8px;flex-direction:column;gap:4px;width:100%;padding:10px;transition:border-color .12s;display:flex}.pay-item-btn:hover:not(:disabled){border-color:var(--color-accent)}.pay-item-btn:disabled{opacity:.4;cursor:not-allowed}.pay-item-btn img{border-radius:4px}.pay-item-name{font-size:13px;font-weight:600}.pay-item-price{color:var(--color-accent);font-size:13px;font-weight:700}.pay-item-stock{color:var(--color-text-faint);font-size:11px}.pay-cart{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;flex-direction:column;gap:10px;padding:14px;display:flex;position:sticky;top:16px}.pay-cart-header{justify-content:space-between;align-items:baseline;display:flex}.pay-cart-header h3{margin:0;font-size:14px}.pay-cart-total{font-family:var(--font-display);color:var(--color-accent);font-size:22px;font-weight:700}.pay-cart-list{margin:0;padding:0;list-style:none}.pay-cart-row{border-bottom:1px solid var(--color-border);grid-template-columns:1fr auto auto;align-items:center;gap:8px;padding:6px 0;font-size:13px;display:grid}.pay-cart-qty{align-items:center;gap:4px;display:flex}.pay-cart-qty button{border:1px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:4px;width:24px;height:24px}.pay-cart-qty span{text-align:center;min-width:20px;font-weight:600}.pay-cart-sub{font-weight:700}.pay-cart-empty{color:var(--color-text-muted);font-size:12px}.pay-scanner-actions{flex-direction:column;gap:6px;display:flex}.pay-scan-btn{border:1px solid var(--color-accent);background:var(--color-accent-tinted-bg);min-height:40px;color:var(--color-accent);cursor:pointer;border-radius:8px;font-size:13px;font-weight:700}.pay-scan-btn:disabled{opacity:.45;cursor:not-allowed}.pay-scan-help{color:var(--color-text-muted);margin:0;font-size:12px;line-height:1.45}.pay-scanner-panel{border:1px solid var(--color-border);background:var(--color-surface-raised,var(--color-surface));border-radius:10px;flex-direction:column;gap:10px;padding:10px;display:flex}.pay-scanner-video{aspect-ratio:4/3;object-fit:cover;background:#000;border-radius:8px;width:100%}.pay-scanner-footer{color:var(--color-text-muted);justify-content:space-between;align-items:center;gap:10px;font-size:12px;display:flex}.pay-scanner-stop{border:1px solid var(--color-border);min-height:32px;color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:999px;padding:0 12px}.pay-token-field{flex-direction:column;gap:4px;display:flex}.pay-token-field span{color:var(--color-text-muted);font-size:12px}.pay-token-field textarea{border:1px solid var(--color-border);resize:vertical;border-radius:6px;padding:8px 10px;font-family:monospace;font-size:12px}.pay-error{color:var(--color-bank-negative);margin:0;font-size:12px}.pay-cart-actions{gap:6px;display:flex}.pay-cart-clear{border:1px solid var(--color-border);color:var(--color-text-muted);cursor:pointer;background:0 0;border-radius:6px;padding:8px 12px;font-size:13px}.pay-cart-charge{background:var(--color-accent);color:#fff;border:1px solid var(--color-accent);cursor:pointer;border-radius:6px;flex:1;padding:10px;font-size:14px;font-weight:700}.pay-cart-charge:disabled{opacity:.4;cursor:not-allowed}.pay-receipt{background:var(--color-surface);border-radius:12px;flex-direction:column;gap:12px;width:calc(100vw - 32px);max-width:420px;padding:24px;display:flex}.pay-receipt h3{margin:0}.pay-receipt-items{margin:0;padding:0;font-size:13px;list-style:none}.pay-receipt-items li{border-bottom:1px solid var(--color-border);padding:4px 0}.pay-receipt-total{text-align:right;margin-top:4px;font-size:16px;font-weight:700}.pay-receipt-close{background:var(--color-accent);color:#fff;border:1px solid var(--color-accent);cursor:pointer;border-radius:6px;align-self:flex-end;padding:8px 18px;font-weight:600}.pay-empty{color:var(--color-text-muted);font-size:13px}.wallet-page{max-width:860px;margin:0 auto;padding:24px 16px 40px}.wallet-home{flex-direction:column;gap:20px;display:flex}.wallet-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:12px;display:flex}.wallet-header h1{margin:0;font-size:22px}.wallet-balance{text-align:right}.wallet-balance-label{color:var(--color-text-muted);font-size:12px}.wallet-balance-value{font-family:var(--font-display);color:var(--color-text);font-size:32px;font-weight:700}.wallet-grid{grid-template-columns:300px 1fr;align-items:start;gap:20px;display:grid}@media (max-width:760px){.wallet-grid{grid-template-columns:1fr}}.wallet-duty-section{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.wallet-duty-card{background:var(--color-accent-tinted-bg);border-radius:var(--radius-card);color:var(--color-accent-tinted-text);border:1px solid #0000;align-items:center;gap:12px;padding:14px 16px;text-decoration:none;transition:box-shadow .18s,border-color .18s,transform .18s;display:flex}.wallet-duty-card:hover{border-color:var(--color-accent);box-shadow:var(--shadow-card-hover);transform:translateY(-1px)}.wallet-duty-emoji{font-size:26px;line-height:1}.wallet-duty-role{font-family:var(--font-display);flex:1;font-size:15px;font-weight:700}.wallet-duty-cta{color:var(--color-accent);font-size:12px;font-weight:600}.wallet-card-qr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;flex-direction:column;align-items:center;gap:10px;padding:16px;display:flex}.wallet-card-header{justify-content:space-between;align-items:baseline;width:100%;display:flex}.wallet-card-header h3{margin:0;font-size:14px}.wallet-card-number{color:var(--color-text-muted);letter-spacing:2px;font-family:monospace;font-size:13px}.wallet-qr-frame{background:#fff;border-radius:8px;justify-content:center;align-items:center;width:220px;height:220px;display:flex}.wallet-qr-skeleton{background:var(--color-surface-alt);border-radius:8px;width:220px;height:220px}.wallet-qr-timer{width:100%}.wallet-qr-timer-bar{background:var(--color-accent);border-radius:2px;height:4px;transition:width .2s linear}.wallet-qr-timer-label{color:var(--color-text-faint);text-align:center;margin-top:4px;font-size:11px}.wallet-qr-copy{border:1px solid var(--color-border);color:var(--color-text);cursor:pointer;background:0 0;border-radius:6px;padding:6px 14px;font-size:12px}.wallet-qr-help{color:var(--color-text-muted);text-align:center;margin:0;font-size:11px}.wallet-txn-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:16px}.wallet-txn-section h3{margin:0 0 10px;font-size:14px}.wallet-txn-list{margin:0;padding:0;list-style:none}.wallet-txn-row{border-bottom:1px solid var(--color-border);grid-template-columns:70px auto 1fr auto;align-items:center;gap:8px;padding:8px 0;font-size:13px;display:grid}.wallet-txn-type{background:var(--color-surface-alt);color:var(--color-text-muted);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.wallet-txn-amount{font-weight:700}.wallet-txn-deposit .wallet-txn-amount,.wallet-txn-fd_matured .wallet-txn-amount,.wallet-txn-fd_cancelled .wallet-txn-amount{color:var(--color-bank-positive)}.wallet-txn-withdraw .wallet-txn-amount,.wallet-txn-purchase .wallet-txn-amount,.wallet-txn-fd_open .wallet-txn-amount{color:var(--color-bank-negative)}.wallet-txn-note{color:var(--color-text-muted);font-size:12px}.wallet-txn-time{color:var(--color-text-faint);font-size:11px}.wallet-fd-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;padding:16px}.wallet-fd-list{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:8px;margin:0;padding:0;list-style:none;display:grid}.wallet-fd-card{border:1px solid var(--color-accent);background:var(--color-accent-tinted-bg);border-radius:8px;flex-direction:column;gap:4px;padding:12px;display:flex}.wallet-fd-label{color:var(--color-accent);letter-spacing:.1em;font-size:10px;font-weight:700}.wallet-fd-principal{font-size:18px;font-weight:700}.wallet-fd-meta{color:var(--color-text-muted);font-size:11px}.wallet-fd-projected{color:var(--color-bank-positive);margin-top:4px;font-size:11px}.wallet-fd-cancel{border:1px solid var(--color-bank-negative);color:var(--color-bank-negative);cursor:pointer;background:0 0;border-radius:999px;align-self:flex-end;margin-top:8px;padding:5px 10px;font-size:12px;font-weight:700}.wallet-fd-cancel:disabled{opacity:.55;cursor:not-allowed}.wallet-fd-error{color:var(--color-bank-negative);margin:8px 0 0;font-size:12px;font-weight:600}.wallet-loading,.wallet-error{text-align:center;color:var(--color-text-muted);padding:48px 16px}@media (prefers-reduced-motion:reduce){.wallet-qr-timer-bar{transition:none}}.classroom-tabs{border-bottom:1px solid var(--color-border);gap:2px;margin-bottom:16px;display:flex;overflow-x:auto}.classroom-tab{color:var(--color-text-muted);cursor:pointer;transition:color var(--t-normal), border-color var(--t-normal);white-space:nowrap;background:0 0;border:none;border-bottom:2px solid #0000;align-items:center;gap:6px;padding:10px 16px;font-family:inherit;font-size:14px;font-weight:500;display:inline-flex;position:relative}.classroom-tab:hover{color:var(--color-text)}.classroom-tab.is-active{color:var(--color-text);border-bottom-color:var(--color-accent);font-weight:600}.classroom-tab-count{border-radius:var(--radius-pill);background:var(--color-surface-alt);min-width:22px;height:20px;color:var(--color-text-muted);letter-spacing:.1px;justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-flex}.classroom-tab.is-active .classroom-tab-count{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text)}.classroom-tab-badge{border-radius:var(--radius-pill);background:var(--color-warning-tinted-bg);min-width:22px;height:20px;color:var(--color-warning);justify-content:center;align-items:center;padding:0 6px;font-size:11px;font-weight:700;display:inline-flex}.classroom-parents-stat{background:var(--color-warning-tinted-bg);border-radius:var(--radius-card);color:var(--color-warning);flex-direction:column;align-items:center;min-width:120px;padding:14px 20px;display:flex}.classroom-parents-stat-num{font-family:var(--font-display);letter-spacing:-.3px;font-size:28px;font-weight:700;line-height:1}.classroom-parents-stat-label{letter-spacing:.1px;text-transform:none;margin-top:4px;font-size:11px;font-weight:600}.classroom-parents-cta{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);transition:background var(--t-normal);align-self:flex-start;align-items:center;gap:6px;padding:10px 16px;font-size:14px;font-weight:600;text-decoration:none;display:inline-flex}.classroom-parents-cta:hover{background:var(--color-accent-active)}.classroom-settings-panel{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;gap:24px;max-width:640px;padding:28px;display:flex}.classroom-setting-row{flex-direction:column;gap:6px;display:flex}.classroom-setting-label{color:var(--color-text-muted);margin:0;font-size:13px;font-weight:600}.classroom-setting-name-row{align-items:center;gap:10px;display:flex}.classroom-setting-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);width:100%;max-width:380px;color:var(--color-text);background:var(--color-bg-alt);transition:border-color var(--t-normal), box-shadow var(--t-normal);outline:none;padding:10px 14px;font-family:inherit;font-size:15px}.classroom-setting-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0075de26}.classroom-setting-saving{color:var(--color-text-muted);font-size:12px}.classroom-setting-err{color:var(--color-danger);margin:0;font-size:12px}.classroom-setting-hint{color:var(--color-text-muted);max-width:420px;margin:4px 0 0;font-size:13px;line-height:1.5}.classroom-setting-danger{border-top:1px solid var(--color-border);flex-flow:wrap;justify-content:space-between;align-items:flex-start;gap:20px;padding-top:20px}@media (max-width:540px){.classroom-setting-danger{flex-direction:column}.classroom-setting-input{max-width:100%}}.classroom-avatar{color:#fff;letter-spacing:0;-webkit-user-select:none;user-select:none;border-radius:9999px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:inline-flex}.classroom-td-avatar{padding-left:4px!important;padding-right:4px!important}.classroom-tabs-sep{flex:auto;min-width:12px}.classroom-tab-link{color:var(--color-text-muted);align-items:center;gap:6px;text-decoration:none;display:inline-flex}.classroom-tab-link:hover{color:var(--color-accent-tinted-text);background:var(--color-accent-tinted-bg)}.classroom-tab-link:after{content:"↗";opacity:.6;font-size:11px}@media (max-width:640px){.classroom-tabs-sep,.classroom-tab-link:after{display:none}}.classroom-detail-name-row{align-items:center;gap:10px;display:flex}.classroom-settings-gear{border:1px solid var(--color-border);background:var(--color-surface);width:32px;height:32px;color:var(--color-text-muted);cursor:pointer;transition:background var(--t-normal,.15s ease), color var(--t-normal,.15s ease), border-color var(--t-normal,.15s ease);border-radius:9999px;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:inline-flex}.classroom-settings-gear:hover{background:var(--color-surface-alt);color:var(--color-text);border-color:var(--color-border-hover)}.classroom-settings-modal{background:var(--color-surface);border-radius:var(--radius-card);width:calc(100vw - 32px);max-width:560px;max-height:calc(100vh - 80px);box-shadow:var(--shadow-card);flex-direction:column;display:flex;overflow:auto}.classroom-settings-modal-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.classroom-settings-modal-header h3{margin:0;font-size:16px;font-weight:700}.classroom-settings-modal-body{flex-direction:column;gap:16px;padding:20px;display:flex}.classroom-name-stack{flex-direction:column;align-items:flex-start;gap:4px;display:flex}.classroom-name-text{color:var(--color-text);font-weight:600}.classroom-role-select-inline{min-width:0;max-width:140px;padding:2px 6px;font-size:11px}
.student-page{background:var(--color-bg);min-height:100vh;max-width:var(--container-max-width);margin:0 auto;padding:48px 32px}.student-greeting-row{flex-wrap:wrap;align-items:baseline;gap:8px;margin-bottom:16px;display:flex}.student-greeting{font-family:var(--font-display);letter-spacing:-.5px;color:var(--color-text);margin:0;font-size:26px;font-weight:600}.student-sub{letter-spacing:-.15px;color:var(--color-text);margin:20px 0 12px;font-size:15px;font-weight:700}.student-classroom-badge{background:var(--color-accent-tinted-bg);color:var(--color-accent-tinted-text);border-radius:var(--radius-pill);padding:3px 10px;font-size:13px;font-weight:600;display:inline-block}.student-logout-btn{border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text-muted);cursor:pointer;font-size:13px;font-family:var(--font-body);transition:color var(--t-normal), border-color var(--t-normal);background:0 0;padding:6px 14px}.student-logout-btn:hover{color:var(--color-accent);border-color:var(--color-accent)}.student-logout-btn:disabled{opacity:.5;cursor:not-allowed}.student-duty-section{background:var(--color-accent-tinted-bg);border-radius:var(--radius-card);margin-top:28px;padding:20px}.student-duty-title{font-family:var(--font-display);color:var(--color-accent-tinted-text);letter-spacing:-.2px;margin:0 0 12px;font-size:15px;font-weight:700}.student-duty-grid{grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;display:grid}.student-duty-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);color:var(--color-text);align-items:center;gap:12px;padding:14px 16px;text-decoration:none;transition:box-shadow .18s,border-color .18s,transform .18s;display:flex}.student-duty-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-accent);transform:translateY(-1px)}.student-duty-emoji{font-size:28px;line-height:1}.student-duty-role{font-family:var(--font-display);flex:1;font-size:15px;font-weight:700}.student-duty-cta{color:var(--color-accent);font-size:12px;font-weight:600}.student-board-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px;margin-top:24px;display:grid}.student-board-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);color:var(--color-text);cursor:pointer;flex-direction:column;gap:8px;padding:20px;text-decoration:none;transition:box-shadow .18s,border-color .18s;display:flex}.student-board-card:hover{box-shadow:var(--shadow-card-hover);border-color:var(--color-border-hover)}.student-board-card-title{font-family:var(--font-display);color:var(--color-text);font-size:16px;font-weight:700}.student-board-card-meta{color:var(--color-text-muted);margin-top:8px;font-size:13px}.student-wallet-section{margin-top:20px}.student-wallet-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);box-shadow:var(--shadow-card);flex-direction:column;gap:16px;padding:20px;display:flex}.student-wallet-header{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.student-wallet-eyebrow{color:var(--color-accent);margin:0 0 6px;font-size:12px;font-weight:700}.student-wallet-title{font-family:var(--font-display);color:var(--color-text);margin:0;font-size:18px;font-weight:700}.student-wallet-link{border:1px solid var(--color-border);border-radius:var(--radius-btn);color:var(--color-text);white-space:nowrap;align-items:center;padding:8px 12px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex}.student-wallet-link:hover{border-color:var(--color-accent);color:var(--color-accent)}.student-wallet-balance-row{flex-wrap:wrap;justify-content:space-between;align-items:end;gap:16px;display:flex}.student-wallet-balance-label{color:var(--color-text-muted);font-size:13px}.student-wallet-balance-value{font-family:var(--font-display);color:var(--color-text);font-size:28px;font-weight:700}.student-wallet-fd-strip{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.student-wallet-fd-chip{background:var(--color-accent-tinted-bg);min-height:112px;color:var(--color-accent-tinted-text);border:1px solid #0000000a;border-radius:8px;flex-direction:column;gap:4px;padding:14px;display:flex}.student-wallet-fd-label{color:var(--color-accent);font-size:11px;font-weight:700}.student-wallet-fd-chip strong{color:var(--color-text);font-size:18px}.student-wallet-fd-chip span:last-child{color:var(--color-text-muted);font-size:12px}.student-wallet-fd-cancel{border:1px solid var(--color-bank-negative);color:var(--color-bank-negative);cursor:pointer;background:0 0;border-radius:999px;align-self:flex-start;margin-top:auto;padding:5px 10px;font-size:12px;font-weight:700}.student-wallet-fd-cancel:disabled{opacity:.55;cursor:not-allowed}.student-wallet-fd-error{color:var(--color-bank-negative);margin:4px 0 0;font-size:12px;font-weight:600}.student-wallet-empty{background:var(--color-bg-alt);color:var(--color-text-muted);border-radius:8px;padding:16px;font-size:13px}@media (max-width:760px){.student-wallet-header{flex-direction:column}.student-wallet-link{justify-content:center;width:100%}}.student-login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex}.student-login-card{background:var(--color-surface);border:var(--border-card);border-radius:var(--radius-card);width:100%;max-width:400px;box-shadow:var(--shadow-card);text-align:center;padding:48px 40px}.student-login-title{font-family:var(--font-display);letter-spacing:-.3px;text-align:center;color:var(--color-text);margin:0 0 24px;font-size:24px;font-weight:700}.student-login-input{border:1px solid var(--color-border);border-radius:var(--radius-btn);background:var(--color-bg-alt);width:100%;font-family:var(--font-mono);letter-spacing:6px;text-align:center;text-transform:uppercase;color:var(--color-text);box-sizing:border-box;transition:border-color var(--t-normal), box-shadow var(--t-normal);outline:none;padding:14px 16px;font-size:22px;font-weight:700}.student-login-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #0075de26}.student-login-btn{background:var(--color-accent);color:#fff;border-radius:var(--radius-btn);width:100%;font-family:var(--font-body);cursor:pointer;text-align:center;transition:background var(--t-normal);border:none;margin-top:16px;padding:12px;font-size:15px;font-weight:600;text-decoration:none;display:block}.student-login-btn:hover:not(:disabled){background:var(--color-accent-active)}.student-login-btn:disabled{opacity:.45;cursor:not-allowed}.student-login-error{color:var(--color-danger);text-align:center;margin:8px 0 0;font-size:13px}.student-empty{text-align:center;color:var(--color-text-muted);padding:48px;font-size:14px}.student-qr-landing{background:var(--color-bg);flex-direction:column;justify-content:center;align-items:center;min-height:100vh;padding:32px;display:flex}.student-qr-error{text-align:center;max-width:400px}.student-qr-error h2{font-family:var(--font-display);color:var(--color-text);margin:0 0 8px;font-size:20px;font-weight:700}.student-qr-error p{color:var(--color-text-muted);margin:0 0 24px;font-size:14px;line-height:1.5}
.breakout-header{max-width:1040px;margin:16px auto 0;padding:0 24px}.breakout-breadcrumb{letter-spacing:.05px;color:var(--color-text-muted);font-size:13px;font-weight:600}.breakout-grid{grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:16px;max-width:1040px;margin:16px auto 40px;padding:0 24px;display:grid}.breakout-empty{text-align:center;max-width:1040px;color:var(--color-text-faint);background:var(--color-surface);border-radius:var(--radius-card);border:var(--border-card);margin:32px auto;padding:24px}.share-panel{background:var(--color-surface);border-radius:var(--radius-card);border:var(--border-card);max-width:640px;box-shadow:var(--shadow-card);margin:24px auto 40px;padding:24px}.share-label{color:var(--color-text-muted);margin-bottom:8px;font-size:13px;font-weight:600;display:block}.share-actions{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.share-url-input{min-width:0;font-family:var(--font-body,inherit);color:var(--color-text);background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;flex:260px;padding:10px 12px;font-size:14px}.share-url-input:hover{border-color:var(--color-border-hover)}.share-url-input:focus{outline:2px solid var(--color-accent-tinted-text);outline-offset:1px}.share-help{color:var(--color-text-muted);margin:12px 0 0;font-size:13px}.share-help-warn{color:var(--color-text-faint)}.share-empty{color:var(--color-text-muted);margin:0 0 16px}.share-status{color:var(--color-accent);min-height:1.2em;margin:12px 0 0;font-size:13px}
