@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: #f5f5f7;--color-background-tertiary: #fafafa;--color-border-secondary: #e5e5e8;--color-border-tertiary: #ececee;--color-text-primary: #1a1a1e;--color-text-secondary: #5c5c66;--color-text-tertiary: #8e8e98;--border-radius-md: 6px;--border-radius-lg: 10px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--color-background-tertiary);color:var(--color-text-primary)}.app{display:flex;min-height:100vh;background:var(--color-background-tertiary)}.sidebar{width:220px;background:var(--color-background-primary);border-right:.5px solid var(--color-border-tertiary);padding:16px 0;flex-shrink:0}.sidebar-logo{padding:0 16px 16px;border-bottom:.5px solid var(--color-border-tertiary);margin-bottom:8px}.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:#eaf3de;color:#3b6d11;font-weight:500;border-left:2px solid #639922}.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}.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-quick-bar{margin-top:8px;padding:14px 16px;background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg)}.dashboard-quick-bar-label{font-size:10px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-text-tertiary);margin-bottom:10px}.dashboard-quick-bar-buttons{display:flex;flex-wrap:wrap;gap:8px}.dashboard-quick-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;padding:7px 12px}.dashboard-quick-btn .nav-icon{width:14px;height:14px;flex-shrink:0}.dashboard-notifications-card{align-self:start}.dashboard-notif-summary{margin-top:3px;font-size:11px;color:var(--color-text-secondary)}.dashboard-notif-all-btn{font-size:11px;padding:4px 8px}.dashboard-notif-list{display:grid;gap:4px}.dashboard-notif-item{padding:8px 0}.dashboard-notif-body{min-width:0}.dashboard-notif-text{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.dashboard-notif-meta{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:2px}.dashboard-notif-more-btn{margin-top:8px;font-size:11px;padding:4px 8px}.dashboard-focus-strip{margin-bottom:16px;padding:14px 16px;background:var(--color-background-primary);border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg)}.dashboard-focus-strip-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.dashboard-focus-strip-title{font-size:13px;font-weight:600;color:var(--color-text-primary)}.dashboard-focus-strip-sub{margin-top:3px;font-size:11px;color:var(--color-text-secondary)}.dashboard-focus-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.dashboard-focus-card{display:flex;align-items:flex-start;gap:10px;width:100%;padding:12px;border:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-md);background:var(--color-background-secondary);font:inherit;color:inherit;text-align:left;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .15s ease}.dashboard-focus-card:hover{background:#eef5e6;border-color:#63992247;transform:translateY(-1px)}.dashboard-focus-icon{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;flex-shrink:0;border-radius:10px;background:var(--color-background-primary);color:#5b8c20}.dashboard-focus-icon .nav-icon{width:15px;height:15px}.dashboard-focus-body{min-width:0;display:flex;flex-direction:column}.dashboard-focus-label{font-size:11px;color:var(--color-text-secondary)}.dashboard-focus-value{margin-top:2px;font-size:13px;font-weight:600;color:var(--color-text-primary)}.dashboard-focus-meta{margin-top:4px;font-size:11px;color:var(--color-text-tertiary)}@media(max-width:1100px){.dashboard-focus-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media(max-width:640px){.dashboard-focus-grid{grid-template-columns:1fr}}.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:.5px solid var(--color-border-tertiary);border-radius:var(--border-radius-lg);padding:16px;margin-bottom:16px}.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:#eaf3de;border-color:#97c459;color:#3b6d11}.btn-green:hover:not(:disabled){background:#c0dd97}.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)}.pill{display:inline-block;padding:2px 8px;border-radius:10px;font-size:10px;font-weight:500}.pill-green{background:#eaf3de;color:#3b6d11}.pill-amber{background:#faeeda;color:#633806}.pill-red{background:#fcebeb;color:#a32d2d}.pill-blue{background:#e6f1fb;color:#185fa5}.pill-gray{background:var(--color-background-secondary);color:var(--color-text-secondary)}.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-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-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-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:220px}}.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}.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}.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;box-shadow:4px 0 24px #0000001f;transform:translate(-100%);transition:transform .22s ease;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch;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:8px;padding:0 16px 16px}.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)}.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}.notif{display:flex;gap:10px;padding:10px 0;border-bottom:.5px solid var(--color-border-tertiary);align-items:flex-start}.notif:last-child{border-bottom:none}.notif.notif-read .notif-text,.notif.notif-read .notif-time{opacity:.55}.notif.notif-read .notif-dot{opacity:.35}.notif-dot{width:8px;height:8px;border-radius:50%;margin-top:4px;flex-shrink:0}.notif-text{font-size:12px;color:var(--color-text-primary);line-height:1.5}.notif-time{font-size:10px;color:var(--color-text-tertiary);margin-top:2px}.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:0 12px 40px #0000001f;max-height:min(90vh,720px);overflow:hidden;display:flex;flex-direction:column;margin:auto}.modal-wide{max-width:520px;max-height:min(92vh,800px)}.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-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}.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}.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-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}@media(max-width:768px){.groups-grid{grid-template-columns:1fr}}.modal-receipt{max-width:480px}.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;justify-content:space-between;gap:16px;margin-top:16px;padding-top:14px;border-top:1px dashed var(--color-border-secondary)}.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}.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}@media(max-width:980px){.auth-layout{grid-template-columns:1fr}.auth-title{font-size:24px}}
