:root{--red: #e2342d;--red-600: #c81e1e;--red-50: #fef2f2;--red-100: #fee2e2;--ink: #16181d;--ink-2: #5b616e;--ink-3: #8b909c;--line: #ebecf0;--line-2: #f1f2f5;--bg: #fafbfc;--surface: #ffffff;--surface-2: #f7f8fa;--green: #0f9d58;--green-bg: #eafaf1;--amber: #b7791f;--amber-bg: #fdf6e7;--blue: #2563eb;--blue-bg: #eef3ff;--radius: 14px;--radius-sm: 10px;--shadow-sm: 0 1px 2px rgba(20, 25, 40, .04);--shadow: 0 1px 3px rgba(20, 25, 40, .05), 0 6px 16px rgba(20, 25, 40, .04);--shadow-pop: 0 16px 48px rgba(20, 25, 40, .14);--ring: 0 0 0 3px var(--red-100)}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:Inter,-apple-system,system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;letter-spacing:-.01em}h1,h2,h3,h4{font-family:Sora,Inter,sans-serif;font-weight:600;letter-spacing:-.02em;color:var(--ink)}a{color:inherit;text-decoration:none}button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}input,select,textarea{font-family:inherit;font-size:14px;color:var(--ink)}svg{display:block}::selection{background:var(--red-100)}.app-shell{display:flex;min-height:100vh}.sidebar{width:256px;flex-shrink:0;background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;position:fixed;inset:0 auto 0 0;z-index:30}.brand{display:flex;align-items:center;gap:11px;padding:20px 22px 18px}.brand .logo{width:34px;height:34px;border-radius:9px;flex-shrink:0;background:var(--red);color:#fff;display:grid;place-items:center}.brand .logo svg{width:18px;height:18px}.brand .bt{font-family:Sora,sans-serif;font-weight:700;font-size:15px;line-height:1.1}.brand .bs{font-size:11px;color:var(--ink-3);font-weight:500}.nav{padding:6px 12px;flex:1;overflow-y:auto}.nav-group{font-size:10.5px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-3);padding:14px 12px 6px}.nav-link{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:var(--radius-sm);color:var(--ink-2);font-weight:500;font-size:13.5px;margin-bottom:2px;transition:background .12s,color .12s}.nav-link svg{width:18px;height:18px;stroke-width:1.9}.nav-link:hover{background:var(--surface-2);color:var(--ink)}.nav-link.active{background:var(--red-50);color:var(--red-600);font-weight:600}.nav-link.active svg{color:var(--red)}.sidebar-foot{padding:14px;border-top:1px solid var(--line)}.user-chip{display:flex;align-items:center;gap:10px;padding:8px;border-radius:var(--radius-sm)}.user-chip:hover{background:var(--surface-2)}.user-chip .ava{width:34px;height:34px;border-radius:9px;background:var(--ink);color:#fff;display:grid;place-items:center;font-weight:600;font-size:13px;flex-shrink:0}.user-chip .un{font-weight:600;font-size:13px;line-height:1.2}.user-chip .ur{font-size:11.5px;color:var(--ink-3)}.logout-btn{margin-left:auto;padding:6px;border-radius:8px;color:var(--ink-3)}.logout-btn:hover{background:var(--red-50);color:var(--red)}.logout-btn svg{width:16px;height:16px}.main{flex:1;margin-left:256px;min-width:0}.topbar{height:64px;background:#fffc;-webkit-backdrop-filter:saturate(180%) blur(10px);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;position:sticky;top:0;z-index:20}.topbar h1{font-size:18px}.topbar .crumb{font-size:12.5px;color:var(--ink-3);margin-bottom:1px}.content{padding:28px;max-width:1400px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:38px;padding:0 16px;border-radius:var(--radius-sm);font-weight:600;font-size:13.5px;white-space:nowrap;transition:background .12s,border-color .12s,box-shadow .12s,transform .04s}.btn:active{transform:translateY(.5px)}.btn svg{width:16px;height:16px}.btn-primary{background:var(--red);color:#fff;box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--red-600)}.btn-ghost{background:var(--surface);color:var(--ink);border:1px solid var(--line)}.btn-ghost:hover{background:var(--surface-2);border-color:#dfe1e7}.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:8px}.btn-block{width:100%;height:44px;font-size:14px}.icon-btn{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;color:var(--ink-3);border:1px solid transparent;transition:all .12s}.icon-btn svg{width:16px;height:16px}.icon-btn:hover{background:var(--surface-2);color:var(--ink);border-color:var(--line)}.icon-btn.danger:hover{background:var(--red-50);color:var(--red);border-color:var(--red-100)}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm)}.card-pad{padding:22px}.card-head{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}.card-head h2{font-size:15px}.card-head .sub{font-size:12.5px;color:var(--ink-3);margin-top:1px}.grid{display:grid;gap:16px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(190px,1fr))}.two-col{display:grid;grid-template-columns:1.6fr 1fr;gap:16px}.card-grid{grid-template-columns:repeat(auto-fill,minmax(264px,1fr))}.stat{padding:20px;display:flex;flex-direction:column;gap:14px;transition:box-shadow .15s,border-color .15s}.stat:hover{box-shadow:var(--shadow);border-color:#e3e5ea}.stat-top{display:flex;align-items:center;justify-content:space-between}.stat .ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:var(--red-50);color:var(--red)}.stat .ic svg{width:19px;height:19px;stroke-width:2}.stat .ic.neutral{background:var(--surface-2);color:var(--ink-2)}.stat .delta{font-size:12px;font-weight:600;padding:2px 8px;border-radius:100px}.stat .delta.up{background:var(--green-bg);color:var(--green)}.stat .num{font-size:27px;font-weight:700;font-family:Sora,sans-serif;line-height:1}.stat .label{font-size:13px;color:var(--ink-3);font-weight:500}.toolbar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:18px}.search{flex:1;min-width:220px;max-width:380px;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 13px;height:38px;transition:border-color .12s,box-shadow .12s}.search:focus-within{border-color:var(--red);box-shadow:var(--ring)}.search svg{width:16px;height:16px;color:var(--ink-3);flex-shrink:0}.search input{border:none;outline:none;width:100%;background:transparent}.select{height:38px;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:0 12px;color:var(--ink);outline:none;cursor:pointer;transition:border-color .12s}.select:hover{border-color:#dfe1e7}.spacer{flex:1}.table-wrap{overflow-x:auto}table{width:100%;border-collapse:collapse}th{text-align:left;padding:12px 18px;font-size:11.5px;font-weight:600;color:var(--ink-3);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line);background:var(--surface-2)}th:first-child{border-top-left-radius:var(--radius)}th:last-child{border-top-right-radius:var(--radius)}td{padding:14px 18px;border-bottom:1px solid var(--line-2);vertical-align:middle}tbody tr{transition:background .1s}tbody tr:hover{background:var(--surface-2)}tbody tr:last-child td{border-bottom:none}.cell-name{font-weight:600;color:var(--ink)}.cell-sub{color:var(--ink-3);font-size:12.5px}.row-ava{width:34px;height:34px;border-radius:9px;background:var(--surface-2);color:var(--ink-2);display:grid;place-items:center;font-weight:600;font-size:12.5px;flex-shrink:0}.name-cell{display:flex;align-items:center;gap:11px}.row-actions{display:flex;gap:4px;justify-content:flex-end}.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;border-radius:100px;font-size:12px;font-weight:600;white-space:nowrap}.badge:before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor}.b-new,.b-scheduled{background:var(--blue-bg);color:var(--blue)}.b-contacted,.b-followup,.b-follow-up,.b-frozen{background:var(--amber-bg);color:var(--amber)}.b-converted,.b-active,.b-completed{background:var(--green-bg);color:var(--green)}.b-lost,.b-expired,.b-cancelled,.b-no-show{background:var(--red-50);color:var(--red)}.tag{display:inline-flex;align-items:center;padding:3px 10px;border-radius:7px;font-size:12px;font-weight:500;background:var(--surface-2);color:var(--ink-2);border:1px solid var(--line)}.role-pill{display:inline-flex;padding:3px 10px;border-radius:7px;font-size:12px;font-weight:600}.role-admin{background:var(--red-50);color:var(--red-600)}.role-manager{background:var(--blue-bg);color:var(--blue)}.role-staff,.role-trainer{background:var(--surface-2);color:var(--ink-2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f12196b;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:grid;place-items:center;z-index:60;padding:20px;animation:fade .15s}@keyframes fade{0%{opacity:0}}.modal{background:var(--surface);border-radius:18px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-pop);animation:pop .18s cubic-bezier(.2,.8,.3,1)}@keyframes pop{0%{opacity:0;transform:translateY(10px) scale(.985)}}.modal-head{padding:20px 24px;display:flex;align-items:flex-start;justify-content:space-between}.modal-head h3{font-size:17px}.modal-head .sub{font-size:12.5px;color:var(--ink-3);margin-top:2px}.modal-head .x{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;color:var(--ink-3)}.modal-head .x:hover{background:var(--surface-2);color:var(--ink)}.modal-head .x svg{width:17px;height:17px}.modal-body{padding:4px 24px 8px}.modal-foot{padding:18px 24px 22px;display:flex;gap:10px;justify-content:flex-end}.field{margin-bottom:15px}.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:var(--ink-2)}.field input,.field select,.field textarea{width:100%;height:40px;padding:0 13px;border:1px solid var(--line);border-radius:var(--radius-sm);outline:none;background:var(--surface);transition:border-color .12s,box-shadow .12s}.field textarea{height:auto;padding:11px 13px;resize:vertical;min-height:76px}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--red);box-shadow:var(--ring)}.field-row{display:grid;grid-template-columns:1fr 1fr;gap:13px}.pkg-card{padding:22px;display:flex;flex-direction:column;gap:4px;transition:box-shadow .15s,border-color .15s}.pkg-card:hover{box-shadow:var(--shadow);border-color:#e3e5ea}.pkg-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}.pkg-card h3{font-size:16px}.pkg-price{font-size:24px;font-weight:700;font-family:Sora,sans-serif;margin:8px 0 2px}.pkg-price small{font-size:13px;color:var(--ink-3);font-weight:500;font-family:Inter}.pkg-desc{color:var(--ink-2);font-size:13px;min-height:38px}.pkg-feats{display:flex;flex-direction:column;gap:7px;margin:14px 0;padding-top:14px;border-top:1px solid var(--line-2)}.pkg-feat{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--ink-2)}.pkg-feat svg{width:15px;height:15px;color:var(--red);flex-shrink:0}.pkg-actions{display:flex;gap:8px;margin-top:auto}.trainer-card{padding:22px;transition:box-shadow .15s,border-color .15s}.trainer-card:hover{box-shadow:var(--shadow);border-color:#e3e5ea}.trainer-top{display:flex;align-items:center;gap:13px;margin-bottom:14px}.trainer-ava{width:50px;height:50px;border-radius:12px;background:var(--red-50);color:var(--red);display:grid;place-items:center;font-size:18px;font-weight:700;font-family:Sora;flex-shrink:0}.trainer-card h3{font-size:15.5px}.trainer-card .spec{color:var(--ink-3);font-size:12.5px}.trainer-meta{display:flex;flex-direction:column;gap:7px;font-size:13px;color:var(--ink-2);padding:14px 0;border-top:1px solid var(--line-2)}.trainer-meta div{display:flex;align-items:center;gap:9px}.trainer-meta svg{width:15px;height:15px;color:var(--ink-3)}.day-card{margin-bottom:16px}.day-head{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--line)}.day-head .d{font-size:14px;font-weight:600}.day-head .c{font-size:12px;color:var(--ink-3)}.sched-row{display:flex;align-items:center;gap:16px;padding:14px 20px;border-bottom:1px solid var(--line-2);transition:background .1s}.sched-row:last-child{border-bottom:none}.sched-row:hover{background:var(--surface-2)}.sched-time{min-width:92px}.sched-time .st{font-weight:700;font-family:Sora;font-size:14px}.sched-time .et{font-size:12px;color:var(--ink-3)}.sched-bar{width:3px;align-self:stretch;border-radius:3px;background:var(--red);flex-shrink:0}.sched-main{flex:1;min-width:0}.sched-main .t{font-weight:600}.sched-main .m{font-size:12.5px;color:var(--ink-3);margin-top:1px}.empty{text-align:center;padding:64px 20px}.empty .ic{width:52px;height:52px;border-radius:14px;background:var(--surface-2);color:var(--ink-3);display:grid;place-items:center;margin:0 auto 14px}.empty .ic svg{width:24px;height:24px}.empty .t{font-weight:600;color:var(--ink)}.empty .s{font-size:13px;color:var(--ink-3);margin-top:3px}.loading{display:grid;place-items:center;padding:64px}.spinner{width:30px;height:30px;border:2.5px solid var(--line);border-top-color:var(--red);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--surface-2) 25%,#eef0f3 37%,var(--surface-2) 63%);background-size:400% 100%;animation:sk 1.3s infinite;border-radius:6px}@keyframes sk{0%{background-position:100% 0}to{background-position:-100% 0}}.login-wrap{min-height:100vh;display:grid;grid-template-columns:1fr 1fr}.login-aside{background:var(--ink);color:#fff;padding:56px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}.login-aside:before{content:"";position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(226,52,45,.5),transparent 70%);top:-120px;right:-120px}.login-aside .brand-lg{display:flex;align-items:center;gap:12px;position:relative;z-index:1}.login-aside .brand-lg .logo{width:40px;height:40px;border-radius:11px;background:var(--red);display:grid;place-items:center}.login-aside .brand-lg .logo svg{width:22px;height:22px;color:#fff}.login-aside .brand-lg span{font-family:Sora;font-weight:700;font-size:18px}.login-aside .pitch{position:relative;z-index:1}.login-aside .pitch h2{font-size:34px;color:#fff;line-height:1.15;max-width:420px}.login-aside .pitch p{color:#fff9;margin-top:14px;max-width:380px;font-size:14.5px}.login-aside .feats{display:flex;flex-direction:column;gap:12px;margin-top:26px}.login-aside .feats div{display:flex;align-items:center;gap:10px;color:#ffffffd9;font-size:14px}.login-aside .feats svg{width:18px;height:18px;color:var(--red)}.login-aside .copy{position:relative;z-index:1;color:#fff6;font-size:12.5px}.login-panel{display:grid;place-items:center;padding:40px}.login-card{width:100%;max-width:380px}.login-card h1{font-size:26px}.login-card .lead{color:var(--ink-3);margin:6px 0 28px;font-size:14px}.login-card .field input{height:44px}.login-error{background:var(--red-50);color:var(--red-600);border:1px solid var(--red-100);padding:10px 13px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;margin-bottom:16px;display:flex;align-items:center;gap:8px}.login-error svg{width:16px;height:16px;flex-shrink:0}.demo-box{margin-top:22px;padding:14px 16px;background:var(--surface-2);border:1px solid var(--line);border-radius:var(--radius-sm);font-size:12.5px;color:var(--ink-2)}.demo-box b{color:var(--ink)}.demo-box code{background:var(--surface);padding:1px 6px;border-radius:5px;border:1px solid var(--line);font-size:12px}.menu-btn{display:none}@media(max-width:920px){.sidebar{transform:translate(-100%);transition:transform .22s ease;box-shadow:var(--shadow-pop)}.sidebar.open{transform:none}.main{margin-left:0}.menu-btn{display:grid}.two-col,.login-wrap{grid-template-columns:1fr}.login-aside{display:none}}.scrim{display:none}@media(max-width:920px){.scrim.show{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;z-index:25}}
