@import"https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Poppins:wght@400;500;600;700&display=swap";:root{--font-sans: "DM Sans", system-ui, sans-serif;--color-background-primary: #ffffff;--color-background-secondary: #f1f5f9;--color-background-tertiary: #f8fafc;--color-border-secondary: #e2e8f0;--color-border-tertiary: #eef2f7;--color-text-primary: #0f172a;--color-text-secondary: #475569;--color-text-tertiary: #94a3b8;--color-accent: #0d9488;--color-accent-soft: #ccfbf1;--color-brand-blue: #2563eb;--color-brand-violet: #7c3aed;--color-brand-rose: #e11d48;--shadow-elevated: 0 4px 6px -1px rgba(15, 23, 42, .07), 0 10px 20px -5px rgba(15, 23, 42, .08);--shadow-modal-rich: 0 0 0 1px rgba(148, 163, 184, .12), 0 28px 56px -16px rgba(15, 23, 42, .28), 0 12px 28px -10px rgba(37, 99, 235, .12);--border-radius-md: 8px;--border-radius-lg: 12px;--radius-xl: 16px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:linear-gradient(160deg,#f8fafc,#f1f5f9 42%,#eef2ff);background-attachment:fixed;color:var(--color-text-primary)}.app{display:flex;min-height:100vh;background:transparent}.sidebar{display:flex;flex-direction:column;width:236px;min-height:100vh;min-height:100dvh;background:linear-gradient(180deg,#fff,#fafbff);border-right:1px solid var(--color-border-tertiary);padding:16px 0 0;flex-shrink:0;box-shadow:6px 0 32px -12px #0f172a14}.sidebar-nav-search-wrap{flex-shrink:0;padding:0 10px 10px;border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:6px;position:relative}.sidebar-nav-search{width:100%;padding:8px 30px 8px 10px;font-size:12px;border-radius:9px;border:1px solid var(--color-border-secondary);background:var(--color-background-secondary);font-family:inherit;color:var(--color-text-primary);box-sizing:border-box}.sidebar-nav-search::placeholder{color:var(--color-text-tertiary)}.sidebar-nav-search:focus{outline:none;border-color:var(--color-accent);background:var(--color-background-primary);box-shadow:0 0 0 2px #0d94882e}.sidebar-nav-search-clear{position:absolute;right:14px;top:50%;transform:translateY(-50%);width:22px;height:22px;padding:0;border:none;border-radius:6px;background:transparent;color:var(--color-text-tertiary);font-size:18px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.sidebar-nav-search-clear:hover{background:var(--color-background-secondary);color:var(--color-text-primary)}.sidebar-nav-body{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-bottom:20px;-webkit-overflow-scrolling:touch}.sidebar-nav-empty{margin:12px 12px 0;padding:12px 8px;font-size:11px;line-height:1.45;color:var(--color-text-secondary);text-align:center}.sidebar-nav-section .nav-section{padding-top:10px}.nav-item-label{min-width:0;flex:1}.sidebar-logo{flex-shrink:0;padding:0 16px 12px;border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:0}.sidebar-logo-row{display:flex;align-items:center;gap:10px}.sidebar-logo-mark{flex-shrink:0}.logo-text{font-size:14px;font-weight:600;color:var(--color-text-primary)}.logo-sub{font-size:11px;color:var(--color-text-secondary);margin-top:2px}.nav-section{padding:8px 8px 4px;font-size:10px;font-weight:500;color:var(--color-text-tertiary);letter-spacing:.08em;text-transform:uppercase}.nav-item{display:flex;align-items:center;gap:8px;padding:7px 16px;font-size:13px;cursor:pointer;color:var(--color-text-secondary);border-radius:0;transition:background .1s;border:none;background:none;width:100%;text-align:left;font-family:inherit}.nav-item:hover{background:var(--color-background-secondary);color:var(--color-text-primary)}.nav-item.active{background:linear-gradient(90deg,#ccfbf1e6,#ecfdf5a6);color:#0f766e;font-weight:600;border-left:3px solid var(--color-accent)}.nav-item.active .nav-icon{opacity:1;color:#0f766e}.nav-icon{width:14px;height:14px;opacity:.7;flex-shrink:0}.main{flex:1;overflow:auto;min-width:0}.topbar{background:var(--color-background-primary);border-bottom:.5px solid var(--color-border-tertiary);padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.topbar-title{font-size:15px;font-weight:500;color:var(--color-text-primary);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-menu-btn{display:none;flex-shrink:0;align-items:center;justify-content:center;width:40px;height:40px;padding:0}.mobile-menu-btn .nav-icon{width:18px;height:18px}.topbar-right{display:flex;gap:8px;align-items:center}.badge{background:#ef9f27;color:#633806;font-size:10px;font-weight:500;padding:2px 6px;border-radius:10px}.avatar{width:28px;height:28px;border-radius:50%;background:#eaf3de;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:#3b6d11}button.avatar{cursor:pointer;border:none;padding:0;flex-shrink:0}button.avatar:hover{filter:brightness(.97)}button.avatar.avatar--active{box-shadow:0 0 0 2px var(--color-accent, #639922)}.content{padding:20px}.page{display:none}.page.active{display:block}.dashboard-page{animation:dashboard-page-in .5s ease both}@keyframes dashboard-page-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.dashboard-page{animation:none}.dashboard-stats-animate .dashboard-stat-card{animation:none!important}.dashboard-skeleton:after{animation:none!important}}.dashboard-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:18px;padding:2px 2px 0}.dashboard-hero-kicker{margin:0;font-size:13px;font-weight:600;color:var(--color-text-secondary);letter-spacing:.02em;text-transform:capitalize}.dashboard-hero-summary{margin:6px 0 0;font-size:13px;color:var(--color-text-secondary);line-height:1.45}.dashboard-hero-summary strong{color:var(--color-text-primary);font-weight:600}.dashboard-page--loading{animation:none;pointer-events:none}.dashboard-skeleton{position:relative;border-radius:var(--border-radius-lg);background:linear-gradient(110deg,var(--color-background-secondary) 0%,#e8eef5 45%,var(--color-background-secondary) 90%);background-size:200% 100%;overflow:hidden}.dashboard-skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.55) 45%,transparent 90%);animation:dashboard-skeleton-shimmer 1.35s ease-in-out infinite}@keyframes dashboard-skeleton-shimmer{0%{transform:translate(-60%)}to{transform:translate(60%)}}.dashboard-skeleton-hero{height:52px;margin-bottom:16px}.dashboard-skeleton-search{height:118px;margin-bottom:16px}.dashboard-skeleton-stat{min-height:104px}.dashboard-skeleton-panel{min-height:280px}.dashboard-stats-animate .dashboard-stat-card{position:relative;animation:dashboard-stat-in .5s cubic-bezier(.22,1,.36,1) backwards}.dashboard-stats-animate .dashboard-stat-card:nth-child(1){animation-delay:.04s}.dashboard-stats-animate .dashboard-stat-card:nth-child(2){animation-delay:.1s}.dashboard-stats-animate .dashboard-stat-card:nth-child(3){animation-delay:.16s}.dashboard-stats-animate .dashboard-stat-card:nth-child(4){animation-delay:.22s}@keyframes dashboard-stat-in{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.dashboard-stat-card{position:relative;padding-top:16px;min-height:108px;box-shadow:0 1px #ffffffb3 inset}.dashboard-stat-card-icon{position:absolute;top:12px;right:12px;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;pointer-events:none}.dashboard-stat-card-icon .nav-icon{width:18px;height:18px;opacity:.95}.dashboard-stat-card-icon--green{background:linear-gradient(145deg,#6399222e,#bbf7d073);color:#3d7a12}.dashboard-stat-card-icon--blue{background:linear-gradient(145deg,#378add26,#dbeafea6);color:#1d4ed8}.dashboard-stat-card-icon--amber{background:linear-gradient(145deg,#ef9f272e,#fef3c78c);color:#b45309}.dashboard-stat-card-icon--rose{background:linear-gradient(145deg,#e24b4a29,#fee2e28c);color:#b91c1c}.dashboard-stat-card-icon--slate{background:linear-gradient(145deg,#7c879624,#f1f5f9cc);color:#475569}.stat-card-clickable.dashboard-stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px -12px #0f172a2e}.dashboard-search-hero{position:relative;border:1px solid transparent;background:linear-gradient(var(--color-background-primary),var(--color-background-primary)) padding-box,linear-gradient(125deg,#0d948859,#6366f147,#ec489938) border-box;box-shadow:0 12px 40px -20px #0f172a1f,var(--shadow-elevated)}.dashboard-search-title{font-size:15px;font-weight:600;letter-spacing:-.01em}.dashboard-search-count-pill{font-size:10px;font-weight:500}.dashboard-student-search-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);display:flex;color:var(--color-text-tertiary);pointer-events:none;z-index:1}.dashboard-student-search-input-icon .nav-icon{width:17px;height:17px}.dashboard-student-search-input--with-icon{padding-left:44px;padding-right:14px;border-color:var(--color-border-secondary)}.dashboard-student-search-card.dashboard-student-search-v2.card{padding:0;border-radius:var(--radius-xl);box-shadow:0 2px 4px #0f172a0a,0 18px 44px -24px #0f172a2e,var(--shadow-elevated)}.dashboard-student-search-v2-inner{padding:22px 22px 20px}.dashboard-student-search-v2-head{display:flex;flex-direction:column;align-items:stretch;gap:16px;margin-bottom:16px}@media(min-width:900px){.dashboard-student-search-v2-head{flex-direction:row;align-items:flex-start;justify-content:space-between;gap:20px}}.dashboard-student-search-v2-intro{display:flex;align-items:flex-start;gap:14px;min-width:0;flex:1}.dashboard-student-search-v2-badge{flex-shrink:0;width:48px;height:48px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#6366f12e,#0d94881f);color:#4338ca;border:1px solid rgba(99,102,241,.22);box-shadow:inset 0 1px #ffffffa6}.dashboard-student-search-v2-badge .nav-icon{width:22px;height:22px}.dashboard-student-search-v2-titles{min-width:0;flex:1}.dashboard-student-search-v2-title{margin:0 0 6px;font-size:1.25rem;font-weight:700;letter-spacing:-.025em;line-height:1.2;color:var(--color-text-primary)}.dashboard-student-search-v2-desc{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-secondary);max-width:none}.dashboard-student-search-v2-toolbar{flex-shrink:0}@media(max-width:899px){.dashboard-student-search-v2-toolbar .dashboard-header-actions{width:100%}}.dashboard-student-search-v2-field .dashboard-student-search-input{min-height:48px;padding-top:12px;padding-bottom:12px;border-radius:14px;font-size:15px;border:1px solid rgba(148,163,184,.45);background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:inset 0 1px 2px #0f172a0a}.dashboard-student-search-v2-field .dashboard-student-search-input-icon{left:14px}.dashboard-student-search-v2-field .dashboard-student-search-input--with-icon{padding-left:48px}.dashboard-student-search-dropdown-panel{margin-top:12px;border-radius:14px;border:1px solid rgba(148,163,184,.28);background:linear-gradient(180deg,#fff,#f8fafc);box-shadow:0 14px 36px -18px #0f172a33,inset 0 1px #fffc;text-align:left;animation:dashboard-search-dropdown-in .22s ease both}@media(prefers-reduced-motion:reduce){.dashboard-student-search-dropdown-panel{animation:none}}.dashboard-student-search-dropdown-head{display:flex;justify-content:flex-end;align-items:center;padding:8px 8px 0;min-height:36px}.dashboard-student-search-dropdown-close{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;margin:0;padding:0;border:1px solid var(--color-border-tertiary);border-radius:10px;background:var(--color-background-primary);color:var(--color-text-secondary);cursor:pointer;box-shadow:0 1px 2px #0f172a0f;transition:background .15s ease,color .15s ease,border-color .15s ease}.dashboard-student-search-dropdown-close:hover{background:var(--color-background-secondary);color:var(--color-text-primary);border-color:var(--color-border-secondary)}.dashboard-student-search-dropdown-close:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.dashboard-student-search-dropdown-close .nav-icon{width:18px;height:18px}.dashboard-student-search-dropdown-panel .dashboard-student-search-list.dashboard-student-search-list-v2{margin-top:0;margin-bottom:0;padding:2px 8px 8px;border:none;border-radius:0;background:transparent;box-shadow:none;text-align:left;animation:none;max-height:320px;overflow-y:auto}.dashboard-student-search-option-v2{align-items:flex-start;justify-content:flex-start;padding:11px 12px;border-radius:11px;gap:12px;border:1px solid rgba(226,232,240,.85);border-left:3px solid transparent;text-align:left;background:#ffffffb8;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease}.dashboard-student-search-option-avatar{flex-shrink:0;width:42px;height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;letter-spacing:.02em;color:#1e3a8a;background:linear-gradient(145deg,#e0e7ff,#ddf4ff 55%,#ecfeff);border:1px solid rgba(129,140,248,.35)}.dashboard-student-search-option-name{display:block;font-size:14px;font-weight:600;letter-spacing:-.015em;color:var(--color-text-primary);line-height:1.25}.dashboard-student-search-option-meta{display:flex;flex-direction:column;gap:4px;margin-top:6px}.dashboard-student-search-option-meta-line{display:flex;align-items:baseline;justify-content:flex-start;gap:8px;font-size:12px;line-height:1.35;min-width:0;width:100%;text-align:left}.dashboard-student-search-option-v2 .dashboard-student-search-option-tags{align-self:flex-start;padding-top:1px}.dashboard-student-search-dropdown-panel .dashboard-student-search-empty.dashboard-student-search-empty--left{text-align:left;padding-left:14px;padding-right:36px}.dashboard-student-search-kbd-hint--in-panel{margin:0;padding:8px 14px 14px;text-align:left}.dashboard-student-search-option-k{flex-shrink:0;width:2.5rem;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary)}.dashboard-student-search-option-v{flex:1;min-width:0;color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-student-search-option-v2.is-active,.dashboard-student-search-option-v2:hover{background:linear-gradient(135deg,#eef2fffa,#f0fdfabf);border-color:#6366f159;box-shadow:0 6px 18px -12px #4338ca61}.dashboard-student-search-option-v2.is-active{border-left-color:#6366f1}.dashboard-student-search-dropdown-panel .dashboard-student-search-list>li+li{margin-top:6px}.dashboard-student-search-kbd-hint{margin:10px 2px 0;font-size:11px;color:var(--color-text-tertiary);text-align:center;letter-spacing:.02em}.dashboard-student-search-kbd-hint kbd{display:inline-block;margin:0 1px;padding:2px 6px;font-size:10px;font-family:inherit;font-weight:600;color:var(--color-text-secondary);background:var(--color-background-secondary);border:1px solid var(--color-border-tertiary);border-radius:6px;box-shadow:0 1px #0f172a0f}.dashboard-panel-header{align-items:flex-start}.dashboard-panel-title-wrap{display:flex;align-items:center;gap:8px}.dashboard-panel-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:10px;background:linear-gradient(145deg,#3b82f61a,#f1f5f9e6);color:#2563eb;flex-shrink:0}.dashboard-panel-icon .nav-icon{width:17px;height:17px}.dashboard-panel--lessons .dashboard-panel-icon{background:linear-gradient(145deg,#10b9811f,#ecfdf5d9);color:#047857}.dashboard-panel-icon--attention{background:linear-gradient(145deg,#f59e0b24,#fffbebf2);color:#b45309}.dashboard-panel--attention{border-color:#fbbf2438}.dashboard-panel--lessons{border-color:#10b98126}.dashboard-panel-icon--collection{background:linear-gradient(145deg,#0d948829,#ccfbf1e0);color:#0f766e}.dashboard-chart-card{margin-bottom:16px;border-color:#0d948829;background:linear-gradient(165deg,#fff,#f7fdfc 38%,#fafbff);box-shadow:var(--shadow-elevated),0 1px #fffc inset;animation:dashboard-chart-card-in .55s cubic-bezier(.22,1,.36,1) both}@keyframes dashboard-chart-card-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.dashboard-chart-card{animation:none}}.dashboard-chart-card-header{align-items:flex-start}.dashboard-chart-card-header .card-title{font-size:14px;font-weight:600;letter-spacing:-.02em}.dashboard-chart-sub{margin:4px 0 0;font-size:12px;line-height:1.45;color:var(--color-text-secondary);font-weight:400}.dashboard-chart-sub strong{color:var(--color-text-primary);font-weight:600}.dashboard-skeleton-chart{height:212px;margin-bottom:16px}.dashboard-chart-recharts-wrap{margin:4px -4px 0;padding:4px 0 0}.dashboard-chart-core-skeleton{min-height:236px;border-radius:var(--border-radius-md);background:linear-gradient(110deg,var(--color-background-secondary) 0%,#e8eef5 45%,var(--color-background-secondary) 90%);background-size:200% 100%;position:relative;overflow:hidden}.dashboard-chart-core-skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(100deg,transparent 0%,rgba(255,255,255,.5) 45%,transparent 90%);animation:dashboard-skeleton-shimmer 1.35s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.dashboard-chart-core-skeleton:after{animation:none}}.dashboard-chart-tooltip{padding:10px 12px;border-radius:10px;background:#0f172aeb;color:#f8fafc;font-size:12px;line-height:1.35;box-shadow:0 8px 24px #0f172a40;border:1px solid rgba(148,163,184,.25)}.dashboard-chart-tooltip-month{font-size:11px;color:#cbd5e1;margin-bottom:4px}.dashboard-chart-tooltip-value{font-size:14px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em}.dashboard-chart-empty{text-align:center;padding:8px 12px 18px}.dashboard-chart-empty-visual{display:flex;justify-content:center;margin-bottom:4px}.dashboard-chart-empty-svg{width:min(200px,100%);height:52px}.dashboard-chart-empty-title{margin:0 0 6px;font-size:14px;font-weight:600;color:var(--color-text-primary)}.dashboard-chart-empty-text{margin:0 auto 14px;max-width:360px;font-size:12px;line-height:1.5;color:var(--color-text-secondary)}.dashboard-chart-empty-actions{display:flex;justify-content:center;gap:8px}.dashboard-table-scroll{border-radius:10px;border:1px solid var(--color-border-tertiary);overflow:hidden;overflow-x:auto;background:var(--color-background-tertiary);-webkit-overflow-scrolling:touch}.dashboard-lessons-table{margin:0;font-size:12.5px}.dashboard-lessons-table th{background:#ffffffbf}.dashboard-lessons-table tbody tr:hover td{background:#ffffffa6}.dashboard-inline-empty{padding:20px 16px;text-align:center}.dashboard-inline-empty-title{margin:0 0 6px;font-size:13px;font-weight:600;color:var(--color-text-primary)}.dashboard-inline-empty-text{margin:0;font-size:12px;color:var(--color-text-secondary);line-height:1.45}.dashboard-attention-empty{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px 8px 8px;gap:8px}.dashboard-attention-empty-visual{color:#22c55e}.dashboard-attention-empty-svg{width:52px;height:52px;display:block}.dashboard-attention-empty-title{margin:0;font-size:14px;font-weight:600;color:var(--color-text-primary)}.dashboard-attention-empty-text{margin:0;font-size:12px;line-height:1.5;color:var(--color-text-secondary);max-width:280px}.dashboard-occupancy-section .dashboard-panel-icon{background:linear-gradient(145deg,#7c3aed1a,#f3e8ffa6);color:#6d28d9}.btn-ghost-dashboard{font-size:11px;padding:6px 12px;border-radius:999px;border:1px solid var(--color-border-secondary);background:var(--color-background-secondary);font-weight:500}.btn-ghost-dashboard:hover:not(:disabled){background:var(--color-background-tertiary);border-color:#cbd5e1}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:20px}@media(max-width:900px){.stats-grid{grid-template-columns:repeat(2,1fr)}}.dashboard-equal-height-card{display:flex;flex-direction:column;height:min(460px,68vh);max-height:min(460px,68vh)}.dashboard-equal-height-scroll{flex:1;min-height:0;overflow-y:auto}.dashboard-trial-inline{flex-shrink:0;padding:10px 12px 12px;border-bottom:1px solid var(--color-border);background:linear-gradient(180deg,rgba(59,130,246,.07) 0%,transparent 72%)}.dashboard-trial-inline-head{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.dashboard-trial-inline-title{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--color-text-secondary)}.dashboard-trial-inline-link{font-size:11px;padding:3px 10px;min-height:0}.dashboard-trial-inline-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:7px}.dashboard-trial-inline-row{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px 8px;font-size:12px;line-height:1.35}.dashboard-trial-inline-pill{flex:0 0 auto;font-size:9px;font-weight:700;padding:2px 6px;border-radius:4px;letter-spacing:.02em}.dashboard-trial-inline-pill--today{background:#22c55e2e;color:#166534}.dashboard-trial-inline-pill--soon{background:#3b82f624;color:#1e40af}.dashboard-trial-inline-when{flex:0 0 auto;min-width:2.75rem;font-variant-numeric:tabular-nums;color:var(--color-text-secondary);font-size:11px}.dashboard-trial-inline-main{flex:1 1 120px;min-width:0}.dashboard-trial-inline-main strong{font-weight:600}.dashboard-trial-inline-sub{color:var(--color-text-secondary);font-weight:400}.dashboard-trial-inline-more{display:block;width:100%;margin-top:8px;padding:0;border:none;background:none;font:inherit;font-size:11px;color:var(--color-text-secondary);text-decoration:underline;text-underline-offset:2px;cursor:pointer;text-align:left}.dashboard-trial-inline-more:hover{color:var(--color-text)}.dashboard-header-actions{display:flex;flex-wrap:wrap;gap:6px;flex-shrink:0}.dashboard-header-action-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:7px 12px}.dashboard-header-action-btn .nav-icon{width:14px;height:14px;flex-shrink:0}@media(max-width:640px){.dashboard-header-actions{width:100%}.dashboard-header-action-btn{flex:1 1 auto;justify-content:center}}.stat-card-clickable{display:block;width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.stat-card-clickable:hover{background:var(--color-background-secondary);transform:translateY(-1px)}.stat-card-clickable:focus-visible{outline:2px solid rgba(59,130,246,.4);outline-offset:2px}.stat-trend{display:inline-flex;align-items:center;gap:3px;font-weight:500}.stat-trend-up{color:#2e7d32}.stat-trend-down{color:#c62828}.stat-trend-neutral{color:var(--color-text-tertiary)}.dashboard-attention-card{align-self:start}.dashboard-attention-summary{margin-top:3px;font-size:11px;color:var(--color-text-secondary)}.dashboard-attention-all-btn{font-size:11px;padding:4px 8px}.dashboard-attention-list{display:flex;flex-direction:column;gap:14px}.dashboard-attention-section{display:flex;flex-direction:column;gap:4px}.dashboard-attention-section-title{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);padding:0 2px}.dashboard-attention-item{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);background:var(--color-background-primary);font:inherit;color:inherit;text-align:left;cursor:pointer;transition:background .15s ease,border-color .15s ease}.dashboard-attention-item:hover{background:var(--color-background-secondary);border-color:var(--color-border)}.dashboard-attention-item-main{display:flex;flex-direction:column;min-width:0;gap:2px}.dashboard-attention-item-main strong{font-size:13px;font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-attention-item-sub{font-size:11px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-attention-more{margin-top:2px;padding:4px 8px;font-size:11px;border:none;background:transparent;color:var(--color-text-secondary);cursor:pointer;text-align:left}.dashboard-attention-more:hover{color:var(--color-text-primary)}.onboarding-card{margin-bottom:18px;border-radius:var(--border-radius-lg);background:linear-gradient(135deg,#2e7d3214,#1976d20f);border:1px solid var(--color-border-tertiary);box-shadow:0 1px #0000000a}.onboarding-card-inner{padding:20px 22px 22px}.onboarding-card-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:18px}.onboarding-title{margin:0 0 8px;font-size:18px;font-weight:600;letter-spacing:-.02em;color:var(--color-text-primary)}.onboarding-sub{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-secondary);max-width:52rem}.onboarding-progress{flex-shrink:0;display:flex;align-items:baseline;gap:2px;padding:8px 14px;border-radius:999px;background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary)}.onboarding-progress-value{font-size:22px;font-weight:600;color:var(--color-text-primary)}.onboarding-progress-of{font-size:13px;color:var(--color-text-tertiary)}.onboarding-steps{list-style:none;margin:0;padding:0;display:grid;gap:10px}@media(min-width:900px){.onboarding-steps{grid-template-columns:repeat(2,1fr)}}.onboarding-step{display:flex;gap:14px;padding:14px 16px;border-radius:var(--border-radius-md);background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);transition:border-color .15s ease,box-shadow .15s ease}.onboarding-step--next{border-color:#2e7d3273;box-shadow:0 0 0 1px #2e7d321f}.onboarding-step--done{opacity:.88}.onboarding-step-icon{width:40px;height:40px;flex-shrink:0;display:flex;align-items:center;justify-content:center;border-radius:10px;background:var(--color-background-secondary);color:var(--color-text-secondary)}.onboarding-step--done .onboarding-step-icon{background:#2e7d321f;color:#2e7d32}.onboarding-check{font-size:18px;font-weight:700;line-height:1}.onboarding-step-body{min-width:0;flex:1}.onboarding-step-title-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:4px}.onboarding-step-num{font-size:11px;font-weight:700;color:var(--color-text-tertiary);letter-spacing:.04em}.onboarding-step-title{font-size:14px;font-weight:600;color:var(--color-text-primary)}.onboarding-step-badge{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#2e7d32;background:#2e7d321a;padding:2px 8px;border-radius:999px}.onboarding-step-hint{margin:0 0 10px;font-size:12px;line-height:1.45;color:var(--color-text-secondary)}.onboarding-step-cta{font-size:12px;padding:6px 12px}.onboarding-step-wait{margin:0;font-size:12px;line-height:1.45;color:var(--color-text-tertiary);font-style:italic}.modal-setup-callout{margin-bottom:16px;padding:14px 16px;border-radius:var(--border-radius-md);background:linear-gradient(180deg,rgba(25,118,210,.08) 0%,var(--color-background-secondary) 100%);border:1px solid rgba(25,118,210,.22)}.modal-setup-callout--soft{background:var(--color-background-secondary);border-color:var(--color-border-tertiary)}.modal-setup-callout-title{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:6px}.modal-setup-callout-text{margin:0 0 12px;font-size:12px;line-height:1.5;color:var(--color-text-secondary)}.modal-setup-callout-btn{font-size:12px;padding:7px 14px}.modal-fieldset-reset{border:none;margin:0;padding:0;min-width:0}.stat-card{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:14px 16px}.stat-label{font-size:11px;color:var(--color-text-secondary);margin-bottom:6px}.stat-value{font-size:22px;font-weight:500;color:var(--color-text-primary)}.stat-sub{font-size:11px;color:var(--color-text-tertiary);margin-top:3px}.stat-green{border-left:3px solid #639922}.stat-amber{border-left:3px solid #ef9f27}.stat-red{border-left:3px solid #e24b4a}.stat-blue{border-left:3px solid #378add}.stat-slate{border-left:3px solid #7c8796}.card{background:var(--color-background-primary);border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:16px;margin-bottom:16px;box-shadow:var(--shadow-elevated)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;gap:8px;flex-wrap:wrap}.card-title{font-size:13px;font-weight:500;color:var(--color-text-primary)}.btn{padding:6px 12px;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);font-size:12px;cursor:pointer;background:var(--color-background-primary);color:var(--color-text-primary);font-family:inherit}.btn:hover:not(:disabled){background:var(--color-background-secondary)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-green{background:linear-gradient(180deg,#ecfdf5,#d1fae5);border:1px solid #34d399;color:#047857;font-weight:600}.btn-green:hover:not(:disabled){background:linear-gradient(180deg,#d1fae5,#a7f3d0);border-color:#10b981;color:#065f46}.btn-danger-outline{background:#fcebeb;color:#a32d2d;border-color:#f09595}.table{width:100%;border-collapse:collapse;font-size:12px}.table th{text-align:left;padding:8px 10px;font-size:10px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--color-border-secondary);background:var(--color-background-secondary)}.table td{padding:10px;border-bottom:.5px solid var(--color-border-tertiary);color:var(--color-text-primary);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:var(--color-background-secondary)}.table tr.is-selected td{background:var(--color-background-secondary);box-shadow:inset 3px 0 0 0 var(--color-accent, #639922)}.table.veli-table-compact th{padding:6px 8px}.table.veli-table-compact td{padding:8px;vertical-align:top}.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:500}.pill-green{background:linear-gradient(135deg,#d1fae5,#ecfdf5);color:#047857;border:1px solid rgba(16,185,129,.35)}.pill-amber{background:linear-gradient(135deg,#fde68a,#fef3c7);color:#92400e;border:1px solid rgba(245,158,11,.35)}.pill-red{background:linear-gradient(135deg,#fecdd3,#ffe4e6);color:#be123c;border:1px solid rgba(244,63,94,.35)}.pill-blue{background:linear-gradient(135deg,#bfdbfe,#eff6ff);color:#1d4ed8;border:1px solid rgba(59,130,246,.35)}.pill-gray{background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:var(--color-text-secondary);border:1px solid var(--color-border-tertiary)}.teacher-insight-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:28px 20px 32px;gap:10px}.teacher-insight-empty-icon{width:56px;height:56px;border-radius:14px;background:var(--color-background-secondary);display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary)}.teacher-insight-empty-icon svg{width:28px;height:28px}.teacher-insight-empty-title{font-size:14px;font-weight:500;color:var(--color-text-primary);margin:0}.teacher-insight-empty-hint{font-size:12px;color:var(--color-text-tertiary);margin:0;max-width:280px;line-height:1.45}.teacher-insight-hero{display:flex;align-items:center;gap:14px;padding:4px 0 16px;margin-bottom:4px;border-bottom:.5px solid var(--color-border-tertiary)}.teacher-insight-hero-avatar{width:52px;height:52px;border-radius:14px;background:linear-gradient(145deg,#eaf3de,#e6f1fb);border:.5px solid var(--color-border-tertiary);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:600;color:var(--color-text-primary);letter-spacing:.02em;flex-shrink:0}.teacher-insight-hero-text{min-width:0}.teacher-insight-hero-name{font-size:16px;font-weight:600;color:var(--color-text-primary);margin:0 0 4px;line-height:1.25}.teacher-insight-hero-sub{font-size:12px;color:var(--color-text-secondary);margin:0;line-height:1.4}.stats-grid.teacher-insight-stats{margin-bottom:18px;grid-template-columns:repeat(4,minmax(0,1fr))}@media(max-width:900px){.stats-grid.teacher-insight-stats{grid-template-columns:repeat(2,minmax(0,1fr))}}.teacher-insight-groups{display:flex;flex-direction:column;gap:10px}.teacher-insight-group{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-tertiary);overflow:hidden}.teacher-insight-group-summary{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px 14px;cursor:pointer;list-style:none;-webkit-user-select:none;user-select:none}.teacher-insight-group-summary::-webkit-details-marker{display:none}.teacher-insight-group-summary::marker{display:none}.teacher-insight-chevron{flex-shrink:0;margin-top:4px;font-size:11px;color:var(--color-text-tertiary);transition:transform .18s ease;line-height:1}.teacher-insight-group[open] .teacher-insight-chevron{transform:rotate(180deg)}.teacher-insight-group-head{min-width:0;flex:1}.teacher-insight-group-title{font-size:13px;font-weight:600;color:var(--color-text-primary);margin:0 0 6px;line-height:1.3}.teacher-insight-group-meta{display:flex;flex-wrap:wrap;gap:6px 10px;align-items:center}.teacher-insight-group-meta-muted{font-size:11px;color:var(--color-text-tertiary)}.teacher-insight-meter-wrap{margin-top:2px}.teacher-insight-meter-label{display:flex;justify-content:space-between;align-items:baseline;font-size:10px;color:var(--color-text-tertiary);margin-bottom:4px}.teacher-insight-meter{height:6px;border-radius:4px;background:var(--color-border-tertiary);overflow:hidden}.teacher-insight-meter-fill{height:100%;border-radius:4px;transition:width .25s ease}.teacher-insight-group-body{padding:0 14px 14px;border-top:.5px solid var(--color-border-tertiary);background:var(--color-background-primary)}.teacher-insight-student-list{display:flex;flex-direction:column;gap:6px;margin-top:12px}.teacher-insight-student-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--border-radius-md);border:.5px solid var(--color-border-tertiary);background:var(--color-background-tertiary)}.teacher-insight-student-avatar{width:32px;height:32px;border-radius:9px;background:var(--color-background-secondary);border:.5px solid var(--color-border-tertiary);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--color-text-secondary);flex-shrink:0}.teacher-insight-student-info{flex:1;min-width:0}.teacher-insight-student-name{font-size:12px;font-weight:500;color:var(--color-text-primary);margin:0;line-height:1.25}.teacher-insight-student-age{font-size:10px;color:var(--color-text-tertiary);margin:2px 0 0}.teacher-insight-student-tags{display:flex;flex-wrap:wrap;gap:4px;align-items:center;flex-shrink:0}.page--attendance{padding-bottom:calc(92px + env(safe-area-inset-bottom,0px))}.attendance-flow-hint{margin:0 0 14px;padding:10px 12px;font-size:12px;line-height:1.45;color:var(--color-text-secondary);background:var(--color-background-tertiary);border-radius:var(--border-radius-md);border:.5px solid var(--color-border-tertiary)}.attendance-flow-hint strong{font-weight:600;color:var(--color-text-primary)}.attendance-toolbar{margin-bottom:14px}.attendance-toolbar-row{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end}.attendance-field{display:flex;flex-direction:column;gap:4px;flex:1;min-width:160px}.attendance-field-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.attendance-date-input{width:100%;max-width:220px;min-height:40px;font-size:15px}.attendance-refresh{min-height:40px;align-self:flex-end}.attendance-today-btn{min-height:40px;align-self:flex-end;flex-shrink:0;font-weight:600}.attendance-today-btn.is-current{opacity:.55;pointer-events:none}.attendance-context-bar{margin-top:14px;padding:12px 14px;border-radius:var(--border-radius-lg);border:.5px solid color-mix(in srgb,var(--color-accent, #639922) 35%,var(--color-border-tertiary));background:color-mix(in srgb,var(--color-accent, #639922) 6%,var(--color-background-primary));display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px 16px}.attendance-context-main{display:flex;flex-direction:column;gap:2px;min-width:0}.attendance-context-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.attendance-context-name{font-size:17px;font-weight:700;color:var(--color-text-primary);line-height:1.2;word-break:break-word}.attendance-context-teachers{display:block;margin-top:6px;font-size:13px;font-weight:500;color:var(--color-text-secondary);line-height:1.35}.attendance-context-teachers--empty{font-weight:400;font-style:italic;color:var(--color-text-tertiary)}.attendance-context-meta{font-size:13px;color:var(--color-text-secondary);flex-shrink:0}.attendance-search-field{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding:0 4px 0 12px;border-radius:var(--border-radius-lg);border:.5px solid var(--color-border-tertiary);background:var(--color-background-primary);min-height:48px}.attendance-search-icon{display:flex;color:var(--color-text-tertiary);flex-shrink:0}.attendance-search-icon svg{width:18px;height:18px}.attendance-search-input{flex:1;min-width:0;border:none!important;background:transparent!important;box-shadow:none!important;min-height:44px;font-size:16px}.attendance-empty-card--compact{padding:18px 16px;margin-bottom:8px}.attendance-date-hint{margin:8px 0 12px;font-size:13px;color:var(--color-text-secondary)}.attendance-group-scroll{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;margin:0 -4px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch}.attendance-group-scroll::-webkit-scrollbar{height:4px}.attendance-group-scroll::-webkit-scrollbar-thumb{background:var(--color-border-secondary);border-radius:4px}.attendance-empty-groups{font-size:13px;color:var(--color-text-secondary);margin:0}.attendance-group-chip{flex:0 0 auto;scroll-snap-align:start;display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:10px 14px;min-height:48px;min-width:120px;max-width:200px;border-radius:var(--border-radius-lg);border:.5px solid var(--color-border-tertiary);background:var(--color-background-primary);cursor:pointer;font-family:inherit;text-align:left;transition:border-color .12s ease,box-shadow .12s ease}.attendance-group-chip:hover{border-color:var(--color-border-secondary)}.attendance-group-chip.is-active{border-color:var(--color-accent, #639922);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-accent, #639922) 22%,transparent);background:color-mix(in srgb,var(--color-accent, #639922) 8%,var(--color-background-primary))}.attendance-group-chip-name{font-size:13px;font-weight:600;color:var(--color-text-primary);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.attendance-group-chip-meta{font-size:11px;color:var(--color-text-tertiary)}.attendance-group-chip-teachers{font-size:11px;font-weight:500;color:var(--color-text-secondary);line-height:1.35;width:100%;text-align:left;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.attendance-group-chip-teachers--empty{font-weight:400;font-style:italic;color:var(--color-text-tertiary)}.attendance-summary{padding:14px;margin-bottom:14px}.attendance-summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:12px}@media(max-width:520px){.attendance-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.attendance-stat{border-radius:var(--border-radius-md);padding:10px 8px;text-align:center;border:.5px solid var(--color-border-tertiary);background:var(--color-background-tertiary)}.attendance-stat-value{display:block;font-size:20px;font-weight:600;color:var(--color-text-primary);line-height:1.1}.attendance-stat-label{font-size:10px;font-weight:500;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.attendance-stat--ok{border-left:3px solid #639922}.attendance-stat--no{border-left:3px solid #e24b4a}.attendance-stat--ex{border-left:3px solid #378add}.attendance-stat--pending{border-left:3px solid #8e8e98}.attendance-quick-actions{display:flex;flex-wrap:wrap;gap:8px}.attendance-quick-btn{flex:1;min-width:140px;min-height:42px;font-size:13px}.attendance-list-wrap{margin-bottom:8px}.attendance-loading{text-align:center;padding:24px;color:var(--color-text-secondary);font-size:14px}.attendance-empty-card{padding:28px 16px;text-align:center}.attendance-empty-text{margin:0;font-size:14px;color:var(--color-text-secondary)}.attendance-student-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.attendance-student-card{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-primary);padding:14px;box-shadow:0 1px 2px #0000000a}.attendance-student-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}.attendance-student-avatar{width:44px;height:44px;border-radius:12px;background:linear-gradient(145deg,#eaf3de,#e6f1fb);border:.5px solid var(--color-border-tertiary);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:var(--color-text-primary);flex-shrink:0}.attendance-student-text{flex:1;min-width:0}.attendance-student-name{font-size:16px;font-weight:600;color:var(--color-text-primary);line-height:1.25}.attendance-student-age{font-size:12px;color:var(--color-text-tertiary);margin-top:2px}.attendance-status-pill{flex-shrink:0;font-size:11px;font-weight:600;padding:4px 10px;border-radius:999px;background:var(--color-background-secondary);color:var(--color-text-secondary)}.attendance-status-pill.is-present{background:#eaf3de;color:#3b6d11}.attendance-status-pill.is-absent{background:#fcebeb;color:#a32d2d}.attendance-status-pill.is-excused{background:#e6f1fb;color:#185fa5}.attendance-status-pill.is-unset{opacity:.6}.attendance-actions{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}.attendance-action{min-height:48px;border-radius:var(--border-radius-md);border:2px solid var(--color-border-secondary);background:var(--color-background-primary);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;color:var(--color-text-primary);transition:background .12s ease,border-color .12s ease,transform .08s ease}.attendance-action:active{transform:scale(.98)}.attendance-action--present.is-selected{border-color:#639922;background:#eaf3de;color:#2d5010}.attendance-action--absent.is-selected{border-color:#e24b4a;background:#fcebeb;color:#7a2222}.attendance-action--excused.is-selected{border-color:#378add;background:#e6f1fb;color:#185fa5}.attendance-save-bar{position:fixed;left:0;right:0;bottom:0;z-index:50;padding:10px 16px calc(10px + env(safe-area-inset-bottom,0px));background:var(--color-background-primary);border-top:.5px solid var(--color-border-tertiary);box-shadow:0 -4px 20px #0000000f}@media(min-width:961px){.attendance-save-bar{left:236px}}.attendance-save-inner{max-width:720px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.attendance-save-hint{font-size:12px;color:#b45309;font-weight:500}.attendance-save-hint--ok{color:var(--color-text-tertiary);font-weight:400}.attendance-save-btn{min-height:48px;padding-left:22px;padding-right:22px;font-size:15px;font-weight:600}@media(min-width:700px){.page--attendance .attendance-student-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:start}.page--attendance .attendance-student-card{height:100%;display:flex;flex-direction:column}.page--attendance .attendance-actions{margin-top:auto}.page--attendance .attendance-action{min-height:52px;font-size:15px}.page--attendance .attendance-group-chip{min-height:52px;min-width:132px;padding:12px 16px}.page--attendance .attendance-group-chip-name{font-size:14px}.page--attendance .attendance-save-inner{max-width:900px}.page--attendance .attendance-flow-hint{font-size:13px;padding:12px 14px}.page--attendance .attendance-student-name{font-size:17px}.page--attendance .attendance-student-avatar{width:48px;height:48px;font-size:15px}}.page--attendance-report{padding-bottom:24px}.attendance-report-toolbar-row{align-items:center;flex-wrap:wrap}.attendance-report-month-bar{flex:1;min-width:220px;max-width:420px}.attendance-report-legend{display:flex;flex-wrap:wrap;gap:14px 20px;padding:12px 14px;margin-bottom:14px;font-size:12px;color:var(--color-text-secondary)}.attendance-report-legend-item{display:inline-flex;align-items:center;gap:8px}.attendance-report-legend-sym{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;font-size:12px;font-weight:700}.attendance-report-scroll-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border-radius:var(--border-radius-lg);border:.5px solid var(--color-border-tertiary);background:var(--color-background-primary);box-shadow:0 1px 2px #0000000a}.attendance-report-table{border-collapse:separate;border-spacing:0;font-size:12px;min-width:max-content}.attendance-report-th,.attendance-report-row-label,.attendance-report-cell{border-bottom:.5px solid var(--color-border-tertiary);border-right:.5px solid var(--color-border-tertiary);padding:8px 6px;text-align:center;vertical-align:middle}.attendance-report-th:last-child,.attendance-report-cell:last-child{border-right:none}.attendance-report-th{position:sticky;top:0;z-index:2;background:var(--color-background-secondary);font-weight:600;color:var(--color-text-primary)}.attendance-report-th--corner{left:0;top:0;z-index:4;min-width:120px;max-width:200px;text-align:left;padding-left:12px;vertical-align:middle}.attendance-report-th--date{z-index:3;min-width:46px;max-width:58px;width:52px;vertical-align:middle;padding:10px 4px;text-align:center;line-height:1.15}.attendance-report-th-date-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px}.attendance-report-th-date-line1{display:block;font-size:11px;font-weight:600;color:var(--color-text-primary);white-space:nowrap}.attendance-report-th-date-line2{display:block;font-size:10px;font-weight:600;color:var(--color-text-tertiary);white-space:nowrap}.attendance-report-row-label{position:sticky;left:0;z-index:2;background:var(--color-background-primary);text-align:left;min-width:120px;max-width:220px;padding-left:12px;font-weight:500;box-shadow:1px 0 0 var(--color-border-tertiary)}.attendance-report-row-label--student{vertical-align:middle}.attendance-report-student-name{display:block;font-size:13px;color:var(--color-text-primary);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.attendance-report-cell{font-weight:700;min-width:36px;transform:none}.attendance-report-cell--ok{background:color-mix(in srgb,#eaf3de 85%,var(--color-background-primary));color:#3b6d11}.attendance-report-cell--no{background:color-mix(in srgb,#fcebeb 85%,var(--color-background-primary));color:#a32d2d}.attendance-report-cell--ex{background:color-mix(in srgb,#e6f1fb 85%,var(--color-background-primary));color:#185fa5}.attendance-report-cell--unset{color:var(--color-text-tertiary);font-weight:500}.student-detail-attendance-month{border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);margin-bottom:10px;background:var(--color-background-primary)}.student-detail-attendance-summary{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;cursor:pointer;font-size:14px;font-weight:600;color:var(--color-text-primary);list-style:none}.student-detail-attendance-summary::-webkit-details-marker{display:none}.student-detail-attendance-meta{font-size:11px;font-weight:600;color:var(--color-text-tertiary);flex-shrink:0}.student-detail-attendance-body{padding:0 10px 12px}.student-detail-attendance-empty{margin:0;font-size:13px;color:var(--color-text-tertiary)}.student-detail-attendance-table-wrap{max-width:100%}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:960px){.two-col{grid-template-columns:1fr}.dashboard-equal-height-card{height:auto;max-height:none}.dashboard-equal-height-scroll{overflow-y:visible}.app{flex-direction:column}.mobile-menu-btn{display:inline-flex}.mobile-nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:199;margin:0;padding:0;border:none;background:#00000059;cursor:pointer;animation:mobile-nav-backdrop-in .2s ease}@keyframes mobile-nav-backdrop-in{0%{opacity:0}to{opacity:1}}.sidebar{position:fixed;left:0;top:0;bottom:0;width:min(280px,88vw);z-index:200;display:flex;flex-direction:column;flex-wrap:nowrap;align-items:stretch;gap:0;padding:16px 0 0;box-shadow:4px 0 24px #0000001f;transform:translate(-100%);transition:transform .22s ease;overflow:hidden;pointer-events:none;border-right:.5px solid var(--color-border-tertiary)}.sidebar.sidebar--open{transform:translate(0);pointer-events:auto}.sidebar-logo{border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:0;padding:0 16px 12px}.sidebar-nav-body{flex:1;min-height:0}.nav-section{width:100%;flex-shrink:0}.nav-item{flex:0 0 auto;width:100%;min-width:0}}.search-bar{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.search-bar input,.select-input{flex:1;min-width:160px;padding:7px 10px;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);font-size:12px;background:var(--color-background-primary);color:var(--color-text-primary);font-family:inherit}.schedule-grid{display:grid;grid-template-columns:80px repeat(7,1fr);gap:1px;background:var(--color-border-tertiary);border-radius:var(--border-radius-md);overflow:hidden;font-size:11px;min-width:640px}.sch-cell{background:var(--color-background-primary);padding:6px 4px;text-align:center;min-height:44px;vertical-align:top;display:flex;flex-direction:column;align-items:stretch;gap:4px}.sch-slot-wrap{position:relative;text-align:left}.sch-slot-wrap .sch-lesson{padding-right:18px}.sch-remove{position:absolute;top:2px;right:2px;width:18px;height:18px;padding:0;font-size:14px;line-height:1;border:none;border-radius:4px;background:#0000000f;color:var(--color-text-secondary);cursor:pointer;font-family:inherit}.sch-remove:hover{background:#fcebeb;color:#a32d2d}.sch-header{background:var(--color-background-secondary);font-weight:500;color:var(--color-text-secondary);padding:7px 4px;text-align:center;font-size:10px}.sch-time{background:var(--color-background-secondary);color:var(--color-text-tertiary);font-size:10px;display:flex;align-items:center;justify-content:center}.sch-lesson{background:#eaf3de;border-radius:4px;padding:4px 3px;color:#3b6d11;font-size:10px;font-weight:500;cursor:default;line-height:1.3}.sch-lesson-b{background:#e6f1fb;color:#185fa5}.sch-lesson-c{background:#faeeda;color:#633806}.payment-row-late{background:#fff8f8}.payment-row-late td:first-child{border-left:3px solid #e24b4a}.payment-row-late:hover td{background:#fff0f0!important}.info-row{display:flex;justify-content:space-between;padding:7px 0;border-bottom:.5px solid var(--color-border-tertiary);font-size:13px}.info-row:last-child{border-bottom:none}.info-label{color:var(--color-text-secondary)}.student-recurring-preview{margin-top:10px;padding:10px 12px;border-radius:var(--border-radius-md, 8px);border:1px solid var(--color-border-secondary);background:var(--color-background-secondary)}.student-recurring-preview-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:8px}.student-recurring-preview-readonly{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px}.student-recurring-preview-muted{display:block;font-size:11px;color:var(--color-text-tertiary);margin-bottom:2px}.student-recurring-preview-value{font-size:14px;font-weight:600;color:var(--color-text-primary)}.student-recurring-preview-note{grid-column:1 / -1;margin:4px 0 0;font-size:11px;line-height:1.45;color:var(--color-text-secondary)}.student-recurring-preview-note--warn{margin:0;color:var(--color-text-secondary)}.student-prorate-preview{grid-column:1 / -1;margin-top:10px;padding:10px 12px;border-radius:var(--border-radius-md, 8px);border:1px solid rgba(25,118,210,.22);background:linear-gradient(180deg,rgba(25,118,210,.06) 0%,var(--color-background-secondary) 100%)}.student-prorate-preview-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:#1565c0;margin-bottom:8px}.student-prorate-preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px}.student-prorate-preview-amount{color:#1565c0;font-size:15px}.group-fee-sync-muted{font-size:12px;color:var(--color-text-secondary);line-height:1.45}.group-fee-sync-table-wrap{max-height:min(42vh,280px);overflow:auto;border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-md, 8px)}.group-fee-sync-table{margin:0;font-size:13px}.group-fee-sync-table th,.group-fee-sync-table td{white-space:nowrap}.group-fee-sync-table td:first-child{white-space:normal}.group-fee-sync-actions{flex-wrap:wrap;gap:8px;justify-content:flex-end}.progress-bar{background:var(--color-background-secondary);border-radius:4px;height:6px;overflow:hidden;margin-top:4px;max-width:120px}.progress-fill{height:100%;border-radius:4px;background:#639922}.notifications-page{max-width:640px;margin:0 auto;animation:notifications-page-in .45s ease both}@keyframes notifications-page-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.notifications-page{animation:none}}.notifications-hero{position:relative;display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;padding:4px 2px 0}.notifications-hero-glow{position:absolute;left:28px;top:28px;width:120px;height:120px;transform:translate(-50%,-50%);border-radius:50%;background:radial-gradient(circle,rgba(13,148,136,.22) 0%,transparent 68%);pointer-events:none}.notifications-hero-icon-wrap{position:relative;flex-shrink:0;width:52px;height:52px;display:flex;align-items:center;justify-content:center;border-radius:14px;background:linear-gradient(145deg,#fff,#f0fdfa);border:1px solid rgba(13,148,136,.2);box-shadow:0 10px 28px -12px #0d948859,0 0 0 1px #fffc inset;color:var(--color-accent)}.notifications-hero-icon-wrap .nav-icon{width:26px;height:26px}.notifications-hero-text{min-width:0;padding-top:2px}.notifications-hero-title{margin:0;font-size:22px;font-weight:700;letter-spacing:-.03em;line-height:1.2;color:var(--color-text-primary)}.notifications-hero-desc{margin:8px 0 0;font-size:13px;line-height:1.55;color:var(--color-text-secondary);max-width:46ch}.notifications-help{margin-bottom:16px;border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:#ffffffa6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);overflow:hidden;box-shadow:0 1px #ffffffe6 inset}.notifications-help>summary{cursor:pointer;list-style:none;padding:10px 14px;font-size:12px;font-weight:600;color:var(--color-text-secondary);-webkit-user-select:none;user-select:none}.notifications-help>summary::-webkit-details-marker{display:none}.notifications-help[open]>summary{border-bottom:1px solid var(--color-border-tertiary)}.notifications-help-body{margin:0;padding:10px 14px 12px;font-size:12px;color:var(--color-text-secondary);line-height:1.6}.notifications-shell{border-radius:var(--radius-xl);background:linear-gradient(180deg,#fff,#fafbfc);border:1px solid var(--color-border-tertiary);box-shadow:var(--shadow-elevated),0 0 0 1px #ffffffe6 inset;overflow:hidden}.notifications-toolbar{display:grid;grid-template-columns:1fr auto;grid-template-areas:"heading actions" "meta meta";gap:6px 12px;align-items:center;padding:16px 18px 14px;border-bottom:1px solid var(--color-border-tertiary);background:linear-gradient(180deg,#f8fafcf2,#ffffff80)}@media(min-width:560px){.notifications-toolbar{grid-template-columns:auto 1fr auto;grid-template-areas:"heading meta actions";gap:12px 16px}}.notifications-toolbar-heading{grid-area:heading;margin:0;display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-tertiary)}.notifications-toolbar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:22px;height:22px;padding:0 7px;border-radius:999px;font-size:11px;font-weight:700;letter-spacing:0;text-transform:none;color:#fff;background:linear-gradient(135deg,var(--color-accent) 0%,#0f766e 100%);box-shadow:0 2px 8px -2px #0d94888c}.notifications-toolbar-meta{grid-area:meta;font-size:12px;color:var(--color-text-secondary);line-height:1.4}@media(min-width:560px){.notifications-toolbar-meta{justify-self:start}}.notifications-toolbar-actions{grid-area:actions;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end}.notifications-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:inherit;font-size:11px;font-weight:600;padding:7px 12px;border-radius:999px;border:1px solid var(--color-border-secondary);background:#fff;color:var(--color-text-secondary);cursor:pointer;transition:background .15s ease,border-color .15s ease,box-shadow .15s ease,color .15s ease}.notifications-btn:hover:not(:disabled){border-color:#0d948873;color:var(--color-text-primary);background:#f0fdfad9}.notifications-btn:disabled{opacity:.45;cursor:not-allowed}.notifications-btn--primary{border-color:transparent;background:linear-gradient(135deg,var(--color-accent) 0%,#0f766e 100%);color:#fff;box-shadow:0 2px 10px -3px #0d94888c}.notifications-btn--primary:hover:not(:disabled){filter:brightness(1.05);border-color:transparent;color:#fff}.notifications-btn--icon{display:inline-flex;align-items:center;gap:6px}.notifications-btn-refresh-label{display:inline}@media(max-width:420px){.notifications-btn-refresh-label{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.notifications-btn--icon{position:relative}}.notifications-btn-refresh-icon{font-size:14px;line-height:1;display:inline-block;transition:transform .35s ease}.notifications-btn--icon:hover:not(:disabled) .notifications-btn-refresh-icon{transform:rotate(-200deg)}@media(prefers-reduced-motion:reduce){.notifications-btn--icon:hover:not(:disabled) .notifications-btn-refresh-icon{transform:none}}.notifications-list-scroll{max-height:min(480px,calc(100vh - 260px));min-height:0;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-padding:12px 14px 16px;padding:12px 14px 16px;outline:none;background:linear-gradient(180deg,#f8fafc80,#fff 24px)}.notifications-list-scroll:focus-visible{box-shadow:inset 0 0 0 2px #0d948847}.notifications-feed{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.notifications-item{--notif-accent: var(--color-accent);position:relative;display:flex;gap:0;border-radius:12px;border:1px solid var(--color-border-tertiary);background:#fff;box-shadow:0 1px 2px #0f172a0a;transition:box-shadow .2s ease,border-color .2s ease,transform .2s ease;overflow:hidden}.notifications-item:hover{border-color:#94a3b88c;box-shadow:0 8px 24px -12px #0f172a1f}.notifications-item--unread{border-color:#0d948859;background:linear-gradient(90deg,#f0fdfaa6,#fff 48%);box-shadow:0 0 0 1px #0d948814,0 6px 20px -10px #0d948840}.notifications-item-accent{width:4px;flex-shrink:0;background:var(--notif-accent);border-radius:12px 0 0 12px}.notifications-item-body{flex:1;min-width:0;padding:12px 14px 12px 12px}.notifications-item-message{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-primary)}.notifications-item--unread .notifications-item-message{font-weight:500}.notifications-item-meta{display:flex;flex-wrap:wrap;align-items:center;gap:8px 10px;margin-top:10px}.notifications-item-time{font-size:11px;font-weight:500;letter-spacing:.02em;color:var(--color-text-tertiary)}.notifications-chip{display:inline-flex;align-items:center;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:600;letter-spacing:.02em}.notifications-chip--cat{background:var(--color-background-secondary)!important}.notifications-item-actions{margin-left:auto;display:flex;align-items:center}.notifications-inline-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;font-family:inherit;font-size:11px;font-weight:600;padding:4px 0;border:none;background:none;color:var(--color-text-tertiary);cursor:pointer;text-decoration:underline;text-underline-offset:3px;transition:color .15s ease}.notifications-inline-btn:hover{color:var(--color-accent)}.notifications-inline-btn--strong{color:var(--color-accent);text-decoration:none;padding:5px 10px;border-radius:8px;background:#0d94881a}.notifications-inline-btn--strong:hover{background:#0d94882e;color:#0f766e}@media(max-width:520px){.notifications-item-actions{margin-left:0;width:100%;justify-content:flex-start;padding-top:2px}}.notifications-item:not(.notifications-item--unread) .notifications-item-message,.notifications-item:not(.notifications-item--unread) .notifications-item-time{opacity:.72}.notifications-item:not(.notifications-item--unread) .notifications-chip{opacity:.88}.notifications-empty-state{padding:40px 22px 44px;text-align:center}.notifications-empty-visual{display:flex;justify-content:center;margin-bottom:18px}.notifications-empty-ring{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:linear-gradient(145deg,#f0fdfa,#e0f2fe);border:1px solid rgba(13,148,136,.15);color:var(--color-accent);box-shadow:0 12px 32px -16px #0d948859}.notifications-empty-ring .nav-icon{width:32px;height:32px}.notifications-empty-title{margin:0;font-size:16px;font-weight:700;letter-spacing:-.02em;color:var(--color-text-primary)}.notifications-empty-text{margin:10px auto 0;max-width:36ch;font-size:13px;line-height:1.55;color:var(--color-text-secondary)}.notifications-loading .notifications-shell{padding:12px 14px 16px}.notifications-hero--skeleton{display:flex;align-items:flex-start;gap:16px;margin-bottom:16px}.notifications-skeleton{position:relative;overflow:hidden;background:var(--color-background-secondary);border-radius:8px}.notifications-skeleton:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 0%,rgba(255,255,255,.55) 45%,transparent 88%);animation:notifications-skeleton-shimmer 1.35s ease-in-out infinite}@keyframes notifications-skeleton-shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}@media(prefers-reduced-motion:reduce){.notifications-skeleton:after{animation:none}}.notifications-skeleton-hero-icon{width:52px;height:52px;border-radius:14px;flex-shrink:0}.notifications-skeleton-hero-text{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0;padding-top:4px}.notifications-skeleton-line{height:12px}.notifications-skeleton-line--lg{width:56%;max-width:200px;height:20px;border-radius:6px}.notifications-skeleton-line--md{width:88%;max-width:340px}.notifications-skeleton-line--full{width:100%}.notifications-skeleton-line--sm{width:42%;height:10px}.notifications-skeleton-row{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid var(--color-border-tertiary)}.notifications-skeleton-row:last-child{border-bottom:none}.notifications-skeleton-accent{width:4px;height:48px;border-radius:4px;flex-shrink:0}.notifications-skeleton-row-body{flex:1;display:flex;flex-direction:column;gap:10px;min-width:0}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal{background:var(--color-background-primary);border-radius:var(--border-radius-lg);max-width:440px;width:100%;padding:0;box-shadow:var(--shadow-elevated),0 22px 50px -16px #0f172a2e;max-height:min(90vh,720px);overflow:hidden;display:flex;flex-direction:column;margin:auto;border:1px solid rgba(255,255,255,.65)}.modal-wide{max-width:520px;max-height:min(92vh,800px)}.modal-group-detail{max-width:min(920px,calc(100vw - 32px));max-height:min(92vh,880px)}.modal-group-detail.modal-group-detail-revamp{border-radius:var(--radius-xl);box-shadow:var(--shadow-modal-rich);border:1px solid rgba(255,255,255,.75);overflow:hidden;display:flex;flex-direction:column;margin:auto}.modal-backdrop:has(.modal-group-detail-revamp){-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.group-detail-header{padding:0;border-bottom:1px solid var(--color-border-tertiary);background:linear-gradient(125deg,#3b82f61a,#ffffff8c 48%,#10b9810f)}.modal-group-detail-revamp .modal-header.group-detail-header h3{margin:0}.group-detail-header-main{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:20px 22px 18px;flex-wrap:wrap}.group-detail-hero{display:flex;gap:14px;align-items:flex-start;min-width:0}.group-detail-hero-avatar{flex-shrink:0;width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;letter-spacing:.02em;color:#fff;background:linear-gradient(145deg,#3b82f6,#1d4ed8);box-shadow:0 4px 14px #2563eb59}.group-detail-hero-text{min-width:0}.group-detail-title{margin:0 0 4px;font-size:1.35rem;font-weight:700;line-height:1.25;letter-spacing:-.02em}.group-detail-tagline{margin:0 0 10px;font-size:13px;color:var(--color-text-secondary);line-height:1.4}.group-detail-hero-chips{display:flex;flex-wrap:wrap;gap:6px}.group-detail-header-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.group-detail-close-btn{min-width:88px}.group-detail-body{padding:18px 22px 22px;overflow:auto;flex:1;background:var(--color-background)}.group-detail-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:16px}.group-detail-stat-card{border:1px solid var(--color-border-tertiary);border-radius:var(--radius-lg);padding:14px 16px;background:var(--color-background-secondary);display:flex;flex-direction:column;gap:6px;min-height:120px}.group-detail-stat-card--ring{align-items:center;text-align:center}.group-detail-stat-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-secondary)}.group-detail-stat-value{font-size:1.25rem;font-weight:700;line-height:1.2}.group-detail-stat-value--money{font-variant-numeric:tabular-nums}.group-detail-stat-sub{font-size:12px;color:var(--color-text-secondary);line-height:1.35}.group-detail-ring-wrap{display:flex;justify-content:center;padding:4px 0 2px}.group-detail-ring{width:92px;height:92px;border-radius:50%;background:conic-gradient(from -90deg,var(--group-occ-color, #3b82f6) var(--group-occ-deg, 0deg),rgba(15,23,42,.1) 0);display:flex;align-items:center;justify-content:center}.group-detail-ring-inner{width:72px;height:72px;border-radius:50%;background:var(--color-background-secondary);display:flex;align-items:center;justify-content:center;box-shadow:inset 0 1px 2px #0f172a0f}.group-detail-ring-pct{font-size:15px;font-weight:800;font-variant-numeric:tabular-nums;letter-spacing:-.03em}.group-detail-section{margin-bottom:4px}.group-detail-section--sheet{border:1px solid var(--color-border-tertiary);border-radius:var(--radius-lg);padding:14px 16px 16px;background:var(--color-background-secondary);margin-bottom:12px}.group-detail-section--students{margin-bottom:0}.group-detail-section-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:8px}.group-detail-section-title{margin:0;font-size:14px;font-weight:700;letter-spacing:-.02em}.group-detail-section-hint{margin:0;font-size:11px;color:var(--color-text-secondary)}.group-detail-schedule-text{margin:0;font-size:13px;line-height:1.55;color:var(--color-text-primary)}.group-detail-muted{margin:0;font-size:13px;color:var(--color-text-secondary)}.group-detail-table-wrap{overflow-x:auto;margin:0 -4px}.group-detail-students-table{width:100%;min-width:420px;font-size:13px}.group-detail-students-table tbody tr.group-detail-student-row{cursor:pointer;transition:background .12s ease}.group-detail-students-table tbody tr.group-detail-student-row:hover{background:#3b82f60f}.group-detail-students-table tbody tr.group-detail-student-row:focus-visible{outline:2px solid rgba(59,130,246,.45);outline-offset:-2px}.group-detail-students-hint{margin:10px 0 0;font-size:11px;color:var(--color-text-secondary)}.dashboard-occupancy-table .dashboard-occupancy-actions-th,.dashboard-occupancy-table .dashboard-occupancy-actions{width:1%;white-space:nowrap;text-align:right;vertical-align:middle}.dashboard-occupancy-detail-btn{font-size:11px;padding:4px 10px}.dashboard-occupancy-progress{min-width:72px}@media(max-width:640px){.group-detail-header-main{flex-direction:column;align-items:stretch}.group-detail-header-actions{justify-content:flex-end}.group-detail-summary{grid-template-columns:1fr}}.modal-student-detail{max-width:min(1040px,calc(100vw - 32px));max-height:min(94vh,900px);border-radius:var(--radius-xl);box-shadow:var(--shadow-modal-rich);border:1px solid rgba(255,255,255,.75);overflow:hidden}.modal-parent-detail.modal-student-detail{max-width:min(760px,calc(100vw - 32px))}button.parent-detail-student-row{width:100%;text-align:left;cursor:pointer;font-family:inherit;border:.5px solid var(--color-border-tertiary);transition:background .12s ease,border-color .12s ease}button.parent-detail-student-row:hover{border-color:#c7d2fe;background:#eff6ffd9}button.parent-detail-student-row:focus-visible{outline:2px solid #6366f1;outline-offset:2px}.modal-parent-detail .teacher-insight-student-list{margin-top:0}.modal-backdrop:has(.modal-student-detail){background:#0f172a6b;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.modal-student-detail>.modal-header.student-detail-header{padding:22px 22px 18px;margin:0;border-bottom:none;background:linear-gradient(125deg,#fff7ed,#faf5ff 32%,#eff6ff 65%,#ecfeff);position:relative}.modal-student-detail>.modal-header.student-detail-header:after{content:"";position:absolute;left:16px;right:16px;bottom:0;height:1px;background:linear-gradient(90deg,transparent,rgba(148,163,184,.45) 15%,rgba(148,163,184,.45) 85%,transparent)}.modal-student-detail .modal-body.student-detail-body{padding:20px 22px 24px;background:linear-gradient(180deg,#f8fafc,#f1f5f9 55%,#eef2ff)}.modal-student-detail .student-detail-header{border-bottom:none;padding-bottom:0}.modal-student-detail .student-detail-hero-avatar--lg{background:linear-gradient(145deg,#6366f1,#8b5cf6 45%,#ec4899);color:#fff;font-weight:700;box-shadow:0 10px 28px #6366f16b,0 0 0 3px #ffffffd9}.modal-student-detail .student-detail-tagline{color:#475569;font-weight:600}.modal-student-detail .student-detail-hero-chips .pill-red{box-shadow:0 0 0 3px #f43f5e33}.modal-student-detail .student-detail-header-actions--toolbar .btn-green{box-shadow:0 2px 8px #10b98140}.modal-student-detail .student-detail-summary{background:linear-gradient(180deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:var(--radius-xl);box-shadow:var(--shadow-elevated);padding:18px 18px 20px}.modal-student-detail .student-detail-summary-head{border-bottom-color:#e2e8f0}.modal-student-detail .student-detail-summary-title{color:#4f46e5;letter-spacing:.1em}.modal-student-detail .student-detail-summary-block{border-radius:12px;padding:14px 14px 10px;border:1px solid transparent}.modal-student-detail .student-detail-summary-grid>.student-detail-summary-block:first-child{background:linear-gradient(165deg,#eff6fff2,#e0f2fe80);border-color:#3b82f62e}.modal-student-detail .student-detail-summary-grid>.student-detail-summary-block:last-child{background:linear-gradient(165deg,#faf5fff2,#f3e8ff73);border-color:#8b5cf633}.modal-student-detail .student-detail-summary-block-title{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#64748b;margin-bottom:12px}.modal-student-detail .student-detail-dl-row{border-bottom-color:#94a3b840}.modal-student-detail .student-detail-link{color:#2563eb;font-weight:600}.modal-student-detail a.student-detail-wa-btn.btn.btn-green{background:linear-gradient(180deg,#22c55e,#16a34a);border:1px solid #15803d;color:#fff;font-weight:600;border-radius:10px;padding:8px 16px;box-shadow:0 4px 14px #16a34a59}.modal-student-detail .student-detail-wa-btn:hover{filter:brightness(1.06)}.modal-student-detail .student-detail-section--sheet{position:relative;border-radius:var(--radius-xl);border:1px solid #e2e8f0;background:#fff;padding:18px 20px 18px 22px;margin-bottom:20px;box-shadow:var(--shadow-elevated);overflow:hidden}.modal-student-detail .student-detail-section--sheet:before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;border-radius:5px 0 0 5px}.modal-student-detail .student-detail-section--tone-teal:before{background:linear-gradient(180deg,#5eead4,#0d9488)}.modal-student-detail .student-detail-section--tone-indigo:before{background:linear-gradient(180deg,#a5b4fc,#4f46e5)}.modal-student-detail .student-detail-section--tone-violet:before{background:linear-gradient(180deg,#d8b4fe,#7c3aed)}.modal-student-detail .student-detail-section--sheet .student-detail-section-title{color:#475569;font-size:11px;letter-spacing:.09em}.modal-student-detail .student-detail-payments-wrap{border-radius:12px;border:1px solid #e2e8f0;overflow:hidden;background:#fff}.modal-student-detail .student-detail-payments-table thead th{background:linear-gradient(180deg,#f8fafc,#f1f5f9);color:#64748b;border-bottom:1px solid #e2e8f0}.modal-student-detail .student-detail-payments-month-header td{background:linear-gradient(90deg,#eef2ff,#e0e7ff,#f5f3ff);border-top:1px solid #c7d2fe;padding:10px 14px}.modal-student-detail .student-detail-month-head-title{font-size:14px;font-weight:700;color:#3730a3;text-transform:capitalize}.modal-student-detail .student-detail-month-head-meta{color:#4338ca;font-size:12px}.modal-student-detail .student-detail-payments-row td{background:#fff}.modal-student-detail .student-detail-payments-table tbody tr:hover td{background:#eff6ffa6}.modal-student-detail .student-detail-att-nav{background:linear-gradient(90deg,#eef2ffcc,#faf5ffa6);border:1px solid #e2e8f0;border-radius:12px;padding:10px 12px}.modal-student-detail .student-detail-att-nav-title{color:#4338ca;font-weight:700}.modal-student-detail .student-detail-att-legend{border:1px solid #e2e8f0;border-radius:12px;background:linear-gradient(180deg,#fff,#f8fafc)}.modal-student-detail .student-detail-timeline-dot{background:linear-gradient(145deg,#8b5cf6,#6366f1);box-shadow:0 0 0 3px #c4b5fd8c}.modal-student-detail .student-detail-timeline-when{color:#6d28d9}.modal-student-detail .student-detail-timeline-details{margin:14px 0 6px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;overflow:hidden}.modal-student-detail .student-detail-timeline-details>summary{cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;font-weight:600;color:#334155;background:linear-gradient(180deg,#fff,#f8fafc)}.modal-student-detail .student-detail-timeline-details>summary::-webkit-details-marker{display:none}.modal-student-detail .student-detail-timeline-summary-hint{font-weight:500;font-size:12px;color:#64748b}.modal-student-detail .student-detail-timeline-body{padding:0 14px 14px;border-top:1px solid #ede9fe;background:linear-gradient(135deg,#faf5ff,#f8fafc)}.modal-student-detail .student-detail-timeline-table-wrap{margin-top:10px;border-radius:10px;overflow:auto;max-height:min(52vh,420px);border:1px solid #e2e8f0}.modal-student-detail .student-detail-timeline-table{font-size:13px;margin:0}.modal-student-detail .student-detail-timeline-table th{white-space:nowrap}.modal-student-detail .student-detail-timeline-msg{vertical-align:top;line-height:1.45}.modal-student-detail .student-detail-timeline-actor{margin-top:4px;font-size:11px;color:#64748b}.modal-student-detail .student-detail-timeline-date{white-space:nowrap;vertical-align:top;font-size:12px}.modal-student-detail .student-detail-section--sheet:last-child{margin-bottom:10px}.student-detail-header{padding-bottom:16px;border-bottom:1px solid var(--color-border-tertiary);margin-bottom:0}.student-detail-header-revamp{display:block}.student-detail-header-main{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:20px 24px}.modal-student-detail .modal-header h3.student-detail-title,.student-detail-title{font-size:20px;font-weight:600;margin:0 0 4px;line-height:1.25;letter-spacing:-.02em}.student-detail-tagline{margin:0 0 10px;font-size:14px;color:var(--color-text-secondary);font-weight:500}.student-detail-hero{display:flex;gap:14px;align-items:center;flex:1;min-width:0}.student-detail-hero-revamp{align-items:flex-start;flex:1 1 280px;min-width:min(100%,280px)}.student-detail-hero-avatar{width:48px;height:48px;border-radius:50%;background:var(--color-blue-50, #e6f0ff);color:var(--color-blue-600, #1a56db);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;flex-shrink:0}.student-detail-hero-avatar--lg{width:56px;height:56px;font-size:18px;box-shadow:0 2px 8px #1a56db1f}.student-detail-hero-text{min-width:0}.student-detail-hero-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.student-detail-header-actions{display:flex;gap:8px;flex-shrink:0;align-items:center}.student-detail-header-actions--toolbar{flex-wrap:wrap;justify-content:flex-end;flex:0 1 auto}.student-detail-close-btn{font-size:13px}.student-detail-summary{margin-bottom:20px;padding:16px 18px;border:1px solid var(--color-border-tertiary);border-radius:10px;background:var(--color-background-secondary, #f8fafc)}.student-detail-summary-head{margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--color-border-tertiary)}.student-detail-summary-title{display:block;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:4px}.student-detail-summary-hint{font-size:12px;color:var(--color-text-secondary)}.student-detail-summary-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:20px 28px}.student-detail-summary-block-title{font-size:13px;font-weight:600;color:var(--color-text-primary);margin-bottom:10px}.student-detail-dl{margin:0;display:flex;flex-direction:column;gap:0}.student-detail-dl-row{display:grid;grid-template-columns:118px minmax(0,1fr);gap:10px 14px;padding:8px 0;border-bottom:1px solid var(--color-border-tertiary);font-size:13px;align-items:baseline}.student-detail-dl-row:last-child{border-bottom:none;padding-bottom:0}.student-detail-dl-row--multiline{align-items:start}.student-detail-dl-row dt{margin:0;font-size:12px;font-weight:500;color:var(--color-text-tertiary)}.student-detail-dl-row dd{margin:0;color:var(--color-text-primary);word-break:break-word}.student-detail-dl-pill{font-size:11px;vertical-align:middle}.student-detail-muted-inline{color:var(--color-text-tertiary);font-size:13px}.student-detail-link{color:var(--color-blue-600, #1a56db);text-decoration:none;font-weight:500}.student-detail-link:hover{text-decoration:underline}.student-detail-pref-chips{display:flex;flex-wrap:wrap;gap:6px}.student-detail-contact-actions{margin-top:12px;display:flex;flex-wrap:wrap;gap:8px}.student-detail-wa-btn{text-decoration:none;display:inline-flex;align-items:center}.student-detail-body{padding-top:14px}.student-detail-section{margin-bottom:22px}.student-detail-section:last-child{margin-bottom:4px}.student-detail-section-head{margin-bottom:12px}.student-detail-section-title{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:4px}.student-detail-section-lead{margin:0;font-size:12px;color:var(--color-text-secondary);line-height:1.45}.student-detail-section-hint{margin:0 0 12px;font-size:12px;color:var(--color-text-secondary);line-height:1.45}.student-detail-muted{margin:0;font-size:13px;color:var(--color-text-tertiary)}.student-detail-payments-wrap{overflow-x:auto}.student-detail-payments-table{min-width:720px}.student-detail-payments-table th{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-tertiary)}.student-detail-payments-month-header td{background:var(--color-background-secondary);padding:6px 12px;border-top:2px solid var(--color-border-tertiary)}.student-detail-payments-table>tbody>tr.student-detail-payments-month-header:first-child td{border-top:none}.student-detail-month-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap}.student-detail-month-head-title{font-size:13px;font-weight:600;text-transform:capitalize}.student-detail-month-head-meta{font-size:11px;color:var(--color-text-secondary)}.student-detail-payments-row td{vertical-align:top}.student-detail-payments-row--extra td:first-child{padding-left:24px}.student-detail-kalem{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.student-detail-kalem-text{font-weight:500}.student-detail-actions{gap:4px;margin-left:auto;align-items:flex-end}.student-detail-actions .pay-action-btn-main{font-size:11px;padding:4px 10px}.student-detail-actions .pay-actions-secondary{justify-content:flex-end}.student-detail-inline-pill{font-size:9px;padding:1px 6px;margin-left:6px}.student-detail-status-cell{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.student-detail-status-hint{font-size:10px;color:var(--color-text-tertiary)}.student-detail-status-hint--late{color:var(--color-red-600, #b91c1c)}.student-detail-att-legend{margin-bottom:12px;padding:10px 12px}.student-detail-att-nav{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}.student-detail-att-nav-title{font-size:13px;font-weight:600;text-transform:capitalize;color:var(--color-text-secondary)}.student-detail-load-more{display:flex;justify-content:center;margin-top:10px}.student-detail-attendance-month-th{text-align:center;font-size:11px;text-transform:capitalize;letter-spacing:.02em;background:var(--color-background-secondary);border-bottom:1px solid var(--color-border-tertiary);padding:6px 4px}.student-detail-attendance-table--combined th,.student-detail-attendance-table--combined td{min-width:36px}.student-detail-attendance-seg-start{border-left:2px solid var(--color-border)!important}.student-detail-grouplog{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.student-detail-grouplog-item{display:flex;gap:12px;font-size:13px;padding:8px 10px;background:var(--color-background-secondary);border-radius:6px}.student-detail-grouplog-when{font-size:11px;color:var(--color-text-tertiary);min-width:140px;flex-shrink:0}.student-detail-grouplog-text{color:var(--color-text-primary)}.student-detail-timeline{list-style:none;margin:0;padding:0 0 0 4px;display:flex;flex-direction:column;gap:0}.student-detail-timeline-item{position:relative;display:flex;gap:14px;padding:0 0 16px;margin:0}.student-detail-timeline-item:last-child{padding-bottom:0}.student-detail-timeline-item:before{content:"";position:absolute;left:5px;top:10px;bottom:-6px;width:2px;background:var(--color-border-tertiary);border-radius:1px}.student-detail-timeline-item:last-child:before{bottom:auto;height:0}.student-detail-timeline-dot{flex-shrink:0;width:12px;height:12px;margin-top:4px;border-radius:50%;background:var(--color-blue-600, #1a56db);border:2px solid var(--color-background-primary, #fff);box-shadow:0 0 0 2px var(--color-blue-100, #bfdbfe);z-index:1}.student-detail-timeline-body{min-width:0;flex:1;background:var(--color-background-secondary);border-radius:8px;padding:10px 12px}.student-detail-timeline-when{display:block;font-size:11px;font-weight:600;color:var(--color-text-tertiary);letter-spacing:.02em;margin-bottom:4px}.student-detail-timeline-text{margin:0;font-size:13px;line-height:1.45;color:var(--color-text-primary)}@media(max-width:720px){.student-detail-header-main{flex-direction:column;align-items:stretch}.student-detail-header-actions--toolbar{justify-content:stretch}.student-detail-header-actions--toolbar .btn{flex:1 1 auto;justify-content:center}.student-detail-summary-grid{grid-template-columns:1fr}.student-detail-dl-row{grid-template-columns:100px minmax(0,1fr)}.student-detail-grouplog-item{flex-direction:column;gap:2px}.student-detail-grouplog-when{min-width:0}}.dashboard-student-search-card{position:relative;margin-bottom:16px}.dashboard-student-search-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}.dashboard-student-search-hint{margin:4px 0 0;font-size:12px;color:var(--color-text-secondary);line-height:1.45}.dashboard-student-search-field{position:relative}.dashboard-student-search-input{width:100%;padding:10px 14px;border-radius:10px;border:1px solid var(--color-border-secondary);background:var(--color-background-primary);font-size:14px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.dashboard-student-search-input[type=search]::-webkit-search-decoration,.dashboard-student-search-input[type=search]::-webkit-search-cancel-button,.dashboard-student-search-input[type=search]::-webkit-search-results-button,.dashboard-student-search-input[type=search]::-webkit-search-results-decoration{display:none}.dashboard-student-search-input:focus{border-color:var(--color-blue-500, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.dashboard-student-search-input.dashboard-student-search-input--with-icon:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f12e}.dashboard-student-search-list{list-style:none;margin:6px 0 0;padding:4px;max-height:320px;overflow-y:auto;border:1px solid var(--color-border-tertiary);border-radius:10px;background:var(--color-background-primary);box-shadow:0 12px 40px -12px #0f172a2e,0 4px 16px #0f172a0f;animation:dashboard-search-dropdown-in .22s ease both}@keyframes dashboard-search-dropdown-in{0%{opacity:0;transform:translateY(-6px) scale(.99)}to{opacity:1;transform:none}}@media(prefers-reduced-motion:reduce){.dashboard-student-search-list{animation:none}}.dashboard-student-search-empty{padding:12px;font-size:13px;color:var(--color-text-tertiary);text-align:center}.dashboard-student-search-option{display:flex;justify-content:flex-start;align-items:flex-start;gap:12px;width:100%;background:transparent;border:none;border-radius:8px;padding:10px 12px;cursor:pointer;text-align:left;color:inherit;font:inherit}.dashboard-student-search-option:hover:not(.dashboard-student-search-option-v2),.dashboard-student-search-option.is-active:not(.dashboard-student-search-option-v2){background:var(--color-background-secondary)}.dashboard-student-search-option-main{display:flex;flex-direction:column;flex:1;min-width:0;align-items:flex-start;text-align:left}.dashboard-student-search-option-sub{font-size:12px;color:var(--color-text-secondary);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dashboard-student-search-option-tags{display:flex;gap:6px;flex-shrink:0;margin-left:auto}.modal-header{flex-shrink:0;padding:20px 20px 0}.modal-header h3{font-size:15px;font-weight:600;margin:0 0 14px;line-height:1.3}.modal-trial-appt .modal-body{padding-top:2px}.modal-trial-appt-callout{margin-bottom:16px}.modal-trial-appt-callout .modal-trial-appt-callout-text{margin:0;font-size:12px;line-height:1.5;color:var(--color-text-secondary)}.modal-trial-appt-section{margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--color-border-tertiary)}.modal-trial-appt-section:last-of-type{border-bottom:none;margin-bottom:0;padding-bottom:0}.modal-trial-appt-section-title{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-tertiary);margin:0 0 10px}.modal-trial-appt-datetime{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:start;margin-bottom:10px}.modal-trial-appt-datetime .form-row{margin-bottom:0;min-width:0}.modal-trial-appt-datetime .select-input{min-width:0}@media(max-width:460px){.modal-trial-appt-datetime{grid-template-columns:1fr}}.modal-trial-appt textarea.select-input{line-height:1.45;font-family:inherit}.modal-body{flex:1 1 auto;min-height:0;overflow-x:hidden;overflow-y:auto;padding:0 20px 12px;-webkit-overflow-scrolling:touch}.modal>.form-actions{flex-shrink:0;margin-top:0;padding:14px 20px calc(20px + env(safe-area-inset-bottom,0px));border-top:1px solid var(--color-border-tertiary);background:var(--color-background-primary);box-shadow:0 -8px 24px #0000000f;gap:10px}.collect-confirm-modal{max-width:400px}.collect-confirm-header h3{margin-bottom:6px}.collect-confirm-intro{margin:0;font-size:12px;line-height:1.45;color:var(--color-text-secondary)}.collect-confirm-body{padding-top:4px}.collect-confirm-summary{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);background:var(--color-background-secondary);padding:4px 12px;margin-bottom:14px}.collect-confirm-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:8px 0;border-bottom:.5px solid var(--color-border-tertiary);font-size:12px}.collect-confirm-k{flex-shrink:0;max-width:42%;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);line-height:1.35;padding-top:1px}.collect-confirm-v{text-align:right;font-weight:500;color:var(--color-text-primary);line-height:1.4;word-break:break-word}.collect-confirm-row--amount{border-bottom:none;padding-top:10px;margin-top:4px;border-top:1px solid var(--color-border-tertiary);align-items:center}.collect-confirm-row--amount .collect-confirm-k{padding-top:0}.collect-confirm-amount{font-size:17px;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-.02em;color:var(--color-text-primary)}.collect-paid-date-field{margin-bottom:16px}.collect-paid-date-label{display:block;font-size:11px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.collect-paid-date-hint{margin:0 0 8px;font-size:11px;line-height:1.35;color:var(--color-text-tertiary)}.collect-paid-date-input{width:100%;box-sizing:border-box;padding:8px 10px;font-size:13px;font-family:inherit;border-radius:var(--border-radius-md);border:1px solid var(--color-border-secondary);background:var(--color-background-primary);color:var(--color-text-primary)}.collect-paid-date-input:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 2px #0d948829}.collect-method-label{margin:0 0 8px;font-size:11px;font-weight:600;color:var(--color-text-secondary)}.collect-method-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}@media(max-width:380px){.collect-method-grid{grid-template-columns:1fr}}.collect-method-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:2px;min-height:56px;padding:10px 11px;margin:0;border-radius:var(--border-radius-md);border:1px solid var(--color-border-secondary);background:var(--color-background-primary);cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}.collect-method-card:hover{border-color:color-mix(in srgb,var(--color-accent, #639922) 38%,var(--color-border-secondary))}.collect-method-card.is-selected{border-color:var(--color-accent, #639922);background:color-mix(in srgb,var(--color-accent, #639922) 10%,var(--color-background-primary));box-shadow:0 0 0 1px color-mix(in srgb,var(--color-accent, #639922) 25%,transparent)}.collect-method-card:has(.collect-method-input:focus-visible){outline:2px solid var(--color-accent, #639922);outline-offset:2px}.collect-method-input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.collect-method-title{font-size:12px;font-weight:600;color:var(--color-text-primary);line-height:1.3}.collect-method-hint{font-size:10px;color:var(--color-text-tertiary);line-height:1.25}.collect-confirm-actions .btn-collect-confirm{background:var(--color-accent, #639922);color:#fff;border-color:color-mix(in srgb,var(--color-accent, #639922) 70%,#000);font-weight:600}.collect-confirm-actions .btn-collect-confirm:hover:not(:disabled){background:color-mix(in srgb,var(--color-accent, #639922) 88%,#000);filter:none}.collect-confirm-actions .btn-collect-confirm:disabled{opacity:.55}.monthly-inv-open-btn{border-color:color-mix(in srgb,var(--color-accent, #639922) 35%,var(--color-border-secondary));color:color-mix(in srgb,var(--color-accent, #639922) 90%,var(--color-text-primary))}.monthly-inv-open-btn:hover{background:color-mix(in srgb,var(--color-accent, #639922) 8%,var(--color-background-primary))}.modal-monthly-invoice{max-width:720px;max-height:min(92vh,880px)}.monthly-inv-intro{margin:0;font-size:12px;line-height:1.45;color:var(--color-text-secondary)}.monthly-inv-body{padding-top:4px}.monthly-inv-toolbar{display:flex;flex-direction:column;gap:12px;margin-bottom:12px}.monthly-inv-month-bar{max-width:100%}.monthly-inv-filters{display:flex;flex-wrap:wrap;gap:12px 16px;align-items:flex-end}.monthly-inv-filter label{display:block;font-size:11px;font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.monthly-inv-select{min-width:200px}.monthly-inv-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.monthly-inv-summary{display:flex;flex-wrap:wrap;align-items:center;gap:6px 10px;font-size:13px;color:var(--color-text-secondary);margin-bottom:10px}.monthly-inv-summary strong{color:var(--color-text-primary);font-weight:600}.monthly-inv-summary-sep{color:var(--color-text-tertiary)}.monthly-inv-loading{font-size:12px;color:var(--color-text-tertiary)}.monthly-inv-table-wrap{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);overflow:auto;max-height:min(48vh,420px);-webkit-overflow-scrolling:touch}.monthly-inv-table{margin:0;font-size:12px}.monthly-inv-table th,.monthly-inv-table td{white-space:nowrap}.monthly-inv-table td:nth-child(7){white-space:normal;max-width:200px}.monthly-inv-col-amt{text-align:right!important;font-variant-numeric:tabular-nums}.monthly-inv-empty{text-align:center;color:var(--color-text-tertiary);padding:20px 12px!important}.monthly-inv-extra-title{color:var(--color-text-tertiary);font-size:11px}.monthly-inv-table tfoot .monthly-inv-tfoot-row td{border-top:2px solid var(--color-border-secondary);padding-top:12px;padding-bottom:10px;font-weight:700;font-size:13px;color:var(--color-text-primary);background:var(--color-background-secondary)}.monthly-inv-table tfoot .monthly-inv-tfoot-row td:first-child{text-align:left}.form-row{margin-bottom:10px}.form-row label{display:block;font-size:11px;color:var(--color-text-secondary);margin-bottom:4px}.form-row-error label{color:#b42318}.form-hint{font-size:11px;color:var(--color-text-tertiary);margin:0 0 6px;line-height:1.35}.form-error-banner{font-size:12px;color:#b42318;background:#fef3f2;border:1px solid #fecdca;border-radius:var(--border-radius-md);padding:10px 12px;margin-bottom:12px;line-height:1.4}.form-field-error{font-size:11px;color:#b42318;margin:4px 0 0;line-height:1.35}.select-input-invalid,.select-input.select-input-invalid{border-color:#e24b4a!important;box-shadow:0 0 0 1px #e24b4a33}.parent-combobox-wrap{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-secondary);padding:12px}.parent-combobox-wrap--error{border-color:#e24b4a;box-shadow:0 0 0 1px #e24b4a26}.parent-combobox-wrap--disabled{opacity:.65;pointer-events:none}.geo-combobox{position:relative;width:100%}.geo-combobox--disabled{opacity:.65;pointer-events:none}.geo-combobox-field{position:relative;width:100%}.geo-combobox-input{width:100%;box-sizing:border-box;font-size:13px}.geo-combobox-input--has-clear{padding-right:32px}.geo-combobox-clear{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:28px;height:28px;display:flex;align-items:center;justify-content:center;margin:0;padding:0;border:none;border-radius:var(--border-radius-sm, 4px);background:transparent;color:var(--color-text-tertiary);font-size:20px;line-height:1;cursor:pointer}.geo-combobox-clear:hover{color:var(--color-text-primary);background:var(--color-background-secondary)}.geo-combobox-list{list-style:none;position:absolute;left:0;right:0;z-index:50;margin:4px 0 0;padding:0;max-height:220px;overflow-y:auto;border-radius:var(--border-radius-md);border:1px solid var(--color-border-secondary);background:var(--color-background-primary);box-shadow:0 6px 20px #00000014}.geo-combobox-empty{padding:12px 10px;font-size:12px;color:var(--color-text-tertiary);text-align:center}.geo-combobox-option{display:block;width:100%;padding:8px 12px;border:none;border-bottom:1px solid var(--color-border-tertiary);background:transparent;cursor:pointer;text-align:left;font:inherit;font-size:13px;font-weight:500;color:var(--color-text-primary)}.geo-combobox-option:last-child{border-bottom:none}.geo-combobox-option:hover,.geo-combobox-option:focus-visible{background:var(--color-background-secondary);outline:none}.geo-combobox-option--selected{background:#3d872e14}.parent-combobox-search-row{display:flex;gap:8px;align-items:center}.parent-combobox-input{flex:1;min-width:0;font-size:13px}.parent-combobox-clear{flex-shrink:0;font-size:11px;padding:6px 10px}.parent-combobox-selected{font-size:11px;color:var(--color-text-secondary);margin-top:8px}.parent-combobox-list{list-style:none;margin:10px 0 0;padding:0;max-height:240px;overflow-y:auto;border-radius:var(--border-radius-md);border:1px solid var(--color-border-secondary);background:var(--color-background-primary)}.parent-combobox-empty{padding:14px 12px;font-size:12px;color:var(--color-text-tertiary);text-align:center}.parent-combobox-option{display:flex;flex-direction:column;align-items:flex-start;gap:2px;width:100%;padding:10px 12px;border:none;border-bottom:1px solid var(--color-border-tertiary);background:transparent;cursor:pointer;text-align:left;font:inherit;color:var(--color-text-primary)}.parent-combobox-option:last-child{border-bottom:none}.parent-combobox-option:hover,.parent-combobox-option:focus-visible{background:var(--color-background-secondary);outline:none}.parent-combobox-option--selected{background:#3d872e14}.parent-combobox-option-name{font-size:13px;font-weight:600}.parent-combobox-option-meta{font-size:11px;color:var(--color-text-tertiary);word-break:break-word}.teacher-pick-wrap{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);background:var(--color-background-secondary);padding:12px}.teacher-pick-wrap--error{border-color:#e24b4a;box-shadow:0 0 0 1px #e24b4a26}.teacher-pick-search-row{display:flex;gap:8px;align-items:center;margin-bottom:10px}.teacher-pick-search{flex:1;min-width:0;font-size:13px}.teacher-pick-clear{flex-shrink:0;font-size:11px;padding:6px 10px}.teacher-pick-summary{margin-bottom:12px}.teacher-pick-count{display:block;font-size:11px;font-weight:500;color:var(--color-text-secondary);margin-bottom:8px}.teacher-pick-chips{display:flex;flex-wrap:wrap;gap:6px}.teacher-chip{display:inline-flex;align-items:center;gap:6px;padding:4px 6px 4px 4px;background:var(--color-background-primary);border:1px solid #c5d9a8;border-radius:999px;font-size:12px;max-width:100%}.teacher-chip-avatar{width:22px;height:22px;border-radius:50%;background:linear-gradient(145deg,#eaf3de,#d4e8bc);color:#3b6d11;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.teacher-chip-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px;color:var(--color-text-primary)}.teacher-chip-remove{border:none;background:transparent;color:var(--color-text-tertiary);cursor:pointer;font-size:16px;line-height:1;padding:0 2px;border-radius:4px;flex-shrink:0}.teacher-chip-remove:hover{color:#b42318;background:#b4231814}.teacher-pick-empty-hint{font-size:11px;color:var(--color-text-tertiary);margin:0 0 10px;font-style:italic}.teacher-pick-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(104px,1fr));gap:8px;max-height:220px;overflow-y:auto;padding:2px}.teacher-pick-no-match{grid-column:1 / -1;font-size:12px;color:var(--color-text-tertiary);text-align:center;padding:16px 8px;margin:0}.teacher-tile{position:relative;display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 8px 8px;border:1.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);background:var(--color-background-primary);cursor:pointer;font-family:inherit;text-align:center;transition:border-color .12s,background .12s,box-shadow .12s}.teacher-tile:hover{border-color:#a8c97a;background:#fafcf7}.teacher-tile--selected{border-color:#639922;background:linear-gradient(180deg,#f4f9ec,#fff);box-shadow:0 0 0 1px #6399221f}.teacher-tile-check{position:absolute;top:4px;right:5px;width:16px;height:16px;font-size:11px;font-weight:700;color:#639922;line-height:16px}.teacher-tile-avatar{width:40px;height:40px;border-radius:50%;background:var(--color-background-secondary);border:1px solid var(--color-border-tertiary);color:var(--color-text-secondary);font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.teacher-tile--selected .teacher-tile-avatar{background:linear-gradient(145deg,#eaf3de,#dcecc4);border-color:#b8d68f;color:#3b6d11}.teacher-tile-name{font-size:11px;font-weight:500;color:var(--color-text-primary);line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word}.form-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}.toast{position:fixed;bottom:20px;right:20px;background:#1a1a1e;color:#fff;padding:12px 16px;border-radius:8px;font-size:13px;z-index:200;max-width:360px;box-shadow:0 8px 24px #0003}.table-actions{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.schedule-toolbar{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px}.schedule-view-toggle{display:flex;gap:6px}.month-nav{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.month-nav-label{font-size:13px;font-weight:500;min-width:140px;text-align:center}.pay-month-bar{display:flex;align-items:center;gap:0;background:var(--color-background-primary);border:1.5px solid var(--color-border-secondary);border-radius:14px;padding:6px 8px;margin-bottom:20px;width:fit-content;box-shadow:0 1px 4px #0000000f}.pay-month-arrow{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;border:1.5px solid var(--color-border-secondary);background:var(--color-background-secondary);color:var(--color-text-primary);font-size:18px;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s,transform .1s;flex-shrink:0;line-height:1}.pay-month-arrow:hover:not(:disabled){background:#f0fdf4;border-color:#4ade80;transform:scale(1.08)}.pay-month-arrow-disabled,.pay-month-arrow:disabled{opacity:.35;cursor:not-allowed;transform:none!important}.pay-month-center{display:flex;align-items:center;gap:8px;padding:0 18px;min-width:180px;justify-content:center}.pay-month-label{font-size:16px;font-weight:700;color:var(--color-text-primary);letter-spacing:-.2px;text-transform:capitalize}.pay-month-badge{font-size:10px;font-weight:600;background:#dcfce7;color:#15803d;border-radius:20px;padding:2px 8px;white-space:nowrap}.pay-month-today-btn{margin-left:10px;font-size:12px;font-weight:500;color:#16a34a;background:none;border:1.5px solid #86efac;border-radius:8px;padding:4px 10px;cursor:pointer;transition:background .15s;white-space:nowrap}.pay-month-today-btn:hover{background:#f0fdf4}.pay-auto-recurring-hint{margin:6px 0 0;font-size:12px;line-height:1.45;color:var(--color-text-secondary);max-width:420px}.pay-table-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.pay-header-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.pay-search-input{min-width:180px;max-width:320px;flex:1 1 180px;padding:7px 10px;border:.5px solid var(--color-border-secondary);border-radius:var(--border-radius-md);font-size:12px;background:var(--color-background-primary);color:var(--color-text-primary);font-family:inherit}.pay-search-input::placeholder{color:var(--color-text-tertiary)}.pay-search-empty{text-align:center;padding:24px 12px;color:var(--color-text-secondary);font-size:13px}.pay-filter-tabs{display:flex;background:var(--color-background-secondary);border:1px solid var(--color-border-secondary);border-radius:8px;padding:3px;gap:2px}.pay-filter-tab{padding:5px 14px;border-radius:6px;border:none;background:transparent;font-size:12px;font-weight:500;color:var(--color-text-secondary);cursor:pointer;transition:background .15s,color .15s,box-shadow .15s;font-family:inherit;white-space:nowrap}.pay-filter-tab:hover:not(.active){background:var(--color-background-primary);color:var(--color-text-primary)}.pay-filter-tab.active{background:var(--color-background-primary);color:var(--color-text-primary);font-weight:600;box-shadow:0 1px 3px #0000001a}.pay-filter-tab-danger.active{background:#fef2f2;color:#dc2626}.pay-filter-tab-amber.active{background:#fffbeb;color:#d97706}.pay-action-group{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.pay-recurring-btn{border-color:#86efac;color:#15803d}.pay-recurring-btn:hover{background:#f0fdf4;border-color:#4ade80}.pay-status-cell{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.pay-status-hint{font-size:11px;line-height:1.3;color:var(--color-text-tertiary)}.pay-status-hint--late{color:#c2410c;font-weight:500}.pay-actions-col{width:1%;white-space:nowrap}.pay-actions-cell{vertical-align:middle}.pay-actions-stack{display:flex;flex-direction:column;align-items:stretch;gap:8px;min-width:118px;max-width:148px}.pay-action-btn-main{font-size:12px;font-weight:600;padding:7px 10px;width:100%;justify-content:center}.pay-actions-secondary{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:0 2px;line-height:1.4}.pay-action-link{background:none;border:none;padding:2px 3px;margin:0;cursor:pointer;color:var(--color-text-secondary);font-size:11px;text-decoration:underline;text-underline-offset:2px}.pay-action-link:hover{color:var(--color-text-primary)}.pay-action-link-danger{color:var(--color-text-tertiary)}.pay-action-link-danger:hover{color:#e24b4a}.pay-action-sep{color:var(--color-text-tertiary);font-size:11px;-webkit-user-select:none;user-select:none;padding:0 1px}.slot-rows{display:flex;flex-direction:column;gap:8px}.slot-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.slot-row .select-input{flex:1;min-width:120px}.group-card-actions{display:flex;gap:8px;margin-top:12px;padding-top:10px;border-top:.5px solid var(--color-border-tertiary)}.month-cal{min-width:280px}.month-cal-head{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;margin-bottom:4px}.month-cal-dow{text-align:center;font-size:10px;font-weight:600;color:var(--color-text-secondary);padding:4px}.month-cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:1px;background:var(--color-border-tertiary);border-radius:var(--border-radius-md);overflow:hidden}.month-cal-cell{background:var(--color-background-primary);min-height:88px;padding:6px 4px;font-size:10px}.month-cal-empty{background:var(--color-background-secondary);min-height:88px}.month-cal-today{box-shadow:inset 0 0 0 2px #639922}.month-cal-daynum{font-weight:600;color:var(--color-text-secondary);margin-bottom:4px}.month-cal-slots{display:flex;flex-direction:column;gap:3px}.month-slot{border-radius:4px;padding:3px 4px;line-height:1.25;font-weight:500}.month-slot-time{font-weight:600;opacity:.85}.groups-page{max-width:1200px;margin:0 auto}.groups-page-header{display:flex;flex-wrap:wrap;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:20px}.groups-page-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--color-text-primary);margin:0 0 6px;line-height:1.2}.groups-page-subtitle{margin:0;font-size:13px;line-height:1.5;color:var(--color-text-secondary);max-width:52ch}.groups-page-subtitle strong{font-weight:600;color:var(--color-text-primary)}.groups-page-cta{flex-shrink:0;padding:10px 18px;font-weight:600;border-radius:var(--radius-xl);box-shadow:0 4px 14px -4px #10b98173}.groups-empty{text-align:center;padding:36px 28px 40px;border-radius:var(--radius-xl);border:1px dashed var(--color-border-secondary);background:linear-gradient(180deg,var(--color-background-primary) 0%,var(--color-background-tertiary) 100%);box-shadow:var(--shadow-elevated)}.groups-empty-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;margin-bottom:16px;border-radius:16px;background:linear-gradient(145deg,#e0e7ff,#fae8ff);color:var(--color-brand-violet)}.groups-empty-icon svg{width:28px;height:28px}.groups-empty-title{font-size:1.05rem;font-weight:600;margin:0 0 8px;color:var(--color-text-primary)}.groups-empty-text{font-size:13px;line-height:1.55;color:var(--color-text-secondary);max-width:42ch;margin:0 auto 20px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:18px}.groups-grid .group-card.card{margin-bottom:0}.group-card{position:relative;overflow:hidden;padding:0;border-radius:var(--radius-xl);border:1px solid rgba(148,163,184,.22);box-shadow:0 2px 4px #0f172a0a,0 12px 28px -8px #0f172a1a;transition:box-shadow .2s ease,transform .2s ease}.group-card:hover{box-shadow:0 4px 8px #0f172a0f,0 20px 40px -12px #0f172a24;transform:translateY(-1px)}.group-card-accent{height:4px;width:100%}.group-card-top{display:flex;align-items:flex-start;gap:12px;padding:16px 16px 12px}.group-card-avatar{flex-shrink:0;width:44px;height:44px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;letter-spacing:.02em;color:#1e3a5f;background:linear-gradient(145deg,#dbeafe,#e0e7ff 55%,#f5f3ff);border:1px solid rgba(148,163,184,.28)}.group-card-heading{flex:1;min-width:0}.group-card-name{font-size:15px;font-weight:600;line-height:1.3;margin:0 0 6px;color:var(--color-text-primary);letter-spacing:-.01em}.group-card-chips{display:flex;flex-wrap:wrap;align-items:center;gap:4px;font-size:11px;color:var(--color-text-secondary)}.group-card-level{font-weight:500;color:var(--color-text-primary)}.group-card-dot{color:var(--color-text-tertiary);-webkit-user-select:none;user-select:none}.group-card-age{color:var(--color-text-secondary)}.group-card-top .pill{flex-shrink:0;align-self:flex-start;font-size:10px;font-weight:600;padding:4px 9px;border-radius:999px}.group-card-occblock{padding:0 16px 14px}.group-card-occ-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:8px}.group-card-occ-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary)}.group-card-occ-pct{font-size:18px;font-weight:700;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.group-card-occ-track{height:8px;border-radius:999px;background:var(--color-background-secondary);overflow:hidden;box-shadow:inset 0 1px 2px #0f172a0f}.group-card-occ-fill{height:100%;border-radius:999px;transition:width .35s ease}.group-card-occ-fill--muted{width:100%;background:repeating-linear-gradient(-45deg,var(--color-border-secondary),var(--color-border-secondary) 4px,var(--color-background-tertiary) 4px,var(--color-background-tertiary) 8px);opacity:.65}.group-card-occ-foot{margin-top:8px;font-size:12px;line-height:1.45;color:var(--color-text-secondary)}.group-card-occ-warn{color:#c2410c;font-weight:600}.group-card-occ-free{color:#15803d;font-weight:500}.group-card-occ-muted{color:var(--color-text-tertiary);font-weight:400}.group-card-facts{margin:0;padding:12px 16px;border-top:1px solid var(--color-border-tertiary);background:linear-gradient(180deg,rgba(248,250,252,.65) 0%,var(--color-background-primary) 100%)}.group-card-fact{display:grid;grid-template-columns:minmax(0,1fr);gap:2px;padding:10px 0;border-bottom:1px solid var(--color-border-tertiary)}.group-card-fact:last-child{border-bottom:none;padding-bottom:0}.group-card-fact:first-child{padding-top:2px}.group-card-fact dt{display:flex;align-items:center;gap:8px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.group-card-fact-icon{display:inline-flex;color:var(--color-text-secondary);opacity:.85}.group-card-fact-icon .nav-icon{width:14px;height:14px}.group-card-fact dd{margin:0;padding-left:22px;font-size:13px;font-weight:500;color:var(--color-text-primary);line-height:1.45;word-break:break-word}.group-card-fact--schedule dd{font-size:12px;font-weight:400;color:var(--color-text-secondary)}.group-card-actions.group-card-actions--revamp{flex-direction:column;align-items:stretch;gap:10px;margin-top:0;padding:14px 16px 16px;border-top:none}.group-card-action-primary{width:100%;justify-content:center;padding:10px 14px;font-weight:600;border-radius:var(--border-radius-md)}.group-card-action-row{display:flex;gap:8px;justify-content:stretch}.group-card-action-secondary{flex:1;font-size:12px;padding:8px 12px;border-radius:var(--border-radius-md)}@media(max-width:768px){.groups-page-header{flex-direction:column;align-items:stretch}.groups-page-cta{width:100%}.groups-grid{grid-template-columns:1fr}}.modal-receipt{max-width:480px}.receipt-modal-header h3{margin-bottom:4px}.receipt-modal-subtitle{margin:0;font-size:12px;line-height:1.45;color:var(--color-text-secondary);font-weight:400}.receipt-modal-subtitle--muted{color:var(--color-text-tertiary)}.receipt-modal-body{padding-top:6px}.receipt-share-stack{margin-top:16px;display:flex;flex-direction:column;gap:12px}.receipt-share-heading{margin:0;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-tertiary)}.receipt-action-panel{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);background:var(--color-background-secondary);padding:12px 14px}.receipt-action-panel-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:6px}.receipt-action-panel-title{font-size:13px;font-weight:600;color:var(--color-text-primary)}.receipt-action-panel-badge{flex-shrink:0;font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary);background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);padding:3px 7px;border-radius:999px}.receipt-action-panel-hint{margin:0 0 10px;font-size:11px;line-height:1.4;color:var(--color-text-secondary)}.receipt-action-input{width:100%}.receipt-action-primary{width:100%;margin-top:10px;font-weight:600}.receipt-whatsapp-actions--tight{margin-bottom:0}.receipt-wa-phone-line{margin:0 0 10px;font-size:12px;color:var(--color-text-secondary)}.receipt-wa-phone-line strong{font-weight:600;color:var(--color-text-primary)}.receipt-modal-footer-actions{gap:10px}.btn-receipt-print{font-weight:600;border-color:var(--color-border-secondary)}.btn-receipt-print:hover:not(:disabled){background:var(--color-background-secondary)}.receipt-sheet{border:1px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:22px 20px 20px;background:linear-gradient(165deg,#f8faf6,#fff 55%);box-shadow:inset 0 4px #639922;margin-bottom:4px}.receipt-sheet-inner{font-size:13px;line-height:1.45;color:var(--color-text-primary)}.receipt-brand-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.receipt-brand{font-size:17px;font-weight:700;letter-spacing:-.02em;line-height:1.25}.receipt-doc-badge{flex-shrink:0;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#4a7a1c;background:#eaf3de;padding:6px 10px;border-radius:var(--border-radius-md)}.receipt-muted{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.receipt-addr{margin-top:10px;white-space:pre-wrap}.receipt-contact-line{display:flex;flex-wrap:wrap;gap:10px 16px;margin-top:8px;font-size:12px;color:var(--color-text-secondary)}.receipt-meta-row{display:flex;flex-wrap:wrap;justify-content:flex-start;gap:12px 20px;margin-top:16px;padding-top:14px;border-top:1px dashed var(--color-border-secondary)}.receipt-meta-row>div{min-width:min(100%,120px);flex:1 1 120px}.receipt-meta-label{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-tertiary)}.receipt-meta-value{font-size:14px;font-weight:600;margin-top:2px}.receipt-party-block{margin-top:16px;padding:12px 14px;background:var(--color-background-secondary);border-radius:var(--border-radius-md)}.receipt-party-name{font-weight:600;font-size:14px;margin-top:2px}.receipt-table{width:100%;border-collapse:collapse;font-size:13px;margin-top:16px}.receipt-table th,.receipt-table td{padding:10px 8px;text-align:left;border-bottom:1px solid var(--color-border-tertiary);vertical-align:top}.receipt-table th{font-size:11px;font-weight:600;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.04em}.receipt-col-amount{text-align:right!important;white-space:nowrap;width:28%}.receipt-table .receipt-total td{font-weight:700;font-size:15px;border-bottom:none;padding-top:12px;color:var(--color-text-primary)}.receipt-footer{margin:18px 0 0;font-size:12px;color:var(--color-text-secondary);text-align:center}.receipt-email-panel{margin-top:18px;padding-top:16px;border-top:1px solid var(--color-border-tertiary)}.receipt-email-title{font-size:13px;font-weight:600;margin-bottom:4px}.receipt-checkbox-row{display:flex;align-items:flex-start;gap:8px;margin-top:10px;font-size:12px;line-height:1.4;cursor:pointer;color:var(--color-text-secondary)}.receipt-checkbox-row input{margin-top:2px;flex-shrink:0}.receipt-whatsapp-panel{margin-top:18px;padding-top:16px;border-top:1px solid var(--color-border-tertiary)}.receipt-whatsapp-actions{display:flex;flex-wrap:wrap;gap:8px}.receipt-whatsapp-actions .btn{flex:1;min-width:140px}.guide-page{max-width:900px;margin:0 auto;padding-bottom:40px}.guide-hero{text-align:center;padding:48px 24px 40px;background:linear-gradient(170deg,#f4f9ec,#e6f1fb,#fafafa);border-radius:var(--border-radius-lg);margin-bottom:32px;border:.5px solid var(--color-border-tertiary)}.guide-hero-brand{width:64px;height:64px;margin:0 auto 14px;border-radius:18px;display:grid;place-items:center;background:#fff;border:1px solid #dce7f5;box-shadow:0 6px 18px #378add24}.guide-hero-badge{display:inline-block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#4a7a1c;background:#eaf3de;padding:5px 14px;border-radius:20px;margin-bottom:16px}.guide-hero-title{font-size:28px;font-weight:700;line-height:1.3;color:var(--color-text-primary);margin:0 0 16px;letter-spacing:-.02em}.guide-hero-sub{font-size:15px;line-height:1.7;color:var(--color-text-secondary);max-width:600px;margin:0 auto}.guide-section{margin-bottom:36px}.guide-section-title{font-size:20px;font-weight:700;color:var(--color-text-primary);margin:0 0 10px;display:flex;align-items:center;gap:10px}.guide-section-icon{font-size:22px;line-height:1}.guide-section-desc{font-size:14px;color:var(--color-text-secondary);line-height:1.65;margin:0 0 20px}.guide-compare{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media(max-width:700px){.guide-compare{grid-template-columns:1fr}}.guide-compare-col{border-radius:var(--border-radius-lg);border:.5px solid var(--color-border-tertiary);overflow:hidden}.guide-compare-header{padding:14px 16px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}.guide-compare-header--old{background:#fef3f2;color:#a32d2d;border-bottom:1px solid #fecdca}.guide-compare-header--new{background:#eaf3de;color:#3b6d11;border-bottom:1px solid #c5d9a8}.guide-compare-icon{font-size:18px;line-height:1}.guide-compare-list{list-style:none;padding:12px 16px;margin:0;font-size:13px;line-height:1.55;color:var(--color-text-primary);background:var(--color-background-primary)}.guide-compare-list li{padding:8px 0 8px 22px;position:relative;border-bottom:.5px solid var(--color-border-tertiary)}.guide-compare-list li:last-child{border-bottom:none}.guide-compare-old .guide-compare-list li:before{content:"✕";position:absolute;left:0;top:8px;font-size:12px;font-weight:700;color:#e24b4a}.guide-compare-new .guide-compare-list li:before{content:"✓";position:absolute;left:0;top:8px;font-size:13px;font-weight:700;color:#639922}.guide-value-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}@media(max-width:700px){.guide-value-grid{grid-template-columns:repeat(2,1fr)}}.guide-value-card{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:20px 16px;text-align:center}.guide-value-card--green{border-top:3px solid #639922}.guide-value-card--blue{border-top:3px solid #378add}.guide-value-card--amber{border-top:3px solid #ef9f27}.guide-value-card--purple{border-top:3px solid #8b5cf6}.guide-value-number{font-size:32px;font-weight:800;color:var(--color-text-primary);line-height:1;margin-bottom:6px}.guide-value-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.guide-value-desc{font-size:12px;color:var(--color-text-tertiary);line-height:1.5}.guide-features{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}@media(max-width:700px){.guide-features{grid-template-columns:1fr}}.guide-feature{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:20px 16px;transition:box-shadow .15s,border-color .15s}.guide-feature:hover{border-color:#c5d9a8;box-shadow:0 4px 16px #63992214}.guide-feature-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:12px}.guide-feature-title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.guide-feature-desc{font-size:12px;color:var(--color-text-secondary);line-height:1.6;margin:0}.guide-steps{position:relative;padding-left:36px}.guide-steps:before{content:"";position:absolute;left:15px;top:4px;bottom:4px;width:2px;background:linear-gradient(180deg,#639922,#378add,#ef9f27);border-radius:2px}.guide-step{display:flex;gap:16px;margin-bottom:28px;position:relative}.guide-step:last-child{margin-bottom:0}.guide-step-number{position:absolute;left:-36px;width:30px;height:30px;border-radius:50%;background:#639922;color:#fff;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 6px #63992240;z-index:1}.guide-step-content{background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:16px 18px;flex:1}.guide-step-title{font-size:14px;font-weight:600;color:var(--color-text-primary);margin:0 0 8px}.guide-step-desc{font-size:13px;color:var(--color-text-secondary);line-height:1.65;margin:0}.guide-step-tip{margin-top:10px;padding:10px 12px;background:#fafcf7;border:1px solid #dcecc4;border-radius:var(--border-radius-md);font-size:12px;color:#3b6d11;line-height:1.55}.guide-footer{text-align:center;padding:32px 24px;background:linear-gradient(170deg,#eaf3de,#e6f1fb);border-radius:var(--border-radius-lg);border:.5px solid var(--color-border-tertiary);margin-top:8px}.guide-footer-text{font-size:15px;color:var(--color-text-primary);line-height:1.7;max-width:560px;margin:0 auto}@media print{.no-print{display:none!important}.modal-backdrop:has(.modal-receipt){position:static!important;inset:auto!important;background:#fff!important;padding:12px!important;align-items:flex-start!important}.modal-backdrop:has(.modal-receipt) .modal.modal-receipt{box-shadow:none!important;max-height:none!important;margin:0!important}.modal-backdrop:has(.modal-receipt) .modal-body{overflow:visible!important}.app>.sidebar,.app>.main{display:none!important}.app>.modal-backdrop:has(.modal-receipt){display:flex!important}}.auth-page{min-height:100vh;display:flex;background:#f0f2f5}.auth-layout{display:flex;width:100%;min-height:100vh}.auth-hero{width:45%;flex-shrink:0;background:#0f172a;display:flex;flex-direction:column;justify-content:center;padding:56px 52px;position:relative;overflow:hidden}.auth-hero:before{content:"";position:absolute;top:-120px;left:-80px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.18) 0%,transparent 70%);pointer-events:none}.auth-hero:after{content:"";position:absolute;bottom:-80px;right:-60px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(59,130,246,.12) 0%,transparent 70%);pointer-events:none}.auth-logo-row{display:flex;align-items:center;gap:14px;margin-bottom:48px}.auth-logo-wordmark{font-family:Poppins,sans-serif;font-size:26px;font-weight:600;letter-spacing:-.5px;line-height:1}.auth-logo-wordmark .wm-gym{color:#f1f5f9}.auth-logo-wordmark .wm-pro{color:#3b82f6}.auth-logo-tagline{font-size:11px;color:#ffffff61;letter-spacing:.5px;text-transform:uppercase;margin-top:2px}.auth-title{font-size:30px;font-weight:600;line-height:1.25;letter-spacing:-.03em;color:#f1f5f9;margin-bottom:14px}.auth-sub{font-size:14px;line-height:1.65;color:#f1f5f98c;max-width:38ch;margin-bottom:36px}.auth-features{display:flex;flex-direction:column;gap:12px}.auth-feature-item{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#f1f5f9bf}.auth-feature-icon{width:20px;height:20px;border-radius:50%;background:#3b82f633;border:1px solid rgba(59,130,246,.35);display:flex;align-items:center;justify-content:center;flex-shrink:0}.auth-feature-icon svg{width:11px;height:11px;stroke:#60a5fa;fill:none}.auth-form-side{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 32px;background:#f0f2f5}.auth-card{width:100%;max-width:400px;background:#fff;border-radius:16px;border:1px solid #e8eaed;padding:36px 36px 32px;box-shadow:0 2px 12px #0000000f,0 1px 3px #0000000a}.auth-card-logo{display:flex;align-items:center;gap:10px;margin-bottom:28px}.auth-card-logo .wm-gym{color:#1a1a1e}.auth-card-logo .wm-pro{color:#3b82f6}.auth-card-logo-text{font-family:Poppins,sans-serif;font-size:18px;font-weight:600;letter-spacing:-.3px;line-height:1}.auth-heading{font-size:20px;font-weight:600;color:#1a1a1e;letter-spacing:-.02em;margin-bottom:4px}.auth-subheading{font-size:13.5px;color:var(--color-text-secondary);margin-bottom:24px}.auth-tabs{display:flex;gap:0;border-bottom:1.5px solid #e8eaed;margin-bottom:24px}.auth-tab{flex:1;border:none;background:transparent;color:var(--color-text-secondary);padding:9px 4px;font-size:13.5px;font-weight:500;font-family:inherit;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1.5px;transition:color .15s,border-color .15s;letter-spacing:-.01em}.auth-tab:hover:not(.active){color:#1a1a1e}.auth-tab.active{color:#3b82f6;border-bottom-color:#3b82f6;font-weight:600}.auth-field{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}.auth-field label{font-size:13px;font-weight:500;color:#374151;letter-spacing:-.01em}.auth-input{width:100%;padding:9px 12px;border:1.5px solid #e2e5ea;border-radius:8px;font-size:14px;font-family:inherit;color:#1a1a1e;background:#fafafa;outline:none;transition:border-color .15s,box-shadow .15s,background .15s;line-height:1.5}.auth-input::placeholder{color:#b0b4ba}.auth-input:focus{border-color:#3b82f6;background:#fff;box-shadow:0 0 0 3px #3b82f61a}.auth-input-wrap{position:relative}.auth-input-wrap .auth-input{padding-right:40px}.auth-pw-toggle{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:2px 4px;color:#9ca3af;display:flex;align-items:center;line-height:1}.auth-pw-toggle:hover{color:#374151}.auth-pw-toggle svg{width:16px;height:16px;stroke:currentColor;fill:none}.auth-error{background:#fff1f2;border:1px solid #fecdd3;border-radius:8px;padding:9px 12px;font-size:13px;color:#be123c;margin-bottom:14px}.auth-submit{width:100%;padding:10px 16px;background:#1d4ed8;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;margin-top:6px;letter-spacing:-.01em;transition:background .15s,transform .1s}.auth-submit:hover:not(:disabled){background:#1e40af}.auth-submit:active:not(:disabled){transform:scale(.99)}.auth-submit:disabled{opacity:.65;cursor:not-allowed}.auth-submit-spinner{display:inline-flex;align-items:center;gap:8px}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-spinner-dot{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:auth-spin .7s linear infinite}.auth-divider{height:1px;background:#e8eaed;margin:20px 0 16px}.auth-footer-note{font-size:12px;color:#9ca3af;text-align:center;line-height:1.5}@media(max-width:860px){.auth-layout{flex-direction:column}.auth-hero{width:100%;padding:40px 28px 36px;min-height:unset}.auth-hero:before,.auth-hero:after{display:none}.auth-title{font-size:24px}.auth-sub{max-width:none;margin-bottom:24px}.auth-features{flex-direction:row;flex-wrap:wrap;gap:8px}.auth-feature-item{background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:999px;padding:5px 12px 5px 8px}.auth-form-side{padding:32px 20px 40px;align-items:flex-start}.auth-card{padding:28px 24px 24px}}.admin-actions{display:flex;gap:6px;flex-wrap:wrap}.trial-appt-page .trial-appt-toolbar{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:14px 16px;margin-bottom:18px}.trial-appt-page .trial-appt-lead{margin:0;max-width:52ch;font-size:13px;line-height:1.5;color:var(--color-text-secondary)}.trial-appt-page .trial-appt-create-btn{flex-shrink:0;align-self:center}.trial-appt-page .trial-appt-calendar-card{margin-bottom:16px;padding:14px 16px 16px}.trial-appt-page .trial-appt-calendar-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:10px 16px;margin-bottom:12px}.trial-appt-page .trial-appt-calendar-subtitle{font-size:12px;color:var(--color-text-secondary);margin-top:4px}.trial-appt-page .trial-appt-month-cal .month-cal-cell{min-height:104px}.trial-appt-page .trial-appt-month-cal .month-cal-slots{max-height:9.5em;overflow-y:auto;min-height:0}.trial-appt-page .trial-appt-month-slot{display:flex;align-items:baseline;gap:4px;min-width:0;width:100%;text-align:left;border:none;cursor:pointer;font-family:inherit}.trial-appt-page .trial-appt-month-slot .month-slot-time{flex-shrink:0}.trial-appt-page .trial-appt-month-slot-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.trial-appt-page .trial-appt-month-slot--lesson{background:var(--color-background-secondary);color:var(--color-text-secondary);border:1px dashed var(--color-border-secondary);font-weight:500;cursor:pointer}.trial-appt-page .trial-appt-month-slot--danger{background:#fcebeb;color:#a32d2d}.trial-appt-page .trial-appt-month-slot:hover{filter:brightness(.98)}.trial-appt-page .trial-appt-month-empty{color:var(--color-text-tertiary);font-size:10px;line-height:1.2}.trial-appt-page .trial-appt-filters-card{margin-bottom:16px;padding:14px 16px 16px}.trial-appt-page .trial-appt-filters-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--color-text-tertiary);margin-bottom:10px}.trial-appt-page .trial-appt-filter-chips{display:flex;flex-wrap:wrap;gap:8px}.trial-appt-page .trial-appt-filter-chip{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:1px solid var(--color-border-secondary);background:var(--color-background-primary);color:var(--color-text-primary);font-size:12px;font-weight:500;padding:7px 14px;border-radius:999px;cursor:pointer;transition:background .15s ease,border-color .15s ease,color .15s ease}.trial-appt-page .trial-appt-filter-chip:hover{border-color:var(--color-border-primary);background:var(--color-background-secondary)}.trial-appt-page .trial-appt-filter-chip--active{background:#eaf3de;border-color:#b8d68a;color:#2d5016}.trial-appt-page .trial-appt-filter-chip:focus-visible{outline:2px solid var(--color-accent, #639922);outline-offset:2px}.trial-appt-page .trial-appt-table-card{padding:0;overflow:hidden}.trial-appt-page .trial-appt-table-card:not(.trial-appt-table-wrap){padding:16px 20px}.trial-appt-page .trial-appt-table-wrap{overflow-x:auto}.trial-appt-page .trial-appt-table{min-width:880px;font-size:13px}.trial-appt-page .trial-appt-table th:nth-last-child(2),.trial-appt-page .trial-appt-table td:nth-last-child(2){min-width:128px;max-width:200px}.trial-appt-page .trial-appt-table th:last-child,.trial-appt-page .trial-appt-table td:last-child{width:1%;white-space:nowrap}.trial-appt-page .trial-appt-table td{vertical-align:middle;padding-top:8px;padding-bottom:8px}.trial-appt-page .trial-appt-name-cell{font-weight:500;max-width:160px}.trial-appt-page .trial-appt-phone-cell{white-space:nowrap;font-variant-numeric:tabular-nums;color:var(--color-text-secondary);font-size:12px}.trial-appt-page .trial-appt-when-cell{white-space:nowrap}.trial-appt-page .trial-appt-when-cell .trial-appt-time{margin-left:6px;font-weight:600;color:var(--color-text-primary)}.trial-appt-page .trial-appt-when-cell .trial-appt-date{color:var(--color-text-secondary)}.trial-appt-page .trial-appt-status-cell{vertical-align:middle}.trial-appt-page .trial-appt-inline-status{width:100%;max-width:100%;font-size:11px;padding:4px 8px;min-height:28px}.trial-appt-page .trial-appt-actions-cell{vertical-align:middle}.trial-appt-page .trial-appt-actions{display:inline-flex;flex-direction:row;flex-wrap:nowrap;align-items:center;gap:4px}.trial-appt-page .trial-appt-compact-btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;margin:0;border:1px solid var(--color-border-secondary);background:var(--color-background-primary);color:var(--color-text-primary);font-size:11px;font-weight:500;padding:3px 8px;line-height:1.3;border-radius:5px;cursor:pointer;white-space:nowrap;transition:background .12s ease,border-color .12s ease}.trial-appt-page .trial-appt-compact-btn:hover:not(:disabled){background:var(--color-background-secondary);border-color:var(--color-border-primary)}.trial-appt-page .trial-appt-compact-btn:disabled{opacity:.5;cursor:not-allowed}.trial-appt-page .trial-appt-compact-btn--primary{background:#eaf3de;border-color:#b8d68a;color:#2d5016}.trial-appt-page .trial-appt-compact-btn--primary:hover:not(:disabled){background:#dff0cc}.trial-appt-page .trial-appt-compact-btn--danger{background:#fff8f8;border-color:#f0c4c4;color:#a32d2d}.trial-appt-page .trial-appt-compact-btn--danger:hover:not(:disabled){background:#fcebeb}@media(max-width:980px){.trial-appt-page .trial-appt-calendar-header{align-items:stretch}.trial-appt-page .trial-appt-calendar-header .month-nav{width:100%;justify-content:flex-start}.auth-layout{grid-template-columns:1fr}.auth-title{font-size:24px}}
