:root{--color-accent:#007aff;--color-accent-hover:#0063d1;--color-accent-light:#e8f1ff;--color-danger:#ff3b30;--color-danger-light:#fff0ef;--color-success:#34c759;--color-warning:#ff9500;--color-bg:#f2f2f7;--color-surface:#fff;--color-surface-2:#f9f9fb;--color-border:#e5e5ea;--color-border-strong:#c7c7cc;--color-text-primary:#1c1c1e;--color-text-secondary:#6c6c70;--color-text-tertiary:#aeaeb2;--color-text-on-accent:#fff;--font-family:-apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text", "Helvetica Neue", Arial, sans-serif;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:15px;--font-size-md:17px;--font-size-lg:20px;--font-size-xl:24px;--font-size-2xl:28px;--font-size-3xl:34px;--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:20px;--spacing-6:24px;--spacing-8:32px;--spacing-10:40px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px;--radius-full:9999px;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000001a, 0 2px 4px #0000000f;--shadow-lg:0 8px 24px #0000001f, 0 4px 8px #0000000f;--transition-fast:.15s ease;--transition-base:.2s ease;--transition-slow:.3s ease;--sidebar-width:240px;--topbar-height:60px;--content-max-width:1040px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{font-family:var(--font-family);font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}button,input,select,textarea{font:inherit}.app-layout{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.main-content{flex-direction:column;flex:1;display:flex;overflow-y:auto}.topbar{height:var(--topbar-height);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-6);z-index:10;align-items:center;gap:var(--spacing-4);background:#ffffffd9;display:flex;position:sticky;top:0}.page-content{width:100%;max-width:calc(var(--content-max-width) + var(--spacing-6) * 2);padding:var(--spacing-6);flex:1;margin:0 auto}.sidebar-header{padding:var(--spacing-5) var(--spacing-4);border-bottom:1px solid var(--color-border)}.sidebar-academy-name{font-size:var(--font-size-md);color:var(--color-text-primary);font-weight:700;line-height:1.3}.sidebar-academy-sub{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:2px}.sidebar-nav{padding:var(--spacing-3) 0;flex:1}.sidebar-section-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.06em;padding:var(--spacing-3) var(--spacing-4) var(--spacing-1);font-weight:600}.sidebar-nav-item{align-items:center;gap:var(--spacing-3);min-height:38px;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);margin:1px var(--spacing-2);cursor:pointer;color:var(--color-text-primary);font-size:var(--font-size-sm);width:calc(100% - var(--spacing-4));text-align:left;transition:background var(--transition-fast), color var(--transition-fast);background:0 0;border:none;font-weight:500;display:flex}.sidebar-nav-item:hover{background:var(--color-bg)}.sidebar-nav-item.active{background:var(--color-accent-light);color:var(--color-accent)}.nav-icon{width:20px;height:20px;color:inherit;flex-shrink:0;justify-content:center;align-items:center;display:flex}.nav-icon svg{display:block}.sidebar-nav-item.active .nav-icon{color:var(--color-accent)}.btn{justify-content:center;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;border:none;outline:none;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--color-accent);color:var(--color-text-on-accent)}.btn-primary:hover{background:var(--color-accent-hover)}.btn-secondary{background:var(--color-surface-2);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover{background:var(--color-border)}.btn-danger{background:var(--color-danger-light);color:var(--color-danger)}.btn-danger:hover{background:var(--color-danger);color:#fff}.btn-ghost{color:var(--color-accent);background:0 0}.btn-ghost:hover{background:var(--color-accent-light)}.btn-sm{padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-xs)}.btn-lg{padding:var(--spacing-3) var(--spacing-6);font-size:var(--font-size-base)}.btn-full{width:100%}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{padding:var(--spacing-4) var(--spacing-5);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:var(--spacing-3);display:flex}.card-title{font-size:var(--font-size-md);font-weight:700}.form-group{margin-bottom:var(--spacing-4)}.form-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2);font-weight:600;display:block}.form-input,.form-select,.form-textarea{width:100%;padding:var(--spacing-3) var(--spacing-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--color-text-primary);background:var(--color-surface);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #007aff26}.form-textarea{resize:vertical;min-height:80px}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--color-border);background:var(--color-surface);overflow-x:auto}table{border-collapse:collapse;background:var(--color-surface);width:100%}thead th{padding:var(--spacing-3) var(--spacing-4);text-align:left;font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;background:var(--color-surface-2);border-bottom:1px solid var(--color-border);font-weight:600}tbody td{padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}tbody tr:last-child td{border-bottom:none}tbody tr{transition:background var(--transition-fast)}tbody tr.row-click{cursor:pointer}tbody tr:hover{background:var(--color-surface-2)}.badge{padding:2px var(--spacing-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);align-items:center;font-weight:600;display:inline-flex}.badge-blue{background:var(--color-accent-light);color:var(--color-accent)}.badge-green{color:#1d7d3a;background:#e8f8ed}.badge-red{background:var(--color-danger-light);color:var(--color-danger)}.badge-gray{background:var(--color-bg);color:var(--color-text-secondary)}.badge-orange{color:#c05000;background:#fff3e5}.muted-text{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-top:2px}.billing-stack{gap:var(--spacing-5);flex-direction:column;display:flex}.billing-tabs{align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-5);padding-bottom:var(--spacing-1);display:flex;overflow-x:auto}.billing-tabs button{align-items:center;gap:var(--spacing-2);border:1px solid var(--color-border);background:var(--color-surface);min-height:38px;color:var(--color-text-secondary);border-radius:var(--radius-full);padding:var(--spacing-2) var(--spacing-4);cursor:pointer;white-space:nowrap;display:inline-flex}.billing-tabs button.active{background:var(--color-accent);border-color:var(--color-accent);color:var(--color-text-on-accent)}.billing-stats-grid{grid-template-columns:repeat(5,minmax(0,1fr))}.billing-toolbar{gap:var(--spacing-4);grid-template-columns:minmax(220px,1fr) 180px;align-items:end;display:grid}.billing-row-actions{align-items:center;gap:var(--spacing-2);flex-wrap:wrap;display:flex}.billing-payment-check,.billing-summary-strip,.billing-warning{gap:var(--spacing-3);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface-2);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-4);color:var(--color-text-secondary);flex-wrap:wrap;display:flex}.billing-payment-check strong,.billing-summary-strip strong{color:var(--color-text-primary)}.billing-warning{color:#8a4b00;background:#fff8eb;border-color:#ffe0a3}.billing-action-list{gap:var(--spacing-3);flex-direction:column;display:flex}.billing-action-row{justify-content:space-between;align-items:center;gap:var(--spacing-4);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-4);background:var(--color-surface);display:flex}.billing-preview-box{margin-top:var(--spacing-4);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--spacing-4);background:var(--color-surface-2)}.billing-preview-box p{margin-top:var(--spacing-2);color:var(--color-text-secondary);line-height:1.6}.billing-timeline{gap:var(--spacing-3);flex-direction:column;display:flex}.billing-timeline-item{justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-4);border-left:3px solid var(--color-accent);background:var(--color-surface-2);border-radius:var(--radius-md);display:flex}.billing-mobile-list{display:none}.billing-mobile-card{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);padding:var(--spacing-4);gap:var(--spacing-3);flex-direction:column;display:flex}.billing-mobile-card-head,.billing-mobile-money{justify-content:space-between;align-items:center;gap:var(--spacing-3);display:flex}.billing-mobile-money span{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;opacity:0;pointer-events:none;transition:opacity var(--transition-base);background:#0006;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.modal-overlay.open{opacity:1;pointer-events:auto}.modal-sheet{background:var(--color-surface);border-radius:var(--radius-xl) var(--radius-xl) 0 0;width:100%;max-width:640px;max-height:90vh;transition:transform var(--transition-slow);padding-bottom:env(safe-area-inset-bottom,20px);overflow-y:auto;transform:translateY(100%)}.modal-overlay.open .modal-sheet{transform:translateY(0)}.modal-handle{background:var(--color-border-strong);border-radius:var(--radius-full);width:36px;height:4px;margin:var(--spacing-3) auto var(--spacing-4)}.modal-header{padding:0 var(--spacing-5) var(--spacing-4);justify-content:space-between;align-items:center;display:flex}.modal-title{font-size:var(--font-size-lg);font-weight:700}.modal-close{border-radius:var(--radius-full);background:var(--color-bg);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);transition:background var(--transition-fast);border:none;justify-content:center;align-items:center;display:flex}.modal-close:hover{background:var(--color-border)}.modal-body{padding:0 var(--spacing-5) var(--spacing-6)}.toast-container{top:var(--spacing-5);right:var(--spacing-5);z-index:200;gap:var(--spacing-2);flex-direction:column;display:flex;position:fixed}.toast{align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-text-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--font-size-sm);box-shadow:var(--shadow-lg);min-width:240px;max-width:360px;font-weight:500;animation:.3s forwards toastIn;display:flex}.toast.success{background:#1d7d3a}.toast.error{background:var(--color-danger)}.toast.warning{background:var(--color-warning)}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.skeleton{background:linear-gradient(90deg, var(--color-border) 25%, var(--color-surface-2) 50%, var(--color-border) 75%);border-radius:var(--radius-sm);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.loading-spinner{border:2px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.attendance-btn{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-sm);border:1.5px solid var(--color-border);background:var(--color-surface);font-size:var(--font-size-xs);cursor:pointer;transition:all var(--transition-fast);color:var(--color-text-secondary);font-weight:600}.attendance-btn:hover{border-color:var(--color-accent);color:var(--color-accent)}.attendance-btn.active-present{color:#1d7d3a;background:#e8f8ed;border-color:#34c759}.attendance-btn.active-late{color:#c05000;background:#fff3e5;border-color:#ff9500}.attendance-btn.active-absent{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger)}.attendance-btn.active-early{background:var(--color-accent-light);border-color:var(--color-accent);color:var(--color-accent)}.empty-state{padding:var(--spacing-10) var(--spacing-6);text-align:center;color:var(--color-text-tertiary);flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{margin-bottom:var(--spacing-4);font-size:36px}.empty-state-title{font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-2);font-weight:600}.empty-state-desc{font-size:var(--font-size-sm);margin-bottom:var(--spacing-5)}.onboarding-wrap{background:var(--color-bg);min-height:100vh;padding:var(--spacing-6);justify-content:center;align-items:center;display:flex}.onboarding-card{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:560px;padding:var(--spacing-8)}.onboarding-logo{font-size:var(--font-size-2xl);color:var(--color-accent);margin-bottom:var(--spacing-2);font-weight:800}.onboarding-title{font-size:var(--font-size-xl);margin-bottom:var(--spacing-2);font-weight:700}.onboarding-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-6)}.step-indicator{gap:var(--spacing-2);margin-bottom:var(--spacing-6);display:flex}.step-dot{border-radius:var(--radius-full);background:var(--color-border);height:4px;transition:background var(--transition-base);flex:1}.step-dot.active{background:var(--color-accent)}.step-dot.done{background:var(--color-success)}.template-grid{gap:var(--spacing-3);margin-bottom:var(--spacing-6);grid-template-columns:repeat(2,1fr);display:grid}.template-card{border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-4);cursor:pointer;transition:all var(--transition-fast);background:var(--color-surface);text-align:left}.template-card:hover,.template-card.selected{border-color:var(--color-accent);background:var(--color-accent-light)}.template-icon{margin-bottom:var(--spacing-2);color:var(--color-accent);font-size:24px;font-weight:800}.template-name{font-size:var(--font-size-sm);margin-bottom:2px;font-weight:700}.template-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.45}.stat-grid{gap:var(--spacing-4);margin-bottom:var(--spacing-6);grid-template-columns:repeat(auto-fit,minmax(140px,1fr));display:grid}.stat-card{background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border);box-shadow:var(--shadow-sm);padding:var(--spacing-5)}.stat-card-flat{padding:var(--spacing-4);background:var(--color-surface-2);border-radius:var(--radius-md);border:none}.stat-card-flat .stat-value{font-size:28px}.stat-card[data-color=green],.stat-card-flat[data-color=green]{border-left:3px solid var(--color-success)}.stat-card[data-color=orange],.stat-card-flat[data-color=orange]{border-left:3px solid var(--color-warning)}.stat-card[data-color=red],.stat-card-flat[data-color=red]{border-left:3px solid var(--color-danger)}.stat-card[data-color=blue],.stat-card-flat[data-color=blue]{border-left:3px solid var(--color-accent)}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:var(--spacing-2);font-weight:600}.stat-value{font-size:var(--font-size-3xl);color:var(--color-text-primary);font-weight:800;line-height:1}.stat-sub{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.page-header{margin-bottom:var(--spacing-6);justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);display:flex}.page-title{font-size:var(--font-size-2xl);letter-spacing:0;font-weight:800}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.search-bar{align-items:center;gap:var(--spacing-3);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-full);padding:var(--spacing-2) var(--spacing-4);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);display:flex}.search-bar:focus-within{border-color:var(--color-accent);box-shadow:0 0 0 3px #007aff1f}.search-bar input{font-size:var(--font-size-sm);font-family:var(--font-family);color:var(--color-text-primary);background:0 0;border:none;outline:none;flex:1}.search-icon{color:var(--color-text-tertiary);justify-content:center;align-items:center;font-size:14px;display:inline-flex}.search-icon svg{display:block}.date-nav{align-items:center;gap:var(--spacing-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:var(--spacing-1) var(--spacing-2);display:flex}.date-nav button{border-radius:var(--radius-full);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);transition:background var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;display:flex}.date-nav button:hover{background:var(--color-bg)}.date-nav .date-label{font-size:var(--font-size-sm);text-align:center;min-width:100px;font-weight:600}.toolbar{gap:var(--spacing-3);margin-bottom:var(--spacing-5);flex-wrap:wrap;align-items:center;display:flex}.stack{gap:var(--spacing-4);display:grid}.grid-2{gap:var(--spacing-4);grid-template-columns:repeat(2,minmax(0,1fr));display:grid}.class-grid{gap:var(--spacing-4);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));display:grid}.class-card{cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast)}.class-card:hover{box-shadow:var(--shadow-sm);transform:translateY(-1px)}.switch-row{justify-content:space-between;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) 0;border-bottom:1px solid var(--color-border);display:flex}.switch-row:last-child{border-bottom:none}.status-line{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.inline-actions{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.memo-input{margin-top:var(--spacing-2)}@media (width<=768px){.app-layout{display:block;overflow:auto}.sidebar{display:none}.template-grid,.grid-2{grid-template-columns:1fr}.stat-grid{grid-template-columns:repeat(2,1fr)}.billing-stats-grid,.billing-toolbar{grid-template-columns:1fr}.billing-desktop-table{display:none}.billing-mobile-list{gap:var(--spacing-3);flex-direction:column;display:flex}.billing-action-row{flex-direction:column;align-items:flex-start}.billing-row-actions{width:100%}.billing-row-actions .btn{flex:auto;min-height:36px}.page-header{flex-direction:column}.topbar{padding:0 var(--spacing-4)}.page-content{padding:var(--spacing-4)}}#root{min-height:100vh}.error-text{color:var(--color-danger);font-size:var(--font-size-sm)}.notice-box{background:var(--color-accent-light);color:var(--color-accent);border-radius:var(--radius-md);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm)}.warn-box{color:#8a3d00;border-radius:var(--radius-md);padding:var(--spacing-3) var(--spacing-4);font-size:var(--font-size-sm);background:#fff3e5}.app-fallback{justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.form-actions{justify-content:flex-end;gap:var(--spacing-2);margin-top:var(--spacing-4);display:flex}.clickable{cursor:pointer}.muted{color:var(--color-text-secondary)}.small{font-size:var(--font-size-xs)}.page-error{margin-bottom:var(--spacing-4)}@media (width<=768px){.modal-sheet{max-height:96vh}.toast-container{left:var(--spacing-4);right:var(--spacing-4);top:var(--spacing-4)}.toast{width:100%;min-width:0}}.sidebar-role-pill{height:22px;margin-top:var(--spacing-3);border-radius:var(--radius-full);background:var(--color-accent-light);color:var(--color-accent);font-size:var(--font-size-xs);align-items:center;padding:0 8px;font-weight:700;display:inline-flex}.nav-label{flex:1;min-width:0}.nav-soon{border-radius:var(--radius-full);background:var(--color-surface-2);height:18px;color:var(--color-text-tertiary);letter-spacing:-.02em;border:1px solid var(--color-border);align-items:center;padding:0 6px;font-size:10px;font-weight:700;display:inline-flex}.sidebar-nav-item.active .nav-soon{color:var(--color-accent);background:#007aff1a;border-color:#007aff2e}.topbar-role{height:22px;margin-left:var(--spacing-3);border-radius:var(--radius-full);background:var(--color-surface-2);color:var(--color-text-secondary);font-size:var(--font-size-xs);vertical-align:middle;align-items:center;padding:0 8px;font-weight:700;display:inline-flex}.coming-soon-card{max-width:720px}.coming-soon-eyebrow{height:24px;margin-bottom:var(--spacing-4);border-radius:var(--radius-full);background:var(--color-accent-light);color:var(--color-accent);font-size:var(--font-size-xs);align-items:center;padding:0 9px;font-weight:800;display:inline-flex}.coming-soon-title{font-size:var(--font-size-xl);letter-spacing:-.04em;color:var(--color-text-primary);margin-bottom:var(--spacing-3);font-weight:800;line-height:1.25}.coming-soon-desc{color:var(--color-text-secondary);margin-bottom:var(--spacing-5);line-height:1.7}.coming-soon-meta{gap:var(--spacing-2);flex-wrap:wrap;display:flex}.coming-soon-meta span{border-radius:var(--radius-full);background:var(--color-surface-2);height:28px;color:var(--color-text-secondary);border:1px solid var(--color-border);font-size:var(--font-size-xs);align-items:center;padding:0 10px;font-weight:700;display:inline-flex}:root{--color-bg:#f5f5f7;--color-surface-2:#f7f8fa;--color-border:#3c3c4324;--color-border-strong:#3c3c4342;--shadow-sm:0 1px 2px #0000000a, 0 8px 24px #0000000a;--shadow-md:0 12px 32px #00000014, 0 2px 8px #0000000a;--shadow-lg:0 24px 60px #00000024, 0 8px 18px #00000014;--sidebar-width:252px;--topbar-height:60px;--content-max-width:1160px}body{letter-spacing:-.015em;background:radial-gradient(circle at top left, #007aff12, transparent 34vw), var(--color-bg)}.sidebar{background:color-mix(in srgb, var(--color-surface) 92%, var(--color-bg));border-right-color:#3c3c431f}.sidebar-header{border-bottom:1px solid #3c3c431a;padding:22px 18px 16px}.sidebar-academy-name{letter-spacing:-.035em;font-size:18px;font-weight:760}.sidebar-academy-sub{color:var(--color-text-secondary);letter-spacing:-.01em;margin-top:4px}.sidebar-role-pill{letter-spacing:-.02em;background:#007aff1a;border:1px solid #007aff24;height:24px;margin-top:12px;padding:0 10px}.sidebar-nav{padding:12px 10px 18px}.sidebar-nav>div+div .sidebar-section-label{margin-top:10px}.sidebar-section-label{color:var(--color-text-tertiary);letter-spacing:.045em;padding:12px 10px 6px}.sidebar-nav-item{width:100%;min-height:40px;color:var(--color-text-secondary);border-radius:12px;margin:2px 0;padding:9px 10px}.sidebar-nav-item:hover{color:var(--color-text-primary);background:#7676801a}.sidebar-nav-item.active{color:var(--color-accent);background:#007aff1f;box-shadow:inset 0 0 0 1px #007aff14}.nav-label{letter-spacing:-.025em;font-weight:620}.topbar{min-height:var(--topbar-height);background:#ffffffc7;border-bottom-color:#3c3c431f;height:auto;padding:9px 28px}.topbar-main{flex:1;gap:2px;min-width:0;display:grid}.topbar-context{color:var(--color-text-tertiary);letter-spacing:-.01em;text-overflow:ellipsis;white-space:nowrap;font-size:11px;font-weight:680;line-height:1.2;overflow:hidden}.topbar-title-row{align-items:center;gap:10px;min-width:0;display:flex}.topbar-title{letter-spacing:-.04em;color:var(--color-text-primary);text-overflow:ellipsis;white-space:nowrap;font-size:18px;font-weight:760;line-height:1.2;overflow:hidden}.topbar-actions{flex-shrink:0;align-items:center;gap:10px;display:inline-flex}.topbar-date{border-radius:var(--radius-full);background:var(--color-surface-2);height:28px;color:var(--color-text-secondary);border:1px solid var(--color-border);font-size:var(--font-size-xs);font-variant-numeric:tabular-nums;letter-spacing:-.02em;align-items:center;padding:0 10px;font-weight:720;display:inline-flex}.topbar-role{background:var(--color-surface-2);border:1px solid var(--color-border);letter-spacing:-.02em;margin-left:0}.page-content{padding:28px}.page-header{margin-bottom:22px}.page-title{letter-spacing:-.045em;font-weight:780}.page-subtitle{line-height:1.55}.card,.table-wrap,.stat-card{box-shadow:var(--shadow-sm);border-color:#3c3c4321}.card{background:var(--color-surface)}.card-header{background:var(--color-surface-2);border-bottom-color:#3c3c431c;padding:15px 20px}.card-title{letter-spacing:-.03em;font-size:16px;font-weight:740}.card-body{padding:20px}.stat-grid{gap:14px}.stat-card{background:linear-gradient(180deg, var(--color-surface), color-mix(in srgb, var(--color-surface) 92%, var(--color-bg)));padding:20px}.stat-card-flat{border:1px solid #3c3c431a}.stat-label{letter-spacing:.03em}.stat-value{letter-spacing:-.03em;font-variant-numeric:tabular-nums;font-weight:760}.stat-sub{line-height:1.4}.btn{min-height:34px;box-shadow:none;letter-spacing:-.02em}.btn-primary{box-shadow:0 6px 14px #007aff2e}.btn-secondary{background:#7676801a}.form-input,.form-select,.form-textarea,.search-bar,.date-nav,.table-wrap{box-shadow:inset 0 1px #ffffff8c}thead th{letter-spacing:.04em}tbody td{line-height:1.5}.empty-state{border-radius:var(--radius-lg);background:radial-gradient(circle at center 20%, #007aff12, transparent 35%), var(--color-surface-2);min-height:220px;padding:42px 28px}.empty-state-icon{width:44px;height:44px;color:var(--color-accent);background:#007aff1a;border-radius:16px;justify-content:center;align-items:center;margin-bottom:14px;font-size:22px;display:inline-flex}.empty-state-title{color:var(--color-text-primary);letter-spacing:-.025em;font-weight:720}.empty-state-desc{max-width:360px;line-height:1.6}.skeleton{background:linear-gradient(90deg,#7676801f 25%,#ffffffc7 50%,#7676801f 75%) 0 0/220% 100%}.onboarding-wrap{background:radial-gradient(circle at 50% 12%, #007aff1a, transparent 32vw), linear-gradient(180deg, #f8f9fb 0%, var(--color-bg) 100%)}.onboarding-card{border:1px solid #3c3c431f;box-shadow:0 24px 70px #0000001f,0 2px 8px #0000000d}.onboarding-logo,.onboarding-title{letter-spacing:-.045em}.template-card{border-color:#3c3c4329;box-shadow:inset 0 1px #ffffffa6}.template-card:hover,.template-card.selected{box-shadow:0 10px 24px #007aff1a,inset 0 0 0 1px #007aff1a}.switch-row{border-bottom-color:#3c3c431a}@media (prefers-color-scheme:dark){:root{--color-accent:#0a84ff;--color-accent-hover:#409cff;--color-accent-light:#0a84ff2e;--color-danger:#ff453a;--color-danger-light:#ff453a29;--color-success:#30d158;--color-warning:#ff9f0a;--color-bg:#111214;--color-surface:#1c1c1e;--color-surface-2:#252529;--color-border:#ebebf521;--color-border-strong:#ebebf53d;--color-text-primary:#f5f5f7;--color-text-secondary:#ebebf5b3;--color-text-tertiary:#ebebf56b;--shadow-sm:0 1px 2px #00000038, 0 10px 26px #0003;--shadow-md:0 14px 34px #00000047, 0 2px 8px #00000038;--shadow-lg:0 28px 70px #0000006b, 0 8px 18px #00000047}body{background:radial-gradient(circle at top left, #0a84ff24, transparent 34vw), var(--color-bg)}.topbar{background:#1c1c1ec2}.sidebar{background:color-mix(in srgb, var(--color-surface) 92%, var(--color-bg))}.card,.table-wrap,.stat-card,.template-card,.onboarding-card,.modal-sheet{border-color:var(--color-border)}.stat-card{background:linear-gradient(180deg, var(--color-surface), color-mix(in srgb, var(--color-surface) 82%, var(--color-bg)))}.badge-green{color:#7ee99a;background:#30d15829}.badge-orange{color:#ffd18a;background:#ff9f0a29}.warn-box{color:#ffd18a;background:#ff9f0a26}.notice-box{background:#0a84ff29}.skeleton{background:linear-gradient(90deg,#ebebf517 25%,#ebebf529 50%,#ebebf517 75%) 0 0/220% 100%}.onboarding-wrap{background:radial-gradient(circle at 50% 12%, #0a84ff2e, transparent 32vw), var(--color-bg)}}@media (width<=768px){.topbar{min-height:58px;padding:9px 16px}.topbar-date{display:none}.topbar-title{font-size:17px}.page-content{padding:18px 16px}.onboarding-card{padding:26px 22px}}.platform-admin-card{width:min(1120px,100vw - 36px);max-width:1120px}.platform-admin-wrap .table-wrap{margin-top:0}.platform-admin-wrap .card+.card{margin-top:18px}.profile-choice-wrap,.profile-chip-wrap{flex-wrap:wrap;align-items:center;gap:8px;margin-top:8px;display:flex}.profile-choice-button,.profile-chip-button{appearance:none;background:var(--color-surface);color:var(--color-text-primary);border-radius:var(--radius-full);min-height:32px;font-size:var(--font-size-sm);cursor:pointer;transition:background var(--transition-fast), border-color var(--transition-fast), color var(--transition-fast), box-shadow var(--transition-fast), transform var(--transition-fast);white-space:nowrap;border:1px solid #3c3c432e;padding:6px 11px;font-weight:650;line-height:1.15}.profile-choice-button:hover,.profile-chip-button:hover{border-color:var(--color-accent);background:var(--color-accent-light);color:var(--color-accent)}.profile-choice-button.selected,.profile-chip-button.selected{border-color:var(--color-accent);background:var(--color-accent);color:var(--color-text-on-accent);box-shadow:0 8px 18px #007aff29}.profile-choice-button:active,.profile-chip-button:active{transform:scale(.97)}.profile-choice-button:disabled,.profile-chip-button:disabled{opacity:.42;cursor:not-allowed;transform:none}.profile-chip-button.muted:not(.selected){color:var(--color-text-tertiary);background:var(--color-surface-2)}.profile-result-card .card-body{gap:8px;padding:14px 16px}.profile-result-card .toolbar,.onboarding-card .stack>section.stack{gap:8px}.onboarding-card .stack>section.stack>strong{font-size:var(--font-size-sm);color:var(--color-text-primary);letter-spacing:-.01em}@media (width<=768px){.profile-choice-button,.profile-chip-button{min-height:34px;padding:7px 12px}}.mode-switcher{border:1px solid var(--color-border);background:var(--color-surface-2);border-radius:8px;flex-shrink:0;align-items:center;gap:2px;padding:3px;display:inline-flex}.mode-switcher-button{min-height:30px;color:var(--color-text-secondary);font:inherit;cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:6px;padding:0 11px;font-size:13px;font-weight:700}.mode-switcher-button:hover:not(:disabled){color:var(--color-text-primary);background:#7676801a}.mode-switcher-button.active{background:var(--color-surface);color:var(--color-accent);box-shadow:0 1px 3px #00000014}.mode-switcher-button:disabled{cursor:not-allowed;opacity:.45}@media (width<=768px){.topbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:6px}.mode-switcher-button{min-height:28px;padding:0 8px;font-size:12px}}.student-hub-layout{grid-template-columns:minmax(260px,360px) minmax(0,1fr);align-items:start;gap:18px;display:grid}.student-hub-search-panel,.student-hub-summary,.student-hub-section{min-width:0}.student-hub-search-row{align-items:center;gap:8px;display:flex}.student-hub-search-row input{flex:1;min-width:0}.student-hub-results{gap:8px;margin-top:14px;display:grid}.student-hub-result{border:1px solid var(--border-subtle);background:var(--surface-primary);text-align:left;cursor:pointer;border-radius:8px;width:100%;padding:10px 12px}.student-hub-result.is-active,.student-hub-result:hover{border-color:var(--accent-primary);background:var(--surface-secondary)}.student-hub-result-title,.student-hub-card-title,.student-hub-section-title{color:var(--text-primary);font-weight:700}.student-hub-muted{color:var(--text-secondary);font-size:13px}.student-hub-card-grid,.student-hub-section-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.student-hub-card-main,.student-hub-actions,.student-hub-sections{gap:12px;display:grid}.student-hub-actions{grid-template-columns:repeat(5,minmax(0,1fr))}.student-hub-list{gap:8px;display:grid}.student-hub-list-item{border-top:1px solid var(--border-subtle);padding-top:8px}@media (width<=960px){.student-hub-layout,.student-hub-actions,.student-hub-card-grid,.student-hub-section-grid{grid-template-columns:1fr}}.student-hub-search-box,.student-hub-action-panel,.student-hub-form-grid,.student-hub-summary-grid,.student-hub-info-list{gap:10px;display:grid}.student-hub-search-box{grid-template-columns:auto minmax(0,1fr) auto;align-items:center}.student-hub-search-box input,.student-hub-field input,.student-hub-field select,.student-hub-field textarea,.student-hub-action-form textarea{width:100%;min-width:0}.student-hub-result.active{border-color:var(--accent-primary);background:var(--surface-secondary)}.student-hub-summary-head,.student-hub-modal-head,.student-hub-context,.student-hub-info-list>div{justify-content:space-between;align-items:center;gap:10px;display:flex}.student-hub-action-panel{grid-template-columns:repeat(4,minmax(0,1fr))}.student-hub-modal-backdrop{z-index:80;background:#0f172a61;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.student-hub-modal{background:var(--surface-primary);border:1px solid var(--border-subtle);width:min(880px,100%);max-height:min(760px,100vh - 36px);box-shadow:var(--shadow-lg);border-radius:8px;padding:18px;overflow:auto}.student-hub-modal-head{margin-bottom:12px}.student-hub-modal-head button{border:1px solid var(--border-subtle);background:var(--surface-secondary);border-radius:6px;padding:6px 10px}.student-hub-context{border:1px solid var(--border-subtle);background:var(--surface-secondary);border-radius:8px;flex-wrap:wrap;justify-content:flex-start;margin-bottom:12px;padding:10px 12px}.student-hub-action-form{gap:12px;display:grid}.student-hub-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.student-hub-field{color:var(--text-secondary);gap:4px;font-size:13px;display:grid}.student-hub-check{min-height:38px;color:var(--text-secondary);align-items:center;gap:8px;font-size:13px;display:flex}.student-hub-field input,.student-hub-field select,.student-hub-field textarea,.student-hub-action-form textarea{border:1px solid var(--border-subtle);background:var(--surface-primary);color:var(--text-primary);border-radius:6px;padding:8px 10px}.student-hub-field textarea,.student-hub-action-form textarea{resize:vertical;min-height:92px}.student-hub-total{border:1px solid var(--border-subtle);border-radius:8px;gap:4px;padding:10px;display:grid}.page-success{border:1px solid var(--success-border,#86efac);background:var(--success-bg,#f0fdf4);color:var(--success-text,#166534);border-radius:8px;padding:10px 12px}.page-warning{border:1px solid var(--warning-border,#fde68a);background:var(--warning-bg,#fffbeb);color:var(--warning-text,#92400e);border-radius:8px;padding:10px 12px}@media (width<=960px){.student-hub-action-panel,.student-hub-form-grid,.student-hub-summary-grid{grid-template-columns:1fr}.student-hub-modal-backdrop{align-items:end;padding:10px}.student-hub-modal{max-height:calc(100vh - 20px)}}
