:root{--theme-speed: .4s;--radius-xs: 6px;--radius-sm: 10px;--radius: 16px;--radius-lg: 20px;--radius-xl: 24px;--radius-full: 50px;--font: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;--font-display: "Inter", sans-serif;--accent: #7C5CFF;--accent-hover: #6B4FE0;--accent-light: rgba(124, 92, 255, .12);--accent-glow: rgba(124, 92, 255, .2);--accent-2: #A78BFA;--success: #10B981;--success-light: rgba(16, 185, 129, .1);--warning: #F59E0B;--warning-light: rgba(245, 158, 11, .1);--danger: #EF4444;--danger-light: rgba(239, 68, 68, .1);--info: #3B82F6;--info-light: rgba(59, 130, 246, .1)}[data-theme=dark]{--bg: #0C0C10;--bg-elevated: #111116;--surface: #18181F;--surface-2: #22222C;--surface-3: #2C2C38;--surface-hover: #262632;--border: #2A2A36;--border-subtle: #1F1F2A;--border-focus: var(--accent);--text: #F0F0F5;--text-2: #A0A0B5;--text-3: #6B6B80;--text-inverse: #111116;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow: 0 4px 12px rgba(0, 0, 0, .25);--shadow-md: 0 8px 24px rgba(0, 0, 0, .3);--shadow-lg: 0 16px 48px rgba(0, 0, 0, .4);--header-bg: rgba(12, 12, 16, .85);--header-border: var(--border);--modal-backdrop: rgba(0, 0, 0, .7);--toast-bg: var(--surface-2);--cover-1: linear-gradient(135deg, #1e1b4b, #312e81);--cover-2: linear-gradient(135deg, #0c4a6e, #075985);--cover-3: linear-gradient(135deg, #064e3b, #065f46);--cover-4: linear-gradient(135deg, #4a1d96, #5b21b6);--cover-5: linear-gradient(135deg, #78350f, #92400e);--cover-6: linear-gradient(135deg, #155e75, #164e63);--cover-7: linear-gradient(135deg, #7f1d1d, #991b1b);--cover-8: linear-gradient(135deg, #1e3a5f, #1e40af);--cover-admin: linear-gradient(135deg, #1a1040, #2d1b69);--dash-bg: #0C0C10;--dash-surface: #111116;--text-1: var(--text);--dash-border: rgba(255, 255, 255, .08)}[data-theme=light]{--bg: #F5F6FA;--bg-elevated: #FFFFFF;--surface: #FFFFFF;--surface-2: #F0F1F5;--surface-3: #E5E7ED;--surface-hover: #F8F8FC;--border: #E2E4EA;--border-subtle: #EEEFF3;--border-focus: var(--accent);--text: #111827;--text-2: #6B7280;--text-3: #9CA3AF;--text-inverse: #FFFFFF;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .04);--shadow: 0 2px 8px rgba(0, 0, 0, .06);--shadow-md: 0 4px 16px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .1);--header-bg: rgba(255, 255, 255, .85);--header-border: var(--border);--modal-backdrop: rgba(0, 0, 0, .3);--toast-bg: #1F2937;--cover-1: linear-gradient(135deg, #DBEAFE, #C7D2FE);--cover-2: linear-gradient(135deg, #E0F2FE, #BAE6FD);--cover-3: linear-gradient(135deg, #D1FAE5, #A7F3D0);--cover-4: linear-gradient(135deg, #EDE9FE, #DDD6FE);--cover-5: linear-gradient(135deg, #FEF3C7, #FDE68A);--cover-6: linear-gradient(135deg, #CFFAFE, #A5F3FC);--cover-7: linear-gradient(135deg, #FCE7F3, #FBCFE8);--cover-8: linear-gradient(135deg, #DBEAFE, #BFDBFE);--cover-admin: linear-gradient(135deg, #EEF2FF, #E0E7FF);--dash-bg: #F5F6FA;--dash-surface: #FFFFFF;--text-1: var(--text);--dash-border: rgba(0, 0, 0, .08)}*{margin:0;padding:0;box-sizing:border-box}html{scroll-behavior:smooth}body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;overflow-x:hidden;transition:background-color var(--theme-speed) ease,color var(--theme-speed) ease}*,*:before,*:after{transition:background-color var(--theme-speed) ease,border-color var(--theme-speed) ease,color var(--theme-speed) ease,box-shadow var(--theme-speed) ease,fill var(--theme-speed) ease,stroke var(--theme-speed) ease}.no-theme-transition,.no-theme-transition *,input,textarea{transition:none!important}h1,h2,h3,h4,h5{color:var(--text);font-weight:700;line-height:1.2}a{color:var(--accent);text-decoration:none;transition:color .2s,opacity .2s}a:hover{opacity:.85}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-3)}.material-symbols-outlined{font-family:Material Symbols Outlined;font-weight:400;font-style:normal;font-size:24px;line-height:1;letter-spacing:normal;text-transform:none;display:inline-block;white-space:nowrap;word-wrap:normal;direction:ltr;-webkit-font-feature-settings:"liga";font-feature-settings:"liga";-webkit-font-smoothing:antialiased}.container{max-width:1200px;margin:0 auto;padding:0 24px}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0)}.text-muted{color:var(--text-2)}.text-faded{color:var(--text-3)}.text-accent{color:var(--accent)}.text-success{color:var(--success)}.gradient-text{background:linear-gradient(135deg,var(--accent),var(--accent-2),var(--info));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 18px;border-radius:var(--radius-sm);font-family:var(--font);font-weight:700;font-size:.85rem;cursor:pointer;border:none;white-space:nowrap;transition:all .2s ease}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover);transform:translateY(-1px)}.btn-secondary{background:var(--surface-2);color:var(--text-2);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-ghost{background:transparent;color:var(--text-2)}.btn-ghost:hover{background:var(--surface-2);color:var(--text)}.btn-danger{background:var(--danger-light);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-success{background:var(--success-light);color:var(--success)}.btn-sm{padding:5px 12px;font-size:.78rem}.btn-lg{padding:12px 28px;font-size:.95rem}.btn-round{border-radius:var(--radius-full)}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--radius-sm)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-xs);font-size:.72rem;font-weight:700;letter-spacing:.3px}.badge-accent{background:var(--accent-light);color:var(--accent)}.badge-success{background:var(--success-light);color:var(--success)}.badge-warning{background:var(--warning-light);color:var(--warning)}.badge-danger{background:var(--danger-light);color:var(--danger)}.badge-info{background:var(--info-light);color:var(--info)}.badge-pill{border-radius:var(--radius-full)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.card:hover{box-shadow:var(--shadow)}.input-field{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--text);font-family:var(--font);font-size:.9rem;outline:none;transition:border-color .2s,box-shadow .2s}.input-field:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.input-field::placeholder{color:var(--text-3)}textarea.input-field{resize:vertical;min-height:80px}select.input-field{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%239CA3AF' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.input-group{margin-bottom:16px}.input-label{display:block;font-size:.8rem;font-weight:600;color:var(--text-2);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}@keyframes slideInLeft{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes ripple{0%{transform:scale(0);opacity:.5}to{transform:scale(4);opacity:0}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.anim-fade-in{animation:fadeIn .3s ease}.anim-fade-in-up{animation:fadeInUp .4s ease}.anim-scale-in{animation:scaleIn .3s ease}.stagger>*{opacity:0;animation:fadeInUp .35s ease forwards}.stagger>*:nth-child(1){animation-delay:.05s}.stagger>*:nth-child(2){animation-delay:.1s}.stagger>*:nth-child(3){animation-delay:.15s}.stagger>*:nth-child(4){animation-delay:.2s}.stagger>*:nth-child(5){animation-delay:.25s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(7){animation-delay:.35s}.stagger>*:nth-child(8){animation-delay:.4s}.stagger>*:nth-child(9){animation-delay:.45s}.stagger>*:nth-child(10){animation-delay:.5s}.theme-toggle{width:52px;height:28px;border-radius:14px;background:var(--surface-3);border:1px solid var(--border);cursor:pointer;position:relative;display:flex;align-items:center;padding:0 4px;transition:background-color .3s ease}.theme-toggle .toggle-track{width:100%;display:flex;justify-content:space-between;align-items:center;padding:0 2px;font-size:.7rem}.theme-toggle .toggle-thumb{position:absolute;width:22px;height:22px;border-radius:50%;background:var(--accent);top:2px;left:2px;transition:transform .35s cubic-bezier(.68,-.55,.265,1.55);box-shadow:0 2px 6px #7c5cff4d}[data-theme=light] .theme-toggle .toggle-thumb{transform:translate(24px)}[data-theme=light] .theme-toggle{background:var(--accent-light);border-color:var(--accent)}.app-header{position:sticky;top:0;z-index:100;padding:0 24px;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:var(--header-bg);border-bottom:1px solid var(--header-border)}.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;height:56px}.logo{display:flex;align-items:center;gap:10px;text-decoration:none;color:var(--text);cursor:pointer}.logo:hover{opacity:1}.logo-icon{width:34px;height:34px;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent-2));display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:0 2px 8px var(--accent-glow)}.logo-text{font-weight:800;font-size:1.1rem;letter-spacing:-.5px}.header-nav{display:flex;gap:2px;align-items:center}.nav-link{padding:7px 14px;border-radius:var(--radius-sm);font-weight:600;font-size:.85rem;color:var(--text-2);cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:5px;text-decoration:none;position:relative}.nav-link:hover{color:var(--text);background:var(--surface-2);opacity:1}.nav-link.active{color:var(--accent);background:var(--accent-light)}.nav-link .material-icons-outlined{font-size:1.1rem}.nav-link .nav-badge{position:absolute;top:2px;right:2px;width:8px;height:8px;background:var(--danger);border-radius:50%;border:2px solid var(--bg)}.header-actions{display:flex;align-items:center;gap:12px}.burger-btn{display:none;background:none;border:none;color:var(--text);cursor:pointer;width:40px;height:40px;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .2s}.burger-btn:hover{background:var(--surface-2)}.header-menu{display:flex;align-items:center;gap:32px}.lang-selector{position:relative;z-index:10;display:flex;align-items:center}.lang-btn{display:flex;align-items:center;gap:8px;background:var(--surface-2);border:1px solid var(--border);padding:6px 12px;border-radius:var(--radius-sm);color:var(--text-2);font-family:var(--font);font-weight:700;font-size:.8rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.lang-btn:hover{border-color:var(--accent);color:var(--text);background:var(--surface-hover)}.lang-flag-img{width:18px;height:13.5px;object-fit:contain;border-radius:2px}.lang-code{letter-spacing:.5px}.dropdown-icon{font-size:16px!important;color:var(--text-3);transition:transform .2s ease}.lang-selector:has(.lang-dropdown.show) .dropdown-icon{transform:rotate(180deg)}.lang-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);min-width:150px;padding:6px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all .2s cubic-bezier(.165,.84,.44,1);display:flex;flex-direction:column;gap:2px}.lang-dropdown.show{opacity:1;visibility:visible;transform:translateY(0)}.lang-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border-radius:var(--radius-xs);cursor:pointer;color:var(--text-2);font-size:.85rem;font-weight:600;transition:all .2s ease}.lang-item:hover{background:var(--surface-2);color:var(--text)}.lang-item.active{background:var(--accent-light);color:var(--accent)}.active-check{margin-left:auto;font-size:1rem!important}.app-footer{padding:24px;text-align:center;color:var(--text-3);font-size:.82rem;border-top:1px solid var(--border);margin-top:40px}.app-footer a{color:var(--accent);font-weight:600}.footer-links{display:flex;gap:16px;justify-content:center;margin-bottom:6px}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:1000;display:flex;flex-direction:column;gap:8px;align-items:center}.toast{background:var(--toast-bg);border:1px solid var(--border);color:var(--text);padding:10px 20px;border-radius:var(--radius);font-weight:600;font-size:.85rem;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;transform:translateY(100px);opacity:0;transition:all .35s cubic-bezier(.16,1,.3,1);pointer-events:none}[data-theme=light] .toast{background:#1f2937;color:#fff;border:none}.toast.show{transform:translateY(0);opacity:1;pointer-events:auto}.toast .material-icons-outlined{font-size:1.1rem}.modal-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--modal-backdrop);z-index:200;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s ease;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-backdrop.open{opacity:1;pointer-events:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:90%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);transform:scale(.95) translateY(10px);transition:transform .35s cubic-bezier(.16,1,.3,1)}.modal-backdrop.open .modal{transform:scale(1) translateY(0)}.slide-panel-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:var(--modal-backdrop);z-index:200;opacity:0;pointer-events:none;transition:opacity .3s ease}.slide-panel-backdrop.open{opacity:1;pointer-events:auto}.slide-panel{position:fixed;top:0;right:0;width:460px;max-width:100%;height:100%;background:var(--surface);border-left:1px solid var(--border);z-index:201;overflow-y:auto;box-shadow:var(--shadow-lg);transform:translate(100%);transition:transform .4s cubic-bezier(.16,1,.3,1)}.slide-panel.open{transform:translate(0)}.page{display:none;animation:fadeInUp .35s ease}.page.active{display:block}@media(max-width:768px){.container{padding:0 16px}.logo,.burger-btn{position:relative;z-index:101}.burger-btn{display:flex}.header-menu{position:fixed;inset:0;height:100vh;height:100dvh;background:var(--surface);flex-direction:column;padding:80px 24px 40px;gap:32px;z-index:100;transform:translateY(-100%);transition:transform .5s cubic-bezier(.16,1,.3,1);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);align-items:center;justify-content:center;overflow-y:auto}.header-menu.open{transform:translateY(0)}.header-nav{flex-direction:column;align-items:center;width:auto;gap:16px}.header-actions{flex-direction:column;width:auto;gap:20px;align-items:center}.theme-toggle{width:60px;height:32px;justify-content:center}.lang-selector{width:auto;justify-content:center}.lang-btn{width:auto;justify-content:center;height:40px;padding:0 20px}.btn-teach{width:auto;height:48px;padding:0 24px}.user-menu{width:auto;justify-content:center}.user-avatar-sm{width:48px;height:48px}.slide-panel{width:100%}h1{font-size:1.8rem!important}}@media(max-width:480px){.logo-text{font-size:.95rem}.logo-icon{width:30px;height:30px;font-size:.85rem}}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#0c0c10;color:#f0f0f5;padding:24px;text-align:center}.error-container{max-width:600px;width:100%}.error-icon{font-size:3rem;color:var(--danger);margin-bottom:24px}.error-details{text-align:left;margin-top:24px;padding:16px;background:#18181f;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--danger);overflow:auto;max-height:300px;font-size:.8rem;font-family:monospace}.error-message{font-size:1.1rem;margin-bottom:24px;color:var(--text-2)}.error-actions{display:flex;gap:12px;justify-content:center;margin-top:32px}.hero{padding:60px 0 0;text-align:center;position:relative;overflow:hidden}.hero:before{content:"";position:absolute;top:-60%;left:50%;transform:translate(-50%);width:800px;height:800px;background:radial-gradient(circle,var(--accent-glow) 0%,transparent 70%);pointer-events:none;z-index:0}.hero-content{position:relative;z-index:1;max-width:640px;margin:0 auto}.hero-badge{margin-bottom:16px}.hero-title{font-size:3rem;font-weight:900;letter-spacing:-1.5px;line-height:1.1;margin-bottom:14px}.hero-subtitle{font-size:1.05rem;color:var(--text-2);line-height:1.5;margin-bottom:28px;max-width:480px;margin-left:auto;margin-right:auto}.hero-search-wrapper{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 auto 20px;max-width:600px;padding:0 20px}.hero-search{flex:1;display:flex;align-items:center;gap:10px;background:var(--surface);border:1.5px solid var(--border);border-radius:var(--radius);padding:6px 8px 6px 14px;box-shadow:var(--shadow-md);transition:border-color .2s,box-shadow .2s}.filter-trigger-btn{width:50px;height:50px;display:flex;align-items:center;justify-content:center;position:relative;border-radius:var(--radius);background:var(--surface);border:1.5px solid var(--border);color:var(--text-2);transition:all .2s;flex-shrink:0}.filter-trigger-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.filter-trigger-btn.has-active{border-color:var(--accent);background:var(--accent-light);color:var(--accent)}.filter-badge{position:absolute;top:-5px;right:-5px;background:var(--accent);color:#fff;font-size:.65rem;font-weight:800;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 2px 4px #0003}.search-submit-btn{padding:6px 16px;font-size:.8rem}.hero-search:focus-within{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-light),var(--shadow-md)}.search-icon{color:var(--text-3);font-size:1.2rem}.search-input{flex:1;border:none;background:transparent;font-family:var(--font);font-size:.95rem;color:var(--text);outline:none;padding:8px 0}.search-input::placeholder{color:var(--text-3)}.search-clear{background:none;border:none;color:var(--text-3);cursor:pointer;padding:4px;border-radius:50%;display:flex}.search-clear:hover{color:var(--text);background:var(--surface-2)}.quick-filters{display:flex;gap:8px;justify-content:flex-start;overflow-x:auto;padding:4px 20px 20px;margin:0 -20px 16px;-ms-overflow-style:none;scrollbar-width:none;cursor:grab;-webkit-user-select:none;user-select:none}.quick-filters.dragging{cursor:grabbing}.quick-filters::-webkit-scrollbar{display:none}.qf-chip{padding:6px 16px;border-radius:var(--radius-full);background:var(--surface);border:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--text-2);cursor:pointer;transition:all .2s ease;white-space:nowrap}.qf-chip:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}.qf-chip.active{background:var(--accent);color:#fff;border-color:var(--accent)}.stats-bar{border-top:1px solid var(--border);border-bottom:1px solid var(--border);background:var(--bg-elevated);padding:16px 0}.stats-inner{display:flex;align-items:center;justify-content:center;gap:36px}.stat-item{text-align:center}.stat-num{display:block;font-size:1.5rem;font-weight:900;color:var(--accent)}.stat-label{font-size:.72rem;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stat-divider{width:1px;height:28px;background:var(--border)}.groups-section{padding:32px 0}.groups-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.toolbar-left{display:flex;align-items:center;gap:10px}.section-title{font-size:1.1rem;font-weight:800}.toolbar-right{display:flex;align-items:center;gap:8px}.view-toggle{display:flex;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}.vt-btn{width:36px;height:32px;display:flex;align-items:center;justify-content:center;border:none;background:none;color:var(--text-3);cursor:pointer;transition:all .15s}.vt-btn:hover{color:var(--text);background:var(--surface-2)}.vt-btn.active{color:var(--accent);background:var(--accent-light)}.btn-map-toggle{display:flex;align-items:center;gap:8px;padding:6px 14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-2);font-weight:700;font-size:.8rem;cursor:pointer;transition:all .2s cubic-bezier(.4,0,.2,1)}.btn-map-toggle:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-light)}.btn-map-toggle.active{background:var(--accent);color:#fff;border-color:var(--accent);box-shadow:0 4px 12px var(--accent-glow)}.btn-map-toggle .material-icons-outlined,.vt-btn .material-icons-outlined{font-size:1.1rem}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.group-card{display:flex;flex-direction:column;background:var(--surface);border:2px solid transparent;border-radius:var(--radius);overflow:hidden;cursor:pointer;transition:all .25s ease;position:relative;text-decoration:none;color:inherit}.group-card.sync-helsinki{border:2px solid #4285f4!important;box-shadow:0 0 20px #4285f433}.group-card.sync-claimed{border:2px solid #a142f4!important;box-shadow:0 0 20px #a142f433}.group-card.dashboard-mode{border-radius:24px}.group-card.dashboard-mode .gc-cover{height:100px;border-radius:20px 20px 0 0}.group-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent)}.group-card.sync-helsinki:hover,.group-card.sync-claimed:hover{border-color:inherit}.gc-cover{height:120px;position:relative;display:flex;align-items:center;justify-content:center;font-size:2.5rem;overflow:hidden}.gc-cover-bg{width:100%;height:100%;display:flex;align-items:center;justify-content:center;transition:transform .35s ease}.group-card:hover .gc-cover-bg{transform:scale(1.05)}.gc-cover-img{width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.gc-avatar{position:absolute;top:88px;right:16px;width:64px;height:64px;border-radius:50%;border:4px solid var(--surface);background:var(--surface-2);overflow:hidden;box-shadow:0 4px 12px #00000026;z-index:5}.gc-avatar img{width:100%;height:100%;object-fit:cover}.gc-avatar-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--surface-2);color:var(--text-3)}.gc-avatar-placeholder .material-icons-outlined{font-size:32px}.gc-badges{position:absolute;top:10px;right:10px;display:flex;gap:5px}.gc-day-badge{padding:3px 10px;border-radius:var(--radius-full);font-size:.7rem;font-weight:700;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#00000059;color:#fff}.gc-day-badge.today{background:#10b981d9}.gc-day-badge.tomorrow{background:#7c5cffd9}.gc-body{padding:14px 16px}.gc-title{font-size:.95rem;font-weight:700;margin-bottom:6px;display:-webkit-box;-webkit-line-clamp:1;line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.gc-org{font-size:.78rem;color:var(--text-3);margin-bottom:10px;display:flex;align-items:center;gap:4px}.gc-meta{display:flex;gap:0;flex-wrap:wrap;margin-bottom:10px}.gc-meta-item{display:flex;align-items:center;gap:3px;font-size:.78rem;color:var(--text-2);padding:3px 8px 3px 0}.gc-meta-item .material-icons-outlined{font-size:.9rem;color:var(--text-3)}.gc-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border)}.gc-tags{display:flex;gap:5px}.gc-tag{padding:2px 8px;border-radius:var(--radius-xs);font-size:.68rem;font-weight:700}.gc-tag-level{background:var(--accent-light);color:var(--accent)}.gc-tag-free{background:var(--success-light);color:var(--success)}.gc-tag-online{background:var(--info-light);color:var(--info)}.gc-actions{display:flex;gap:4px}.gc-action-btn{width:30px;height:30px;border-radius:var(--radius-xs);display:flex;align-items:center;justify-content:center;border:1px solid var(--border);background:none;color:var(--text-3);cursor:pointer;transition:all .15s;font-size:.85rem}.gc-action-btn:hover{border-color:var(--accent);color:var(--accent)}.gc-action-btn.saved{color:var(--warning);border-color:var(--warning);background:var(--warning-light)}.gc-action-btn.cal-added{color:var(--success);border-color:var(--success);background:var(--success-light)}.groups-timeline{display:flex;flex-direction:column;gap:8px}.timeline-row{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 16px;cursor:pointer;transition:all .2s}.timeline-row:hover{border-color:var(--accent);transform:translate(4px);box-shadow:var(--shadow)}.tl-emoji{width:44px;height:44px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.3rem;flex-shrink:0}.tl-info{flex:1;min-width:0}.tl-name{font-weight:700;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tl-sub{font-size:.78rem;color:var(--text-3)}.tl-right{display:flex;align-items:center;gap:10px;flex-shrink:0}.tl-time{font-weight:700;font-size:.82rem;color:var(--accent);text-align:right}.tl-day{font-size:.7rem;color:var(--text-3)}.map-view{min-height:400px}.map-placeholder{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);height:420px;display:flex;flex-direction:column;align-items:center;justify-content:center;position:relative}.map-pins{position:absolute;width:100%;height:100%}.map-pin{position:absolute;display:flex;align-items:center;gap:6px;padding:4px 10px;background:var(--accent);color:#fff;border-radius:var(--radius-full);font-size:.72rem;font-weight:700;cursor:pointer;box-shadow:0 2px 8px #7c5cff4d;transition:transform .2s;animation:float 3s ease-in-out infinite}.map-pin:hover{transform:scale(1.1)}.hiw-section{padding:48px 0;border-top:1px solid var(--border)}.hiw-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}.hiw-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:28px 24px;text-align:center;position:relative;transition:all .25s}.hiw-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md)}.hiw-num{position:absolute;top:12px;left:14px;font-size:.7rem;font-weight:800;color:var(--text-3);background:var(--surface-2);width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center}.hiw-icon{font-size:2rem;margin-bottom:12px}.hiw-card h3{font-size:.95rem;margin-bottom:6px}.hiw-card p{font-size:.82rem;color:var(--text-2);line-height:1.4}.cta-section{padding:0 0 48px}.cta-card{background:linear-gradient(135deg,var(--accent),#9333EA);border-radius:var(--radius-xl);padding:40px 48px;display:flex;align-items:center;justify-content:space-between;gap:24px;color:#fff;position:relative;overflow:hidden}.cta-content h2{font-size:1.5rem;margin-bottom:10px;color:#fff}.cta-content p{font-size:.95rem;opacity:.85;margin-bottom:20px;max-width:400px;line-height:1.5}.cta-card .btn-primary{background:#fff;color:var(--accent)}.cta-card .btn-primary:hover{background:#f0f0f5}.cta-decoration{font-size:5rem;opacity:.3}.faq-list{display:flex;flex-direction:column;gap:8px}.faq-item{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:border-color .2s}.faq-item.open{border-color:var(--accent)}.faq-question{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;cursor:pointer;font-weight:700;font-size:.9rem;transition:color .2s}.faq-question:hover{color:var(--accent)}.faq-chevron{transition:transform .3s ease;color:var(--text-3)}.faq-item.open .faq-chevron{transform:rotate(180deg);color:var(--accent)}.faq-answer{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}.faq-item.open .faq-answer{max-height:300px}.faq-answer-inner{padding:0 18px 16px;font-size:.85rem;color:var(--text-2);line-height:1.6}.side-panel-backdrop{position:fixed;top:0;left:0;width:100%;height:100%;background:#0006;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;transition:all .3s ease}.side-panel-backdrop.open{opacity:1;visibility:visible}.side-panel{position:fixed;top:0;right:-480px;width:480px;height:100%;background:var(--surface);box-shadow:-10px 0 30px #0003;z-index:1001;transition:right .4s cubic-bezier(.16,1,.3,1);overflow-y:auto}.side-panel.open{right:0}.side-panel::-webkit-scrollbar{width:6px}.side-panel::-webkit-scrollbar-thumb{background:var(--border);border-radius:10px}.side-panel-loading,.side-panel-error{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px;text-align:center;color:var(--text-3)}.side-panel-error .material-icons-outlined{font-size:3rem;margin-bottom:12px}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:500px){.side-panel{width:100%;right:-100%}}.gd-cover{height:200px;display:flex;align-items:center;justify-content:center;font-size:4rem;position:relative}.gd-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border-radius:50%;background:#0000004d;border:none;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.gd-close:hover{background:#0009}.gd-body{padding:24px}.gd-title{font-size:1.3rem;font-weight:800;margin-bottom:4px}.gd-org{font-size:.85rem;color:var(--text-2);margin-bottom:16px}.gd-chips{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:18px}.gd-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}.gd-info-item{background:var(--surface-2);padding:12px;border-radius:var(--radius-sm)}.gd-info-label{font-size:.68rem;color:var(--text-3);text-transform:uppercase;font-weight:700;letter-spacing:.4px;margin-bottom:3px}.gd-info-value{font-weight:700;font-size:.88rem;display:flex;align-items:center;gap:4px}.gd-info-value .material-icons-outlined{font-size:1rem;color:var(--accent)}.gd-address{padding:10px 14px;background:var(--surface-2);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text-2);display:flex;align-items:center;gap:8px;margin-bottom:16px}.gd-address .material-icons-outlined{color:var(--accent)}.gd-desc{font-size:.88rem;color:var(--text-2);line-height:1.65;margin-bottom:20px}.gd-upcoming-title{font-size:.9rem;font-weight:700;margin-bottom:10px}.gd-upcoming-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--surface-2);border-radius:var(--radius-sm);margin-bottom:6px;transition:background .15s}.gd-upcoming-item:hover{background:var(--accent-light)}.gd-upcoming-date{font-weight:700;font-size:.82rem;min-width:100px}.gd-upcoming-time{font-size:.78rem;color:var(--text-2);flex:1}.gd-upcoming-add{background:transparent;border:1px solid var(--border);border-radius:var(--radius-xs);padding:3px 10px;cursor:pointer;color:var(--text-3);font-size:.72rem;font-weight:600;font-family:var(--font);transition:all .15s;display:flex;align-items:center;gap:3px}.gd-upcoming-add:hover{border-color:var(--success);color:var(--success)}.gd-upcoming-add.added{border-color:var(--success);color:var(--success);background:var(--success-light)}.gd-actions{display:flex;gap:8px;margin-top:24px}.gd-actions .btn{flex:1}.gd-container{padding-bottom:40px}.gd-emoji{font-size:4rem;filter:drop-shadow(0 4px 8px rgba(0,0,0,.2))}.gd-cover-img{width:100%;height:100%;object-fit:cover;opacity:.9}.gd-upcoming-list{margin-bottom:20px}.gd-upcoming-item.cancelled{opacity:.6;background:var(--surface-3);text-decoration:line-through}.badge-outline{background:transparent;border:1px solid var(--border);color:var(--text-2)}.no-sessions{padding:20px 0;color:var(--text-3);font-size:.85rem;font-style:italic}.dash-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.dash-title{font-size:1.4rem;font-weight:800}.dash-tabs{display:flex;gap:4px;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border);overflow-x:auto}.dash-tab{padding:8px 16px;font-size:.85rem;font-weight:600;border-radius:var(--radius-sm);border:none;background:none;color:var(--text-3);cursor:pointer;transition:all .2s;white-space:nowrap;font-family:var(--font);display:flex;align-items:center;gap:5px}.dash-tab:hover{color:var(--text);background:var(--surface-2)}.dash-tab.active{color:var(--accent);background:var(--accent-light)}.dash-tab .material-icons-outlined{font-size:1rem}.dash-tab .tab-count{font-size:.65rem;background:var(--accent);color:#fff;padding:1px 6px;border-radius:var(--radius-full)}.dash-stats{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;margin-bottom:24px}.dash-stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;text-align:center}.dash-stat-value{font-size:2rem;font-weight:900;color:var(--accent);display:block;margin-bottom:4px}.dash-stat-label{font-size:.78rem;color:var(--text-3);text-transform:uppercase;font-weight:600;letter-spacing:.3px}.dash-table{width:100%;border-collapse:collapse;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.dash-table th{padding:10px 14px;text-align:left;font-size:.72rem;font-weight:700;color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;background:var(--surface-2);border-bottom:1px solid var(--border)}.dash-table td{padding:10px 14px;font-size:.85rem;border-bottom:1px solid var(--border)}.dash-table tr:last-child td{border-bottom:none}.dash-table tr:hover td{background:var(--surface-hover)}.member-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;transition:border-color .2s}.member-row:hover{border-color:var(--accent)}.member-avatar{width:40px;height:40px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.85rem;flex-shrink:0;background:var(--accent-light);color:var(--accent)}.member-info{flex:1}.member-name{font-weight:700;font-size:.88rem}.member-email{font-size:.78rem;color:var(--text-3)}.member-actions{display:flex;gap:6px}.session-row{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;transition:all .2s}.session-row:hover{border-color:var(--accent)}.sr-emoji{width:40px;height:40px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1.2rem;flex-shrink:0}.sr-info{flex:1}.sr-name{font-weight:700;font-size:.88rem}.sr-sub{font-size:.78rem;color:var(--text-3)}.sr-actions{display:flex;gap:6px}.user-menu{position:relative;display:flex;align-items:center}.user-avatar-sm{width:34px;height:34px;border-radius:50%;background:var(--accent);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s}.user-avatar-sm:hover{transform:scale(1.05);box-shadow:0 0 0 3px var(--accent-light)}.user-initials-sm{color:#fff;font-weight:800;font-size:.75rem}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);min-width:200px;box-shadow:var(--shadow-lg);display:none;z-index:50;animation:fadeInDown .2s ease}.user-dropdown.show{display:block}.ud-header{padding:14px 16px 10px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}.ud-header .user-name{font-weight:700;font-size:.9rem}.ud-item{display:flex;align-items:center;gap:8px;padding:10px 16px;cursor:pointer;font-size:.85rem;font-weight:600;color:var(--text-2);transition:all .15s}.ud-item:hover{background:var(--surface-2);color:var(--text)}.ud-item .material-icons-outlined{font-size:1.1rem}.creator-form .input-group{margin-bottom:14px}.creator-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.creator-actions{display:flex;gap:8px;margin-top:8px}.creator-actions .btn{flex:1}@media(max-width:768px){.hero-title{font-size:2.2rem}.hero{padding:40px 0 0}.stats-inner{gap:16px;flex-wrap:wrap}.stat-num{font-size:1.2rem}.stat-divider{display:none}.groups-grid,.hiw-grid{grid-template-columns:1fr}.cta-card{flex-direction:column;text-align:center;padding:32px 24px}.cta-decoration{display:none}.groups-toolbar{flex-direction:column;align-items:flex-start}.gd-info-grid{grid-template-columns:1fr}.dash-stats{grid-template-columns:1fr 1fr}}@media(max-width:480px){.hero-title{font-size:1.8rem}.hero-subtitle{font-size:.95rem;padding:0 10px}.hero-search-wrapper{flex-direction:column;gap:10px;padding:0 16px}.hero-search{width:100%}.filter-trigger-btn{width:100%;height:44px;border-radius:var(--radius-sm)}.stats-inner{display:grid;grid-template-columns:1fr 1fr;gap:12px}.timeline-row{flex-direction:column;align-items:flex-start;gap:10px}.tl-right{width:100%;justify-content:space-between;border-top:1px solid var(--border-subtle);padding-top:8px}.tl-time{text-align:left}.gd-body{padding:16px}.gd-title{font-size:1.15rem}.cta-content h2{font-size:1.3rem}}.signup-wizard{padding:0}.wizard-progress{display:flex;align-items:center;justify-content:center;margin-bottom:32px;gap:8px}.progress-step{width:28px;height:28px;border-radius:50%;background:var(--bg-3);color:var(--text-3);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;transition:all .3s ease}.progress-step.active{background:var(--accent);color:#fff;box-shadow:0 0 0 4px rgba(var(--accent-rgb),.15)}.progress-line{flex:1;max-width:40px;height:2px;background:var(--border)}.step-title{font-size:1.4rem;margin-bottom:8px;text-align:center}.step-desc{color:var(--text-3);font-size:.95rem;margin-bottom:24px;text-align:center}.category-grid{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:24px;padding-right:4px}.category-card{display:flex;align-items:flex-start;gap:16px;padding:16px;border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:var(--bg-1)}.category-card:hover{border-color:var(--accent);background:var(--bg-2)}.category-card.selected{border-color:var(--accent);background:rgba(var(--accent-rgb),.05);box-shadow:0 0 0 1px var(--accent)}.cat-icon{font-size:24px;color:var(--accent)}.cat-label{font-weight:600;font-size:1rem;margin-bottom:4px}.cat-desc{font-size:.85rem;color:var(--text-3)}.wizard-actions{display:flex;justify-content:space-between;margin-top:32px;gap:12px}.wizard-actions button{flex:1}.fade-in{animation:fadeIn .3s ease forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app-main{min-height:calc(100vh - 56px)}.impersonation-banner{background:var(--danger);color:#fff;padding:8px 24px;position:sticky;top:0;z-index:200;box-shadow:0 4px 12px #ef444466}.banner-content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:16px;font-size:.9rem;font-weight:600}.banner-content .stop-btn{background:#fff;color:var(--danger);border:none;padding:4px 12px;border-radius:var(--radius-xs);cursor:pointer;font-weight:700;font-size:.8rem;transition:all .2s}.banner-content .stop-btn:hover{background:var(--text-inverse);transform:translateY(-1px)}.banner-content .material-symbols-outlined{font-size:1.2rem}
