:root{
  --rack:#12161c; --rack-2:#1b2129; --line:#2b333d; --line-soft:#e3e6e2;
  --surface:#f4f5f2; --panel:#ffffff; --ink:#161b21; --ink-soft:#5c6670; --ink-faint:#8a949e;
  --cyan:#00b3a6; --cyan-deep:#06887f; --tally:#ff3b30;
  --amber:#c87f12; --blue:#2f6fed; --green:#168a4e; --grey:#9aa3ac;
  --r:10px; --r-sm:7px;
  --shadow:0 1px 2px rgba(16,22,28,.06),0 8px 24px rgba(16,22,28,.05);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Inter',system-ui,sans-serif;background:var(--surface);color:var(--ink);-webkit-font-smoothing:antialiased;line-height:1.45}
button{font-family:inherit;cursor:pointer}
.mono{font-family:'JetBrains Mono',ui-monospace,monospace}
.hidden{display:none !important}
a{color:var(--cyan-deep)}

/* ---- Rack header ---- */
header.rack{position:sticky;top:0;z-index:40;background:var(--rack);color:#eef1f4;border-bottom:1px solid #000;box-shadow:0 2px 0 #000}
.rack-in{max-width:1240px;margin:0 auto;padding:9px 16px;display:flex;align-items:center;gap:14px}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.tally{width:11px;height:11px;border-radius:50%;background:var(--tally);box-shadow:0 0 0 3px rgba(255,59,48,.18),0 0 10px rgba(255,59,48,.6);flex:none}
.brand h1{font-family:'Oswald';font-weight:600;font-size:18px;letter-spacing:.06em;text-transform:uppercase;margin:0;white-space:nowrap}
.brand .sub{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#7d8893;margin-top:1px}
.rack-spacer{flex:1}
.nav{display:flex;gap:3px;background:#0c0f13;border:1px solid #2b333d;border-radius:9px;padding:3px}
.nav button{background:none;border:none;color:#9aa6b1;font-size:12.5px;letter-spacing:.04em;font-weight:600;padding:7px 13px;border-radius:6px;text-transform:uppercase}
.nav button.active{background:var(--cyan);color:#04201d}
.nav button:hover:not(.active){color:#fff}
.office-pick{background:#0c0f13;border:1px solid #2b333d;color:#cfd6dd;border-radius:8px;padding:7px 9px;font-size:12px;font-family:'JetBrains Mono'}
.user-chip{display:flex;align-items:center;gap:8px;color:#9aa6b1;font-size:12px}
.user-chip .av{width:26px;height:26px;border-radius:50%;background:var(--cyan-deep);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px}
.icon-btn{background:#0c0f13;border:1px solid #2b333d;color:#cfd6dd;border-radius:8px;padding:7px 10px;font-size:12px}
.icon-btn:hover{border-color:var(--cyan);color:#fff}

@media(max-width:760px){
  .brand .sub{display:none}
  .nav button{padding:7px 9px;font-size:11px}
  .user-chip span{display:none}
}

/* ---- Layout ---- */
.view{max-width:1240px;margin:0 auto;padding:18px 16px 130px}
.split{display:grid;grid-template-columns:1fr;gap:18px}
@media(min-width:1000px){.split{grid-template-columns:1.15fr .85fr;align-items:start}}

/* ---- Cards / form ---- */
.card{background:var(--panel);border:1px solid var(--line-soft);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.card>header{padding:14px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:baseline;gap:10px}
.card>header h2{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:16px;margin:0}
.card>header .hint{font-size:12px;color:var(--ink-faint)}
.editing-flag{margin-left:auto;font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--cyan-deep);font-weight:600}

.section{border-bottom:1px solid var(--line-soft)}
.section:last-child{border-bottom:none}
.sec-head{width:100%;background:none;border:none;display:flex;align-items:center;gap:11px;padding:13px 18px;text-align:left}
.sec-head:hover{background:#fafbfa}
.sec-num{font-family:'JetBrains Mono';font-size:11px;color:var(--ink-faint);font-weight:500;width:20px}
.sec-title{font-family:'Oswald';font-weight:500;letter-spacing:.05em;text-transform:uppercase;font-size:13.5px}
.sec-count{font-size:11px;color:var(--cyan-deep);font-weight:600;font-family:'JetBrains Mono'}
.chev{margin-left:auto;color:var(--ink-faint);transition:transform .18s}
.section.open .chev{transform:rotate(90deg)}
.sec-body{display:none;padding:6px 18px 18px}
.section.open .sec-body{display:grid;grid-template-columns:repeat(2,1fr);gap:13px 14px}
@media(max-width:620px){.section.open .sec-body{grid-template-columns:1fr}}

.field{display:flex;flex-direction:column;gap:5px;min-width:0}
.field.wide{grid-column:1/-1}
label.flab{font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;display:flex;gap:5px;align-items:center}
label.flab .req{color:var(--tally)}
input,select,textarea{font-family:inherit;font-size:14.5px;color:var(--ink);background:#fff;border:1px solid #cfd5cf;border-radius:var(--r-sm);padding:10px 11px;width:100%;transition:border-color .14s,box-shadow .14s}
input.mono,select.mono{font-family:'JetBrains Mono';letter-spacing:.01em}
input:focus,select:focus,textarea:focus,.combo.focus .combo-input{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px rgba(0,179,166,.16)}
textarea{resize:vertical;min-height:60px}
select{appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'><path d='M2 4l4 4 4-4' stroke='%235c6670' stroke-width='1.5' fill='none' stroke-linecap='round'/></svg>");background-repeat:no-repeat;background-position:right 11px center;padding-right:30px}

/* combo */
.combo{position:relative}
.combo-pop{position:absolute;top:calc(100% + 4px);left:0;right:0;z-index:30;background:#fff;border:1px solid #cfd5cf;border-radius:var(--r-sm);box-shadow:0 10px 30px rgba(16,22,28,.16);max-height:240px;overflow:auto;display:none}
.combo.open .combo-pop{display:block}
.combo-opt{padding:9px 11px;font-size:14px;cursor:pointer}
.combo-opt:hover,.combo-opt.active{background:#eefbf9}
.combo-empty{padding:10px 11px;color:var(--ink-faint);font-size:13px}
.combo-clear{position:absolute;right:9px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--ink-faint);font-size:16px;line-height:1;padding:2px 4px;display:none}
.combo.has-val .combo-clear{display:block}
.combo.has-val .combo-input{padding-right:28px}
.heads-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:7px}
.chip{font-family:'JetBrains Mono';font-size:11px;border:1px solid #cfd5cf;border-radius:30px;padding:4px 9px;background:#fff;color:var(--ink-soft)}
.chip:hover{border-color:var(--cyan);color:var(--cyan-deep)}

/* ---- Action bar ---- */
.actionbar{position:fixed;left:0;right:0;bottom:0;z-index:35;background:var(--rack);border-top:1px solid #000;box-shadow:0 -6px 24px rgba(0,0,0,.22)}
.actionbar-in{max-width:1240px;margin:0 auto;padding:11px 16px;display:flex;gap:10px;align-items:center;padding-bottom:calc(11px + env(safe-area-inset-bottom))}
.btn{border:1px solid transparent;border-radius:9px;padding:12px 18px;font-size:14px;font-weight:600;letter-spacing:.02em;display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.btn-primary{background:var(--cyan);color:#04201d;border-color:var(--cyan)}
.btn-primary:hover{background:#00c7b8}
.btn-deep{background:#06887f;border-color:#06887f;color:#fff}
.btn-deep:hover{background:#079b90}
.btn-ghost{background:#0c0f13;color:#cfd6dd;border-color:#2b333d}
.btn-ghost:hover{border-color:var(--cyan);color:#fff}
.btn:disabled{opacity:.5;cursor:not-allowed}
.ab-status{color:#8a949e;font-size:12px;margin-left:auto;text-align:right}
.ab-status b{color:#eef1f4;font-weight:600}

/* ---- Rundown ---- */
.rundown>header .badge{font-family:'JetBrains Mono';font-size:11px;background:#eef2f1;color:var(--ink-soft);border-radius:20px;padding:3px 9px;font-weight:500}
.rd-tools{margin-left:auto;display:flex;gap:6px}
.rd-tool{font-size:11px;letter-spacing:.04em;text-transform:uppercase;border:1px solid var(--line-soft);background:#fff;color:var(--ink-soft);border-radius:7px;padding:6px 9px}
.rd-tool:hover{border-color:var(--cyan);color:var(--cyan-deep)}
.rd-list{max-height:calc(100vh - 230px);overflow:auto}
.rd-day{padding:7px 16px;background:#f0f3f1;border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);font-family:'JetBrains Mono';font-size:11px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);position:sticky;top:0;z-index:1}
.rd-row{display:grid;grid-template-columns:50px 1fr auto;gap:10px;padding:11px 16px;border-bottom:1px solid var(--line-soft);align-items:center;cursor:pointer}
.rd-row:hover{background:#f7faf9}
.rd-row.sel{background:#eefbf9;box-shadow:inset 3px 0 0 var(--cyan)}
.rd-ko{font-family:'JetBrains Mono';font-size:13px;font-weight:600}
.rd-mid{min-width:0}
.rd-match{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rd-sub{font-size:11.5px;color:var(--ink-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.rd-sub .tag{font-family:'JetBrains Mono';color:var(--cyan-deep)}
.rd-right{display:flex;align-items:center;gap:8px}
.cdot{width:9px;height:9px;border-radius:50%;background:var(--grey);flex:none}
.cdot.yes{background:var(--green)} .cdot.no{background:var(--tally)} .cdot.na{background:var(--grey)} .cdot.maybe{background:var(--amber)}
.pushed{font-family:'JetBrains Mono';font-size:9px;letter-spacing:.05em;text-transform:uppercase;color:var(--green);border:1px solid #bfe6cf;border-radius:4px;padding:1px 4px}
.rd-del{border:none;background:none;color:var(--ink-faint);font-size:15px;padding:3px 5px;border-radius:5px}
.rd-del:hover{background:#ffe9e7;color:var(--tally)}
.rd-empty{padding:40px 22px;text-align:center;color:var(--ink-faint)}
.rd-empty .big{font-family:'Oswald';text-transform:uppercase;letter-spacing:.05em;color:var(--ink-soft);font-size:15px;margin-bottom:6px}

/* ---- Tables (crew / master) ---- */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.search{flex:1;min-width:160px;max-width:340px}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft);font-weight:600;padding:10px 14px;border-bottom:1px solid var(--line-soft);position:sticky;top:0;background:#fff}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line-soft)}
.tbl tr:hover td{background:#f7faf9}
.tbl tr.inactive td{opacity:.5}
.role-pill{font-family:'JetBrains Mono';font-size:10px;letter-spacing:.03em;background:#eef2f1;color:var(--ink-soft);border-radius:20px;padding:2px 7px;margin-right:4px}
.row-act{border:none;background:none;color:var(--ink-faint);font-size:13px;padding:4px 7px;border-radius:6px;font-weight:600}
.row-act:hover{background:#eefbf9;color:var(--cyan-deep)}
.tbl-wrap{max-height:calc(100vh - 250px);overflow:auto;border:1px solid var(--line-soft);border-radius:var(--r);background:#fff}
.mtabs{display:flex;gap:4px;margin-bottom:14px;flex-wrap:wrap}
.mtab{border:1px solid var(--line-soft);background:#fff;color:var(--ink-soft);border-radius:8px;padding:8px 13px;font-size:12.5px;font-weight:600;text-transform:uppercase;letter-spacing:.03em}
.mtab.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* ---- Modal ---- */
.modal-bg{position:fixed;inset:0;background:rgba(16,22,28,.55);z-index:60;display:none;align-items:center;justify-content:center;padding:18px}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:14px;max-width:560px;width:100%;box-shadow:0 30px 80px rgba(0,0,0,.4);overflow:hidden;max-height:90vh;display:flex;flex-direction:column}
.modal header{padding:16px 20px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center}
.modal header h3{font-family:'Oswald';text-transform:uppercase;letter-spacing:.04em;font-size:16px;margin:0}
.modal .body{padding:20px;overflow:auto}
.modal .grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media(max-width:520px){.modal .grid2{grid-template-columns:1fr}}
.modal .foot{padding:14px 20px;border-top:1px solid var(--line-soft);display:flex;gap:10px;justify-content:flex-end;background:#fafbfa}
.btn-sm{padding:9px 15px;font-size:13px;border-radius:8px;font-weight:600;border:1px solid var(--line-soft);background:#fff;color:var(--ink)}
.btn-sm.primary{background:var(--cyan);border-color:var(--cyan);color:#04201d}
.btn-sm.danger{color:var(--tally);border-color:#f3c4c0}
.btn-sm:hover{border-color:var(--cyan)}
.x{margin-left:auto;border:none;background:none;font-size:22px;color:var(--ink-faint);line-height:1;cursor:pointer}
code.k{font-family:'JetBrains Mono';font-size:12px;background:#eef2f1;padding:2px 6px;border-radius:5px}
.rolechecks{display:flex;gap:14px;flex-wrap:wrap;margin-top:4px}
.rolechecks label{display:flex;gap:6px;align-items:center;font-size:13px;text-transform:none;letter-spacing:0;color:var(--ink);font-weight:500}
.rolechecks input{width:auto}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(1200px 500px at 50% -10%, #1b2129, var(--rack))}
.login-card{background:var(--panel);border-radius:16px;box-shadow:0 30px 90px rgba(0,0,0,.5);width:100%;max-width:380px;overflow:hidden}
.login-head{background:var(--rack);color:#fff;padding:22px 24px;display:flex;align-items:center;gap:11px}
.login-head h1{font-family:'Oswald';font-weight:600;letter-spacing:.06em;text-transform:uppercase;font-size:19px;margin:0}
.login-head .sub{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:#7d8893}
.login-body{padding:24px}
.login-body .field{margin-bottom:14px}
.login-err{color:var(--tally);font-size:13px;margin-bottom:12px;display:none}
.login-body .btn{width:100%;justify-content:center}

/* ---- toast ---- */
.toast{position:fixed;left:50%;transform:translateX(-50%);bottom:90px;z-index:70;background:var(--rack);color:#eef1f4;padding:12px 18px;border-radius:10px;font-size:13.5px;box-shadow:0 12px 40px rgba(0,0,0,.35);display:flex;gap:10px;align-items:center;opacity:0;pointer-events:none;transition:opacity .2s;max-width:90vw}
.toast.show{opacity:1}
.toast.err{background:#5a1410}
.toast .tdot{width:8px;height:8px;border-radius:50%;background:var(--green);flex:none}
.toast.err .tdot{background:var(--tally)}
.empty{padding:50px 20px;text-align:center;color:var(--ink-faint)}
