:root{--bg: #f4f3f6;--card: #ffffff;--sidebar: #211f2b;--sidebar-2: #2b2937;--ink: #2a2733;--muted: #8d8a98;--line: #ececf0;--brand: #9a8cf0;--brand-soft: #c6bdf8;--brand-tint: #f1effd;--accent: #6c5ce7;--accent-dark: #5747d4;--green: #4b8f6f;--green-bg: #e7f3ec;--amber: #c98a2b;--amber-bg: #fbf0db;--red: #c0493f;--red-bg: #fbe8e6;--blue-bg: #e8eff5;--shadow-sm: 0 1px 2px rgba(24, 20, 34, .06);--shadow: 0 2px 4px rgba(24, 20, 34, .05), 0 12px 28px rgba(24, 20, 34, .06);--radius: 16px;--radius-sm: 11px}*{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(--bg);color:var(--ink);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased}h1{font-size:1.5rem;margin:0;letter-spacing:-.01em}h2{font-size:1.2rem;margin:0;letter-spacing:-.01em}h3{font-size:1rem;margin:0}.muted{color:var(--muted)}code{background:#efecf2;padding:1px 5px;border-radius:5px;font-size:.85em}.layout{display:flex;min-height:100%}.sidebar{width:232px;flex-shrink:0;background:var(--sidebar);color:#d9d6e2;display:flex;flex-direction:column;padding:18px 14px;gap:8px;position:sticky;top:0;height:100vh}.sidebar-brand{padding:6px 8px 14px}.sidebar .brand{display:flex;align-items:center;gap:10px}.sidebar .brand-mark{color:#fff;font-weight:800;font-size:1.25rem;letter-spacing:.5px}.sidebar .brand-sub{color:#9b97a8;font-size:.62rem;text-transform:uppercase;letter-spacing:1.5px}.sidebar .brand-logo{height:38px;width:auto;border-radius:10px}.side-nav{display:flex;flex-direction:column;gap:3px;flex:1}.side-link{display:flex;align-items:center;gap:12px;padding:11px 12px;border-radius:12px;border:none;background:transparent;color:#b6b2c4;cursor:pointer;font-size:.92rem;font-weight:600;text-align:left;width:100%;transition:.15s}.side-link svg{width:19px;height:19px;flex-shrink:0;opacity:.9}.side-link:hover{background:var(--sidebar-2);color:#fff}.side-link.active{background:var(--accent);color:#fff;box-shadow:0 6px 18px #6c5ce780}.side-foot{border-top:1px solid rgba(255,255,255,.08);padding-top:12px;display:flex;flex-direction:column;gap:10px}.user-chip{display:flex;align-items:center;gap:10px}.avatar{width:38px;height:38px;border-radius:50%;background:var(--accent);color:#fff;display:grid;place-items:center;font-weight:700;flex-shrink:0}.user-chip .u-name{color:#fff;font-weight:600;font-size:.86rem;line-height:1.1}.user-chip .u-role{color:#9b97a8;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px}.side-actions{display:flex;gap:8px}.side-actions .link-btn{color:#b6b2c4}.side-actions .link-btn:hover{color:#fff}.main{flex:1;min-width:0;display:flex;flex-direction:column}.content{flex:1;padding:26px 30px;max-width:1320px;width:100%;margin:0 auto}.link-btn{border:none;background:none;color:var(--muted);cursor:pointer;font-size:.82rem;text-decoration:none;padding:0}.link-btn:hover{color:var(--accent);text-decoration:underline}.btn{border:1px solid transparent;border-radius:11px;padding:10px 18px;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);box-shadow:var(--shadow-sm)}.btn.ghost:hover{border-color:var(--brand);color:var(--accent)}.btn.full{width:100%}.btn.small{padding:6px 12px;font-size:.8rem;border-radius:9px}.btn.danger{background:var(--red);color:#fff}.chip{border:1px solid var(--line);background:#fff;border-radius:20px;padding:5px 11px;font-size:.76rem;cursor:pointer;font-weight:600;color:var(--ink);transition:.12s}.chip:hover{border-color:var(--brand)}.chip.on{background:var(--green);color:#fff;border-color:var(--green)}.chip.on.danger{background:var(--red);border-color:var(--red)}.chip.danger-text{color:var(--red);border-color:#eccfcc}.chip.danger-text:hover{background:var(--red-bg);border-color:var(--red)}.tag{font-size:.66rem;font-weight:700;padding:2px 8px;border-radius:20px;text-transform:uppercase;letter-spacing:.4px}.tag.private{background:#ece9f3;color:#6f5fa0}.tag.full{background:var(--red-bg);color:var(--red)}.tag.tiny{background:var(--amber-bg);color:var(--amber)}.alert{padding:11px 14px;border-radius:12px;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}.login-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:linear-gradient(150deg,#efeafe,#e6e9ff 45%,#f6e6f3)}.login-card{background:var(--card);padding:34px;border-radius:22px;box-shadow:var(--shadow);width:100%;max-width:380px;display:flex;flex-direction:column;gap:13px}.login-card h1{text-align:center;font-size:1.2rem}.brand.center{flex-direction:column;align-items:center;gap:4px;margin-bottom:4px}.brand-mark{font-weight:800;font-size:1.35rem;letter-spacing:.5px;color:var(--accent)}.brand-mark.big{font-size:2.1rem}.brand-sub{font-size:.7rem;text-transform:uppercase;letter-spacing:1.5px;color:var(--muted)}.brand-logo{height:40px;width:auto;display:block;object-fit:contain}.brand-logo.big{height:96px}.login-card label,.form-grid label,.modal label,.field label{display:flex;flex-direction:column;gap:5px;font-size:.8rem;font-weight:600;color:var(--muted)}input,select{font:inherit;padding:10px 12px;border:1px solid var(--line);border-radius:11px;background:#fff;color:var(--ink)}input:focus,select:focus{outline:2px solid var(--brand);border-color:var(--brand)}.demo-logins{margin-top:6px;border-top:1px dashed var(--line);padding-top:13px;display:flex;flex-direction:column;gap:8px}.demo-logins p{font-size:.8rem;color:var(--muted);margin:0 0 2px}.page{display:flex;flex-direction:column;gap:18px}.page-head{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;box-shadow:var(--shadow-sm)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}.form-grid .span-2{grid-column:1 / -1}.field-label{font-size:.8rem;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)}.data-table{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm)}.data-table th{text-align:left;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:12px 14px;background:var(--brand-tint);border-bottom:1px solid var(--line)}.data-table td{padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:middle}.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:var(--brand-tint);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}.chip-x{border:none;background:none;cursor:pointer;color:inherit;margin-left:5px;font-weight:700;opacity:.55;padding:0;font-size:.95em;line-height:1}.chip-x:hover{opacity:1;color:var(--red)}.chips-row{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.book-row{display:flex;gap:8px}.book-row input{flex:1}.row-actions{white-space:nowrap;display:flex;gap:6px}.archived-row{opacity:.6}.toolbar{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.search{flex:1;min-width:220px;padding:10px 14px;border:1px solid var(--line);border-radius:24px;background:#fff;box-shadow:var(--shadow-sm)}.pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:9px 16px;font-weight:600;box-shadow:var(--shadow-sm)}.cal-toolbar{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.date-nav{display:inline-flex;align-items:center;gap:4px;background:#fff;border:1px solid var(--line);border-radius:24px;padding:4px;box-shadow:var(--shadow-sm)}.date-nav .nudge{border:none;background:transparent;width:30px;height:30px;border-radius:50%;cursor:pointer;font-size:1rem;color:var(--ink)}.date-nav .nudge:hover{background:var(--brand-tint)}.date-label{font-weight:700;padding:0 10px;min-width:150px;text-align:center}.spacer{flex:1}.timeline-wrap{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow-sm);overflow:hidden}.timeline{overflow-x:auto}.tl-grid{min-width:max-content}.tl-head,.tl-row{display:grid;grid-template-columns:220px 1fr}.tl-head{border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card);z-index:3}.tl-corner{padding:14px 16px;font-size:.72rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-right:1px solid var(--line);position:sticky;left:0;background:var(--card);z-index:2}.tl-axis{position:relative;height:48px}.tl-hour{position:absolute;top:0;height:100%;display:flex;align-items:center;font-size:.78rem;color:var(--muted);font-weight:600;padding-left:8px;border-left:1px solid var(--line)}.tl-row{border-bottom:1px solid var(--line)}.tl-row:last-child{border-bottom:none}.tl-rowhead{padding:12px 16px;border-right:1px solid var(--line);position:sticky;left:0;background:var(--card);z-index:1;display:flex;flex-direction:column;gap:5px;justify-content:center}.tl-rowhead .rh-name{font-weight:700}.tl-rowhead .rh-teach{display:flex;flex-wrap:wrap;gap:4px}.tl-rowhead .rh-off{font-size:.72rem;color:var(--amber);font-weight:600}.tl-track{position:relative;height:84px}.tl-track .gridline{position:absolute;top:0;height:100%;border-left:1px solid #f4f2f5}.tl-track.off{background:repeating-linear-gradient(45deg,#faf9fb,#faf9fb 8px,#f3f1f5 8px,#f3f1f5 16px)}.ev{position:absolute;top:9px;height:66px;border-radius:11px;padding:8px 10px;cursor:pointer;border-left:3px solid;overflow:hidden;display:flex;flex-direction:column;gap:2px;transition:transform .1s,box-shadow .1s;box-shadow:var(--shadow-sm)}.ev:hover{transform:translateY(-1px);box-shadow:var(--shadow);z-index:4}.ev.sel{outline:2px solid var(--accent);outline-offset:1px}.ev .ev-name{font-weight:700;font-size:.82rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ev .ev-time{font-size:.72rem;opacity:.85;white-space:nowrap}.ev .ev-count{font-size:.7rem;font-weight:700;margin-top:auto}.ev .ev-count.full{color:var(--red)}.c0{background:#ebe9fe;color:#4b3fb8;border-left-color:#6c5ce7}.c1{background:#d7f5ef;color:#0f7a68;border-left-color:#14b8a6}.c2{background:#fdeecb;color:#976400;border-left-color:#f5a524}.c3{background:#fde1ea;color:#b32f5e;border-left-color:#f43f8e}.c4{background:#ddeefe;color:#1668b3;border-left-color:#3b9eff}.c5{background:#e2f7dd;color:#2c8a3b;border-left-color:#4ade80}.tl-track.addable{cursor:copy}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:10px}.wk-col{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);min-height:200px;display:flex;flex-direction:column;box-shadow:var(--shadow-sm);overflow:hidden}.wk-col.closed{background:#f6f5f9}.wk-col.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.wk-col.addable{cursor:copy}.wk-head{display:flex;justify-content:space-between;align-items:baseline;padding:10px 12px;border-bottom:1px solid var(--line)}.wk-name{font-weight:700;font-size:.82rem}.wk-date{font-size:.78rem;color:var(--muted)}.wk-body{padding:8px;display:flex;flex-direction:column;gap:6px;flex:1}.wk-card{text-align:left;border:none;border-left:3px solid;border-radius:9px;padding:7px 9px;cursor:pointer;display:grid;gap:1px;box-shadow:var(--shadow-sm)}.wk-card:hover{transform:translateY(-1px);box-shadow:var(--shadow)}.wk-card .c-name{font-weight:700;font-size:.8rem}.wk-card .c-meta{font-size:.72rem;opacity:.9}.wk-empty{font-size:.74rem;color:var(--muted);text-align:center;margin-top:auto;margin-bottom:auto;padding:14px 4px}.wk-closed{font-size:.78rem;color:var(--muted);text-align:center;padding:20px 4px;font-weight:600}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.mo-dow{text-align:center;font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700;padding:4px 0}.mo-cell{background:var(--card);border:1px solid var(--line);border-radius:12px;min-height:92px;padding:8px;cursor:pointer;display:flex;flex-direction:column;gap:5px;box-shadow:var(--shadow-sm);transition:.12s}.mo-cell:hover{border-color:var(--brand)}.mo-cell.other{opacity:.4}.mo-cell.closed{background:#f6f5f9}.mo-cell.today{border-color:var(--accent);box-shadow:0 0 0 1px var(--accent)}.mo-num{font-weight:700;font-size:.85rem}.mo-count{font-size:.7rem;color:var(--accent);font-weight:700}.mo-chips{display:flex;flex-direction:column;gap:3px}.mo-chip{font-size:.68rem;padding:2px 6px;border-radius:6px;border-left:3px solid;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.closed-state{padding:60px 20px;text-align:center;color:var(--muted)}.closed-state .big-emoji{font-size:2rem;display:block;margin-bottom:8px}.legend{display:flex;gap:14px;flex-wrap:wrap;align-items:center;font-size:.78rem;color:var(--muted)}.legend .lk{display:inline-flex;align-items:center;gap:6px}.legend .dot{width:11px;height:11px;border-radius:4px}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#211f2b80;display:flex;align-items:flex-start;justify-content:center;padding:44px 16px;z-index:50;overflow-y:auto;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--card);border-radius:18px;box-shadow:var(--shadow);width:100%;max-width:460px;padding:24px;display:flex;flex-direction:column;gap:13px}.modal.panel{max-width:540px}.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-search{display:flex;flex-direction:column;gap:8px}.book-results{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:12px;max-height:230px;overflow-y:auto}.book-results li{display:flex;align-items:center;gap:10px;padding:9px 11px;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)}.section-label{margin:6px 0 0;color:var(--muted);text-transform:uppercase;font-size:.7rem;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:12px;padding:11px;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:#f2f0f3;opacity:.8}.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}.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:12px}.seg{display:inline-flex;background:var(--brand-tint);border-radius:12px;padding:3px;gap:2px}.seg-btn{border:none;background:transparent;padding:8px 18px;border-radius:9px;font-weight:600;cursor:pointer;color:var(--muted);font-size:.9rem}.seg-btn.on{background:#fff;color:var(--ink);box-shadow:var(--shadow-sm)}.stat-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.stat-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:18px;display:flex;flex-direction:column;gap:4px;box-shadow:var(--shadow-sm)}.stat-num{font-size:2rem;font-weight:800;color:var(--accent);letter-spacing:-.02em}.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:#c6bdf8}.lg14:before{background:#14b8a6}.lg30:before{background:#6c5ce7}.bar-row{display:grid;grid-template-columns:170px 1fr;gap:12px;align-items:center;padding:10px 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:#c6bdf8}.bar-fill.b14{background:#14b8a6}.bar-fill.b30{background:#6c5ce7}.bar-val{font-size:.76rem;font-weight:700;color:var(--muted);min-width:18px}@media (max-width: 760px){.layout{flex-direction:column}.sidebar{width:100%;height:auto;position:sticky;top:0;z-index:30;flex-direction:row;align-items:center;padding:10px 12px;gap:10px;overflow-x:auto}.sidebar-brand{padding:0 4px 0 2px}.sidebar .brand-sub{display:none}.side-nav{flex-direction:row;flex:1;flex-wrap:nowrap;overflow-x:auto;gap:2px}.side-nav::-webkit-scrollbar{height:0}.side-link{flex:0 0 auto;padding:9px 12px}.side-link span.lbl{display:none}.side-link svg{width:20px;height:20px}.side-foot{border-top:none;padding-top:0;flex-direction:row;align-items:center;gap:8px}.side-foot .u-text,.side-actions .reset-link{display:none}.content{padding:18px 16px}.form-grid,.row-2,.stat-cards{grid-template-columns:1fr}.bar-row{grid-template-columns:1fr;gap:6px}.tl-head,.tl-row{grid-template-columns:132px 1fr}.tl-rowhead{padding:10px}.week-grid{grid-template-columns:1fr}.mo-cell{min-height:64px;padding:5px}.mo-chip{display:none}.mo-dow{font-size:.6rem}}
