:root{font-family:Inter,Segoe UI,system-ui,-apple-system,sans-serif;line-height:1.5;font-weight:400;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--bg-page: #f6f7fb;--bg-surface: #ffffff;--bg-surface-secondary: #f6f7fb;--bg-surface-hover: #f1f5f9;--bg-surface-active: #f0f4ff;--bg-inset: #f8fafc;--border-primary: #e6e9ef;--border-secondary: #d8dde5;--border-focus: #3b82f6;--text-primary: #1f2933;--text-secondary: #475569;--text-muted: #677489;--text-dimmed: #94a3b8;--text-link: #1d4ed8;--accent: #1d4ed8;--accent-hover: #1e40af;--accent-light: #eff6ff;--accent-border: #93c5fd;--accent-ring: rgba(29, 78, 216, .4);--blue: #3b82f6;--blue-hover: #2563eb;--blue-bg: #e0f2fe;--blue-text: #075985;--blue-light: #dbeafe;--green: #059669;--green-btn: #10b981;--green-excel: #107c41;--green-excel-hover: #0d6334;--red: #dc2626;--red-bg: #fee2e2;--red-text: #991b1b;--red-border: #fca5a5;--yellow-bg: #fef9c3;--yellow-text: #854d0e;--success-bg: #dcfce7;--success-text: #166534;--success-border: #86efac;--teacher-badge-bg: #fef3c7;--teacher-badge-text: #92400e;--head-badge-bg: #dbeafe;--head-badge-text: #1e3a8a;--subgroup-badge-bg: #dbeafe;--subgroup-badge-text: #1e40af;--subgroup-border: #93c5fd;--subgroup-bg: #eff6ff;--skeleton-from: #f1f5f9;--skeleton-mid: #e2e8f0;--overlay-bg: rgba(15, 23, 42, .45);--overlay-heavy: rgba(15, 23, 42, .55);--shadow-card: 0 10px 30px rgba(15, 23, 42, .08);--shadow-drawer: 0 20px 60px rgba(15, 23, 42, .2);--shadow-modal: 0 20px 60px rgba(15, 23, 42, .25);--tg-bg: #e0f2fe;--tg-text: #0088cc;--tg-hover: #bae6fd;--chat-bg: #f1f5f9;--chat-theirs-bg: #ffffff;--chat-theirs-border: #e2e8f0;--chat-theirs-text: #1e293b;--msg-mine-bg: #3b82f6;--msg-mine-text: #fff;--input-bg: #ffffff;--input-border: #d8dde5;--autocomplete-hover: #eff6ff;color:var(--text-primary);background-color:var(--bg-page)}[data-theme=dark]{--bg-page: #0f1117;--bg-surface: #1a1d27;--bg-surface-secondary: #1e2130;--bg-surface-hover: #252838;--bg-surface-active: #1e2744;--bg-inset: #161922;--border-primary: #2a2d3a;--border-secondary: #333647;--border-focus: #3b82f6;--text-primary: #e2e8f0;--text-secondary: #a0aec0;--text-muted: #8892a4;--text-dimmed: #5a6478;--text-link: #60a5fa;--accent: #3b82f6;--accent-hover: #2563eb;--accent-light: #1e2744;--accent-border: #2563eb;--accent-ring: rgba(59, 130, 246, .4);--blue: #3b82f6;--blue-hover: #2563eb;--blue-bg: #1e2744;--blue-text: #93c5fd;--blue-light: #1e2744;--green: #10b981;--green-btn: #059669;--green-excel: #059669;--green-excel-hover: #047857;--red: #ef4444;--red-bg: #3b1c1c;--red-text: #fca5a5;--red-border: #7f1d1d;--yellow-bg: #3b3510;--yellow-text: #fde68a;--success-bg: #14352a;--success-text: #86efac;--success-border: #065f46;--teacher-badge-bg: #3b3010;--teacher-badge-text: #fde68a;--head-badge-bg: #1e2744;--head-badge-text: #93c5fd;--subgroup-badge-bg: #1e2744;--subgroup-badge-text: #93c5fd;--subgroup-border: #2563eb;--subgroup-bg: #1e2744;--skeleton-from: #1e2130;--skeleton-mid: #252838;--overlay-bg: rgba(0, 0, 0, .6);--overlay-heavy: rgba(0, 0, 0, .7);--shadow-card: 0 10px 30px rgba(0, 0, 0, .3);--shadow-drawer: 0 20px 60px rgba(0, 0, 0, .5);--shadow-modal: 0 20px 60px rgba(0, 0, 0, .5);--tg-bg: #1e2744;--tg-text: #60a5fa;--tg-hover: #252d4a;--chat-bg: #161922;--chat-theirs-bg: #1e2130;--chat-theirs-border: #2a2d3a;--chat-theirs-text: #e2e8f0;--msg-mine-bg: #2563eb;--msg-mine-text: #fff;--input-bg: #1e2130;--input-border: #333647;--autocomplete-hover: #1e2744;color-scheme:dark}*{box-sizing:border-box}body{margin:0;min-height:100vh;background:var(--bg-page)}a{color:inherit;text-decoration:none}button,input,select,textarea{font-family:inherit;color:inherit}#root{min-height:100vh}.app-shell{min-height:100vh;display:flex;flex-direction:column;background:var(--bg-page)}.topbar{display:flex;align-items:center;gap:16px;padding:16px 24px;background:var(--bg-surface);border-bottom:1px solid var(--border-primary);position:sticky;top:0;z-index:10}.hamburger{width:40px;height:40px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--bg-surface);display:grid;place-items:center;cursor:pointer}.hamburger span{width:20px;height:2px;background:var(--text-primary);position:relative}.hamburger span:before,.hamburger span:after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--text-primary)}.hamburger span:before{top:-6px}.hamburger span:after{top:6px}.brand{font-weight:700;font-size:1.1rem}.content{display:grid;grid-template-columns:minmax(0,1fr);gap:24px;padding:24px}.drawer-backdrop{position:fixed;inset:0;background:var(--overlay-bg);opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:20}.drawer-backdrop.open{opacity:1;pointer-events:auto}.drawer{position:fixed;top:0;left:0;height:100vh;width:280px;background:var(--bg-surface);box-shadow:var(--shadow-drawer);transform:translate(-100%);transition:transform .25s ease;z-index:30;padding:24px;display:flex;flex-direction:column;gap:16px}.drawer.open{transform:translate(0)}.drawer-title{font-weight:700;font-size:1.1rem}.drawer-button{border:1px solid var(--border-secondary);background:var(--bg-surface-secondary);padding:12px 16px;border-radius:12px;cursor:pointer;text-align:left;font-weight:600;display:flex;align-items:center;gap:10px}.drawer-button svg{flex-shrink:0}.drawer-button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.panel{background:var(--bg-surface);border-radius:20px;padding:20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:16px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.group-card{border-radius:16px;padding:16px;background:var(--bg-surface-secondary);border:1px solid var(--border-primary);cursor:pointer;display:flex;flex-direction:column;gap:8px}.group-card:hover{border-color:var(--accent-border);background:var(--bg-surface-active)}.group-card.active{border-color:var(--accent);background:var(--accent-light);box-shadow:0 0 0 2px var(--accent)}.group-card strong{font-size:1.05rem}.group-card-status{font-size:.8rem;color:var(--text-dimmed);opacity:0;transition:opacity .15s}.group-card:hover .group-card-status,.group-card-status.selected{opacity:1}.group-card-status.selected{color:var(--accent);font-weight:600}.group-delete-btn{font-size:.75rem;padding:4px 10px}.admin-bulk-actions{display:flex;gap:8px;flex-wrap:wrap}.admin-bulk-actions button{flex:1;font-size:.8rem;padding:8px 12px;margin-bottom:0}.schedule-header{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between}.date-picker{display:grid;gap:10px;justify-items:end;text-align:right}.date-info{display:grid;gap:2px}.date-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em}.date-value{font-size:1.05rem}.date-weekday{color:var(--text-secondary);font-size:.9rem;text-transform:capitalize}.date-controls{display:flex;flex-direction:column;gap:8px;align-items:flex-end}.date-input{padding:8px 12px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--input-bg);font-weight:600}.date-quick{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.date-chip{border:1px solid var(--border-secondary);background:var(--bg-inset);color:var(--text-primary);padding:6px 10px;border-radius:999px;font-size:.8rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,color .15s}.date-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.date-picker-compact{display:flex;flex-wrap:wrap;gap:10px;align-items:center}.date-input-row{display:flex;align-items:center;gap:10px}.date-display{font-size:.9rem;color:var(--text-secondary);font-weight:600;text-transform:capitalize;white-space:nowrap}.time-mode{display:flex;flex-wrap:wrap;gap:8px;margin:20px 0}.time-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:8px}.time-slot{border:1px solid var(--border-secondary);background:var(--bg-surface);border-radius:12px;padding:10px 12px;font-weight:600;text-align:left;cursor:pointer}.time-slot.active{background:var(--accent);color:#fff;border-color:var(--accent)}.time-slot.danger{background:var(--red);color:#fff;border-color:var(--red)}.schedule-list{display:flex;flex-direction:column;gap:12px}.schedule-time-block{display:flex;flex-direction:column;gap:8px;border:1px solid var(--border-primary);border-radius:14px;padding:12px 16px;background:var(--bg-inset)}.schedule-entries-row{display:flex;flex-wrap:wrap;gap:12px}.schedule-entries-row .schedule-item{flex:1;min-width:280px}.schedule-item{border-radius:16px;padding:16px;background:#f6f7fb;border:1px solid #e6e9ef;display:flex;flex-direction:column;gap:8px;position:relative}.subgroup-row-block{padding-bottom:12px}.subgroups-container{display:flex;gap:16px;margin-top:12px;border-top:1px solid #e6e9ef;padding-top:16px}.subgroup-column{flex:1;min-width:0;display:flex;flex-direction:column;gap:8px}.subgroup-label{font-size:.7rem;font-weight:700;text-transform:uppercase;color:#94a3b8;letter-spacing:.05em;margin-bottom:4px}.subgroup-content{display:flex;flex-direction:column;gap:4px}.subgroup-empty{color:#94a3b8;font-style:italic;font-size:.9rem;padding:8px 0}.subgroup-divider{width:1px;background:#e6e9ef;align-self:stretch}@media(max-width:600px){.subgroups-container{flex-direction:column;gap:20px}.subgroup-divider{width:100%;height:1px}}@media(max-width:400px){.schedule-item{min-width:0;padding-right:12px}.subgroup-badge{position:static;display:inline-block;margin-top:4px}}.subgroup-item{border-color:var(--subgroup-border);background:var(--subgroup-bg)}.full-group-item{border-color:var(--border-secondary);background:var(--bg-surface)}.subgroup-badge{position:absolute;top:8px;right:8px;font-size:.7rem;font-weight:700;color:var(--subgroup-badge-text);background:var(--subgroup-badge-bg);padding:2px 8px;border-radius:999px;text-transform:uppercase}.schedule-item.highlighted-red{border-color:var(--red);background:var(--red-bg)}.tag{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:var(--blue-bg);color:var(--blue-text);font-weight:600;font-size:.8rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px}.form-grid input,.form-grid select,.form-grid textarea{padding:10px 12px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--input-bg)}.primary-button{padding:10px 16px;border-radius:12px;border:none;background:var(--accent);color:#fff;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s}.primary-button:hover:not(:disabled){background:var(--accent-hover)}.primary-button:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}.primary-button:disabled{background:var(--text-dimmed);cursor:not-allowed}.secondary-button{padding:10px 16px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--bg-surface);font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,box-shadow .15s}.secondary-button:hover{background:var(--bg-surface-hover);border-color:var(--text-dimmed)}.secondary-button:focus-visible{outline:none;box-shadow:0 0 0 3px #64748b4d}.highlight-button.active{border-color:var(--red);background:var(--red);color:#fff}.muted{color:var(--text-muted);font-size:.9rem}.about-license{white-space:pre-wrap;background:var(--bg-surface-secondary);border-radius:16px;padding:16px;border:1px solid var(--border-primary);max-height:260px;overflow:auto;font-size:.85rem}.teacher-badge{background:var(--teacher-badge-bg);color:var(--teacher-badge-text);padding:6px 12px;border-radius:999px;font-size:.85rem;font-weight:600}.head-badge{background:var(--head-badge-bg);color:var(--head-badge-text);padding:6px 12px;border-radius:999px;font-size:.85rem;font-weight:600}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap;margin:20px 0}.empty-state{padding:12px;border-radius:12px;background:var(--bg-surface-hover);color:var(--text-secondary);font-weight:600}.empty-state.warning{background:var(--yellow-bg);color:var(--yellow-text)}.empty-state.error{background:var(--red-bg);color:var(--red-text)}.auth-grid{display:grid;gap:16px}@media(min-width:768px){.auth-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.auth-card{border:1px solid var(--border-primary);border-radius:16px;padding:16px;display:grid;gap:12px;background:var(--bg-inset)}.auth-form{display:grid;gap:12px}.auth-message{padding:10px 14px;border-radius:12px;font-weight:600;font-size:.9rem}.auth-message.error{background:var(--red-bg);color:var(--red-text);border:1px solid var(--red-border)}.auth-message.success{background:var(--success-bg);color:var(--success-text);border:1px solid var(--success-border)}.auth-form input{padding:10px 12px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--input-bg);transition:border-color .15s,box-shadow .15s}.auth-form input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px #3b82f61a}.messenger-panel{padding:0!important;overflow:hidden;height:calc(100dvh - 100px);display:flex;flex-direction:column}.messenger-container{display:flex;height:100%;background:var(--bg-surface)}.messenger-sidebar{width:320px;min-height:0;border-right:1px solid var(--border-primary);display:flex;flex-direction:column;background:var(--bg-inset)}.messenger-sidebar-header{padding:16px;border-bottom:1px solid var(--border-primary);font-weight:700;font-size:1.1rem;background:var(--bg-surface)}.messenger-chat-list{flex:1;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:4px}.messenger-chat-item{padding:12px;border-radius:12px;cursor:pointer;transition:background .2s;display:flex;flex-direction:column;gap:4px;border:1px solid transparent}.messenger-chat-item:hover{background:var(--accent-light)}.messenger-chat-item.active{background:var(--accent-light);border-color:var(--accent-border)}.messenger-chat-item strong{color:var(--text-primary);font-size:.95rem}.messenger-chat-item .last-message{color:var(--text-secondary);font-size:.85rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.messenger-main{flex:1;display:flex;flex-direction:column;background:var(--bg-surface);position:relative}.messenger-header{padding:16px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;background:var(--bg-surface);z-index:10}.messenger-header-title{font-weight:700;font-size:1.1rem;color:var(--text-primary)}.messenger-messages{flex:1;padding:20px;overflow-y:auto;display:flex;flex-direction:column;gap:12px;background:var(--chat-bg)}.messenger-message{max-width:70%;padding:10px 16px;border-radius:18px;font-size:.95rem;line-height:1.5;position:relative;box-shadow:0 1px 2px #0000000d}.messenger-message.mine{align-self:flex-end;background:var(--msg-mine-bg);color:var(--msg-mine-text);border-bottom-right-radius:4px}.messenger-message.theirs{align-self:flex-start;background:var(--chat-theirs-bg);color:var(--chat-theirs-text);border:1px solid var(--chat-theirs-border);border-bottom-left-radius:4px}.messenger-message-time{font-size:.75rem;margin-top:4px;opacity:.7;text-align:right}.messenger-message.mine .messenger-message-time{color:#ffffffd9}.messenger-message.theirs .messenger-message-time{color:var(--text-secondary)}.messenger-input-area{padding:16px;border-top:1px solid var(--border-primary);background:var(--bg-surface);display:flex;gap:12px;align-items:flex-end}.messenger-textarea{flex:1;padding:12px;border-radius:12px;border:1px solid var(--input-border);background:var(--bg-inset);resize:none;font-family:inherit;font-size:.95rem;outline:none;max-height:120px;transition:border-color .2s,box-shadow .2s}.messenger-textarea:focus{border-color:var(--border-focus);background:var(--bg-surface);box-shadow:0 0 0 3px #3b82f61a}.messenger-send-btn{padding:12px 20px;border-radius:12px;background:var(--blue);color:#fff;border:none;font-weight:600;cursor:pointer;transition:background .2s;height:46px}.messenger-send-btn:hover:not(:disabled){background:var(--blue-hover)}.messenger-send-btn:disabled{background:var(--text-dimmed);cursor:not-allowed}.messenger-empty{flex:1;display:flex;align-items:center;justify-content:center;color:var(--text-dimmed);font-size:1.1rem;background:var(--chat-bg)}.messenger-back-btn{display:none;align-items:center;gap:4px;padding:6px 10px;font-size:.8rem}@media(max-width:768px){.topbar{padding:8px 12px;gap:10px}.topbar .brand{font-size:.9rem}.topbar .muted{display:none}.messenger-container{flex-direction:column}.messenger-sidebar{width:100%;flex:1;min-height:0;display:flex}.messenger-sidebar.hidden-mobile{display:none}.messenger-main{width:100%;flex:1;min-height:0;display:flex}.messenger-main.hidden-mobile{display:none}.messenger-back-btn{display:flex}.messenger-panel{height:calc(100dvh - 50px);margin:-24px;border-radius:0}}.chat-form textarea{padding:10px 12px;border-radius:12px;border:1px solid var(--border-secondary);background:var(--input-bg);resize:vertical}.agreement-backdrop{position:fixed;inset:0;background:var(--overlay-heavy);display:flex;align-items:center;justify-content:center;padding:24px;z-index:50}.update-backdrop{position:fixed;inset:0;background:#0f172aa6;display:flex;align-items:center;justify-content:center;padding:24px;z-index:60}.agreement-modal{width:min(90vw,760px);max-height:85vh;background:var(--bg-surface);border-radius:20px;padding:20px;box-shadow:var(--shadow-modal);display:flex;flex-direction:column;gap:16px}.update-modal{width:min(90vw,520px);background:var(--bg-surface);border-radius:20px;padding:20px;box-shadow:var(--shadow-modal);display:flex;flex-direction:column;gap:16px}.agreement-title,.update-title{font-weight:700;font-size:1.1rem}.agreement-body{background:var(--bg-surface-secondary);border:1px solid var(--border-primary);border-radius:16px;padding:16px;overflow:auto;font-size:.82rem;line-height:1.55}.update-body{background:var(--bg-surface-secondary);border:1px solid var(--border-primary);border-radius:16px;padding:16px;display:grid;gap:8px}.agreement-meta{text-align:center;display:grid;gap:4px;margin-bottom:12px}.agreement-subtitle{font-weight:600}.agreement-date{color:var(--text-muted);font-size:.78rem}.agreement-paragraph{margin:0 0 10px}.agreement-section{display:grid;gap:6px;margin-bottom:10px}.agreement-section-title{font-weight:700}.agreement-item{margin:0}.agreement-subitem{padding-left:16px;color:var(--text-secondary)}.agreement-contact{display:grid;gap:4px;color:var(--text-secondary)}.agreement-actions,.update-actions{display:flex;justify-content:flex-end}.dev-row{display:flex;align-items:center;gap:8px;padding:6px 0}.tg-link{display:inline-flex;align-items:center;gap:6px;background:var(--tg-bg);color:var(--tg-text);padding:8px 14px;border-radius:999px;font-size:.85rem;font-weight:600;text-decoration:none;transition:background .15s;min-height:44px}.tg-link:hover{background:var(--tg-hover)}.sponsor-banner{max-width:min(100%,600px);height:auto;border-radius:12px}.about-panel{max-width:700px}.about-section{display:flex;flex-direction:column;gap:8px}.about-footer{display:flex;flex-wrap:wrap;gap:16px;padding-top:8px;border-top:1px solid var(--border-primary)}.discipline-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-top:8px}.discipline-row input,.discipline-row select{padding:8px 10px;border-radius:10px;border:1px solid var(--border-secondary);background:var(--input-bg);flex:1;min-width:120px}.skeleton-list{display:flex;flex-direction:column;gap:12px}.skeleton-block{height:72px;border-radius:14px;background:linear-gradient(90deg,var(--skeleton-from) 25%,var(--skeleton-mid) 50%,var(--skeleton-from) 75%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite}.skeleton-block.short{height:48px}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.admin-panel-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0}.admin-panel-header:hover{opacity:.8}.admin-chevron{font-size:1.2rem;transition:transform .2s;color:var(--text-secondary)}.admin-chevron.open{transform:rotate(180deg)}.generate-btn{padding:12px 20px;border-radius:12px;border:none;background:var(--green);color:#fff;font-weight:700;cursor:pointer;font-size:.95rem}.generate-btn:disabled{background:var(--text-dimmed);cursor:not-allowed}.download-week-btn{width:100%;padding:12px 20px;margin-bottom:16px;border:none;border-radius:12px;background:var(--green-btn);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer}.download-excel-btn{width:100%;padding:12px 20px;margin-bottom:16px;border:none;border-radius:12px;background:var(--green-excel);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;transition:background .2s ease}.download-excel-btn:hover{background:var(--green-excel-hover)}.download-excel-btn:disabled{background:var(--text-dimmed);cursor:not-allowed}.download-week-btn:disabled{background:var(--text-dimmed);cursor:not-allowed}.teacher-search-bar{padding:10px 24px 12px;background:var(--bg-surface);border-bottom:1px solid var(--border-primary)}.teacher-search-toggle{display:flex;align-items:center;gap:8px;width:100%;padding:8px 0;border:none;background:none;cursor:pointer;font-size:.9rem;font-weight:600;color:var(--text-secondary)}.teacher-search-toggle:hover{color:var(--text-link)}.search-chevron{margin-left:auto;font-size:.8rem;transition:transform .2s;color:var(--text-dimmed)}.search-chevron.open{transform:rotate(180deg)}.teacher-search-input-wrap{display:flex;gap:8px}.teacher-search-input{flex:1;padding:10px 14px;border:1px solid var(--border-secondary);border-radius:12px;font-size:.95rem;outline:none;transition:border-color .15s;background:var(--input-bg)}.teacher-search-input:focus{border-color:var(--border-focus)}.teacher-search-btn{padding:10px 20px;border:none;border-radius:12px;background:var(--blue);color:#fff;font-weight:600;font-size:.95rem;cursor:pointer;white-space:nowrap}.teacher-search-btn:disabled{background:var(--text-dimmed);cursor:not-allowed}.teacher-search-results{display:grid;gap:8px;margin-top:10px}.teacher-search-result-item{border:1px solid var(--border-primary);border-radius:14px;padding:12px 16px;display:grid;gap:4px;background:var(--bg-inset)}.teacher-search-empty{margin-top:8px;padding:10px 14px;color:var(--text-secondary);font-size:.9rem}.groups-mobile-back{display:none}.groups-sidebar-title{margin:0}@media(max-width:1023px){.groups-mobile-back{display:flex;align-items:center;gap:12px;padding-bottom:8px}.groups-mobile-back button{display:flex;align-items:center;gap:4px;font-size:.85rem;padding:6px 12px}.groups-sidebar.has-selection .groups-sidebar-title,.groups-sidebar.has-selection .admin-bulk-actions,.groups-grid.mobile-hidden{display:none}}.groups-view-layout{display:flex;flex-direction:column;gap:24px}.groups-sidebar{background:var(--bg-surface);border-radius:20px;padding:20px;box-shadow:var(--shadow-card);display:flex;flex-direction:column;gap:16px}.groups-main-area{display:flex;flex-direction:column;gap:24px}@media(min-width:1024px){.groups-view-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:24px;align-items:start}.groups-sidebar{position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto}.groups-sidebar .groups-grid{grid-template-columns:1fr}}.teacher-autocomplete-dropdown{position:absolute;top:100%;left:0;right:0;max-height:200px;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border-secondary);border-radius:10px;box-shadow:0 4px 12px #00000014;z-index:50;margin-top:4px}.teacher-autocomplete-item{padding:10px 14px;cursor:pointer;font-size:.9rem;border-bottom:1px solid var(--bg-surface-hover)}.teacher-autocomplete-item:last-child{border-bottom:none}.teacher-autocomplete-item:hover{background:var(--autocomplete-hover);color:var(--text-link)}.tutorial-overlay{position:fixed;inset:0;z-index:9999;pointer-events:auto}.tutorial-spotlight{position:fixed;z-index:10000;border-radius:12px;box-shadow:0 0 0 9999px #0009;transition:left .3s ease,top .3s ease,width .3s ease,height .3s ease;pointer-events:none}.tutorial-spotlight-clickable{pointer-events:auto;cursor:pointer}.tutorial-tooltip{position:fixed;z-index:10001;background:var(--bg-surface);border-radius:16px;padding:20px;max-width:340px;width:calc(100vw - 32px);box-shadow:0 8px 32px #0003;animation:tutorial-fade-in .25s ease}.tutorial-tooltip-center{top:50%;left:50%;transform:translate(-50%,-50%)}@keyframes tutorial-fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.tutorial-tooltip-center{animation-name:tutorial-fade-in-center}@keyframes tutorial-fade-in-center{0%{opacity:0;transform:translate(-50%,-50%) scale(.95)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.tutorial-progress{font-size:.75rem;color:var(--text-dimmed);margin-bottom:8px;font-weight:600;letter-spacing:.05em}.tutorial-content{font-size:.95rem;line-height:1.55;color:var(--text-primary);margin-bottom:16px}.tutorial-actions{display:flex;justify-content:space-between;align-items:center;gap:12px}.tutorial-btn{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 24px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.tutorial-btn:hover{background:var(--accent-hover)}.tutorial-skip-btn{background:none;border:none;color:var(--text-dimmed);font-size:.85rem;cursor:pointer;padding:8px 12px;border-radius:8px;transition:color .15s,background .15s}.tutorial-skip-btn:hover{color:var(--text-secondary);background:var(--bg-surface-hover)}.tutorial-hint{margin-top:12px;padding-top:12px;border-top:1px solid var(--bg-surface-hover);font-size:.8rem;color:var(--accent);font-weight:500;display:flex;align-items:center;gap:6px}.tutorial-hint:before{content:"";display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);animation:tutorial-pulse 1.5s ease infinite}@keyframes tutorial-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}.theme-toggle{width:44px;height:24px;border-radius:999px;border:1px solid var(--border-secondary);background:var(--bg-surface-secondary);cursor:pointer;position:relative;padding:0;flex-shrink:0;transition:background .2s,border-color .2s}.theme-toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:var(--accent);transition:transform .2s}[data-theme=dark] .theme-toggle:after{transform:translate(20px)}.theme-toggle-icon{position:absolute;top:50%;transform:translateY(-50%);width:14px;height:14px;pointer-events:none}.theme-toggle-sun{left:4px;color:#f59e0b}.theme-toggle-moon{right:4px;color:#60a5fa}.favorite-star{position:absolute;top:6px;right:6px;background:none;border:none;cursor:pointer;font-size:1.3rem;color:var(--text-dimmed);padding:2px 4px;line-height:1;transition:color .15s,transform .15s;z-index:1}.favorite-star:hover{transform:scale(1.2);color:#f59e0b}.favorite-star.active{color:#f59e0b}.group-card{position:relative}.groups-divider{grid-column:1 / -1;text-align:center;font-size:.8rem;font-weight:600;color:var(--text-muted);padding:6px 0 2px;border-top:1px solid var(--border-primary);margin-top:4px;letter-spacing:.03em;text-transform:uppercase}
