:root{--paper: #faf7f3;--card: #ffffff;--ink: #2c2825;--muted: #8a817a;--line: #e7e0d8;--brand: #ad9c9c;--brand-soft: #c8bcbc;--brand-tint: #f1ecec;--accent: #8a7172;--accent-dark: #6f5859;--green: #4b8f6f;--green-bg: #e7f3ec;--amber: #c98a2b;--amber-bg: #fbf0db;--red: #c0493f;--red-bg: #fbe8e6;--blue-bg: #e8eff5;--shadow: 0 1px 3px rgba(0, 0, 0, .06), 0 8px 24px rgba(0, 0, 0, .05);--radius: 12px}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;background:var(--paper);color:var(--ink);font-size:15px;line-height:1.45}h1{font-size:1.5rem;margin:0}h2{font-size:1.2rem;margin:0}h3{font-size:1rem}.muted{color:var(--muted)}code{background:#f0ebe4;padding:1px 5px;border-radius:5px;font-size:.85em}.app{display:flex;flex-direction:column;min-height:100%}.topbar{display:flex;align-items:center;gap:20px;flex-wrap:wrap;padding:12px 20px;background:var(--card);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:20}.brand{display:flex;flex-direction:column;line-height:1}.brand.center{align-items:center;gap:4px;margin-bottom:8px}.brand-mark{font-weight:800;font-size:1.35rem;letter-spacing:.5px;color:var(--accent)}.brand-mark.big{font-size:2.1rem}.brand-logo{height:40px;width:auto;display:block;object-fit:contain}.brand-logo.big{height:96px}.brand-sub{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}.nav{display:flex;gap:4px;flex:1}.nav-btn{border:none;background:transparent;color:var(--muted);font-weight:600;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:.95rem}.nav-btn:hover{background:var(--paper);color:var(--ink)}.nav-btn.active{background:var(--accent);color:#fff}.topbar-right{display:flex;align-items:center;gap:12px}.role-badge{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;padding:3px 8px;border-radius:20px}.role-badge.owner{background:var(--accent);color:#fff}.role-badge.trainer{background:#efe7df;color:var(--ink)}.user-name{font-weight:600;font-size:.9rem}.link-btn{border:none;background:none;color:var(--muted);cursor:pointer;font-size:.85rem;text-decoration:underline}.link-btn:hover{color:var(--accent)}.content{flex:1;padding:20px;max-width:1200px;width:100%;margin:0 auto}.footer{padding:10px 20px;font-size:.78rem;color:var(--muted);border-top:1px solid var(--line);text-align:center}.todo-pill{background:var(--amber-bg);color:var(--amber);padding:2px 8px;border-radius:20px}.btn{border:1px solid transparent;border-radius:9px;padding:9px 16px;font-weight:600;cursor:pointer;font-size:.9rem;transition:.15s}.btn.primary{background:var(--accent);color:#fff}.btn.primary:hover{background:var(--accent-dark)}.btn.primary:disabled{opacity:.45;cursor:not-allowed}.btn.ghost{background:var(--card);border-color:var(--line);color:var(--ink)}.btn.ghost:hover{border-color:var(--accent);color:var(--accent)}.btn.full{width:100%}.btn.small{padding:5px 10px;font-size:.8rem}.btn.danger{background:var(--red);color:#fff}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(160deg,#efe9e9,#e2d6d6)}.login-card{background:var(--card);padding:32px;border-radius:18px;box-shadow:var(--shadow);width:100%;max-width:380px;display:flex;flex-direction:column;gap:12px}.login-card h1{text-align:center;font-size:1.2rem;margin-bottom:4px}.login-card label,.form-grid label,.modal label{display:flex;flex-direction:column;gap:4px;font-size:.82rem;font-weight:600;color:var(--muted)}input,select{font:inherit;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--ink)}input:focus,select:focus{outline:2px solid var(--accent);border-color:var(--accent)}.demo-logins{margin-top:8px;border-top:1px dashed var(--line);padding-top:12px;display:flex;flex-direction:column;gap:8px}.demo-logins p{font-size:.8rem;color:var(--muted);margin:0 0 2px}.alert{padding:10px 12px;border-radius:9px;font-size:.85rem;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.alert.error{background:var(--red-bg);color:var(--red)}.alert.ok{background:var(--green-bg);color:var(--green)}.alert.warn{background:var(--amber-bg);color:var(--amber)}.alert.info{background:var(--blue-bg);color:#3a5a7a}.cal-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}.cal-nav{display:flex;gap:6px}.cal-range{font-weight:700;flex:1}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}.day-col{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:8px;min-height:160px;display:flex;flex-direction:column;gap:6px}.day-col.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.day-col.closed{background:#f3efe9}.day-head{display:flex;justify-content:space-between;align-items:baseline;border-bottom:1px solid var(--line);padding-bottom:6px;margin-bottom:2px}.day-name{font-weight:700;font-size:.82rem}.day-date{font-size:.78rem;color:var(--muted)}.closed-note,.empty-note{font-size:.78rem;color:var(--muted);text-align:center;padding:16px 4px}.closed-note{font-weight:600}.session-card{text-align:left;border:1px solid var(--line);border-left:4px solid var(--accent);border-radius:8px;background:#fff;padding:7px 9px;cursor:pointer;display:grid;gap:1px;transition:.12s}.session-card:hover{box-shadow:var(--shadow);transform:translateY(-1px)}.session-card.sel{outline:2px solid var(--accent)}.session-card.private{border-left-color:#7a5fa3}.session-card.full{border-left-color:var(--red)}.sc-time{font-weight:700;font-size:.85rem}.sc-name{font-weight:600;font-size:.85rem}.sc-trainer{font-size:.75rem;color:var(--muted)}.sc-count{font-size:.72rem;color:var(--green);font-weight:700;justify-self:start}.sc-count.full{color:var(--red)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#28231e73;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow-y:auto}.modal{background:var(--card);border-radius:16px;box-shadow:var(--shadow);width:100%;max-width:460px;padding:22px;display:flex;flex-direction:column;gap:12px}.modal.panel{max-width:520px}.modal-head{display:flex;justify-content:space-between;align-items:flex-start}.icon-btn{border:none;background:none;font-size:1.6rem;line-height:1;cursor:pointer;color:var(--muted)}.icon-btn:hover{color:var(--ink)}.capacity-line{font-size:.95rem;display:flex;align-items:center;gap:8px}.book-row{display:flex;gap:8px}.book-row select{flex:1}.section-label{margin:6px 0 0;color:var(--muted);text-transform:uppercase;font-size:.72rem;letter-spacing:1px}.roster{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.roster-item{border:1px solid var(--line);border-radius:10px;padding:10px;display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap}.roster-item.status-attended{background:var(--green-bg)}.roster-item.status-no_show{background:var(--red-bg)}.roster-item.status-cancelled_advance{background:#f1ece6;opacity:.75}.roster-main{display:flex;flex-direction:column}.r-name{font-weight:700}.r-meta{font-size:.78rem;color:var(--muted);display:flex;gap:6px;align-items:center}.roster-actions{display:flex;gap:4px;flex-wrap:wrap}.chip{border:1px solid var(--line);background:#fff;border-radius:20px;padding:4px 10px;font-size:.76rem;cursor:pointer;font-weight:600;color:var(--ink)}.chip:hover{border-color:var(--accent)}.chip.on{background:var(--green);color:#fff;border-color:var(--green)}.chip.on.danger{background:var(--red);border-color:var(--red)}.hint{font-size:.78rem;color:var(--muted)}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.tag{font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.tag.private{background:#efe9f5;color:#7a5fa3}.tag.full{background:var(--red-bg);color:var(--red)}.tag.tiny{background:var(--amber-bg);color:var(--amber)}.page{display:flex;flex-direction:column;gap:16px}.page-head{display:flex;justify-content:space-between;align-items:center}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid .span-2{grid-column:1 / -1}.field-label{font-size:.82rem;font-weight:600;color:var(--muted);display:block;margin-bottom:6px}.checks{display:flex;flex-wrap:wrap;gap:10px}.check{display:flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500;color:var(--ink);flex-direction:row}.check.inline{align-self:end}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.data-table th{text-align:left;font-size:.74rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:10px 12px;background:var(--brand-tint);border-bottom:1px solid var(--line)}.data-table td{padding:10px 12px;border-bottom:1px solid var(--line);vertical-align:top}.data-table tr:last-child td{border-bottom:none}.balance{font-weight:800}.balance.low{color:var(--amber)}.balance.zero{color:var(--red)}.pack-chip{display:inline-block;background:#f0ebe4;border-radius:16px;padding:2px 9px;font-size:.76rem;font-weight:600;margin:2px 4px 2px 0}.add-pack{padding:3px 6px;font-size:.76rem}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.search{flex:1;min-width:220px;padding:9px 12px;border:1px solid var(--line);border-radius:9px}.row-actions{white-space:nowrap;display:flex;gap:6px}.archived-row{opacity:.6}.chip.danger-text{color:var(--red);border-color:#eccfcc}.chip.danger-text:hover{background:var(--red-bg);border-color:var(--red)}.book-search{display:flex;flex-direction:column;gap:8px}.book-results{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:10px;max-height:230px;overflow-y:auto}.book-results li{display:flex;align-items:center;gap:10px;padding:8px 10px;border-bottom:1px solid var(--line)}.book-results li:last-child{border-bottom:none}.book-results .pad{padding:12px}.br-name{flex:1;font-weight:600}.br-left{font-size:.78rem;font-weight:700;color:var(--green)}.br-left.low{color:var(--amber)}.br-left.zero{color:var(--red)}.seg{display:inline-flex;background:var(--brand-tint);border-radius:10px;padding:3px;gap:2px}.seg-btn{border:none;background:transparent;padding:7px 16px;border-radius:8px;font-weight:600;cursor:pointer;color:var(--muted);font-size:.9rem}.seg-btn.on{background:#fff;color:var(--ink);box-shadow:var(--shadow)}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow)}.stat-num{font-size:1.9rem;font-weight:800;color:var(--accent)}.stat-label{font-size:.78rem;color:var(--muted)}.bars-legend{display:flex;gap:14px;justify-content:flex-end;margin-bottom:10px;font-size:.72rem;color:var(--muted)}.lg:before{content:"";display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}.lg7:before{background:var(--brand-soft)}.lg14:before{background:var(--brand)}.lg30:before{background:var(--accent)}.bar-row{display:grid;grid-template-columns:160px 1fr;gap:12px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line)}.bar-row:last-child{border-bottom:none}.bar-name{font-weight:600;font-size:.9rem;display:flex;gap:6px;align-items:center;flex-wrap:wrap}.bar-track-group{display:flex;flex-direction:column;gap:4px}.bar-line{display:flex;align-items:center;gap:8px}.bar-fill{height:10px;border-radius:6px;min-width:2px;transition:width .4s ease}.bar-fill.b7{background:var(--brand-soft)}.bar-fill.b14{background:var(--brand)}.bar-fill.b30{background:var(--accent)}.bar-val{font-size:.76rem;font-weight:700;color:var(--muted);min-width:18px}@media (max-width: 900px){.week-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.topbar{flex-direction:column;align-items:stretch;gap:8px}.topbar .brand{align-self:flex-start}.nav{order:2;width:100%;flex:none;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:2px}.nav::-webkit-scrollbar{height:0}.nav-btn{flex:0 0 auto}.topbar-right{order:3;flex-wrap:wrap;justify-content:flex-start}.week-grid,.form-grid,.row-2,.stat-cards{grid-template-columns:1fr}.bar-row{grid-template-columns:1fr;gap:6px}}
