:root{--bg: #f4f3f8;--card: #ffffff;--primary: #6c4df6;--primary-1: #5b23f4;--primary-2: #8a4bff;--ink: #1b1b2f;--muted: #8b8fa3;--green: #2bb673;--red: #e5484d;--border: #ecebf3;--radius: 16px;--radius-sm: 12px;--shadow: 0 6px 24px rgba(27, 27, 47, .06);--shadow-lg: 0 18px 48px rgba(27, 27, 47, .16);--gradient: linear-gradient(135deg, var(--primary-1), var(--primary-2))}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-size:14px}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:14px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:1px solid var(--border);background:#fff;color:var(--ink);padding:9px 16px;border-radius:var(--radius-sm);font-weight:600;font-size:13px;transition:all .15s ease;white-space:nowrap}.btn:hover{border-color:#d9d7e8;background:#faf9ff}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--gradient);border:none;color:#fff;box-shadow:0 8px 20px #6c4df647}.btn-primary:hover{filter:brightness(1.05);background:var(--gradient)}.btn-danger{color:var(--red);border-color:#f4cfd0;background:#fff}.btn-danger:hover{background:#fdeaea;border-color:#f0b8ba}.btn-success{color:var(--green);border-color:#bfe7d4}.btn-success:hover{background:#e9f8f0}.btn-sm{padding:6px 12px;font-size:12px}.btn-ghost{border-color:transparent;background:transparent}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}.input,.select,.textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--ink);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.input:focus,.select:focus,.textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6c4df61f}.textarea{resize:vertical;min-height:80px}.row{display:flex;gap:14px}.row>*{flex:1}.card{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1}.badge-green{background:#2bb6731f;color:var(--green)}.badge-red{background:#e5484d1f;color:var(--red)}.badge-purple{background:#6c4df61f;color:var(--primary)}.badge-gray{background:#8b8fa324;color:var(--muted)}.dot{width:7px;height:7px;border-radius:50%;background:currentColor}.table-wrap{overflow-x:auto}table.data{width:100%;border-collapse:collapse}table.data th{text-align:left;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);padding:12px 14px;border-bottom:1px solid var(--border)}table.data td{padding:14px;border-bottom:1px solid var(--border);vertical-align:middle}table.data tr:last-child td{border-bottom:none}table.data tbody tr.clickable{cursor:pointer;transition:background .12s ease}table.data tbody tr.clickable:hover{background:#faf9ff}.avatar{width:38px;height:38px;border-radius:50%;background:var(--gradient);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;overflow:hidden;flex-shrink:0}.avatar img{width:100%;height:100%;object-fit:cover}.user-cell{display:flex;align-items:center;gap:12px}.user-cell .name{font-weight:600}.user-cell .sub{color:var(--muted);font-size:12px}.layout{display:flex;min-height:100vh}.sidebar{width:248px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);padding:22px 16px;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 22px}.calendar{width:100%;border-collapse:collapse;table-layout:fixed}.calendar th{padding:12px 8px;text-align:center;font-size:12px;font-weight:700;color:#8b8fa3;border-bottom:1px solid #f0eff5;text-transform:uppercase;letter-spacing:.4px}.calendar td{border-bottom:1px solid #f4f3f8;border-left:1px solid #f4f3f8;vertical-align:top;padding:6px;height:56px}.calendar .cal-time-col{width:64px;text-align:center;font-size:12px;font-weight:700;color:#1b1b2f;border-left:none;white-space:nowrap}.calendar .cal-cell{display:flex;flex-direction:column;gap:6px}.cal-chip{display:flex;flex-direction:column;align-items:flex-start;gap:1px;width:100%;border:none;cursor:pointer;border-radius:10px;padding:7px 9px;color:#fff;text-align:left;line-height:1.2}.cal-chip:hover{filter:brightness(.95)}.cal-chip-name{font-size:12px;font-weight:800}.cal-chip-sub{font-size:11px;font-weight:600;opacity:.9}.brand .logo{width:40px;height:40px;border-radius:12px;background:var(--gradient);color:#fff;display:grid;place-items:center;font-weight:800;font-size:20px;overflow:hidden;box-shadow:0 8px 18px #6c4df64d}.brand .logo img{width:100%;height:100%;object-fit:cover}.brand .title{font-weight:700;font-size:16px}.brand .subtitle{font-size:11px;color:var(--muted)}.nav{display:flex;flex-direction:column;gap:4px}.nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);color:var(--muted);font-weight:600;transition:all .15s ease}.nav a:hover{background:#f6f5fc;color:var(--ink)}.nav a.active{background:var(--gradient);color:#fff;box-shadow:0 8px 18px #6c4df647}.nav a .nav-icon{width:18px;text-align:center;font-size:16px}.sidebar-foot{margin-top:auto;font-size:11px;color:var(--muted);padding:12px 8px 0}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;justify-content:space-between;padding:20px 32px;border-bottom:1px solid var(--border);background:#f4f3f8d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);position:sticky;top:0;z-index:10}.topbar h1{font-size:22px;margin:0}.topbar .who{display:flex;align-items:center;gap:16px}.topbar .email{font-size:13px;color:var(--muted);font-weight:500}.content{padding:28px 32px;flex:1}.stat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px;margin-bottom:24px}.stat{background:var(--card);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px 22px;display:flex;align-items:center;gap:16px}.stat .icon{width:48px;height:48px;border-radius:14px;display:grid;place-items:center;font-size:22px;flex-shrink:0}.stat .value{font-size:28px;font-weight:700;line-height:1.1}.stat .label{color:var(--muted);font-size:13px;font-weight:500}.section-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:16px}.section-head h2{font-size:17px;margin:0}.section-head .sub{color:var(--muted);font-size:13px}.toolbar{display:flex;align-items:center;gap:12px;margin-bottom:18px;flex-wrap:wrap}.search{position:relative;flex:1;max-width:360px}.search input{width:100%;padding:10px 14px 10px 38px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;outline:none}.search input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #6c4df61f}.search .icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--muted)}.segmented{display:inline-flex;background:#efeef6;border-radius:var(--radius-sm);padding:3px;gap:2px}.segmented button{border:none;background:transparent;padding:7px 14px;border-radius:9px;font-weight:600;font-size:13px;color:var(--muted)}.segmented button.active{background:#fff;color:var(--ink);box-shadow:0 2px 6px #1b1b2f14}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b1b2f73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;justify-content:flex-end;z-index:50}.modal-overlay.center{align-items:center;justify-content:center;padding:24px}.drawer{width:480px;max-width:100%;height:100%;background:#fff;box-shadow:var(--shadow-lg);overflow-y:auto;animation:slideIn .2s ease}.modal{width:540px;max-width:100%;max-height:90vh;overflow-y:auto;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow-lg);animation:pop .16s ease}@keyframes slideIn{0%{transform:translate(24px);opacity:.6}}@keyframes pop{0%{transform:scale(.97);opacity:.6}}.modal-head{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border);position:sticky;top:0;background:#fff;z-index:1}.modal-head h3{margin:0;font-size:18px}.modal-body{padding:22px 24px}.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:16px 24px;border-top:1px solid var(--border);position:sticky;bottom:0;background:#fff}.icon-btn{border:none;background:transparent;color:var(--muted);font-size:20px;width:32px;height:32px;border-radius:8px;display:grid;place-items:center}.icon-btn:hover{background:#f2f1f9;color:var(--ink)}.muted{color:var(--muted)}.empty{text-align:center;padding:48px 20px;color:var(--muted)}.empty .big{font-size:34px;margin-bottom:8px}.spinner{width:22px;height:22px;border:3px solid rgba(108,77,246,.25);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.center-screen{min-height:100vh;display:grid;place-items:center;padding:24px}@keyframes spin{to{transform:rotate(360deg)}}.kv{display:grid;grid-template-columns:130px 1fr;gap:8px 12px;margin:16px 0}.kv dt{color:var(--muted);font-size:13px}.kv dd{margin:0;font-weight:500}.divider{height:1px;background:var(--border);margin:22px 0}.subhead{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:0 0 12px}.auth-card{width:400px;max-width:100%;background:#fff;border-radius:22px;box-shadow:var(--shadow-lg);padding:36px 32px}.auth-logo{width:56px;height:56px;border-radius:16px;background:var(--gradient);color:#fff;display:grid;place-items:center;font-weight:800;font-size:26px;margin-bottom:20px;overflow:hidden;box-shadow:0 10px 24px #6c4df652}.auth-logo img{width:100%;height:100%;object-fit:cover}.auth-card h1{font-size:22px;margin:0 0 4px}.auth-card p.sub{color:var(--muted);margin:0 0 24px}.error-text{color:var(--red);font-size:13px;margin:0 0 12px;background:#e5484d14;padding:10px 12px;border-radius:10px}.uid-box{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#f4f3f8;border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px;word-break:break-all;margin:8px 0 20px}.avail-row{display:flex;gap:10px;align-items:center;margin-bottom:10px}.avail-row .select,.avail-row .input{flex:1}.class-group{margin-bottom:26px}.color-swatch{width:18px;height:18px;border-radius:5px;display:inline-block;vertical-align:middle;border:1px solid rgba(0,0,0,.08)}.trainer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:18px}.trainer-card{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;display:flex;flex-direction:column;gap:12px}.trainer-card .head{display:flex;align-items:center;gap:14px}.trainer-card .meta{display:flex;gap:14px;font-size:13px;color:var(--muted);flex-wrap:wrap}.trainer-card .bio{font-size:13px;color:var(--ink);opacity:.85;line-height:1.5}.chips{display:flex;flex-wrap:wrap;gap:6px}.chip{background:#f4f3f8;border:1px solid var(--border);border-radius:8px;padding:4px 8px;font-size:12px;color:var(--ink)}
