:root{--bg-main:#f0f4f8;--bg-card:#fff;--bg-card-hover:#f8fafc;--bg-sidebar:linear-gradient(180deg, #1a2942 0%, #0f1b2d 100%);--primary:#2563eb;--primary-hover:#3b82f6;--accent:#14b8a6;--accent-light:#2dd4bf;--cyan:#0ea5e9;--success:#10b981;--success-hover:#0d9f74;--danger:#ef4444;--danger-hover:#dc2626;--warning:#f59e0b;--warning-hover:#d97706;--info:#0ea5e9;--text-main:#0f172a;--text-muted:#64748b;--text-sidebar:#e2e8f0;--text-sidebar-muted:#e2e8f073;--border:#e2e8f0;--border-light:#f1f5f9;--border-focus:#2563eb;--sidebar-width:240px;--topbar-height:56px;--toolbar-height:60px;--touch-target:56px;--font-base:16px;--font-sm:14px;--font-xs:12px;--font-lg:20px;--font-xl:24px;--font-xxl:32px;--gap:12px;--gap-sm:8px;--gap-lg:24px;--gap-xl:36px;--radius:10px;--radius-sm:8px;--radius-lg:16px;--radius-xl:20px;--shadow-sm:0 1px 3px #0f1b2d0f, 0 4px 12px #0f1b2d0f;--shadow-md:0 2px 8px #0f1b2d14, 0 8px 24px #0f1b2d1a;--shadow-lg:0 4px 16px #0f1b2d1a, 0 16px 48px #0f1b2d24;--transition:.2s cubic-bezier(.25, .46, .45, .94);--transition-fast:.15s cubic-bezier(.25, .46, .45, .94);--spring:cubic-bezier(.25, .46, .45, .94);--level-1:#94a3b8;--level-2:#10b981;--level-3:#f59e0b;--level-4:#ef4444;--level-5:#2563eb;--level-6:#8b5cf6;--level-7:#ec4899;--level-8:#0ea5e9;--color-primary:var(--primary);--color-error:var(--danger);--color-danger:var(--danger);--font-md:15px;--gap-md:16px;--text-primary:var(--text-main);--text-secondary:var(--text-muted)}[data-theme=dark]{--bg-main:#0d1521;--bg-card:#162033;--bg-card-hover:#1c2a42;--text-main:#e2e8f0;--text-muted:#94a3b8;--text-sidebar:#e2e8f0;--text-sidebar-muted:#e2e8f066;--border:#e2e8f014;--border-light:#e2e8f00d;--shadow-sm:0 1px 3px #0000004d, 0 4px 12px #0000004d;--shadow-md:0 2px 8px #0006, 0 8px 24px #0006;--shadow-lg:0 4px 16px #00000073, 0 16px 48px #00000080}[data-theme=dark] .topbar,[data-theme=dark] .main-topbar{background:#162033d9;border-bottom-color:#e2e8f014}[data-theme=dark] .context-bar{border-bottom-color:#e2e8f014}[data-theme=dark] .ctx-bell:hover{background:#e2e8f014}[data-theme=dark] .topbar-online,[data-theme=dark] .topbar-bell:hover{background:#e2e8f00f}[data-theme=dark] .modal-close-btn,[data-theme=dark] .qa-close-btn,[data-theme=dark] .tk-panel-close{background:#e2e8f014}[data-theme=dark] .modal-close-btn:hover,[data-theme=dark] .qa-close-btn:hover,[data-theme=dark] .tk-panel-close:hover{background:#e2e8f029}[data-theme=dark] .form-input{border-color:#e2e8f024}[data-theme=dark] .tab-bar{background:#e2e8f00f}[data-theme=dark] .tab-item.active{box-shadow:0 1px 4px #0006}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#e2e8f029}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:#e2e8f047}[data-theme=dark] .quick-actions-bar{border-color:#e2e8f01a}[data-theme=dark] .qa-btn{background:#e2e8f014}[data-theme=dark] .qa-btn:hover{background:#e2e8f024}[data-theme=dark] .mode-switcher{background:#e2e8f00f}[data-theme=dark] .mode-switcher .mode-btn:hover{background:#e2e8f01a}[data-theme=dark] .mode-switcher .mode-btn.active{background:var(--bg-card-hover);box-shadow:0 1px 4px #0006}[data-theme=dark] .timer-menu{border-color:#e2e8f01a}[data-theme=dark] .timer-menu-btn:hover{background:#e2e8f014}[data-theme=dark] .toolkit-menu{box-shadow:var(--shadow-lg), 0 0 0 1px #e2e8f014}[data-theme=dark] .toolkit-menu-item:hover{background:#e2e8f00f}[data-theme=dark] .toolkit-menu-item:active{background:#e2e8f01a}[data-theme=dark] .tk-panel{box-shadow:var(--shadow-lg), 0 0 0 1px #e2e8f014}[data-theme=dark] .tk-ring-bg{stroke:#e2e8f01a}[data-theme=dark] .tk-preset-btn{background:#e2e8f014}[data-theme=dark] .tk-ctrl--ghost{background:#e2e8f01a}[data-theme=dark] .tk-ctrl--ghost:not(:disabled):hover{background:#e2e8f029}[data-theme=dark] .tk-adj-btn{background:#e2e8f014}[data-theme=dark] .dash-pulse-student:hover{background:#e2e8f00f}[data-theme=dark] .whiteboard-toolbar .tool-group{border-right-color:#e2e8f014}[data-theme=dark] .tool-btn:hover{background:#e2e8f014}[data-theme=dark] .wb-toolbar{background:#162033e0;border-color:#e2e8f01a;box-shadow:0 8px 32px #00000073,0 2px 8px #0000004d}[data-theme=dark] .wb-toolbar-group{border-right-color:#e2e8f01a}[data-theme=dark] .quick-color{border-color:#e2e8f02e}[data-theme=dark] .group-member-chip{background:#e2e8f00f}[data-theme=dark] .leaderboard-item{border-bottom-color:#e2e8f00f}[data-theme=dark] .leaderboard-item:hover{background:#e2e8f00a}[data-theme=dark] .ai-chat-panel{border-left-color:#e2e8f014;box-shadow:-4px 0 32px #00000073}[data-theme=dark] .ai-chat-header{border-bottom-color:#e2e8f014}[data-theme=dark] .ai-chat-close:hover{background:#e2e8f014}[data-theme=dark] .ai-quick-prompts{border-bottom-color:#e2e8f00f}[data-theme=dark] .ai-message--ai .ai-message-bubble{color:var(--text-main);background:#e2e8f014}[data-theme=dark] .ai-message--thinking .ai-message-bubble{background:#e2e8f00f}[data-theme=dark] .ai-chat-input-row{border-top-color:#e2e8f014}[data-theme=dark] .ai-chat-input{color:var(--text-main);border-color:#e2e8f024}[data-theme=dark] .ai-suggestion-dismiss{border-color:#e2e8f024}[data-theme=dark] .ai-suggestion-dismiss:hover{background:#e2e8f014}[data-theme=dark] .ai-report-text{color:var(--text-main);background:#e2e8f00d}[data-theme=dark] .ai-quiz-question{background:#e2e8f00d}[data-theme=dark] .ai-quiz-letter{background:#e2e8f01a}[data-theme=dark] .ai-quiz-footer{border-top-color:#e2e8f014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{width:100%;height:100%;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Inter,Segoe UI,sans-serif;font-size:var(--font-base);letter-spacing:-.01em;color:var(--text-main);background:var(--bg-main);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;touch-action:manipulation;font-weight:400;line-height:1.5;overflow:hidden}#app{flex-direction:column;width:100vw;height:100vh;display:flex;overflow:hidden}.app-shell{flex-direction:row;flex:auto;min-height:0;display:flex;overflow:hidden}.loading-screen{background:var(--bg-main);width:100%;height:100%;color:var(--text-main);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex}.loading-bear{font-size:72px;animation:1.2s cubic-bezier(.45,.05,.55,.95) infinite bounce}.loading-text{letter-spacing:-.02em;color:var(--text-main);font-size:28px;font-weight:600}.loading-spinner{border:3px solid #2563eb1f;border-top-color:var(--primary);border-radius:50%;width:36px;height:36px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-14px)}}.sidebar{width:var(--sidebar-width);min-width:0;color:var(--text-sidebar);z-index:10;transition:width .25s var(--spring);background:linear-gradient(#1a2942 0%,#0f1b2d 100%);flex-direction:column;flex-shrink:0;padding:0;display:flex;overflow:hidden auto}.sidebar-logo{background:linear-gradient(#2563eb0f 0%,#0000 100%);border-bottom:1px solid #2563eb33;flex-shrink:0;align-items:center;gap:10px;padding:20px 16px 16px;display:flex;position:relative;overflow:hidden}.sidebar-bear{color:var(--accent-light,#2dd4bf);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-title{letter-spacing:-.01em;color:#fff;white-space:nowrap;transition:opacity .15s ease, width .25s var(--spring);font-size:15px;font-weight:700;line-height:1.25;overflow:hidden}.sidebar-toggle{color:#e2e8f0;cursor:pointer;width:32px;min-width:32px;height:32px;min-height:32px;transition:background var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast), transform .25s var(--spring);background:#2563eb1a;border:1px solid #e2e8f02e;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;display:flex}.sidebar-toggle svg{width:18px;height:18px}.sidebar-toggle:hover{color:#93c5fd;background:#2563eb38;border-color:#93c5fd73}.sidebar.collapsed{width:68px}.sidebar.collapsed .sidebar-logo{justify-content:center;gap:0;padding:20px 0 16px}.sidebar.collapsed .sidebar-title{display:none}.sidebar.collapsed .sidebar-toggle{position:absolute;top:50%;right:4px;transform:translateY(-50%)rotate(180deg)}.sidebar.collapsed .nav-item{justify-content:center;padding:0;position:relative}.sidebar.collapsed .nav-item.active{background:#2563eb26}.sidebar.collapsed .nav-icon{margin-right:0}.sidebar.collapsed .nav-text{display:none}.sidebar.collapsed .online-indicator{justify-content:center;padding:6px 0}.sidebar.collapsed .online-text{display:none}.sidebar.collapsed .sync-pending{justify-content:center;padding:6px 0}.sidebar.collapsed .sync-pending span{display:none}.sidebar.collapsed .nav-item[title]:hover:after{content:attr(title);color:#e2e8f0;white-space:nowrap;border-radius:var(--radius-sm);box-shadow:var(--shadow-md);pointer-events:none;z-index:100;background:#0f1b2d;border:1px solid #ffffff14;padding:6px 12px;font-size:13px;font-weight:500;position:absolute;top:50%;left:calc(100% + 8px);transform:translateY(-50%)}.nav-items{flex-direction:column;flex:1;gap:0;padding:8px 0;display:flex}.sidebar-footer{border-top:1px solid #ffffff12;flex-direction:column;gap:4px;padding:10px 0 14px;display:flex}.online-indicator{color:var(--text-sidebar-muted);align-items:center;gap:8px;padding:6px 20px;font-size:12px;display:flex}.online-dot{background:#34c759;border-radius:50%;flex-shrink:0;width:7px;height:7px}.online-dot.offline{background:#ff3b30}.sync-pending{color:var(--warning);align-items:center;padding:6px 20px;font-size:12px;display:flex}.nav-item{color:#ffffff8c;cursor:pointer;-webkit-user-select:none;user-select:none;width:calc(100% - 16px);height:44px;min-height:44px;transition:background var(--transition-fast), color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation;text-align:left;background:0 0;border:none;border-radius:10px;align-items:center;gap:12px;margin:2px 8px;padding:0 8px;font-size:14px;font-weight:500;display:flex}.nav-item .nav-icon{color:#fff6;width:20px;height:20px;transition:color var(--transition-fast);flex-shrink:0;justify-content:center;align-items:center;padding-left:4px;display:flex}.nav-item .nav-icon svg{stroke-width:1.5px;width:20px;height:20px}.nav-item .nav-text{white-space:nowrap;flex:1;overflow:hidden}.nav-item .nav-badge{background:var(--danger);color:#fff;border-radius:999px;margin-right:4px;padding:2px 6px;font-size:11px;font-weight:600}.nav-item:hover{color:#e2e8f0d9;background:#2563eb14}.nav-item:hover .nav-icon{color:#e2e8f0b3}.nav-item.active{color:#93c5fd;padding-left:calc(var(--p,0px) - 2px);background:#2563eb26;border-left:2px solid #2563eb}.nav-item.active .nav-icon{color:#60a5fa}.nav-item--calm{color:#e2e8f08c}.nav-item--calm.active{color:#c4b5fd;background:#8b5cf62e;border-left-color:#8b5cf6}.nav-item--calm.active .nav-icon{color:#c4b5fd}.mode-selector{flex-direction:column;gap:6px;padding:8px 16px;display:flex}.mode-selector-label{color:var(--text-sidebar-muted);letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-weight:600}.mode-selector-btns{gap:4px;display:flex}.mode-btn{color:#ffffff8c;cursor:pointer;height:36px;min-height:36px;transition:background var(--transition-fast), color var(--transition-fast);background:#ffffff0f;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;font-size:16px;display:flex}.mode-btn:hover{color:#fff;background:#ffffff1f}.mode-btn.active{color:#60a5fa;background:#2563eb40}.sidebar.collapsed .mode-selector-label{display:none}.sidebar.collapsed .mode-selector-btns{flex-direction:column;gap:2px}.sidebar.collapsed .mode-btn{flex:none;width:36px}.nav-item--logout{color:#ef4444b3}.nav-item--logout .nav-icon{color:#ef444499}.nav-item--logout:hover{color:#ef4444;background:#ef44441a;border-left:none}.nav-item--logout:hover .nav-icon{color:#ef4444}.content-wrapper{background:var(--bg-main);flex-direction:column;flex:1;display:flex;overflow:hidden}.context-bar{z-index:6;background:var(--bg-card);border-bottom:1px solid #00000012;flex-shrink:0;align-items:center;gap:12px;height:54px;min-height:54px;padding:0 20px;display:flex;position:relative;overflow:hidden}.context-bar:before{content:"";background:linear-gradient(90deg, var(--primary) 0%, var(--accent) 35%, var(--cyan) 65%, var(--primary) 100%);opacity:.7;background-size:300% 100%;height:2px;animation:8s linear infinite ctx-accent-slide;position:absolute;top:0;left:0;right:0}@keyframes ctx-accent-slide{0%{background-position:0 0}to{background-position:300% 0}}.ctx-date{min-width:0;color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;letter-spacing:-.01em;flex:1;font-size:19px;font-style:normal;font-weight:500;overflow:hidden}.ctx-selectors{flex-shrink:0;align-items:center;gap:8px;display:flex}.ctx-pill{height:32px;transition:border-color var(--transition-fast), background var(--transition-fast), box-shadow var(--transition-fast);background:#2563eb12;border:1px solid #2563eb2e;border-radius:20px;align-items:center;gap:6px;padding:0 14px 0 10px;display:flex}.ctx-pill:focus-within{border-color:var(--primary);background:#2563eb1c;box-shadow:0 0 0 3px #2563eb21}.ctx-pill-label{color:var(--primary);cursor:default;min-height:unset;min-width:unset;background:0 0;border:none;flex-shrink:0;align-items:center;padding:0;display:flex}.ctx-pill-label:hover{filter:none}.ctx-pill-label:active{filter:none;transform:none}.ctx-pill-select{color:var(--primary);cursor:pointer;min-height:unset;letter-spacing:-.01em;appearance:none;background:0 0;border:none;outline:none;max-width:160px;padding:0;font-family:inherit;font-size:13px;font-weight:600}.ctx-pill-select--class{max-width:120px}.ctx-pill-select option{color:var(--text-main);background:var(--bg-card);font-weight:500}.ctx-pill-select::-ms-expand{display:none}.ctx-right{flex:1;justify-content:flex-end;align-items:center;gap:8px;display:flex}.ctx-clock{color:var(--text-main);white-space:nowrap;font-variant-numeric:tabular-nums;font-feature-settings:"tnum";letter-spacing:.04em;font-size:20px;font-weight:600}.ctx-bell{min-height:unset;min-width:unset;border-radius:var(--radius-sm);width:32px;height:32px;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;display:flex}.ctx-bell:hover{color:var(--text-main);filter:none;background:#0000000d}.ctx-bell:active{filter:none;transform:scale(.92)}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}@media (width<=600px){.context-bar{gap:6px;padding:0 14px}.ctx-date{font-size:12px}.ctx-selectors{gap:6px}.ctx-pill{height:28px;padding:0 10px 0 8px}.ctx-pill-select{max-width:90px;font-size:11px}.ctx-pill-select--class{max-width:80px}.ctx-clock{font-size:13px}}.main-topbar{height:var(--topbar-height);min-height:var(--topbar-height);-webkit-backdrop-filter:blur(20px);align-items:center;gap:var(--gap);z-index:5;background:#fffc;border-bottom:1px solid #0000000f;flex-shrink:0;padding:0 20px;display:flex}.topbar-left{flex:1;align-items:center;display:flex;overflow:hidden}.topbar-greeting{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;color:var(--text-main);font-size:15px;font-weight:500;overflow:hidden}.topbar-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.topbar-class-badge{color:var(--primary);white-space:nowrap;background:#2563eb14;border-radius:20px;padding:5px 14px;font-size:13px;font-weight:500}.topbar-dot{background:#34c759;border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-right:6px;display:inline-block}.topbar-dot.offline{background:#ff3b30}.topbar-online{color:var(--text-muted);white-space:nowrap;background:#0000000a;border-radius:20px;align-items:center;padding:5px 14px;font-size:13px;font-weight:500;display:flex}.topbar-bell{min-width:36px;min-height:36px;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;border-radius:10px;justify-content:center;align-items:center;padding:0;display:flex}.topbar-bell:hover{color:var(--text-main);background:#0000000a}.topbar-class-select{color:var(--primary);cursor:pointer;appearance:none;letter-spacing:-.01em;min-height:unset;transition:background var(--transition-fast), border-color var(--transition-fast), box-shadow var(--transition-fast);white-space:nowrap;background:#2563eb14;border:1px solid #2563eb2e;border-radius:20px;outline:none;padding:5px 14px;font-family:inherit;font-size:13px;font-weight:600}.topbar-class-select:hover{filter:none;background:#2563eb1f;border-color:#2563eb4d}.topbar-class-select:focus{border-color:var(--primary);background:#2563eb1f;box-shadow:0 0 0 3px #2563eb21}.topbar-class-select option{color:var(--text-main);background:var(--bg-card);font-weight:500}.main{background:var(--bg-main);flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.page-content{min-height:0;padding:var(--gap-lg);flex:1;overflow:hidden auto}.unified-nav{color:#fff;z-index:50;background:linear-gradient(90deg,#0f1b2d 0%,#1a2942 100%);border-bottom:1px solid #ffffff14;flex-shrink:0;align-items:center;height:48px;padding:0 16px;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Helvetica Neue,Arial,sans-serif;display:flex}.unified-nav-brand{color:inherit;align-items:center;gap:8px;padding:0 8px;font-size:1rem;font-weight:700;text-decoration:none;display:flex}.unified-nav-brand:hover{opacity:.85}.unified-nav-bear{font-size:22px;line-height:1}.unified-nav-name{letter-spacing:-.01em}.unified-nav-tabs{flex:1;gap:4px;margin-left:24px;display:flex}.unified-nav-tab{color:#ffffffb8;white-space:nowrap;border-radius:999px;align-items:center;gap:8px;padding:8px 14px;font-size:.9rem;font-weight:600;text-decoration:none;transition:background .15s,color .15s;display:inline-flex}.unified-nav-tab:hover{color:#fff;background:#ffffff14}.unified-nav-tab.active{color:#fff;cursor:default;background:#60a5fa2e}.unified-nav-tab-icon{font-size:1rem}.unified-nav-right{align-items:center;gap:12px;display:flex}.unified-nav-lang{color:#ffffffd9;align-items:center;gap:6px;font-size:.85rem;display:flex}.unified-nav-lang select{color:#fff;cursor:pointer;background:#ffffff14;border:1px solid #ffffff2e;border-radius:8px;padding:4px 8px;font-family:inherit;font-size:.85rem}.unified-nav-lang select:hover{background:#ffffff24}.unified-nav-lang select option{color:#fff;background:#1a2942}@media (width<=640px){.unified-nav{height:44px;padding:0 8px}.unified-nav-name{display:none}.unified-nav-tabs{gap:2px;margin-left:8px}.unified-nav-tab-label{display:none}.unified-nav-tab{padding:6px 10px}}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);opacity:0;pointer-events:none;background:#00000073;justify-content:center;align-items:center;padding:20px;transition:opacity .2s;display:flex;position:fixed;inset:0}.modal-overlay.modal-visible{opacity:1;pointer-events:all}.modal-box{background:var(--bg-card);box-shadow:var(--shadow-lg);border-radius:16px;flex-direction:column;width:100%;max-width:480px;max-height:90vh;transition:transform .2s;display:flex;overflow:hidden;transform:scale(.95)translateY(8px)}.modal-overlay.modal-visible .modal-box{transform:scale(1)translateY(0)}.modal-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:18px 20px 14px;display:flex}.modal-title{color:var(--text-main);letter-spacing:-.02em;font-size:17px;font-weight:600}.modal-close-btn{cursor:pointer;width:44px;min-width:44px;height:44px;min-height:44px;color:var(--text-muted);transition:background var(--transition-fast);background:#0000000f;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:13px;display:flex}.modal-close-btn:hover{filter:none;background:#0000001f}.modal-body{flex:1;min-height:0;padding:16px 20px;overflow-y:auto}.modal-footer{border-top:1px solid var(--border);flex-shrink:0;justify-content:flex-end;gap:8px;padding:12px 20px 16px;display:flex}.modal-footer button{min-height:unset;min-width:unset;padding:8px 20px;font-size:14px}.modal-footer:empty{display:none}button,[role=button],.tool-btn{min-height:var(--touch-target);min-width:var(--touch-target);font-size:var(--font-sm);cursor:pointer;border-radius:var(--radius);-webkit-user-select:none;user-select:none;transition:filter var(--transition-fast), transform var(--transition-fast), background var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation;letter-spacing:-.01em;border:none;justify-content:center;align-items:center;padding:0 20px;font-family:inherit;font-weight:500;display:flex}button:hover{filter:brightness(1.06)}button:active{filter:brightness(.95);transform:scale(.98)}button:disabled{opacity:.4;cursor:not-allowed;filter:none;transform:none}.btn-primary{color:#fff;background:linear-gradient(145deg,#2563eb,#3b82f6);border-radius:10px;font-weight:500;box-shadow:0 1px 3px #2563eb40,0 4px 12px #2563eb26}.btn-primary:hover{filter:brightness(1.07);box-shadow:0 2px 6px #2563eb59,0 6px 16px #2563eb33}.btn-success{background:var(--success);color:#fff;border-radius:10px;font-weight:500}.btn-danger{background:var(--danger);color:#fff;border-radius:10px;font-weight:500}.btn-warning{background:var(--warning);color:#fff;border-radius:10px;font-weight:500}.btn-ghost{color:var(--accent);filter:none;background:0 0;border:1px solid #14b8a64d;border-radius:10px}.btn-ghost:hover{filter:none;background:#14b8a60f;border-color:#14b8a680}.btn-sm{border-radius:8px;min-width:44px;min-height:44px;padding:0 14px;font-size:13px}.btn-lg{min-height:var(--touch-target);font-size:var(--font-lg);border-radius:12px;padding:0 28px}.btn-icon{min-width:var(--touch-target);padding:0}.card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:transform .3s var(--spring), box-shadow .3s var(--spring);padding:20px 24px}.card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.card-header{margin-bottom:var(--gap);justify-content:space-between;align-items:center;display:flex}.card-title{letter-spacing:-.01em;color:var(--text-main);font-size:15px;font-weight:600}.section-title{letter-spacing:.05em;text-transform:uppercase;margin-bottom:var(--gap);color:var(--text-muted);font-size:13px;font-weight:600}.login-page{background:linear-gradient(135deg,#0f1b2d 0%,#1a2942 40%,#1e3a5f 70%,#0f1b2d 100%);justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.login-blob{filter:blur(60px);opacity:.4;pointer-events:none;z-index:0;border-radius:50%;position:absolute}.login-blob-1{background:#2563eb80;width:420px;height:420px;animation:10s ease-in-out infinite blob-float;top:-140px;left:-80px}.login-blob-2{background:#14b8a666;width:320px;height:320px;animation:12s ease-in-out infinite reverse blob-float;bottom:-80px;right:-60px}.login-blob-3{background:#0ea5e94d;width:240px;height:240px;animation:8s ease-in-out 2s infinite blob-float;top:50%;left:65%}@keyframes blob-float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(20px,-30px)scale(1.05)}66%{transform:translate(-15px,15px)scale(.95)}}.login-card{-webkit-backdrop-filter:blur(24px);border-radius:var(--radius-xl);gap:var(--gap-lg);z-index:1;background:#fffffff5;border:1px solid #2563eb1f;flex-direction:column;width:90vw;min-width:360px;max-width:420px;padding:48px 40px;display:flex;position:relative;box-shadow:0 8px 40px #0f1b2d59,0 2px 8px #0f1b2d26,0 0 0 1px #2563eb14}.login-logo{text-align:center;font-size:80px}.login-title{text-align:center;letter-spacing:-.02em;font-size:28px;font-weight:600}.login-subtitle{text-align:center;color:var(--text-muted);font-size:var(--font-sm)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--font-sm);font-weight:500}.form-input{border-radius:var(--radius);height:48px;font-size:var(--font-base);width:100%;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);background:var(--bg-main);color:var(--text-main);border:1.5px solid #0000001a;outline:none;padding:0 16px;font-family:inherit}.form-input:focus{border-color:var(--primary);background:var(--bg-card);box-shadow:0 0 0 3px #2563eb1f}.form-input::placeholder{color:var(--text-muted)}.form-error{color:var(--danger);font-size:var(--font-sm)}.hidden{display:none!important}.flex{display:flex}.flex-col{flex-direction:column}.gap-lg{gap:var(--gap-lg)}.tab-bar{margin:0 var(--gap-lg) var(--gap-lg);background:#0000000d;border-radius:10px;justify-content:center;align-self:center;gap:0;padding:4px;display:flex}.tab-item{color:var(--text-muted);cursor:pointer;transition:background .2s var(--spring), color .2s var(--spring), box-shadow .2s var(--spring);min-height:unset;min-width:unset;letter-spacing:-.01em;background:0 0;border:none;border-radius:8px;padding:8px 18px;font-size:14px;font-weight:500}.tab-item:hover{color:var(--text-main);filter:none}.tab-item:active{filter:none;transform:none}.tab-item.active{background:var(--bg-card);color:var(--text-main);filter:none;font-weight:500;box-shadow:0 1px 4px #0000001a}#toast-container{gap:var(--gap-sm);z-index:9999;pointer-events:none;flex-direction:column;display:flex;position:fixed;bottom:24px;right:24px}.toast{-webkit-backdrop-filter:blur(20px);color:#ffffffe6;border-radius:var(--radius);box-shadow:var(--shadow-lg);max-width:360px;animation:slideInRight .22s var(--spring);pointer-events:all;border-left:3px solid var(--primary);background:#1d1d1feb;padding:12px 18px;font-size:14px;font-weight:500}.toast.toast-success{border-left-color:var(--success)}.toast.toast-error{border-left-color:var(--danger)}.toast.toast-warning{border-left-color:var(--warning)}.toast.toast-out{animation:slideOutRight .22s var(--spring) forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(110%)}}.loading-dots{color:var(--text-muted);font-size:var(--font-base)}.error-msg{color:var(--danger);font-size:var(--font-base)}.empty-msg{color:var(--text-muted);font-size:var(--font-sm);font-style:italic}.points-positive{color:var(--success);font-weight:600}.points-negative{color:var(--danger);font-weight:600}.topbar{-webkit-backdrop-filter:blur(20px);height:56px;min-height:56px;padding:0 var(--gap-lg);align-items:center;gap:var(--gap);z-index:5;background:#fffc;border-bottom:1px solid #0000000f;flex-shrink:0;display:flex}.topbar-title{font-size:var(--font-lg);letter-spacing:-.02em;flex:1;font-weight:600}.topbar-actions{gap:var(--gap);display:flex}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#0000001f;border-radius:3px}@media (width<=760px){.dashboard-wrap{gap:14px;padding:14px 16px 48px}.dash-quick-actions{grid-template-columns:repeat(5,1fr);gap:6px}.dqa-btn{padding:10px 4px}.dqa-icon{font-size:18px}.dqa-label{display:none}.dash-bottom-grid{grid-template-columns:1fr}.dash-header{flex-direction:column;align-items:flex-start;gap:4px}}@media (width<=480px){.dash-quick-actions{grid-template-columns:repeat(3,1fr)}.dqa-btn:nth-child(4),.dqa-btn:nth-child(5){display:none}}@keyframes page-enter-anim{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes page-leave-anim{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-4px)}}.page-enter{opacity:0;transform:translateY(8px)}.page-enter-active{animation:.2s cubic-bezier(.25,.46,.45,.94) both page-enter-anim}.page-leave-active{animation:.15s cubic-bezier(.25,.46,.45,.94) both page-leave-anim}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:64px 40px;display:flex}.empty-state-icon{color:var(--text-muted);opacity:.4;margin-bottom:4px}.empty-state-title{font-size:var(--font-lg);color:var(--text-muted);margin:0;font-weight:600}.empty-state-sub{font-size:var(--font-sm);color:var(--text-muted);opacity:.75;margin:0}.breadcrumb-bar{height:32px;padding:0 var(--gap);color:var(--text-secondary);align-items:center;gap:6px;font-size:13px;display:flex}.breadcrumb-separator{opacity:.4}.breadcrumb-current{color:var(--text-primary);font-weight:500}.student-avatar svg{width:100%;height:100%;display:block}.level-accent-strip{border-radius:0 0 var(--radius-lg) var(--radius-lg);height:4px;transition:background .3s;position:absolute;bottom:0;left:0;right:0}.online-badge{background:var(--bg-card);box-shadow:var(--shadow-sm);color:var(--text-muted);border-radius:20px;align-items:center;gap:6px;padding:6px 14px;font-size:13px;font-weight:500;display:flex}.online-badge.offline{color:var(--danger)}.stat-icon{font-size:22px;line-height:1}.stat-value{letter-spacing:-.03em;color:var(--text-main);font-size:32px;font-weight:600;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:500}.students-grid{gap:var(--gap);padding:var(--gap);grid-template-columns:repeat(auto-fill,minmax(148px,1fr));display:grid}@media (width>=1920px){.students-grid{grid-template-columns:repeat(auto-fill,minmax(168px,1fr))}}.student-card{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);cursor:pointer;border:1px solid var(--border);border-left:3px solid var(--level-color,var(--border));-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent;flex-direction:column;align-items:center;gap:6px;padding:16px 16px 16px 18px;transition:transform .3s cubic-bezier(.25,.46,.45,.94),box-shadow .3s cubic-bezier(.25,.46,.45,.94),border-color .3s cubic-bezier(.25,.46,.45,.94);display:flex;position:relative}.student-card:hover{box-shadow:var(--shadow-lg);border-color:var(--level-color,var(--border));border-left-color:var(--level-color,var(--primary));transform:translateY(-3px)}.student-card:active{box-shadow:var(--shadow-sm);transform:scale(.97)}.student-card.selected{border-color:var(--primary);border-left-color:var(--primary);box-shadow:0 0 0 3px #2563eb26, var(--shadow-md)}@keyframes card-points-flash{0%{box-shadow:0 0 0 3px #10b98180}to{box-shadow:none}}.student-card.card-points-updated{animation:.6s ease-out forwards card-points-flash}.student-avatar{color:#fff;letter-spacing:-.01em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:48px;height:48px;font-size:18px;font-weight:600;display:flex;overflow:hidden}.student-name{text-align:center;color:var(--text-main);font-size:14px;font-weight:500;line-height:1.25}.student-points{color:var(--text-main);letter-spacing:-.02em;font-size:20px;font-weight:600;line-height:1}.student-points.points-zero{color:var(--text-muted)}.student-points.points-negative{color:var(--danger)}.student-level-badge{color:#fff;background:var(--text-muted);border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;font-weight:500;display:flex}.quick-action-overlay{z-index:250;-webkit-backdrop-filter:blur(6px);background:#0000004d;justify-content:center;align-items:center;animation:.2s fadeIn;display:flex;position:fixed;inset:0}.quick-action-overlay.qa-closing{animation:.25s forwards fadeOut}.quick-action-overlay.qa-closing .qa-panel{animation:.25s cubic-bezier(.4,0,1,1) forwards slideDown}@keyframes fadeOut{to{opacity:0}}@keyframes slideDown{to{opacity:0;transform:translateY(24px)scale(.96)}}.qa-panel{background:var(--bg-card);border-radius:20px;flex-direction:column;gap:16px;width:min(400px,92vw);padding:24px;animation:.3s cubic-bezier(.34,1.56,.64,1) slideUp;display:flex;position:relative;box-shadow:0 8px 40px #0000002e,0 2px 8px #00000014}.qa-close-btn{cursor:pointer;width:44px;min-width:44px;height:44px;min-height:44px;color:var(--text-muted);transition:background var(--transition-fast), color var(--transition-fast);background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:13px;display:flex;position:absolute;top:14px;right:14px}.qa-close-btn:hover{color:var(--text-main);background:#0000001f}.qa-header{border-bottom:1px solid var(--border);align-items:center;gap:14px;padding-bottom:16px;display:flex}.qa-avatar{color:#fff;letter-spacing:-.02em;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:22px;font-weight:700;display:flex}.qa-header-info{flex:1;min-width:0}.qa-student-name{letter-spacing:-.02em;white-space:nowrap;text-overflow:ellipsis;font-size:18px;font-weight:600;overflow:hidden}.qa-points-total{letter-spacing:-.03em;color:var(--text-main);font-size:28px;font-weight:700;line-height:1.1;transition:color .3s}.qa-level-pill{white-space:nowrap;border:1.5px solid;border-radius:20px;flex-shrink:0;padding:4px 10px;font-size:12px;font-weight:600}.qa-category-row{align-items:center;gap:8px;display:flex}.qa-category-label{color:var(--text-muted);white-space:nowrap;font-size:13px;font-weight:600}.qa-category-select{border:1.5px solid var(--border);background:var(--bg-main);color:var(--text-main);cursor:pointer;appearance:auto;transition:border-color var(--transition-fast);border-radius:10px;flex:1;padding:7px 10px;font-family:inherit;font-size:14px;font-weight:500}.qa-category-select:focus{border-color:var(--primary);outline:none}.qa-note-row{margin-top:6px}.qa-note-input{box-sizing:border-box;border:1.5px solid var(--border);background:var(--bg-main);width:100%;color:var(--text-main);transition:border-color var(--transition-fast);border-radius:10px;padding:7px 10px;font-family:inherit;font-size:13px}.qa-note-input:focus{border-color:var(--primary);outline:none}.qa-note-input::placeholder{color:var(--text-muted)}.qa-hist-note{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;max-width:120px;font-size:11px;font-style:italic;overflow:hidden}.qa-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.qa-point-btn{cursor:pointer;color:#fff;-webkit-tap-highlight-color:transparent;touch-action:manipulation;border:none;border-radius:16px;flex-direction:column;justify-content:center;align-items:center;gap:2px;min-height:72px;transition:transform .15s cubic-bezier(.34,1.56,.64,1),box-shadow .15s;display:flex;box-shadow:0 2px 8px #00000026}.qa-point-btn:hover{transform:scale(1.05);box-shadow:0 4px 16px #0003}.qa-point-btn:active,.qa-point-btn.qa-btn-pressed{transform:scale(.95);box-shadow:0 1px 4px #00000026}.qa-btn-num{letter-spacing:-.03em;font-size:24px;font-weight:700;line-height:1}.qa-btn-label{opacity:.9;letter-spacing:.01em;font-size:11px;font-weight:500}.qa-history-section{flex-direction:column;gap:6px;display:flex}.qa-history-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:12px;font-weight:600}.qa-history-list{flex-direction:column;gap:4px;max-height:150px;display:flex;overflow-y:auto}.qa-history-item{border-bottom:1px solid var(--border);align-items:center;gap:6px;padding:5px 0;font-size:13px;display:flex}.qa-history-item:last-child{border-bottom:none}.qa-hist-cat{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;flex:1;font-weight:500;overflow:hidden}.qa-hist-pos{color:var(--success);font-weight:700}.qa-hist-neg{color:var(--danger);font-weight:700}.qa-hist-time{color:var(--text-muted);white-space:nowrap;font-size:12px}.qa-history-empty{color:var(--text-muted);text-align:center;padding:10px 0;font-size:13px}.bulk-panel{background:var(--bg-card);border-radius:var(--radius-xl,20px);flex-direction:column;width:min(520px,95vw);max-height:90vh;animation:.22s qa-slide-up;display:flex;overflow:hidden;box-shadow:0 8px 40px #0000002e}.bulk-panel-header{padding:var(--gap-lg) var(--gap-lg) var(--gap);flex-shrink:0;justify-content:space-between;align-items:flex-start;display:flex}.bulk-quick-row{padding:0 var(--gap-lg) var(--gap);flex-wrap:wrap;flex-shrink:0;gap:6px;display:flex}.bulk-list{padding:0 var(--gap-lg);flex:1;overflow-y:auto}.bulk-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:7px 0;display:flex}.bulk-row:last-child{border-bottom:none}.bulk-name{font-size:var(--font-sm);text-overflow:ellipsis;white-space:nowrap;flex:1;font-weight:500;overflow:hidden}.bulk-btns{flex-shrink:0;gap:4px;display:flex}.bulk-vote{border:1.5px solid var(--border);background:var(--bg-main);cursor:pointer;width:44px;height:44px;min-height:44px;color:var(--text-muted);border-radius:8px;font-size:13px;font-weight:600;transition:all .15s}.bulk-vote--active.bulk-zero{background:var(--border);color:var(--text-main);border-color:var(--border)}.bulk-vote--active.bulk-plus{background:var(--success,#34c759);color:#fff;border-color:#0000}.bulk-vote--active.bulk-minus{background:var(--danger,#ff3b30);color:#fff;border-color:#0000}.bulk-plus:hover{border-color:var(--success,#34c759);color:var(--success,#34c759)}.bulk-minus:hover{border-color:var(--danger,#ff3b30);color:var(--danger,#ff3b30)}.bulk-footer{padding:var(--gap) var(--gap-lg) var(--gap-lg);border-top:1px solid var(--border);flex-shrink:0;gap:8px;display:flex}.groups-grid{gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(260px,1fr));display:grid}.group-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--gap-lg);box-shadow:var(--shadow-sm);gap:var(--gap-sm);flex-direction:column;display:flex}.group-header{align-items:center;gap:var(--gap);justify-content:space-between;display:flex}.group-name{font-size:var(--font-lg);letter-spacing:-.02em;font-weight:600}.group-points{font-size:var(--font-lg);color:var(--primary);font-weight:600}.group-members{gap:var(--gap-sm);flex-wrap:wrap;display:flex}.group-member-chip{font-size:var(--font-sm);background:#0000000a;border-radius:999px;align-items:center;gap:6px;padding:4px 10px;display:flex}.group-member-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:10px;font-weight:600;display:flex}.dash-picker-grid{grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:10px;max-height:340px;padding:4px 0;display:grid;overflow-y:auto}.dash-picker-student{border:1.5px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;min-height:unset;min-width:unset;background:0 0;flex-direction:column;align-items:center;gap:5px;padding:10px 6px;transition:border-color .12s,background .12s,transform .1s;display:flex}.dash-picker-student:hover{border-color:var(--primary);filter:none;background:#2563eb0d;transform:translateY(-1px)}.dash-picker-student:active{filter:none;transform:scale(.96)}.dash-picker-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:700;display:flex}.dash-picker-name{color:var(--text-main);text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:68px;font-size:12px;font-weight:600;overflow:hidden}.dash-picker-pts{color:var(--text-muted);font-size:11px;font-weight:600}.login-split{align-items:center;gap:0;width:100%;max-width:900px;margin:0 auto;display:flex}.login-illustration{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:none}.login-illus-text{color:#fff;letter-spacing:-.02em;font-size:24px;font-weight:700}.login-illus-sub{color:#ffffffb3;font-size:14px}.login-form-side{flex:1;justify-content:center;align-items:center;display:flex}@media (width>=768px){.login-illustration{display:flex}.login-split{gap:0}.login-page{justify-content:center;align-items:center}}.heatmap-wrap{padding:8px 0 4px}.heatmap-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;font-size:11px;font-weight:600}.heatmap-svg{display:block}.heatmap-legend{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.heatmap-leg-item{color:var(--text-muted);align-items:center;gap:3px;font-size:10px;display:flex}.heatmap-leg-cell{border-radius:2px;width:10px;height:10px;display:inline-block}.trend-chart-wrap{padding:6px 0 4px}.trend-chart-header{justify-content:space-between;align-items:center;margin-bottom:4px;display:flex}.trend-chart-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:11px;font-weight:600}.trend-arrow{font-size:18px;font-weight:700}.trend-chart-svg{display:block;overflow:visible}.qa-insights-section{padding:8px var(--gap) var(--gap);border-top:1px solid var(--border);margin-top:4px}.class-mood-card{font-size:var(--font-sm);background:var(--bg-card);box-shadow:var(--shadow-sm);border-radius:24px;align-items:center;gap:8px;margin:0 auto 12px;padding:8px 16px;font-weight:600;display:inline-flex}#dash-mood-row{justify-content:center;margin-top:-4px;margin-bottom:8px;display:flex}.class-mood-great{color:#166534;background:#f0fdf4}.class-mood-ok{color:#713f12;background:#fefce8}.class-mood-bad{color:#991b1b;background:#fef2f2}.class-mood-neutral{background:var(--bg-card);color:var(--text-muted)}.class-mood-emoji{font-size:22px;line-height:1;display:inline-block}@keyframes mood-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}@keyframes mood-sway{0%,to{transform:rotate(0)}25%{transform:rotate(-5deg)}75%{transform:rotate(5deg)}}@keyframes mood-shake{0%,to{transform:translate(0)}20%{transform:translate(-3px)}40%{transform:translate(3px)}60%{transform:translate(-2px)}80%{transform:translate(2px)}}@keyframes mood-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.mood-anim-great{animation:2s ease-in-out infinite mood-bounce}.mood-anim-ok{animation:2.5s ease-in-out infinite mood-sway}.mood-anim-bad{animation:2s ease-in-out infinite mood-shake}.mood-anim-neutral{animation:3s ease-in-out infinite mood-pulse}.attend-panel{background:var(--bg-card);border-radius:var(--radius-xl);width:92vw;max-width:640px;max-height:88vh;box-shadow:var(--shadow-lg);flex-direction:column;display:flex;position:relative;overflow:hidden}.attend-header{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:20px 20px 12px;display:flex}.attend-grid{flex:1;grid-template-columns:repeat(auto-fill,minmax(90px,1fr));gap:8px;padding:16px;display:grid;overflow-y:auto}.attend-student{border-radius:var(--radius);cursor:pointer;transition:all .2s var(--spring);background:var(--bg-main);font-size:var(--font-xs);border:2px solid #0000;flex-direction:column;align-items:center;gap:4px;padding:10px 6px;display:flex}.attend-present{border-color:var(--success);background:#f0fdf4}.attend-absent{border-color:var(--danger);opacity:.75;background:#fef2f2}.attend-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:13px;font-weight:700;display:flex}.attend-name{color:var(--text-main);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:80px;font-size:11px;font-weight:600;overflow:hidden}.attend-status-icon{font-size:16px;font-weight:700;line-height:1}.attend-present .attend-status-icon{color:var(--success)}.attend-absent .attend-status-icon{color:var(--danger)}.attend-footer{border-top:1px solid var(--border);background:var(--bg-main);flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.attend-count{font-size:var(--font-sm);color:var(--text-muted);font-weight:600}.wb-live-badge{color:#fff;pointer-events:none;z-index:10;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0000008c;border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:12px;font-weight:600;display:flex;position:absolute;bottom:12px;right:12px}.wb-live-dot{background:#4ade80;border-radius:50%;width:7px;height:7px;animation:1.6s infinite cd-pulse;box-shadow:0 0 5px #4ade80}.wb-remote-toast{color:#fff;pointer-events:none;z-index:20;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000a6;border-radius:20px;padding:6px 16px;font-size:13px;font-weight:600;transition:opacity .4s;position:absolute;top:12px;left:50%;transform:translate(-50%)}.whiteboard-wrapper{flex-direction:column;height:100%;display:flex;overflow:hidden}.whiteboard-toolbar{height:var(--toolbar-height);background:var(--bg-card);-webkit-backdrop-filter:blur(12px);border-bottom:1px solid var(--border);align-items:center;gap:var(--gap-sm);padding:0 var(--gap);z-index:5;flex-shrink:0;display:flex;overflow:auto hidden}.whiteboard-toolbar .tool-group{padding-right:var(--gap-sm);border-right:1px solid #0000000f;align-items:center;gap:4px;margin-right:4px;display:flex}.whiteboard-toolbar .tool-group:last-child{border-right:none}.tool-btn{filter:none;background:0 0;border:1px solid #0000;border-radius:10px;min-width:48px;min-height:48px;padding:0;font-size:20px;position:relative}.tool-btn:hover{filter:none;background:#0000000d}.tool-btn.active{background:var(--primary);color:#fff;filter:none;border-color:#0000}.tool-btn .tool-label{opacity:.7;font-size:9px;font-weight:600;position:absolute;bottom:-2px;right:2px}@media (width<=700px){.whiteboard-toolbar{flex-wrap:wrap;gap:4px;height:auto;padding:8px}.wb-toolbar-group{flex-shrink:0}.wb-size-label span:first-child{display:none}}.board-area{background:var(--bg-main);cursor:crosshair;flex:1;position:relative;overflow:hidden}canvas{touch-action:none;display:block}.color-swatches{align-items:center;gap:4px;display:flex}.color-swatch{cursor:pointer;width:28px;height:28px;transition:transform var(--transition-fast);border:3px solid #0000;border-radius:50%;flex-shrink:0}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--text-main);transform:scale(1.15)}.brush-size-slider{width:100px;accent-color:var(--primary);cursor:pointer;height:4px}.page-nav{align-items:center;gap:6px;display:flex}.page-indicator{font-size:var(--font-sm);text-align:center;min-width:60px;color:var(--text-muted);font-weight:500}.wb-wrapper{position:relative!important}.wb-toolbar{z-index:20;-webkit-backdrop-filter:blur(20px);white-space:nowrap;background:#ffffffe0;border:1px solid #ffffffa6;border-radius:24px;flex-wrap:nowrap;align-items:center;gap:2px;max-width:95vw;padding:8px 12px;display:flex;position:absolute;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 8px 32px #00000024,0 2px 8px #00000014}.wb-toolbar-group{border-right:1px solid #00000014;align-items:center;gap:2px;margin-right:4px;padding-right:8px;display:flex}.wb-toolbar-group:last-child{border-right:none;margin-right:0;padding-right:0}.wb-color-group{align-items:center}.wb-size-label{font-size:var(--font-xs);color:var(--text-muted);white-space:nowrap;align-items:center;gap:6px;display:flex}.wb-quick-colors{align-items:center;gap:4px;display:flex}.quick-color{cursor:pointer;width:20px;height:20px;min-width:unset;min-height:unset;filter:none;border:2px solid #0000001a;border-radius:50%;flex-shrink:0;padding:0;transition:transform .15s cubic-bezier(.25,.46,.45,.94),border-color .15s}.quick-color:hover{filter:none;transform:scale(1.25)}.quick-color:active{filter:none;transform:scale(.9)}.wb-page-indicator{font-size:var(--font-xs);color:var(--text-muted);text-align:center;min-width:42px;font-weight:500}.wb-bg-grid{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Cpath d='M 20 0 L 0 0 0 20' fill='none' stroke='%23ccc' stroke-width='0.5'/%3E%3C/svg%3E")!important}.wb-bg-dots{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20'%3E%3Ccircle cx='1' cy='1' r='1' fill='%23ccc'/%3E%3C/svg%3E")!important}.wb-bg-ruled{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='100%25' height='28'%3E%3Cline x1='0' y1='27' x2='100%25' y2='27' stroke='%23c5cae9' stroke-width='1'/%3E%3C/svg%3E")!important}.wb-bg-dark{background:#1a1a2e!important}.wb-bg-dropdown{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);z-index:200;min-width:140px;position:absolute;bottom:calc(100% + 4px);right:0;overflow:hidden}.wb-bg-option{text-align:left;width:100%;font-size:var(--font-sm);cursor:pointer;color:var(--text-main);background:0 0;border:none;border-radius:0;padding:9px 14px;transition:background .1s;display:block}.wb-bg-option:hover{background:var(--bg-main)}.leaderboard-list{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;gap:0;display:flex;overflow:hidden}.leaderboard-item{background:var(--bg-card);align-items:center;gap:var(--gap);transition:background var(--transition-fast);border-bottom:1px solid #0000000a;padding:12px 16px;display:flex}.leaderboard-item:last-child{border-bottom:none}.leaderboard-item:hover{background:#00000005}.leaderboard-rank{text-align:center;min-width:36px;color:var(--text-muted);font-size:14px;font-weight:600}.leaderboard-rank.rank-1{background:linear-gradient(135deg,gold,orange);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:16px}.leaderboard-rank.rank-2{background:linear-gradient(135deg,silver,#a9a9a9);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:16px}.leaderboard-rank.rank-3{background:linear-gradient(135deg,#cd7f32,sienna);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:16px}.leaderboard-info{flex:1}.leaderboard-name{font-size:15px;font-weight:500}.leaderboard-level{color:var(--text-muted);margin-top:1px;font-size:12px}.leaderboard-points{color:var(--text-main);letter-spacing:-.02em;font-size:18px;font-weight:600}.rewards-grid{gap:var(--gap);grid-template-columns:repeat(auto-fill,minmax(200px,1fr));display:grid}.reward-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--gap-lg);text-align:center;box-shadow:var(--shadow-sm);gap:var(--gap-sm);cursor:pointer;transition:transform .3s var(--spring), box-shadow .3s var(--spring);border:2px solid #0000;flex-direction:column;display:flex}.reward-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.reward-card.can-afford{border-color:var(--success)}.reward-card.cannot-afford{opacity:.5}.reward-icon{font-size:44px}.reward-name{font-size:var(--font-base);font-weight:500}.reward-cost{font-size:var(--font-lg);color:var(--warning);font-weight:600}.reward-desc{font-size:var(--font-sm);color:var(--text-muted)}.missions-list{gap:var(--gap);flex-direction:column;display:flex}.mission-card{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--gap-lg);box-shadow:var(--shadow-sm);gap:var(--gap-lg);align-items:center;display:flex}.mission-icon{flex-shrink:0;font-size:36px}.mission-info{flex:1}.mission-title{font-size:var(--font-base);font-weight:500}.mission-desc{font-size:var(--font-sm);color:var(--text-muted);margin:4px 0}.mission-progress{background:var(--border-light,#f1f5f9);border-radius:999px;height:6px;margin-top:8px;overflow:hidden}.mission-progress-bar{background:linear-gradient(90deg, var(--accent,#14b8a6), var(--primary,#2563eb));height:100%;transition:width .4s var(--spring);border-radius:999px}.mission-reward{font-size:var(--font-sm);color:var(--warning);white-space:nowrap;font-weight:600}.mission-card.completed{opacity:.65}.mission-card.completed .mission-progress-bar{background:var(--success)}@keyframes levelPulse{0%{filter:drop-shadow(0 0 #ffc80000);transform:scale(1)}50%{filter:drop-shadow(0 0 24px #ffc800e6);transform:scale(1.2)}to{filter:drop-shadow(0 0 #ffc80000);transform:scale(1)}}@keyframes levelTextIn{0%{opacity:0;transform:scale(0)translateY(20px)}70%{opacity:1;transform:scale(1.05)translateY(-4px)}to{opacity:1;transform:scale(1)translateY(0)}}@keyframes levelOverlayIn{0%{opacity:0;-webkit-backdrop-filter:blur();backdrop-filter:blur()}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}@keyframes levelOverlayOut{0%{opacity:1}to{opacity:0}}.level-up-epic-overlay{-webkit-backdrop-filter:blur(8px);z-index:9995;cursor:pointer;background:#000c;justify-content:center;align-items:center;animation:.4s forwards levelOverlayIn;display:flex;position:fixed;inset:0}.level-up-epic-overlay.level-up-epic-out{animation:.5s forwards levelOverlayOut}.level-up-epic-card{text-align:center;flex-direction:column;align-items:center;gap:12px;animation:.5s cubic-bezier(.34,1.56,.64,1) both levelTextIn;display:flex}.level-up-epic-icon{font-size:80px;line-height:1;animation:1.5s ease-in-out .4s infinite levelPulse}.level-up-epic-banner{color:gold;letter-spacing:.08em;text-shadow:0 0 40px #ffd700b3,0 2px 4px #00000080;font-size:48px;font-weight:800;animation:.5s cubic-bezier(.34,1.56,.64,1) .1s both levelTextIn}.level-up-epic-name{color:#ffffffe6;font-size:24px;font-weight:600;animation:.5s cubic-bezier(.34,1.56,.64,1) .2s both levelTextIn}.level-up-epic-level{color:#ffffffb3;font-size:20px;font-weight:500;animation:.5s cubic-bezier(.34,1.56,.64,1) .3s both levelTextIn}.dash-hero{gap:var(--gap-lg);padding:0 var(--gap-lg) var(--gap);flex-shrink:0;align-items:center;display:flex}.dash-hero-ring{flex-shrink:0;width:120px;height:120px;position:relative}.dash-ring-svg{display:block}.dash-ring-track{fill:none;stroke:#14b8a61f;stroke-width:8px}.dash-ring-fill{fill:none;stroke:#14b8a6;stroke-width:8px;stroke-linecap:round;transition:stroke-dashoffset .8s cubic-bezier(.25,.46,.45,.94)}.dash-ring-center{flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex;position:absolute;inset:0}.dash-ring-value{color:var(--text-main);letter-spacing:-.02em;font-size:22px;font-weight:700;line-height:1}.dash-ring-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10px}.dash-star-card{border-radius:var(--radius-lg);padding:var(--gap) var(--gap-lg);box-shadow:0 0 0 2px #f59e0b40, var(--shadow-sm);text-align:center;background:linear-gradient(135deg,#fffbeb 0%,#fef9c3 50%,#fef3c7 100%);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:6px;min-height:120px;display:flex}.dash-star-title{font-size:var(--font-xs);color:#b45309;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.dash-star-avatar{width:48px!important;height:48px!important;font-size:18px!important}.dash-star-name{font-size:var(--font-base);color:var(--text-main);font-weight:600}.dash-star-points{font-size:var(--font-sm);color:#f57f17;font-weight:500}.dash-star-empty{opacity:.6}.dash-star-empty-msg{font-size:var(--font-sm);color:var(--text-muted);margin-top:4px}.dash-stat-pills{padding:0 var(--gap-lg) var(--gap);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;display:flex}.dash-stat-pill{font-size:var(--font-sm);color:var(--text-muted);align-items:center;gap:6px;font-weight:500;display:flex}.dash-pill-sep{color:var(--border);font-size:var(--font-sm);opacity:.5}.student-xp-bar{background:var(--border-light,#f1f5f9);border-radius:2px;width:100%;height:4px;overflow:hidden}.student-xp-fill{background:var(--accent,#14b8a6);border-radius:2px;min-width:2px;height:100%;transition:width .6s cubic-bezier(.25,.46,.45,.94)}.student-badges{flex-wrap:wrap;justify-content:center;align-items:center;gap:2px;display:flex}.badge-icon{cursor:default;filter:drop-shadow(0 1px 2px #00000026);font-size:14px;line-height:1;transition:transform .15s}.badge-icon:hover{transform:scale(1.3)}.badge-overflow{background:var(--bg-main);color:var(--text-muted);border-radius:10px;padding:1px 5px;font-size:10px;font-weight:600}.class-pet-wrap{background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;align-items:center;gap:4px;min-width:110px;padding:8px 12px;display:flex}#dash-class-pet{flex-shrink:0}.class-pet-svg{justify-content:center;align-items:center;display:flex}.class-pet-name{color:var(--text-main);text-align:center;font-size:11px;font-weight:700}.class-pet-points{color:var(--text-muted);text-align:center;font-size:10px}.class-pet-progress-bar{background:var(--border-light,#f1f5f9);border-radius:2px;width:80px;height:4px;overflow:hidden}.class-pet-progress-fill{background:var(--accent,#14b8a6);height:100%;transition:width .6s var(--spring);border-radius:2px}.class-pet-next{color:var(--text-muted);text-align:center;font-size:9px}.class-pet-egg{animation:3s ease-in-out infinite pet-wobble}.class-pet-baby{animation:2.5s ease-in-out infinite pet-bounce}.class-pet-teen{animation:2s ease-in-out infinite pet-bounce}.class-pet-adult{animation:3s ease-in-out infinite pet-sway}.class-pet-king{animation:2s ease-in-out infinite pet-shimmer}@keyframes pet-wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-3deg)}75%{transform:rotate(3deg)}}@keyframes pet-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@keyframes pet-sway{0%,to{transform:rotate(0)scale(1)}33%{transform:rotate(-2deg)scale(1.02)}66%{transform:rotate(2deg)scale(1.02)}}@keyframes pet-shimmer{0%,to{filter:drop-shadow(0 0 4px #fbbf244d)}50%{filter:drop-shadow(0 0 12px #fbbf24b3)}}.mode-switcher{background:#0000000d;border-radius:10px;align-items:center;gap:2px;padding:3px;display:flex}.mode-btn{min-width:34px;height:30px;min-height:30px;color:var(--text-muted);cursor:pointer;transition:background var(--transition-fast), transform var(--transition-fast);background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:0 8px;font-size:16px;display:flex}.mode-btn:hover{filter:none;background:#0000000f;transform:none}.mode-btn:active{filter:none;transform:scale(.95)}.mode-btn.active{color:var(--text-main);background:#fff;box-shadow:0 1px 4px #0000001f}body.mode-calm .main-topbar,body.mode-calm .sidebar{background:#121214f7}body.mode-calm .main,body.mode-calm .content-wrapper{background:#1a1a1e}body.mode-calm .card,body.mode-calm .student-card,body.mode-calm .qa-panel{color:#ffffffbf;background:#ffffff0f;border:1px solid #ffffff14}body.mode-calm{color:#fffc;background:#1a1a1e}body.mode-calm .topbar-greeting,body.mode-calm .topbar-class-badge{color:#fff9}body.mode-calm .student-name,body.mode-calm .student-points{color:#ffffffb3}body.mode-calm .bg-main{background:#1a1a1e}body.mode-calm h2,body.mode-calm h3{color:#ffffffbf}.assessment-btns{gap:4px;width:100%;margin-top:4px;display:none}body.mode-assessment .assessment-btns{display:flex}.assessment-btn{cursor:pointer;min-width:0;height:44px;min-height:28px;transition:transform var(--transition-fast), filter var(--transition-fast);border:none;border-radius:6px;flex:1;justify-content:center;align-items:center;padding:0;font-size:13px;font-weight:700;display:flex}.assessment-btn--plus{color:#34c759;background:#34c75926}.assessment-btn--minus{color:#ff3b30;background:#ff3b301f}.assessment-btn--plus:hover{background:#34c75947}.assessment-btn--minus:hover{background:#ff3b3038}.assessment-btn:active{filter:none;transform:scale(.93)}body.mode-teamwork .student-card{border-left:4px solid var(--primary)}.quick-actions-bar{z-index:200;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);border:1px solid #00000014;border-radius:20px;align-items:center;gap:8px;padding:8px 12px;transition:opacity .2s,transform .2s;display:flex;position:fixed;bottom:16px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #0000001f,0 1px 4px #0000000f}.quick-actions-bar--hidden{opacity:0;pointer-events:none;transform:translate(-50%)translateY(8px)}.qa-btn{min-width:0;height:40px;min-height:40px;color:var(--text-main);cursor:pointer;white-space:nowrap;transition:background var(--transition-fast), transform var(--transition-fast);background:#0000000d;border:none;border-radius:12px;align-items:center;gap:6px;padding:0 14px;font-size:13px;font-weight:500;display:flex}.qa-btn:hover{filter:none;background:#00000017}.qa-btn:active{filter:none;transform:scale(.96)}.qa-btn--success{color:#27ae60;background:#34c7591f}.qa-btn--success:hover{background:#34c75938}.qa-btn--active{color:var(--warning);background:#ff95001f}.timer-badge{z-index:201;color:#fff;letter-spacing:-.03em;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);pointer-events:none;background:#ff9500eb;border-radius:16px;padding:6px 16px;font-size:20px;font-weight:700;transition:opacity .25s,transform .25s;position:fixed;top:16px;right:24px;box-shadow:0 2px 12px #ff95004d}.timer-badge--hidden{opacity:0;transform:translateY(-6px)}.timer-badge--urgent{background:#ff3b30eb;animation:.5s infinite alternate timer-pulse;box-shadow:0 2px 12px #ff3b3066}.timer-badge--done{background:#34c759eb;box-shadow:0 2px 12px #34c75966}@keyframes timer-pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}body.mode-calm .timer-badge{border-radius:20px;padding:10px 24px;font-size:32px;top:50%;left:50%;right:auto;transform:translate(-50%,-50%)}body.mode-calm .timer-badge--hidden{opacity:0;transform:translate(-50%,-50%)scale(.95)}.timer-menu{z-index:210;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid #00000014;flex-direction:column;gap:4px;min-width:160px;padding:8px;display:flex;position:fixed}.timer-menu-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 8px 6px;font-size:12px;font-weight:600}.timer-menu-btn{min-width:0;height:36px;min-height:36px;color:var(--text-main);cursor:pointer;text-align:left;transition:background var(--transition-fast);background:0 0;border:none;border-radius:8px;align-items:center;padding:0 12px;font-size:14px;font-weight:500;display:flex}.timer-menu-btn:hover{filter:none;background:#0000000d}.timer-menu-cancel{color:var(--text-muted)}.random-picker-modal{z-index:300;background:#00000073;justify-content:center;align-items:center;animation:.2s fade-in;display:flex;position:fixed;inset:0}.random-picker-card{background:var(--bg-card);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);flex-direction:column;align-items:center;gap:16px;min-width:280px;padding:40px 48px;animation:.35s cubic-bezier(.34,1.56,.64,1) picker-bounce;display:flex}@keyframes picker-bounce{0%{opacity:0;transform:scale(.7)}to{opacity:1;transform:scale(1)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.random-picker-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:13px;font-weight:600}.random-picker-avatar{color:#fff;letter-spacing:-.02em;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;font-size:28px;font-weight:700;display:flex}.random-picker-name{letter-spacing:-.03em;color:var(--text-main);text-align:center;font-size:28px;font-weight:700}.random-picker-points{color:var(--text-muted);font-size:15px}::-webkit-scrollbar-thumb:hover{background:#00000038}.toolkit-fab{z-index:220;width:52px;height:52px;min-width:unset;min-height:unset;background:var(--primary);color:#fff;cursor:pointer;transition:transform .2s var(--spring), box-shadow .2s var(--spring), background .2s;-webkit-tap-highlight-color:transparent;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;position:fixed;bottom:28px;right:28px;box-shadow:0 4px 16px #2563eb66,0 2px 6px #0f1b2d26}.toolkit-fab:hover{filter:none;transform:scale(1.08);box-shadow:0 6px 24px #2563eb73,0 2px 8px #00000024}.toolkit-fab:active{filter:none;transform:scale(.95)}.toolkit-fab--open{background:#0f1b2d;transform:rotate(20deg)scale(1.05)}.toolkit-fab--open:hover{background:#0f1b2d}.toolkit-menu{z-index:220;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg), 0 0 0 1px #0000000d;opacity:0;pointer-events:none;transform-origin:100% 100%;min-width:200px;transition:opacity .18s var(--spring), transform .18s var(--spring);flex-direction:column;gap:2px;padding:8px;display:flex;position:fixed;bottom:92px;right:28px;transform:translateY(10px)scale(.97)}.toolkit-menu--open{opacity:1;pointer-events:auto;transform:translateY(0)scale(1)}.toolkit-menu-item{border-radius:var(--radius-sm);cursor:pointer;text-align:left;min-height:unset;width:100%;transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:12px;padding:10px 12px;display:flex}.toolkit-menu-item:hover{filter:none;background:#0000000a}.toolkit-menu-item:active{filter:none;background:#00000012;transform:none}.toolkit-menu-icon{flex-shrink:0;font-size:20px;line-height:1}.toolkit-menu-text{flex-direction:column;gap:1px;display:flex}.toolkit-menu-label{color:var(--text-main);font-size:14px;font-weight:600}.toolkit-menu-desc{color:var(--text-muted);font-size:11px}.tk-panel{z-index:215;background:var(--bg-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg), 0 0 0 1px #0000000d;opacity:0;transform-origin:100% 100%;width:280px;transition:opacity .2s var(--spring), transform .2s var(--spring);position:fixed;bottom:92px;right:92px;overflow:hidden;transform:translateY(12px)scale(.97)}.tk-panel--visible{opacity:1;transform:translateY(0)scale(1)}.tk-panel-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;display:flex}.tk-panel-title{color:var(--text-main);letter-spacing:-.01em;font-size:14px;font-weight:700}.tk-panel-close{cursor:pointer;width:44px;min-width:44px;height:44px;min-height:44px;color:var(--text-muted);transition:background var(--transition-fast);background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:12px;display:flex}.tk-panel-close:hover{color:var(--text-main);filter:none;background:#0000001f}.tk-panel-close:active{filter:none;transform:scale(.9)}.tk-panel-body{padding:16px}.tk-timer{flex-direction:column;align-items:center;gap:16px;display:flex}.tk-timer-ring-wrap{justify-content:center;align-items:center;width:130px;height:130px;display:flex;position:relative}.tk-timer-ring{width:130px;height:130px;transform:rotate(-90deg)}.tk-ring-bg{fill:none;stroke:#00000012;stroke-width:7px}.tk-ring-fill{fill:none;stroke:var(--primary);stroke-width:7px;stroke-linecap:round;transition:stroke-dashoffset .9s linear,stroke .4s}.tk-timer-display{letter-spacing:-.02em;color:var(--text-main);font-variant-numeric:tabular-nums;font-size:26px;font-weight:700;position:absolute}.tk-timer-presets{flex-wrap:wrap;justify-content:center;gap:6px;display:flex}.tk-preset-btn{min-height:unset;min-width:unset;cursor:pointer;height:32px;color:var(--text-main);transition:background var(--transition-fast), color var(--transition-fast);background:#0000000d;border:none;border-radius:20px;padding:0 12px;font-size:13px;font-weight:600}.tk-preset-btn:hover{color:var(--primary);filter:none;background:#2563eb1a}.tk-preset-btn:active{filter:none;transform:scale(.95)}.tk-preset-btn.active{background:var(--primary);color:#fff}.tk-timer-controls{gap:10px;display:flex}.tk-ctrl-btn{min-height:unset;min-width:unset;background:var(--primary);color:#fff;cursor:pointer;width:44px;height:44px;transition:background var(--transition-fast), transform var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;display:flex}.tk-ctrl-btn:disabled{opacity:.3;cursor:not-allowed}.tk-ctrl-btn:not(:disabled):hover{filter:brightness(1.1)}.tk-ctrl-btn:not(:disabled):active{filter:none;transform:scale(.93)}.tk-ctrl-btn--active{background:var(--warning)}.tk-ctrl--ghost{color:var(--text-main);background:#00000012}.tk-ctrl--ghost:not(:disabled):hover{filter:none;background:#0000001f}.tk-traffic{flex-direction:column;align-items:center;gap:14px;display:flex}.tk-traffic-housing{background:#0f1b2d;border-radius:40px;flex-direction:column;gap:10px;padding:12px 10px;display:flex;box-shadow:inset 0 2px 8px #0006,0 4px 16px #0003}.tk-bulb{min-height:unset;min-width:unset;cursor:pointer;background:#ffffff14;border:none;border-radius:50%;width:52px;height:52px;padding:0;transition:background .2s,box-shadow .2s,transform .15s;box-shadow:inset 0 2px 6px #00000080}.tk-bulb:hover{filter:brightness(1.3)}.tk-bulb:active{filter:none;transform:scale(.93)}.tk-bulb--on{background:var(--c);box-shadow:0 0 18px color-mix(in srgb, var(--c) 70%, transparent), inset 0 1px 3px #ffffff4d}.tk-traffic-msg{color:var(--text-muted);text-align:center;margin:0;font-size:13px;font-weight:500}.tk-wheel{flex-direction:column;align-items:center;gap:20px;padding:8px 0;display:flex}.tk-wheel-orb{background:linear-gradient(135deg,#2563eb1f 0%,#af52de1f 100%);border:3px solid #2563eb33;border-radius:50%;justify-content:center;align-items:center;width:150px;height:150px;transition:border-color .3s,box-shadow .3s;display:flex}.tk-wheel-orb--spinning{border-color:var(--primary);animation:.4s linear infinite tk-orb-spin}.tk-wheel-orb--winner{animation:tk-orb-pop .4s var(--spring);border-color:#34c759;box-shadow:0 0 0 4px #34c75933}@keyframes tk-orb-spin{0%{transform:rotate(0)scale(1)}to{transform:rotate(360deg)scale(1)}}@keyframes tk-orb-pop{0%{transform:scale(.9)}60%{transform:scale(1.08)}to{transform:scale(1)}}.tk-wheel-char{letter-spacing:-.03em;color:var(--text-main);text-align:center;padding:0 8px;font-size:28px;font-weight:800}.tk-wheel-name{color:var(--text-main);letter-spacing:-.02em;text-align:center;min-height:28px;margin:0;font-size:18px;font-weight:600}.tk-spin-btn{min-height:unset;height:44px;padding:0 28px;font-size:15px}.tk-day-note{flex-direction:column;gap:10px;display:flex}.tk-note-ta{border:1px solid var(--border);border-radius:var(--radius);width:100%;min-height:160px;color:var(--text-main);resize:vertical;transition:border-color var(--transition-fast), box-shadow var(--transition-fast);box-sizing:border-box;outline:none;padding:12px;font-family:inherit;font-size:14px;line-height:1.6}.tk-note-ta:focus{border-color:var(--primary);box-shadow:0 0 0 3px #2563eb1f}.tk-note-meta{color:var(--text-muted);justify-content:space-between;font-size:11px;display:flex}@media (width<=600px){.toolkit-fab{width:48px;height:48px;bottom:20px;right:16px}.toolkit-menu{min-width:180px;bottom:80px;right:16px}.tk-panel{width:calc(100vw - 32px);max-width:320px;bottom:80px;right:16px}}.tk-timer-adjust{align-items:center;gap:8px;display:flex}.tk-adj-btn{cursor:pointer;width:44px;min-width:44px;height:44px;min-height:44px;color:var(--text-main);transition:background var(--transition-fast);background:#0000000f;border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:16px;font-weight:600;line-height:1;display:flex}.tk-adj-btn:hover{color:var(--primary);filter:none;background:#2563eb1f}.tk-adj-btn:active{filter:none;transform:scale(.9)}.tk-adj-label{color:var(--text-muted);text-align:center;min-width:16px;font-size:12px;font-weight:600}.dashboard-wrap{box-sizing:border-box;flex-direction:column;gap:18px;width:100%;max-width:960px;margin:0 auto;padding:20px 24px 32px;display:flex}.dash-header{flex-wrap:wrap;justify-content:space-between;align-items:baseline;gap:16px;display:flex}.dash-class-name{color:var(--text-main);letter-spacing:-.02em;margin:0;font-size:22px;font-weight:700}.dash-stat-strip{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.dash-stat-item{color:var(--text-muted);align-items:center;gap:4px;font-size:13px;font-weight:500;display:flex}.dash-stat-icon{font-size:14px}.dash-strip-dot{color:var(--border);font-size:16px;line-height:1}.dash-quick-actions{grid-template-columns:repeat(5,1fr);gap:10px;display:grid}.dqa-btn{border-radius:var(--radius);background:var(--bg-card);box-shadow:var(--shadow-sm);cursor:pointer;min-height:unset;min-width:unset;border:none;flex-direction:column;justify-content:center;align-items:center;gap:6px;padding:14px 8px;transition:transform .12s,box-shadow .12s,background .12s;display:flex}.dqa-btn:hover{box-shadow:var(--shadow-md);filter:none;transform:translateY(-2px)}.dqa-btn:active{filter:none;transform:scale(.96)}.dqa-btn--pos{background:linear-gradient(145deg,#ecfdf5,#d1fae5)}.dqa-btn--neg{background:linear-gradient(145deg,#fff1f2,#ffe4e6)}.dash-na-strip{flex-wrap:wrap;gap:10px;margin:0 0 12px;display:flex}.dash-na-card{box-shadow:var(--shadow-sm);color:#3730a3;cursor:pointer;background:linear-gradient(135deg,#eef2ff,#e0e7ff);border:1px solid #6366f133;border-radius:999px;align-items:center;gap:10px;padding:10px 14px 10px 12px;font-size:13px;font-weight:600;transition:transform .12s,box-shadow .12s,filter .12s;display:inline-flex}.dash-na-card:hover{box-shadow:var(--shadow-md);filter:brightness(1.02);transform:translateY(-1px)}.dash-na-card:active{transform:scale(.98)}.dash-na-icon{font-size:16px;line-height:1}.dash-na-label{line-height:1.2}.dash-na-dismiss{color:#6366f1;background:#fff9;border-radius:50%;justify-content:center;align-items:center;width:20px;height:20px;margin-left:2px;font-size:11px;transition:background .12s;display:inline-flex}.dash-na-dismiss:hover{background:#fffffff2}.dqa-btn{position:relative}.dqa-badge{color:#fff;text-align:center;background:#ff9500;border-radius:9px;min-width:18px;height:18px;padding:0 5px;font-size:11px;font-weight:700;line-height:18px;position:absolute;top:4px;right:4px;box-shadow:0 1px 3px #0003}.dqa-icon{font-size:22px;line-height:1}.dqa-label{color:var(--text-muted);letter-spacing:.01em;font-size:11px;font-weight:600}.dash-pulse-section{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:16px 20px}.dash-pulse-header{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.dash-pulse-header .section-title{margin:0}.dash-pulse-legend{color:var(--text-muted);align-items:center;gap:6px;font-size:12px;display:flex}.dash-legend-dot{border-radius:50%;width:8px;height:8px;margin-left:6px;display:inline-block}.dash-legend-dot--green{background:#34c759}.dash-legend-dot--yellow{background:#ff9500}.dash-legend-dot--red{background:#ff3b30}.dash-pulse-grid{flex-wrap:wrap;gap:10px;display:flex}.dash-pulse-student{cursor:pointer;border-radius:var(--radius-sm);min-height:unset;min-width:unset;background:0 0;border:none;flex-direction:column;align-items:center;gap:4px;padding:8px 10px;transition:background .12s,transform .1s;display:flex}.dash-pulse-student:hover{filter:none;background:#0000000a;transform:translateY(-1px)}.dash-pulse-student:active{filter:none;transform:scale(.95)}.dash-pulse-avatar{color:#fff;letter-spacing:.03em;outline-offset:2px;border-radius:50%;outline:3px solid #0000;justify-content:center;align-items:center;width:44px;height:44px;font-size:14px;font-weight:700;transition:outline-color .3s;display:flex}.dash-pulse-student--green .dash-pulse-avatar{outline-color:#34c759}.dash-pulse-student--yellow .dash-pulse-avatar{outline-color:#ff9500}.dash-pulse-student--red .dash-pulse-avatar{outline-color:#ff3b30}.dash-pulse-name{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;max-width:52px;font-size:11px;font-weight:600;overflow:hidden}.dash-pulse-pts{color:var(--text-muted);font-size:11px;font-weight:700}.dash-bottom-grid{grid-template-columns:1fr 1fr;align-items:start;gap:18px;display:grid}.dash-note-widget{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:10px;padding:16px 18px 14px;display:flex}.dash-note-header{align-items:center;gap:8px;display:flex}.dash-note-nav{color:var(--primary);cursor:pointer;border-radius:var(--radius-sm);transition:background var(--transition-fast), opacity var(--transition-fast);min-height:unset;min-width:unset;background:0 0;border:none;padding:2px 6px;font-size:22px;font-weight:300;line-height:1}.dash-note-nav:hover:not(:disabled){filter:none;background:#2563eb17}.dash-note-nav:disabled{opacity:.3;cursor:default}.dash-note-date-wrap{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex;position:relative}.dash-note-date-label{color:var(--text-main);cursor:pointer;letter-spacing:-.01em;font-size:13px;font-weight:600}.dash-note-date-picker{opacity:0;cursor:pointer;background:0 0;border:none;width:100%;height:100%;font-size:0;position:absolute;top:0;left:0}.dash-note-ta{box-sizing:border-box;resize:vertical;width:100%;min-height:130px;color:var(--text-main);background:var(--bg-main);border:1.5px solid var(--border);border-radius:var(--radius-sm);transition:border-color var(--transition-fast);outline:none;padding:10px 12px;font-family:inherit;font-size:14px;line-height:1.6}.dash-note-ta:focus{border-color:var(--border-focus)}.dash-note-footer{justify-content:space-between;align-items:center;display:flex}.dash-note-count{color:var(--text-muted);font-size:12px}.dash-note-save{border-radius:var(--radius-sm);min-height:unset;min-width:unset;padding:6px 16px;font-size:13px}.dash-recent-section{background:var(--bg-card);border-radius:var(--radius);box-shadow:var(--shadow-sm);flex-direction:column;gap:12px;padding:16px 18px;display:flex}.dash-recent-section .section-title{margin:0}.dash-recent-list{flex-direction:column;gap:6px;display:flex}.dash-recent-item{border-radius:var(--radius-sm);border-left:2px solid #0000;align-items:center;gap:10px;padding:7px 8px 7px 12px;transition:background .12s,border-color .12s;display:flex}.dash-recent-item:hover{background:var(--bg-main)}.dash-recent-item.event-positive{border-left-color:var(--success)}.dash-recent-item.event-negative{border-left-color:var(--danger)}.dash-recent-item.event-neutral{border-left-color:var(--accent)}.dash-recent-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:11px;font-weight:700;display:flex}.dash-recent-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.dash-recent-name{color:var(--text-main);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.dash-recent-reason{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.dash-recent-pts{flex-shrink:0;font-size:13px;font-weight:700}.dash-recent-pos{color:var(--success)}.dash-recent-neg{color:var(--danger)}.dash-recent-time{color:var(--text-muted);white-space:nowrap;flex-shrink:0;font-size:11px}.floating-points{pointer-events:none;z-index:9998;animation:floatUp 1.2s var(--spring) forwards;letter-spacing:-.02em;font-size:28px;font-weight:700;position:fixed}.floating-points.positive{color:var(--success)}.floating-points.negative{color:var(--danger)}@keyframes floatUp{0%{opacity:1;transform:translateY(0)scale(1)}to{opacity:0;transform:translateY(-80px)scale(1.3)}}.level-up-overlay{-webkit-backdrop-filter:blur(8px);z-index:9990;background:#0009;justify-content:center;align-items:center;animation:.3s fadeIn;display:flex;position:fixed;inset:0}.level-up-card{background:var(--bg-card);border-radius:var(--radius-xl);text-align:center;box-shadow:var(--shadow-lg);padding:56px 72px;animation:.4s cubic-bezier(.34,1.56,.64,1) popIn}.level-up-emoji{margin-bottom:16px;font-size:88px;display:block}.level-up-title{letter-spacing:-.02em;margin-bottom:8px;font-size:28px;font-weight:600}.level-up-subtitle{font-size:var(--font-xl);color:var(--text-muted)}@keyframes popIn{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}#confetti-canvas{pointer-events:none;z-index:9997;position:fixed;inset:0}.ai-fab{color:#fff;cursor:pointer;z-index:1000;background:linear-gradient(135deg,#a855f7,#3b82f6);border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;font-size:22px;transition:transform .2s,box-shadow .2s;animation:2.5s ease-in-out infinite ai-pulse;display:flex;position:fixed;bottom:100px;right:20px;box-shadow:0 4px 16px #a855f766}.ai-fab:hover{transform:scale(1.1);box-shadow:0 6px 24px #a855f780,0 0 0 8px #a855f71a}@keyframes ai-pulse{0%,to{box-shadow:0 4px 16px #a855f766,0 0 #a855f74d}50%{box-shadow:0 4px 16px #a855f766,0 0 0 10px #a855f700}}.ai-chat-panel{background:var(--bg-card,#fff);z-index:1100;border-left:1px solid #00000014;border-radius:16px 0 0 16px;flex-direction:column;width:350px;height:100dvh;transition:right .3s cubic-bezier(.4,0,.2,1);display:flex;position:fixed;top:0;right:-360px;box-shadow:-4px 0 32px #0000001f}.ai-chat-panel--open{right:0}.ai-chat-header{border-bottom:1px solid #0000000f;flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 16px 12px;display:flex}.ai-chat-title{background:linear-gradient(135deg,#a855f7,#3b82f6);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:16px;font-weight:600}.ai-chat-close{cursor:pointer;color:var(--text-secondary,#666);background:0 0;border:none;border-radius:8px;padding:4px 8px;font-size:18px;transition:background .15s}.ai-chat-close:hover{background:#0000000f}.ai-quick-prompts{border-bottom:1px solid #0000000d;flex-wrap:wrap;flex-shrink:0;gap:6px;padding:10px 12px;display:flex}.ai-quick-btn{color:#7c3aed;cursor:pointer;white-space:nowrap;text-overflow:ellipsis;background:#a855f714;border:1px solid #a855f733;border-radius:20px;max-width:100%;padding:4px 10px;font-size:11px;transition:background .15s;overflow:hidden}.ai-quick-btn:hover{background:#a855f729}.ai-chat-messages{flex-direction:column;flex:1;gap:10px;padding:12px;display:flex;overflow-y:auto}.ai-message{display:flex}.ai-message--user{justify-content:flex-end}.ai-message--ai,.ai-message--thinking{justify-content:flex-start}.ai-message-bubble{border-radius:16px;max-width:85%;padding:8px 12px;font-size:13px;line-height:1.5}.ai-message--user .ai-message-bubble{color:#fff;background:linear-gradient(135deg,#a855f7,#3b82f6);border-bottom-right-radius:4px}.ai-message--ai .ai-message-bubble{color:var(--text-primary,#1c1c1e);background:#0000000d;border-bottom-left-radius:4px}.ai-message--thinking .ai-message-bubble{color:#999;background:#0000000a;font-style:italic}.ai-chat-input-row{border-top:1px solid #0000000f;flex-shrink:0;gap:8px;padding:12px;display:flex}.ai-chat-input{background:var(--bg-main,#f5f5f7);border:1.5px solid #0000001f;border-radius:24px;outline:none;flex:1;padding:8px 14px;font-size:13px;transition:border-color .15s}.ai-chat-input:focus{border-color:#a855f7}.ai-chat-send{color:#fff;cursor:pointer;background:linear-gradient(135deg,#a855f7,#3b82f6);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;transition:transform .15s;display:flex}.ai-chat-send:hover{transform:scale(1.08)}.ai-suggestions-wrap{flex-direction:column;gap:8px;padding:0 0 4px;display:flex}.ai-suggestion-card{background:#a855f70d;border:1px solid #a855f726;border-radius:12px;align-items:center;gap:8px;padding:10px 12px;animation:.25s ai-slide-down;display:flex}@keyframes ai-slide-down{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ai-suggestion-icon{flex-shrink:0;font-size:20px}.ai-suggestion-msg{color:var(--text-primary,#1c1c1e);flex:1;font-size:13px;line-height:1.4}.ai-suggestion-actions{flex-shrink:0;gap:4px;display:flex}.ai-suggestion-act{color:#fff;cursor:pointer;background:linear-gradient(135deg,#a855f7,#3b82f6);border:none;border-radius:8px;padding:4px 10px;font-size:12px;transition:opacity .15s}.ai-suggestion-act:hover{opacity:.85}.ai-suggestion-dismiss{cursor:pointer;color:var(--text-secondary,#666);background:0 0;border:1px solid #0000001f;border-radius:8px;padding:4px 8px;font-size:12px;transition:background .15s}.ai-suggestion-dismiss:hover{background:#0000000d}.ai-report-content{flex-direction:column;gap:12px;display:flex}.ai-report-text{color:var(--text-primary,#1c1c1e);background:#00000008;border-radius:10px;max-height:320px;padding:14px 16px;font-size:14px;line-height:1.7;overflow-y:auto}.ai-report-actions{justify-content:flex-end;gap:8px;display:flex}.ai-report-picker{gap:10px;padding:4px 0;display:flex}.ai-quiz-form .form-group{margin-bottom:12px}.ai-quiz-form .form-group label{color:var(--text-secondary,#666);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px;font-size:12px;font-weight:600;display:block}.ai-quiz-preview{flex-direction:column;gap:12px;max-height:60vh;display:flex;overflow-y:auto}.ai-quiz-list{flex-direction:column;gap:16px;display:flex}.ai-quiz-question{background:#00000008;border-radius:10px;padding:12px}.ai-quiz-q-text{margin-bottom:8px;font-size:14px;font-weight:500;line-height:1.5}.ai-quiz-editable{border-bottom:1px dashed #0000;outline:none;transition:border-color .15s}.ai-quiz-editable:focus{border-color:#a855f7}.ai-quiz-options{flex-direction:column;gap:4px;display:flex}.ai-quiz-option{border-radius:8px;align-items:center;gap:8px;padding:6px 8px;font-size:13px;display:flex}.ai-quiz-option--correct{color:#1a7a35;background:#34c7591a;font-weight:500}.ai-quiz-letter{background:#0000000f;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:20px;height:20px;font-size:11px;font-weight:700;display:flex}.ai-quiz-option--correct .ai-quiz-letter{color:#fff;background:#34c759}.ai-quiz-hint{color:var(--text-secondary,#666);text-align:center;margin:4px 0 0;font-size:12px}.ai-quiz-footer{border-top:1px solid #0000000f;padding-top:8px}.ai-error{color:var(--danger,#ff3b30);text-align:center;padding:8px;font-size:14px}.portfolio-overlay{z-index:9000;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;animation:.2s portfolioOverlayIn;display:flex;position:fixed;inset:0}@keyframes portfolioOverlayIn{0%{opacity:0}to{opacity:1}}.portfolio-shell{background:var(--bg-card,#fff);border-radius:16px;width:100%;max-width:920px;max-height:92vh;position:relative;overflow-y:auto;box-shadow:0 30px 80px #0f172a40}.portfolio-close{border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);cursor:pointer;z-index:2;border-radius:50%;width:36px;height:36px;font-size:16px;position:absolute;top:12px;right:12px}.portfolio-loading{text-align:center;color:var(--text-muted,#64748b);padding:40px}.portfolio-empty{color:var(--text-muted,#64748b);font-size:var(--font-sm,13px);margin:4px 0}.portfolio-body{padding:24px 28px 32px}.portfolio-header{border-bottom:1px solid var(--border,#e2e8f0);flex-wrap:wrap;align-items:center;gap:16px;margin-bottom:18px;padding-bottom:16px;display:flex}.portfolio-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;font-size:22px;font-weight:700;display:flex;overflow:hidden}.portfolio-avatar svg{width:100%;height:100%}.portfolio-id{flex:1;min-width:200px}.portfolio-name{margin:0;font-size:22px;font-weight:700}.portfolio-meta{color:var(--text-muted,#64748b);flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;font-size:13px;display:flex}.portfolio-level-pill{border:1px solid;border-radius:999px;padding:2px 10px;font-size:12px;font-weight:600}.portfolio-actions{flex-wrap:wrap;gap:6px;display:flex}.portfolio-section{border-bottom:1px solid var(--border,#e2e8f0);padding:18px 0}.portfolio-section:last-child{border-bottom:0}.portfolio-section-title{margin:0 0 12px;font-size:16px;font-weight:700}.portfolio-section-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.portfolio-section-head .portfolio-section-title{margin:0}.portfolio-snapshot-grid{grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-bottom:12px;display:grid}.portfolio-stat{background:var(--bg-soft,#f8fafc);text-align:center;border-radius:10px;padding:12px}.portfolio-stat-value{font-size:22px;font-weight:700}.portfolio-stat-label{color:var(--text-muted,#64748b);margin-top:4px;font-size:11px}.portfolio-badges-row{flex-wrap:wrap;align-items:center;gap:8px;margin-top:6px;display:flex}.portfolio-badge{background:var(--bg-soft,#f8fafc);border:1px solid var(--border,#e2e8f0);border-radius:999px;align-items:center;gap:6px;padding:4px 10px;font-size:12px;display:inline-flex}.portfolio-radar-section{display:block}.portfolio-radar-wrap{--portfolio-radar-grid:var(--border,#e2e8f0);--portfolio-radar-stroke:#3b82f6;--portfolio-radar-fill:#3b82f62e;justify-content:center;margin:4px 0 14px;display:flex}.portfolio-radar{max-width:100%;height:auto}.portfolio-sw-grid{grid-template-columns:1fr 1fr;gap:12px;display:grid}.portfolio-sw{background:var(--bg-soft,#f8fafc);border-left:4px solid;border-radius:10px;padding:12px}.portfolio-sw h3{margin:0 0 6px;font-size:13px;font-weight:700}.portfolio-sw ul{margin:0;padding-left:18px}.portfolio-sw li{font-size:13px;line-height:1.7}.portfolio-sw--good{border-left-color:#16a34a}.portfolio-sw--needs{border-left-color:#f59e0b}@media (width<=600px){.portfolio-sw-grid{grid-template-columns:1fr}}.portfolio-goals{flex-direction:column;gap:8px;display:flex}.portfolio-goal{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-left-width:4px;border-radius:10px;padding:10px 12px}.portfolio-goal--in-progress{border-left-color:#f59e0b}.portfolio-goal--achieved{border-left-color:#16a34a}.portfolio-goal--not-met{border-left-color:#dc2626}.portfolio-goal-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;display:flex}.portfolio-goal-status{color:var(--text-muted,#64748b);font-size:12px;font-weight:600}.portfolio-goal-actions{gap:4px;margin-left:auto;display:flex}.portfolio-goal-text{margin:0;font-size:14px;line-height:1.5}.portfolio-goal-target{color:var(--text-muted,#64748b);margin:4px 0 0;font-size:12px}.portfolio-goal-evidence{background:#22c55e14;border-radius:6px;margin:6px 0 0;padding:6px 8px;font-size:12px}.portfolio-notes{flex-direction:column;gap:8px;display:flex}.portfolio-note{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:10px;padding:10px 12px}.portfolio-note--public{background:#3b82f60a}.portfolio-note--private{background:var(--bg-card,#fff)}.portfolio-note-head{color:var(--text-muted,#64748b);flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:6px;font-size:11px;display:flex}.portfolio-note-head time{font-variant-numeric:tabular-nums}.portfolio-note-head .portfolio-note-delete{margin-left:auto}.portfolio-note-text{white-space:pre-wrap;margin:0;font-size:14px;line-height:1.5}.portfolio-vis-badge{background:var(--bg-soft,#f1f5f9);border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:11px;display:inline-flex}.portfolio-chip{background:var(--bg-soft,#f1f5f9);color:var(--text-muted,#64748b);border-radius:999px;padding:2px 8px;font-size:11px;display:inline-block}.portfolio-chip--current{color:#1d4ed8;background:#eff6ff}.portfolio-timeline{padding-left:22px;position:relative}.portfolio-timeline:before{content:"";background:var(--border,#e2e8f0);width:2px;position:absolute;top:4px;bottom:4px;left:8px}.portfolio-timeline-entry{padding-bottom:14px;position:relative}.portfolio-timeline-dot{border:2px solid var(--bg-card,#fff);background:#94a3b8;border-radius:50%;width:12px;height:12px;position:absolute;top:6px;left:-18px}.portfolio-timeline-entry--current .portfolio-timeline-dot{background:#3b82f6;box-shadow:0 0 0 4px #3b82f62e}.portfolio-timeline-content{background:var(--bg-soft,#f8fafc);border-radius:10px;padding:10px 12px}.portfolio-timeline-head{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px;font-size:13px;display:flex}.portfolio-timeline-class{color:var(--text-muted,#64748b);font-size:12px}.portfolio-timeline-stats{color:var(--text-muted,#64748b);flex-wrap:wrap;gap:16px;margin:0;padding:0;font-size:12px;list-style:none;display:flex}.portfolio-timeline-stats strong{color:var(--text,#0f172a);font-weight:600}.portfolio-form-overlay{z-index:9100;background:#0f172a8c;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.portfolio-form-panel{background:var(--bg-card,#fff);border-radius:14px;width:100%;max-width:460px;padding:18px 20px;box-shadow:0 24px 60px #0f172a4d}.portfolio-form-panel h3{margin:0 0 12px;font-size:18px;font-weight:700}.portfolio-form-panel form{flex-direction:column;gap:10px;display:flex}.portfolio-form-panel label{color:var(--text-muted,#64748b);flex-direction:column;gap:4px;font-size:12px;font-weight:600;display:flex}.portfolio-form-panel input,.portfolio-form-panel select,.portfolio-form-panel textarea{border:1px solid var(--border,#e2e8f0);background:var(--bg-card,#fff);color:var(--text,#0f172a);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:14px}.portfolio-form-panel textarea{resize:vertical}.portfolio-vis-toggle{border:1px solid var(--border,#e2e8f0);border-radius:8px;flex-direction:column;gap:6px;padding:8px 10px;font-size:12px;display:flex}.portfolio-vis-toggle legend{color:var(--text-muted,#64748b);padding:0 4px;font-weight:600}.portfolio-vis-toggle label{color:inherit;flex-direction:row;align-items:center;gap:8px;font-size:13px}.portfolio-form-actions{gap:8px;margin-top:6px;display:flex}.portfolio-form-actions button{flex:1}.portfolio-transfer-code{text-align:center;letter-spacing:6px;background:var(--bg-soft,#f1f5f9);-webkit-user-select:all;user-select:all;border-radius:10px;margin:8px 0;padding:14px 8px;font-family:SF Mono,Menlo,monospace;font-size:26px;font-weight:700}.portfolio-tab-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;display:grid}.portfolio-pick-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);cursor:pointer;text-align:left;font:inherit;border-radius:10px;align-items:center;gap:10px;padding:10px;display:flex}.portfolio-pick-card:hover{background:var(--bg-soft,#f8fafc)}.portfolio-pick-name{flex:1;font-size:13px;font-weight:600}.portfolio-pick-arrow{color:var(--text-muted,#64748b);font-size:12px}.portfolio-tab-detail{margin-top:18px}.portfolio-icon-btn{color:#334155;cursor:pointer;z-index:3;opacity:0;background:#ffffffd9;border:0;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:14px;transition:opacity .15s;display:flex;position:absolute;top:4px;left:4px}.student-card:hover .portfolio-icon-btn,.student-card:focus-within .portfolio-icon-btn{opacity:1}.portfolio-icon-btn:hover{background:#fff;transform:scale(1.05)}@media (hover:none){.portfolio-icon-btn{opacity:1}}@media print{.portfolio-overlay{background:0 0;padding:0;position:static}.portfolio-shell{box-shadow:none;border-radius:0;max-width:none;max-height:none;overflow:visible}.portfolio-close,.portfolio-actions,.portfolio-section-head .btn-primary,.portfolio-goal-actions,.portfolio-note-delete{display:none!important}.portfolio-section{break-inside:avoid}.portfolio-form-overlay{display:none}}.dash-insight-row{gap:var(--gap-lg,16px);margin-bottom:var(--gap-lg,16px);grid-template-columns:repeat(3,minmax(0,1fr));display:grid}@media (width<=900px){.dash-insight-row{grid-template-columns:1fr}}.dash-insight-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:var(--radius,14px);flex-direction:column;gap:10px;min-height:168px;padding:14px 16px;display:flex}.dash-insight-card--goals{border-top:3px solid #14b8a6}.dash-insight-card--attention{border-top:3px solid #f59e0b}.dash-insight-card--improvements{border-top:3px solid #22c55e}.dash-insight-head{align-items:center;gap:8px;display:flex}.dash-insight-icon{font-size:18px}.dash-insight-title{color:var(--text,#0f172a);margin:0;font-size:14px;font-weight:600}.dash-insight-sub{color:var(--text-muted,#64748b);margin:0;font-size:12px}.dash-insight-rows{flex-direction:column;gap:6px;display:flex}.dash-insight-row{grid-template-columns:70px 1fr auto;align-items:center;gap:8px;display:grid}.dash-insight-row-label{color:var(--text,#0f172a);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.dash-insight-row-track{background:#00000014;border-radius:999px;height:6px;overflow:hidden}.dash-insight-row-fill{background:linear-gradient(90deg,#14b8a6,#22c55e);height:100%;transition:width .4s}.dash-insight-row-value{color:var(--text,#0f172a);text-align:right;min-width:32px;font-size:12px;font-weight:600}.dash-insight-achieved{color:var(--text-muted,#64748b);align-items:center;gap:6px;font-size:12px;display:flex}.dash-insight-link{color:var(--accent,#14b8a6);align-self:flex-start;margin-top:auto;font-size:12px;text-decoration:none}.dash-insight-link:hover{text-decoration:underline}.dash-insight-empty{color:var(--text-muted,#64748b);margin:0;font-size:13px}.dash-insight-positive{color:#16a34a}.dash-insight-students{flex-direction:column;gap:6px;display:flex}.dash-insight-student{cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:10px;align-items:center;gap:10px;width:100%;padding:6px 8px;transition:background .15s;display:flex}.dash-insight-student:hover{border-color:var(--border,#e2e8f0);background:#0000000a}.dash-insight-avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.dash-insight-student-info{flex-direction:column;gap:2px;min-width:0;display:flex}.dash-insight-student-name{color:var(--text,#0f172a);font-size:13px;font-weight:600}.dash-insight-student-reason{color:var(--text-muted,#64748b);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.dash-energy-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:var(--radius,14px);margin-bottom:var(--gap-lg,16px);flex-direction:column;gap:4px;padding:12px 16px;display:flex}.dash-energy-card.mood-great{border-left:4px solid #22c55e}.dash-energy-card.mood-ok{border-left:4px solid #f59e0b}.dash-energy-card.mood-bad{border-left:4px solid #ef4444}.dash-energy-text{color:var(--text,#0f172a);font-size:14px;font-weight:600}.dash-energy-focus{color:var(--text-muted,#64748b);font-size:12px}.dash-pet-row{margin-bottom:var(--gap-lg,16px);justify-content:center;display:flex}.overview-pane{gap:var(--gap-lg,16px);padding:var(--gap-lg,16px);grid-template-columns:repeat(auto-fit,minmax(280px,1fr));display:grid}.overview-card{background:var(--bg-card,#fff);border:1px solid var(--border,#e2e8f0);border-radius:var(--radius,14px);padding:14px 16px}.overview-card-head{justify-content:space-between;align-items:center;gap:8px;margin-bottom:10px;display:flex}.overview-card-title{color:var(--text,#0f172a);margin:0;font-size:14px;font-weight:600}.overview-card-sub{color:var(--text-muted,#64748b);font-size:12px}.overview-behavior-bars{flex-direction:column;gap:8px;display:flex}.overview-bar-row{grid-template-columns:70px 1fr auto;align-items:center;gap:8px;display:grid}.overview-bar-label{color:var(--text-muted,#64748b);font-size:12px}.overview-bar-track{background:#0000000f;border-radius:999px;height:8px;overflow:hidden}.overview-bar-fill{height:100%;transition:width .4s}.overview-bar-fill--pos{background:linear-gradient(90deg,#22c55e,#14b8a6)}.overview-bar-fill--neg{background:linear-gradient(90deg,#ef4444,#f59e0b)}.overview-bar-value{text-align:right;min-width:32px;font-size:12px;font-weight:600}.overview-subject-list{flex-direction:column;gap:6px;display:flex}.overview-subject-row{grid-template-columns:100px 1fr auto;align-items:center;gap:8px;display:grid}.overview-subject-name{color:var(--text,#0f172a);font-size:12px}.overview-subject-track{background:#0000000f;border-radius:999px;height:6px;overflow:hidden}.overview-subject-fill{background:var(--accent,#14b8a6);height:100%;transition:width .4s}.overview-subject-count{color:var(--text-muted,#64748b);font-size:12px}.overview-notes-list{flex-direction:column;gap:8px;display:flex}.overview-note-item{grid-template-columns:28px 1fr auto;align-items:center;gap:10px;display:grid}.overview-note-avatar{color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.overview-note-info{flex-direction:column;gap:2px;min-width:0;display:flex}.overview-note-name{color:var(--text,#0f172a);font-size:13px;font-weight:600}.overview-note-text{color:var(--text-muted,#64748b);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.overview-note-time{color:var(--text-muted,#64748b);white-space:nowrap;font-size:11px}.overview-goals-list{flex-direction:column;gap:10px;display:flex}.overview-goal-row{flex-direction:column;gap:4px;display:flex}.overview-goal-head{justify-content:space-between;align-items:center;display:flex}.overview-goal-student{color:var(--text,#0f172a);font-size:12px;font-weight:600}.overview-goal-percent{color:var(--text-muted,#64748b);font-size:12px}.overview-goal-track{background:#0000000f;border-radius:999px;height:6px;overflow:hidden}.overview-goal-fill{background:linear-gradient(90deg,#14b8a6,#22c55e);height:100%;transition:width .4s}.overview-goal-text{color:var(--text-muted,#64748b);font-size:12px}.student-behavior-indicator{background:#0000000a;border-radius:999px;align-items:center;gap:6px;margin-top:4px;padding:2px 8px;font-size:12px;display:inline-flex}.student-behavior-indicator--green{background:#22c55e1a}.student-behavior-indicator--yellow{background:#f59e0b1a}.student-behavior-indicator--red{background:#ef44441a}.student-behavior-dot{font-size:10px;line-height:1}.student-points-secondary{opacity:.95;font-size:13px;font-weight:600}.student-note-preview{color:var(--text-muted,#64748b);white-space:nowrap;text-overflow:ellipsis;max-width:100%;margin-top:2px;padding:0 8px;font-size:11px;overflow:hidden}body.season-christmas,body.season-easter,body.season-summer,body.season-halloween{transition:background-color .5s,color .5s}body.season-christmas{--season-accent:#dc2626;--season-accent-soft:#dc26261f}body.season-christmas .sidebar{background:linear-gradient(#1a2d20 0%,#0f1b12 100%)}body.season-christmas:before{content:"";pointer-events:none;z-index:9998;background-image:radial-gradient(circle at 20% 0,#fffc 1px,#0000 1px),radial-gradient(circle at 80% 10%,#ffffffb3 1.5px,#0000 1.5px),radial-gradient(circle at 50% 5%,#fff9 1px,#0000 1px),radial-gradient(circle at 30% 15%,#ffffffe6 1px,#0000 1px),radial-gradient(circle at 70% 20%,#ffffffb3 1.5px,#0000 1.5px);background-size:300px 300px,400px 400px,250px 250px,350px 350px,450px 450px;animation:8s linear infinite snow-fall;position:fixed;inset:0}@keyframes snow-fall{0%{background-position:0 -300px,0 -400px,0 -250px,0 -350px,0 -450px}to{background-position:0 100vh,0 100vh,0 100vh,0 100vh,0 100vh}}body.season-easter{--season-accent:#a855f7;--season-accent-soft:#a855f71a}body.season-easter .student-card{border-left-color:var(--season-accent)}body.season-summer{--season-accent:#0891b2;--season-accent-soft:#0891b21a}body.season-halloween{--season-accent:#ea580c;--season-accent-soft:#ea580c1f}body.season-halloween .sidebar{background:linear-gradient(#2d1906 0%,#1a0e04 100%)}.group-drag-chip{cursor:grab;background:var(--bg-main);font-size:var(--font-sm);border:1px solid var(--border);-webkit-user-select:none;user-select:none;transition:opacity var(--transition-fast), box-shadow var(--transition-fast);border-radius:999px;align-items:center;gap:6px;padding:5px 10px;display:flex}.group-drag-chip:active{cursor:grabbing}.group-drag-chip.dragging{opacity:.4}.group-drag-chip--member{background:#2563eb1a;border-color:#2563eb4d}.group-chip-remove{cursor:pointer;color:var(--danger);background:0 0;border:none;padding:0 0 0 4px;font-size:16px;line-height:1}.group-drop-zone{border:2px dashed var(--border);border-radius:var(--radius);flex-wrap:wrap;align-content:flex-start;gap:6px;min-height:120px;max-height:200px;padding:8px;transition:border-color .2s,background .2s;display:flex;overflow-y:auto}.group-drop-zone--over{border-color:var(--primary);background:#2563eb0a}.group-drop-hint{color:var(--text-muted);font-size:var(--font-sm);text-align:center;pointer-events:none;align-self:center;width:100%}.wb-float-preview{border-radius:var(--radius);width:120px;height:80px;box-shadow:var(--shadow-lg);cursor:pointer;z-index:400;transition:transform var(--transition), box-shadow var(--transition);background:#fff;border:2px solid #ffffff4d;position:fixed;bottom:90px;right:16px;overflow:hidden}.wb-float-preview:hover{transform:scale(1.06);box-shadow:0 8px 32px #0000002e}.wb-float-preview img{object-fit:cover;width:100%;height:100%;display:block}.wb-float-preview[hidden]{display:none}#qa-voice.qa-btn--active{color:var(--danger);background:#ff3b3026;animation:1s infinite alternate voice-pulse}@keyframes voice-pulse{0%{box-shadow:0 0 #ff3b304d}to{box-shadow:0 0 0 8px #ff3b3000}}.spotlight-overlay{z-index:9000;-webkit-backdrop-filter:blur(6px);background:#00000073;justify-content:center;align-items:flex-start;padding-top:15vh;animation:.15s spotlight-in;display:flex;position:fixed;inset:0}@keyframes spotlight-in{0%{opacity:0}to{opacity:1}}.spotlight-box{background:var(--bg-card);border-radius:var(--radius-xl);width:min(600px,92vw);box-shadow:var(--shadow-lg), 0 0 0 1px var(--border);flex-direction:column;max-height:70vh;display:flex;overflow:hidden}.spotlight-input{width:100%;font-size:var(--font-lg);color:var(--text-main);border:none;border-bottom:1px solid var(--border);background:0 0;outline:none;padding:18px 20px;font-family:inherit}.spotlight-results{flex:1;padding:6px;overflow-y:auto}.spotlight-item{border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;color:var(--text-main);font-family:inherit;font-size:var(--font-sm);transition:background var(--transition-fast);background:0 0;border:none;align-items:center;gap:12px;padding:11px 14px;display:flex}.spotlight-item--active,.spotlight-item:hover{background:#2563eb14}.spotlight-item-icon{text-align:center;flex-shrink:0;width:28px;font-size:20px}.spotlight-item-body{flex-direction:column;gap:1px;min-width:0;display:flex}.spotlight-item-label{font-weight:500}.spotlight-item-sub{font-size:var(--font-xs);color:var(--text-muted)}.spotlight-empty{text-align:center;color:var(--text-muted);font-size:var(--font-sm);padding:24px}.offline-banner{z-index:800;color:#fff;font-size:var(--font-xs);text-align:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ff9500eb;padding:6px 16px;font-weight:600;animation:.3s offline-slide-up;position:fixed;bottom:0;left:0;right:0}@keyframes offline-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.reaction-emoji{pointer-events:none;z-index:10;font-size:28px;animation:1.5s forwards reaction-pop;position:absolute;top:8px;right:8px}.student-card{position:relative}@keyframes reaction-pop{0%{opacity:0;transform:scale(.5)translateY(0)}20%{opacity:1;transform:scale(1.2)translateY(-4px)}80%{opacity:1;transform:scale(1)translateY(-8px)}to{opacity:0;transform:scale(.9)translateY(-16px)}}@keyframes leaderboard-flash{0%{background:0 0}20%{background:#ffc40059;box-shadow:0 0 12px #ffc40066}to{background:0 0}}.leaderboard-flash{animation:.6s leaderboard-flash}
