:root{
  --ink:#0D0C10; --surface:#15141A; --surface2:#1B1A21; --line:rgba(201,168,76,.22);
  --gold:#C9A84C; --gold-dim:#8A7440; --cream:#F2EDE3; --muted:#9A948A;
  --green:#7BA87A; --amber:#D4A24E; --red:#C66A58;
}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--ink);color:var(--cream);font-family:'Jost',sans-serif;font-weight:300;-webkit-font-smoothing:antialiased}
::selection{background:var(--gold);color:var(--ink)}
.hidden{display:none !important}
.wrap{max-width:1180px;margin:0 auto;padding:0 28px}

/* login */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-card{width:min(420px,92vw);background:var(--surface);border:1px solid var(--line);padding:42px 38px;text-align:center}
.login-card input{width:100%;margin:18px 0 12px;background:var(--ink);border:1px solid var(--line);color:var(--cream);padding:12px;font-family:'Jost';font-size:15px}
.login-card input:focus{outline:1px solid var(--gold)}

/* chrome */
header{border-bottom:1px solid var(--line);position:sticky;top:0;background:rgba(13,12,16,.92);backdrop-filter:blur(8px);z-index:10}
.bar{display:flex;align-items:center;justify-content:space-between;height:64px}
.mark{font-weight:500;letter-spacing:.42em;font-size:15px}
.mark.big{font-size:22px;margin-bottom:10px}
.mark b{color:var(--gold);font-weight:500}
.right{display:flex;align-items:center;gap:14px}
.practice{font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.picker{background:var(--ink);border:1px solid var(--line);color:var(--cream);padding:8px 10px;font-family:'Jost';font-size:12px;letter-spacing:.08em;border-radius:2px;transition:border-color .18s ease, box-shadow .18s ease}

.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.hero{padding:54px 0 40px;border-bottom:1px solid var(--line)}
h1{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:clamp(34px,5vw,52px);line-height:1.05}
h1 em,h2 em{font-style:italic;color:var(--gold)}
.updated{margin-top:12px;font-size:12px;color:var(--muted);letter-spacing:.08em}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:36px}
.stat{padding:6px 22px;border-right:1px solid var(--gold);display:flex;flex-direction:column;align-items:flex-end;text-align:right}
.stat .v{font-family:'Cormorant Garamond',serif;font-size:36px;font-weight:600;font-variant-numeric:tabular-nums}
.stat .l{font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);margin-top:2px}
.stat .d{font-size:11px;margin-top:6px}
.d.good{color:var(--green)}.d.warn{color:var(--amber)}.d.bad{color:var(--red)}.d.idle{color:var(--muted)}

section{padding:44px 0;border-bottom:1px solid var(--line)}
h2{font-family:'Cormorant Garamond',serif;font-weight:500;font-size:28px;margin-bottom:6px}
h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:19px;margin:30px 0 4px;color:var(--gold)}
.sub{color:var(--muted);font-size:13.5px;margin-bottom:22px;letter-spacing:.04em}

/* timeline */
.timeline{display:flex;flex-wrap:wrap;gap:0}
.tl{flex:1;min-width:200px;padding:0 18px 6px 0;position:relative}
.tl .dot{width:11px;height:11px;border-radius:50%;border:1px solid var(--gold);background:var(--ink);margin-bottom:12px}
.tl.done .dot{background:var(--gold)}
.tl.current .dot{background:var(--cream);border-color:var(--cream)}
.tl::before{content:'';position:absolute;top:5px;left:14px;right:6px;height:1px;background:var(--line)}
.tl:last-child::before{display:none}
.tl .n{font-size:14px;letter-spacing:.02em}
.tl.current .n{color:var(--gold)}
.tl .d{font-size:11.5px;color:var(--muted);margin-top:4px;line-height:1.45}
.tl .tag{display:inline-block;font-size:9px;letter-spacing:.24em;text-transform:uppercase;margin-top:8px;color:var(--muted)}
.tl.current .tag{color:var(--gold)}
/* roadmap dates: completion is prominent (gold), planned dates are muted/tentative */
.tldate-done{display:block;margin-top:6px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.tldate-plan{display:block;margin-top:6px;font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);opacity:.65;font-style:italic}
.tldate-done.sm{display:inline-block;margin:0 0 0 10px;font-size:9px;opacity:.85}
.tldate-lbl{display:block;font-size:8.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}

/* team milestone editor list */
.mslist{display:flex;flex-direction:column;gap:16px}
.msphase{border:1px solid var(--line);border-radius:4px;background:var(--surface);overflow:hidden}
.msphase-head{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--surface2)}
.msphase-items{display:flex;flex-direction:column}
.msrow{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid rgba(201,168,76,.08);cursor:grab}
.msrow:last-child{border-bottom:none}
.msrow.over,.msrow:hover{background:rgba(201,168,76,.06)}
.msrow.dragging{opacity:.45}
.msrow-main{flex:1;min-width:0}
.msrow-title{font-size:14px;color:var(--cream)}
.msrow-meta{font-size:11px;color:var(--muted);margin-top:3px}
.msowner{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);margin-left:6px}
.msprog{font-size:10px;color:var(--gold);margin-left:6px}
.mslink{display:inline-block;margin-top:6px;font-size:11px;color:var(--gold)}
.mshist{margin-top:14px;border-top:1px solid var(--line);padding-top:12px}
.mshist-row{display:grid;grid-template-columns:90px 1fr auto;gap:8px;font-size:11px;padding:5px 0;border-bottom:1px solid rgba(201,168,76,.06)}
.mshist-row:last-child{border-bottom:none}
.mform-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:4px}
.modalcard-wide{width:min(640px,94vw)}
@media(max-width:640px){.mform-row{grid-template-columns:1fr}.chart-filters{grid-template-columns:repeat(2,1fr);max-width:none}}

/* deliverables */
.progressbar{height:6px;background:var(--surface2);border:1px solid var(--line);margin-bottom:18px}
.progressbar div{height:100%;background:var(--gold);width:0;transition:width .6s}
.tablebox{overflow-x:auto;border:1px solid var(--line)}
table{width:100%;border-collapse:collapse;font-size:13px}
th{background:var(--surface2);color:var(--gold);font-weight:400;font-size:10px;letter-spacing:.2em;text-transform:uppercase;padding:10px 14px;text-align:left;border-bottom:1px solid var(--line)}
td{padding:10px 14px;border-bottom:1px solid rgba(201,168,76,.1)}
.chip{font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--line)}
.chip.delivered{color:var(--green);border-color:var(--green)}
.chip.in_progress{color:var(--amber);border-color:var(--amber)}
.chip.promised{color:var(--muted)}

/* ===== deliverable phase cards (like the video board) ===== */
.phasewrap{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:14px}
.phasecard{background:var(--surface);border:1px solid var(--line);border-radius:4px;overflow:hidden;display:flex;flex-direction:column}
.phasecard.dragging{opacity:.4}
.phasecard.over{border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.phasehead{display:flex;align-items:center;gap:6px;padding:10px 12px;background:var(--surface2);border-bottom:1px solid var(--line)}
.grip{color:var(--muted);cursor:grab;font-size:12px;letter-spacing:-2px;user-select:none}
.phasehead:hover .grip{color:var(--gold)}
.phasename{flex:1;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--gold);background:transparent;border:1px solid transparent;padding:4px 6px;border-radius:2px;line-height:1.4;min-width:0}
.phasename:hover{border-color:var(--line)}
.phasename:focus{outline:none;border-color:var(--gold);background:var(--ink)}
.phasenameC{flex:1;font-family:'Cormorant Garamond',serif;font-size:16px;font-weight:600;color:var(--gold)}
.phasecount{font-size:11px;color:var(--muted);font-variant-numeric:tabular-nums;letter-spacing:.05em;white-space:nowrap}
.phasedel{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 4px;opacity:.5}
.phasedel:hover{color:var(--red);opacity:1}
.phaserows{padding:8px;display:flex;flex-direction:column;gap:6px;flex:1}
.drow{display:flex;align-items:center;gap:6px;padding:5px 4px;border-radius:2px}
.drow:hover{background:rgba(201,168,76,.04)}
.taskgrip{color:var(--muted);cursor:grab;font-size:10px;letter-spacing:-2px;user-select:none;opacity:.5;flex-shrink:0}
.drow:hover .taskgrip{color:var(--gold);opacity:1}
.drow.dragging{opacity:.4}
.drow.taskover{box-shadow:inset 0 2px 0 var(--gold)}
.drow .dname{flex:1;font-size:13px;line-height:1.5;min-width:0}
.drow .owner{width:52px;text-transform:uppercase;letter-spacing:.06em;color:var(--gold);font-size:11px;text-align:center;flex-shrink:0}
.drow .dueinput{width:128px;flex-shrink:0;font-size:12px;color:var(--cream)}
.drow .statussel{flex-shrink:0}
.drow.client{padding:7px 6px;border-bottom:1px solid rgba(201,168,76,.07)}
.drow.client:last-child{border-bottom:none}
.dnameC{flex:1;font-size:13px;color:var(--cream)}
/* truncate long names/titles; click (client) or focus (team) expands to full text */
.drow,.phasehead{flex-wrap:wrap}
.dname,.phasename,.dnameC,.phasenameC{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dnameC,.phasenameC{cursor:pointer}
.dname:focus,.phasename:focus,
.dnameC.expanded,.phasenameC.expanded{white-space:normal;overflow:visible;text-overflow:clip;overflow-wrap:anywhere}
.dname:focus,.phasename:focus{flex-basis:100%;min-width:100%}
.adddeliv{margin-top:2px;background:none;border:1px dashed var(--line);color:var(--muted);font-family:'Jost';font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:7px;cursor:pointer;border-radius:2px}
.adddeliv:hover{border-color:var(--gold);color:var(--gold)}
.newphase{display:flex;gap:10px;margin-top:14px;align-items:center}
.newphase input{flex:0 1 260px}
/* feed edit/delete */
.fitem{position:relative}
.fmsg{display:inline}
.factions{margin-left:8px;white-space:nowrap}
.fedit,.fdel{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 4px;opacity:.5}
.fedit:hover{color:var(--gold);opacity:1}
.fdel:hover{color:var(--red);opacity:1}

/* pipeline */
.pipeline{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:12px;overflow-x:auto}
.col{background:var(--surface);border:1px solid var(--line);padding:12px}
.col .h{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.vitem{font-size:12.5px;padding:8px 10px;background:var(--ink);border:1px solid var(--line);margin-bottom:8px;line-height:1.4}
.vitem.blocked{border-color:var(--gold)}
.vitem .why{display:block;font-size:10.5px;color:var(--gold);margin-top:4px;letter-spacing:.04em}

/* kpi trend charts */
.kpi-charts{margin-bottom:28px;animation:viewin .22s ease}
.kpi-charts-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;flex-wrap:wrap;margin-bottom:14px}
.chartpanel{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:14px 14px 10px;margin-bottom:14px}
.chartpanel-invest{margin-bottom:18px}
.charttitle{font-family:'Cormorant Garamond',serif;font-size:17px;color:var(--cream);margin-bottom:2px}
.chartsub{font-size:11.5px;color:var(--muted);margin-bottom:10px}
.chartbox{position:relative;height:200px}
.chartbox-lg{height:260px}
.chart-filters{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px 12px;max-width:480px;margin-bottom:12px}
.chart-filter{display:inline-flex;align-items:center;gap:7px;padding:5px 2px;background:none;border:none;cursor:pointer;font-family:'Jost',sans-serif;font-size:12px;color:var(--cream);letter-spacing:.02em;line-height:1}
.chart-filter:hover .cf-box{box-shadow:0 0 0 1px color-mix(in srgb,var(--cf) 55%,transparent)}
.chart-filter:focus{outline:none}
.chart-filter:focus-visible .cf-box{outline:1px solid var(--cream);outline-offset:2px}
.cf-box{flex-shrink:0;width:14px;height:14px;border:2px solid var(--cf);border-radius:2px;background:transparent;transition:background-color .15s ease,box-shadow .15s ease}
.chart-filter.on .cf-box{background:var(--cf)}
/* one trend chart per metric — own auto-scaled axis, no shared/percentage axis */
.chartgrid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-bottom:6px}
.chartcard{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:12px 14px 10px;animation:viewin .22s ease}
.chartcard-h{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:8px}
.cc-title{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.cc-latest{font-family:'Cormorant Garamond',serif;font-size:22px;font-weight:600;color:var(--cc,var(--gold));font-variant-numeric:tabular-nums}
.chartcard .chartbox{height:152px}
@media(max-width:640px){.chartgrid{grid-template-columns:1fr}}
.cf-label{color:var(--cream)}

/* kpi cards + status */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:16px}
.card{background:var(--surface);border:1px solid var(--line);padding:18px 20px 14px}
.card .k{font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:6px}
.card .big{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:600;margin:6px 0 2px;font-variant-numeric:tabular-nums}
.card .tgt{font-size:11px;color:var(--muted)}
/* month-aware green sublabel under each KPI card ('this month' / 'in March') */
.card .mnote{font-size:10.5px;letter-spacing:.04em;margin-top:3px;color:var(--muted)}
.card .mnote.g{color:var(--green)}
/* themed ⓘ info button on each metric card (no default browser tooltip styling) */
.metricinfo{margin-left:auto;width:16px;height:16px;line-height:14px;padding:0;border:1px solid var(--line);
  border-radius:50%;background:transparent;color:var(--muted);font-size:11px;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;transition:color .15s ease,border-color .15s ease}
.metricinfo:hover{color:var(--gold);border-color:var(--gold)}
.metricinfo:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.card .trend{margin-top:8px;font-size:11px;font-variant-numeric:tabular-nums;letter-spacing:.02em}
.trend.up{color:#3aa76d}
.trend.down{color:#c0573f}
.trend.flat{color:var(--muted)}
.status{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:14px}
.srow{display:flex;justify-content:space-between;align-items:baseline;padding:12px 16px;background:var(--surface);border:1px solid var(--line)}
.srow .n{font-size:13px}
.srow .s{font-size:10px;letter-spacing:.22em;text-transform:uppercase}
.s.g{color:var(--green)}.s.a{color:var(--amber)}.s.r{color:var(--red)}.s.i{color:var(--muted)}

/* feed */
.fitem{padding:14px 0;border-bottom:1px solid rgba(201,168,76,.1);font-size:14px;line-height:1.5}
.fitem .meta{font-size:11px;color:var(--muted);letter-spacing:.08em;margin-top:4px}

/* team forms — sit flush on the near-black page (no lighter --surface panel) like the client side */
.entry{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:14px 18px;margin-top:14px}
.f label{display:block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.f input,.f select{width:100%;background:var(--ink);border:1px solid var(--line);color:var(--cream);padding:11px 12px;font-family:'Jost';font-size:14px;transition:border-color .18s ease, box-shadow .18s ease}
.f select,.picker{
  appearance:none;-webkit-appearance:none;-moz-appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23C9A84C' stroke-width='1.5'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;background-size:11px;
  padding-right:38px;
}
.f select:hover,.picker:hover{border-color:var(--gold)}
.f input:hover{border-color:var(--gold-dim)}
.f input:focus,.f select:focus,.picker:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
select option{background:var(--surface2);color:var(--cream)}
.actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:20px;align-items:center}
.btn{background:var(--gold);color:#171410;border:none;font-family:'Jost';font-weight:500;font-size:11px;letter-spacing:.22em;text-transform:uppercase;padding:12px 22px;cursor:pointer}
.btn.ghost{background:none;border:1px solid var(--line);color:var(--cream)}
.btn.ghost.previewing{background:var(--gold);color:#171410}
.btn.danger{background:none;border:1px solid var(--red);color:var(--red)}
.btn.danger:hover{background:var(--red);color:#171410}
.btn.danger:disabled{opacity:.5;cursor:default}
.danger-title{color:var(--red) !important}
.dangerzone{border:1px solid rgba(198,106,88,.4);border-radius:4px;padding:14px 16px;margin-top:4px;background:rgba(198,106,88,.05)}
.dangerzone .actions{margin-top:12px}
/* notification banner (client) */
.notifybar{display:flex;align-items:center;gap:12px;background:linear-gradient(90deg,rgba(201,168,76,.16),rgba(201,168,76,.04));border-bottom:1px solid var(--gold);padding:12px 28px;color:var(--cream);font-size:14px}
.notifybar .noteicon{color:var(--gold);font-size:10px}
.notifybar .notetext{flex:1;letter-spacing:.02em}
.notifybar .noteclose{background:none;border:none;color:var(--muted);cursor:pointer;font-size:15px;padding:2px 6px}
.notifybar .noteclose:hover{color:var(--gold)}
.metricshead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:26px}
.metricshead .sub{margin-bottom:14px}
#metricsPicker{min-width:150px}
.note{font-size:12px;color:var(--muted);line-height:1.5}
/* Team workspace · primary navigation */
.teamtopnav{background:var(--surface);border-bottom:1px solid var(--line);margin-bottom:0}
.teamtopnav-inner{display:flex;gap:6px;padding:10px 0 12px}
.teamtop{font-family:'Jost',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);text-decoration:none;padding:8px 14px;border:1px solid transparent;border-radius:3px;transition:color .15s ease,border-color .15s ease,background .15s ease}
.teamtop:hover{color:var(--cream);border-color:var(--line)}
.teamtop.active{color:var(--gold);border-color:rgba(201,168,76,.45);background:rgba(201,168,76,.08)}
/* Operations Dashboard */
#operationsPanel{padding-top:8px;animation:viewin .25s ease}
.ops-head{margin-bottom:22px}
.ops-head h2{margin-bottom:4px}
.ops-search-wrap{margin-top:14px;max-width:520px}
.ops-search{width:100%;padding:12px 14px}
.ops-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:24px}
.ops-metric{min-height:108px;display:flex;flex-direction:column;justify-content:flex-start}
.ops-metric-primary .big{font-size:32px}
.ops-metric-secondary .big{font-size:26px}
.ops-metric-secondary .k{color:var(--muted)}
.ops-metric-g .big{color:var(--green)}
.ops-metric-a .big{color:var(--amber)}
.ops-metric-r .big{color:var(--red)}
.ops-card{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:14px 16px;text-align:center}
.ops-card-val{font-family:'Cormorant Garamond',serif;font-size:28px;font-weight:600;color:var(--cream);font-variant-numeric:tabular-nums;line-height:1.1}
.ops-card-lbl{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-top:6px;line-height:1.35}
.ops-card-g .ops-card-val{color:var(--green)}
.ops-card-a .ops-card-val{color:var(--amber)}
.ops-card-r .ops-card-val{color:var(--red)}
.ops-split{display:grid;grid-template-columns:1.2fr .8fr;gap:16px;margin-bottom:16px}
.ops-panel{background:var(--surface);border:1px solid var(--line);border-radius:4px;padding:16px 18px;margin-bottom:16px}
.ops-panel h3{font-family:'Cormorant Garamond',serif;font-size:18px;color:var(--cream);margin:0 0 2px;line-height:1.25}
.ops-panel-note{margin:0 0 12px;line-height:1.45}
.ops-queue,.ops-feed{display:flex;flex-direction:column;gap:8px}
.ops-alert{display:flex;gap:10px;padding:11px 12px;background:var(--ink);border:1px solid var(--line);border-radius:3px;cursor:pointer;transition:border-color .15s ease,transform .12s ease;align-items:flex-start}
.ops-alert:hover{border-color:rgba(201,168,76,.35);transform:translateX(2px)}
.ops-alert-icon{font-size:14px;line-height:1.2;flex-shrink:0;margin-top:1px}
.ops-alert-body{display:flex;flex-direction:column;justify-content:center;min-height:44px}
.ops-alert-practice{font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);line-height:1.3}
.ops-alert-title{font-size:13px;color:var(--cream);margin-top:3px;line-height:1.35}
.ops-alert-detail{font-size:11.5px;color:var(--muted);margin-top:3px;line-height:1.4}
.ops-alert-red{border-left:3px solid var(--red)}
.ops-alert-yellow{border-left:3px solid var(--amber)}
.ops-alert-green{border-left:3px solid var(--green)}
.ops-kpi-rollup{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:12px;margin-top:8px}
.ops-kpi{background:var(--ink);border:1px solid var(--line);padding:12px;border-radius:3px}
.ops-kpi-v{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--cream);font-variant-numeric:tabular-nums}
.ops-kpi-l{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px}
.ops-overview-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap;margin-bottom:8px}
.ops-overview-tools{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.ops-client-search{min-width:220px}
.ops-client-count{margin:0 0 10px}
.ops-urgent-strip{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.ops-urgent-chip{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 11px;background:var(--ink);border:1px solid var(--line);border-radius:3px;cursor:pointer;font-family:'Jost',sans-serif;text-align:left;max-width:260px;transition:border-color .15s ease}
.ops-urgent-chip:hover{border-color:rgba(201,168,76,.35)}
.ops-urgent-red{border-left:3px solid var(--red)}
.ops-urgent-yellow{border-left:3px solid var(--amber)}
.ops-urgent-practice{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.ops-urgent-title{font-size:12px;color:var(--cream);line-height:1.35}
.ops-client-list{display:flex;flex-direction:column;gap:8px}
.ops-client-block{border:1px solid var(--line);border-radius:3px;background:var(--ink);overflow:hidden}
.ops-client-block.expanded{border-color:rgba(201,168,76,.28)}
.ops-client-head{width:100%;display:grid;grid-template-columns:auto 1fr auto auto;grid-template-areas:"caret name pill meta" ". next next next";gap:4px 10px;padding:12px 14px;background:none;border:none;color:var(--cream);font-family:'Jost',sans-serif;text-align:left;cursor:pointer;align-items:center}
.ops-client-head:hover{background:rgba(201,168,76,.04)}
.ops-client-caret{grid-area:caret;color:var(--gold);font-size:12px;line-height:1}
.ops-client-name{grid-area:name;font-size:14px;color:var(--cream)}
.ops-client-meta{grid-area:meta;font-size:11px;color:var(--muted);justify-self:end}
.ops-client-next{grid-area:next;font-size:11px;color:var(--muted);padding-left:18px}
.ops-client-detail{padding:0 14px 14px;border-top:1px solid rgba(201,168,76,.1)}
.ops-client-metrics{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px;margin:12px 0 14px}
.ops-client-metric{background:var(--surface);border:1px solid var(--line);padding:10px 12px;border-radius:3px}
.ops-client-metric-v{font-family:'Cormorant Garamond',serif;font-size:22px;color:var(--cream);line-height:1.1}
.ops-client-metric-l{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:4px;line-height:1.3}
.ops-client-metric.warn .ops-client-metric-v{color:var(--amber)}
.ops-client-metric.band-red .ops-client-metric-v{color:var(--red)}
.ops-client-metric.band-yellow .ops-client-metric-v{color:var(--amber)}
.ops-client-metric.band-green .ops-client-metric-v{color:var(--green)}
.ops-client-section{margin-bottom:14px}
.ops-client-section h4{font-family:'Cormorant Garamond',serif;font-size:15px;color:var(--gold);margin:0 0 8px;font-weight:500}
.ops-table-compact td,.ops-table-compact th{padding:7px 8px}
.ops-due-cell{min-width:128px}
.ops-due-input{max-width:132px;font-size:12px}
.ops-open-client{margin-top:4px}
.login-persist{color:var(--muted);margin-top:10px;font-size:11.5px}
.deeplink-flash{animation:deeplinkpulse 2.4s ease}
@keyframes deeplinkpulse{0%,100%{box-shadow:none}15%,45%{box-shadow:0 0 0 2px rgba(201,168,76,.55), inset 0 0 0 1px rgba(201,168,76,.35)}}
.ops-table-wrap{overflow-x:auto;margin-top:8px}
.ops-table{width:100%;border-collapse:collapse;font-size:12.5px}
.ops-table th{text-align:left;font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);padding:8px 10px;border-bottom:1px solid var(--line);white-space:nowrap}
.ops-table td{padding:9px 10px;border-bottom:1px solid rgba(201,168,76,.08);color:var(--cream);vertical-align:top}
.ops-table tr:hover td{background:rgba(201,168,76,.04)}
.ops-row-click{cursor:pointer}
.ops-row-warn td{color:#e8a090}
.ops-row-caution td{color:var(--amber)}
.ops-row-overdue td,.ops-row-warn.ops-row-overdue td{color:var(--red)}
.ops-pill{display:inline-block;padding:2px 8px;border-radius:2px;font-size:11px;font-variant-numeric:tabular-nums}
.ops-pill-green{background:rgba(58,167,109,.15);color:var(--green)}
.ops-pill-yellow{background:rgba(201,168,76,.15);color:var(--amber)}
.ops-pill-red{background:rgba(198,106,88,.15);color:var(--red)}
@media(max-width:900px){.ops-split{grid-template-columns:1fr}}
/* Team Controls global screen */
.adminback{display:inline-block;margin-bottom:14px;font-size:12px;letter-spacing:.06em;color:var(--gold);text-decoration:none}
.adminback:hover{text-decoration:underline}
.clientlist{margin-top:6px;display:flex;flex-direction:column;gap:1px}
.clientrow{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 12px;background:var(--surface);border:1px solid var(--line)}
.clientrow .cname{font-size:14px}
#saveMsg,#loginMsg{font-size:12px;color:var(--green);letter-spacing:.06em}
footer{padding:34px 0 50px;color:var(--muted);font-size:11px;letter-spacing:.2em;text-transform:uppercase;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
@media(max-width:640px){.stat{align-items:flex-start;text-align:left;border-right:none;border-left:1px solid var(--gold);padding:6px 0 6px 16px;margin-bottom:14px}}

/* ===== inline editing (team) ===== */
.cellinput{width:100%;background:transparent;border:1px solid transparent;color:var(--cream);font-family:'Jost';font-size:13px;padding:6px 8px;border-radius:2px}
.cellinput:hover{border-color:var(--line)}
.cellinput:focus{outline:none;border-color:var(--gold);background:var(--ink)}
.cellinput.owner{max-width:80px;text-transform:uppercase;letter-spacing:.1em;color:var(--gold)}
.statussel,.stagesel,.milesel,td .statussel,td .stagesel{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--ink);border:1px solid var(--line);color:var(--cream);font-family:'Jost';font-size:12px;padding:6px 26px 6px 10px;cursor:pointer;border-radius:2px;
  background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23C9A84C' stroke-width='1.5'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 9px center}
.statussel:focus,.stagesel:focus,.milesel:focus{outline:none;border-color:var(--gold)}
.statussel option,.stagesel option,.milesel option{background:var(--surface2);color:var(--cream)}
.rowdel{background:none;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:4px 8px;border-radius:2px}
.rowdel:hover{color:var(--red);background:rgba(198,106,88,.1)}
tr.addrow td{background:rgba(201,168,76,.04)}
.addrow .cellinput{border-color:var(--line)}
.btn.sm{padding:7px 14px;font-size:10px}

/* video pipeline drag-and-drop (team) */
.col.dropcol{transition:border-color .15s, background .15s}
.col.dropcol.over{border-color:var(--gold);background:rgba(201,168,76,.06)}
.coldrop{min-height:80px}
.col.dropcol{display:flex;flex-direction:column}
.col.dropcol .coldrop{flex:1}
.vitem[data-vid]{cursor:pointer}
.vitem[draggable]{cursor:grab}
.vitem[draggable]:hover{border-color:var(--gold)}
.vitem.dragging{opacity:.4;cursor:grabbing}
.col .cnt{color:var(--muted)}
.vtitle{display:block;padding-right:18px}
.vdate{display:block;font-size:10px;color:var(--muted);letter-spacing:.04em;margin-top:6px;line-height:1.5}
.vdays{display:block;font-size:9.5px;color:var(--muted);letter-spacing:.08em;text-transform:uppercase;margin-top:5px}
/* team-only age-based SLA states (>=3d warn, >=7d overdue) for video + deliverables */
.vdays.warn{color:var(--amber)}
.vdays.overdue{color:var(--red)}
.vitem.warn{border-color:var(--amber);background:rgba(212,162,78,.07)}
.vitem.overdue{border-color:var(--red);background:rgba(198,106,88,.10)}
.drow.taskrow.warn{box-shadow:inset 2px 0 0 var(--amber);background:rgba(212,162,78,.06)}
.drow.taskrow.overdue{box-shadow:inset 2px 0 0 var(--red);background:rgba(198,106,88,.08)}
.agechip{flex-shrink:0;font-size:9.5px;letter-spacing:.06em;padding:1px 5px;border-radius:8px;font-variant-numeric:tabular-nums}
.agechip.warn{color:var(--amber);border:1px solid var(--amber)}
.agechip.overdue{color:var(--red);border:1px solid var(--red)}
.vlink{display:inline-block;font-size:10px;color:var(--gold);margin-top:4px;letter-spacing:.1em;text-transform:uppercase;text-decoration:none}
.vlink:hover{text-decoration:underline}
.vitem{position:relative}
.vdel{position:absolute;top:5px;right:5px;background:none;border:none;color:var(--muted);font-size:11px;cursor:pointer;padding:2px 4px;line-height:1;opacity:0;transition:opacity .15s}
.vitem:hover .vdel{opacity:1}
.vdel:hover{color:var(--red)}
.vadd{width:100%;margin-top:8px;background:none;border:1px dashed var(--line);color:var(--muted);font-family:'Jost';font-size:11px;letter-spacing:.12em;text-transform:uppercase;padding:8px;cursor:pointer;border-radius:2px}
.vadd:hover{border-color:var(--gold);color:var(--gold)}
.mtextarea{resize:vertical;min-height:48px;line-height:1.5;font-family:'Jost'}

/* milestone date edit (team) — original roadmap look, just an editable date */
.tldate{margin-top:8px}
.dateedit{background:var(--ink);border:1px solid var(--line);color:var(--gold);font-family:'Jost';font-size:11px;letter-spacing:.08em;padding:5px 8px;border-radius:2px;cursor:pointer}
.dateedit:hover{border-color:var(--gold)}
.dateedit:focus{outline:none;border-color:var(--gold)}
.dateedit::-webkit-calendar-picker-indicator{filter:invert(70%) sepia(40%) saturate(500%) hue-rotate(5deg)}

/* video detail modal */
.modal{position:fixed;inset:0;background:rgba(8,7,10,.78);backdrop-filter:blur(4px);display:none;align-items:center;justify-content:center;z-index:50;padding:24px}
.modal.open{display:flex}
.modalcard{width:min(560px,94vw);max-height:88vh;overflow-y:auto;background:var(--surface);border:1px solid var(--gold);border-radius:4px}
.modalhead{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line)}
.modalhead h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:22px;color:var(--cream)}
.modalx{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer}
.modalx:hover{color:var(--gold)}
.modalbody{padding:18px 22px;display:flex;flex-direction:column;gap:6px}
.mlabel{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-top:12px}
.mfield{font-size:14px}
.mstage{color:var(--cream);font-size:14px;padding:6px 0}
.mdates{display:flex;flex-direction:column;gap:10px}
.mdates .mlabel{margin-top:0}
.mdates>div{display:flex;flex-direction:column;gap:4px}
.histbox{border:1px solid var(--line);border-radius:3px;padding:4px 0;margin-top:4px}
.histrow{display:flex;align-items:center;gap:10px;padding:7px 14px;font-size:12.5px;border-bottom:1px solid rgba(201,168,76,.08)}
.histrow:last-child{border-bottom:none}
.hstage{color:var(--cream);flex:1}
.hdate{color:var(--muted);font-variant-numeric:tabular-nums}
.histdel{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 2px;opacity:.5}
.histdel:hover{color:var(--red);opacity:1}
.modalfoot{display:flex;flex-wrap:wrap;gap:12px;align-items:center;padding:16px 22px;border-top:1px solid var(--line)}

/* ============================================================
   PHASE A · tabbed views, searchable switcher, deliverables redesign
   ============================================================ */
a.btn{text-decoration:none;display:inline-block}

/* tabbed navigation (hash-routed) */
.tabs{display:flex;flex-wrap:wrap;gap:2px;border-bottom:1px solid var(--line);margin-top:6px}
.tab{padding:14px 20px;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .15s,border-color .15s}
.tab:hover{color:var(--cream)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}

/* only the active view is shown */
.view{display:none}
.view.active{display:block;animation:viewin .18s ease}
@keyframes viewin{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

/* searchable client switcher (team) */
.switcher{position:relative}
.switcher-btn{display:flex;align-items:center;gap:8px;min-width:200px;max-width:280px;cursor:pointer;text-align:left}
.switcher-btn-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.switcher-caret{font-size:10px;color:var(--gold);flex-shrink:0}
.switcher-pop{position:absolute;top:calc(100% + 4px);right:0;left:0;min-width:280px;background:var(--surface2);
  border:1px solid var(--gold);border-radius:3px;z-index:30;box-shadow:0 10px 30px rgba(0,0,0,.4);overflow:hidden}
.switcher-search{display:block;width:100%;box-sizing:border-box;border:none;border-bottom:1px solid var(--line);
  background:var(--ink);color:var(--cream);font-family:'Jost';font-size:13px;padding:10px 12px;border-radius:0}
.switcher-search:focus{outline:none;background:var(--surface)}
.switcher-search::placeholder{color:var(--muted)}
.switcher-results{max-height:280px;overflow-y:auto}
.switcher-item{display:block;width:100%;text-align:left;background:none;border:none;color:var(--cream);font-family:'Jost';font-size:13px;padding:9px 12px;cursor:pointer;letter-spacing:.02em}
.switcher-item:hover{background:rgba(201,168,76,.12);color:var(--gold)}
.switcher-item.current{color:var(--gold)}
.switcher-item.current::after{content:' ✓';color:var(--gold)}
.switcher-empty{padding:10px 12px;font-size:12px;color:var(--muted)}

/* section header with an action on the right */
.sechead{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}

/* deliverables info-guide */
.guide{border:1px solid var(--line);border-radius:4px;padding:16px 18px;margin:6px 0 18px;background:var(--surface);font-size:13.5px;line-height:1.6;color:var(--cream)}
.guide p{margin-bottom:10px}
.guidelist{list-style:none;display:flex;flex-direction:column;gap:8px;margin:4px 0 12px}
.guidelist li{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.guidelist .chip{flex-shrink:0}

/* collapsible phase cards + per-phase progress */
.caret{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 2px;transition:transform .15s;flex-shrink:0}
.caret:hover{color:var(--gold)}
.phasecard.collapsed .caret{transform:rotate(-90deg)}
.phasecard.collapsed .phaserows{display:none}
.phaseprog{flex:1;height:4px;min-width:36px;background:var(--ink);border-radius:2px;overflow:hidden}
.phaseprog>span{display:block;height:100%;background:var(--gold);transition:width .5s}

/* per-deliverable info (ⓘ) layer */
.infobtn{background:none;border:none;color:var(--muted);cursor:pointer;font-size:12px;padding:0 4px;flex-shrink:0;opacity:.55}
.infobtn:hover{color:var(--gold);opacity:1}
.infobtn.has{color:var(--gold);opacity:.9}
.dinfo{display:block;font-size:12px;color:var(--muted);line-height:1.5;margin-top:5px;padding:7px 10px;border-left:2px solid var(--gold);background:rgba(201,168,76,.05);border-radius:0 2px 2px 0}
.drow.client .dnameC{display:block}

/* edited-update marker */
.edited{color:var(--gold);font-style:italic;letter-spacing:.04em}

/* ============================================================
   POLISH PASS · subtle size increase, smoother interactions,
   themed dialogs + native controls (overrides earlier rules)
   ============================================================ */

/* --- 1) slightly larger, more spacious --- */
.wrap{max-width:1240px}
h2{font-size:31px}
.sub{font-size:14px}
.card{padding:21px 24px 17px}
.tab{padding:15px 24px;font-size:12px}
.picker,.f select{font-size:13px}
.f input,.f select{font-size:14.5px;padding:12px 13px}
.btn{font-size:11.5px;padding:13px 26px;border-radius:3px}
.btn.sm{padding:9px 17px;font-size:10.5px;border-radius:3px}

/* --- 2) smoother / more polished interactions --- */
.btn{transition:background .16s ease, color .16s ease, border-color .16s ease, box-shadow .16s ease, transform .1s ease}
.btn:hover{box-shadow:0 3px 14px rgba(201,168,76,.18)}
.btn.ghost:hover{border-color:var(--gold);color:var(--gold);box-shadow:none}
.btn:active{transform:translateY(1px)}
.btn:disabled{opacity:.5;cursor:default;box-shadow:none;transform:none}
.card{transition:border-color .18s ease, transform .18s ease, box-shadow .18s ease}
.tab{transition:color .18s ease, border-color .18s ease}
.switcher-item,.clientrow,.srow,.histrow,.fitem{transition:background .15s ease, border-color .15s ease}
.clientrow:hover{border-color:var(--gold)}
.noteclose,.modalx,.caret,.infobtn,.rowdel,.vdel,.phasedel,.histdel{transition:color .15s ease, opacity .15s ease, transform .12s ease}
.modalx:hover,.noteclose:hover{transform:rotate(90deg)}

/* --- 3) themed confirm/prompt dialogs (replace native confirm/alert/prompt) --- */
.dlg-overlay{position:fixed;inset:0;z-index:80;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,7,10,.66);backdrop-filter:blur(5px);opacity:0;transition:opacity .16s ease}
.dlg-overlay.show{opacity:1}
.dlg{width:min(440px,94vw);background:var(--surface);border:1px solid var(--gold);border-radius:6px;
  box-shadow:0 24px 70px rgba(0,0,0,.55);padding:24px 24px 20px;
  transform:translateY(8px) scale(.98);opacity:0;transition:transform .18s cubic-bezier(.2,.8,.2,1), opacity .18s ease}
.dlg-overlay.show .dlg{transform:none;opacity:1}
.dlg-head{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:23px;color:var(--cream);margin-bottom:8px}
.dlg-body{font-size:13.5px;line-height:1.6;color:var(--muted)}
.dlg-body b{color:var(--cream);font-weight:500}
/* metric explainer body inside the themed dialog (ⓘ popover content) */
.metricdef{display:flex;flex-direction:column;gap:12px}
.metricdef .mdrow{display:grid;grid-template-columns:96px 1fr;gap:12px;align-items:start}
.metricdef .mdlabel{font-size:9.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);padding-top:2px}
.metricdef .mdrow>div:last-child{color:var(--cream);font-size:13px;line-height:1.55}
@media(max-width:520px){.metricdef .mdrow{grid-template-columns:1fr;gap:3px}}
.dlg-input{width:100%;margin-top:16px;background:var(--ink);border:1px solid var(--line);color:var(--cream);
  padding:12px 13px;font-family:'Jost';font-size:14.5px;border-radius:3px;transition:border-color .16s ease, box-shadow .16s ease}
.dlg-input:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.dlg-input.bad{border-color:var(--red);box-shadow:0 0 0 1px var(--red)}
.dlg-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}

/* --- 4) themed native controls (selects + date/month pickers) --- */
input,select,textarea{color-scheme:dark}                       /* dark native calendar / option popups */
.f select,.picker{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:34px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23C9A84C' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 13px center;cursor:pointer}
/* dark-themed field + native calendar popup (color-scheme:dark) — no white control */
input[type=date],input[type=month]{color-scheme:dark;background:var(--ink);color:var(--cream);border:1px solid var(--line)}
input[type=date]::-webkit-calendar-picker-indicator,
input[type=month]::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.65;
  filter:invert(72%) sepia(38%) saturate(560%) hue-rotate(2deg) brightness(92%)}
input[type=date]::-webkit-calendar-picker-indicator:hover,
input[type=month]::-webkit-calendar-picker-indicator:hover{opacity:1}

/* ============================================================
   MOBILE / TABLET OPTIMIZATION (desktop-first → graceful down)
   ============================================================ */
@media(max-width:900px){
  .wrap{padding:0 20px}
  .phasewrap{grid-template-columns:1fr 1fr}
  h2{font-size:28px}
  section{padding:36px 0}
}
@media(max-width:640px){
  .wrap{padding:0 15px}

  /* header: let controls wrap, switcher goes full-width */
  .bar{height:auto;flex-wrap:wrap;gap:10px;padding:10px 0}
  .right{flex-wrap:wrap;gap:10px;width:100%}
  #practiceSwitcher,.switcher-btn{width:100%;max-width:none}
  .switcher-pop{width:100%}
  .practice{display:none}                      /* drop the email/role label on phones */

  /* hero */
  .hero{padding:32px 0 26px}
  .updated{font-size:11.5px}
  .stats{margin-top:24px;gap:2px}

  /* tabs: horizontal scroll instead of wrapping into 3 rows */
  .tabs{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .tabs::-webkit-scrollbar{display:none}
  .tab{flex:0 0 auto;padding:13px 16px;font-size:11px}

  /* one-column layouts for grids */
  .phasewrap{grid-template-columns:1fr}
  .entry{grid-template-columns:1fr}
  .cards{grid-template-columns:1fr 1fr}
  .status{grid-template-columns:1fr}

  /* pipeline stays a horizontal-scroll kanban (the mobile-friendly pattern for a board) */
  .pipeline{grid-auto-flow:column;grid-auto-columns:78vw;grid-template-columns:none;
    overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity;gap:10px}
  .pipeline .col{scroll-snap-align:start}

  /* typography + spacing trims */
  h2{font-size:25px}
  section{padding:30px 0}
  .btn{padding:12px 20px}
  .sechead,.metricshead{gap:10px}

  /* dialogs + modals full-bleed-ish on small screens */
  .dlg{width:94vw;padding:20px}
  .modalcard{width:94vw}

  /* admin client rows wrap nicely */
  .clientrow{flex-wrap:wrap;gap:8px}
}
@media(max-width:400px){
  .cards{grid-template-columns:1fr}
  .pipeline{grid-auto-columns:86vw}
}

/* Admin · manual KPI sync trigger */
.syncnowrow{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:10px 0 12px}
.syncnowrow .note{margin:0}
.syncnowrow.syncing #btnSyncNow{opacity:.6;pointer-events:none}
.syncnowrow.ok #syncNowMsg{color:var(--green)}
.syncnowrow.err #syncNowMsg{color:var(--red)}

/* Admin onboarding checklist */
.onboard-check{margin:12px 0 18px;padding:14px 16px;background:rgba(201,168,76,.08);border:1px solid rgba(201,168,76,.25);border-radius:4px}
.onboard-title{font-size:13px;margin-bottom:8px}
.onboard-steps{margin:0;padding-left:20px;font-size:12.5px;line-height:1.7;color:var(--muted)}
.onboard-steps li.onboard-done{color:var(--text);list-style-type:'✓ '}
.onboard-steps li.onboard-pending{list-style-type:'○ '}
.onboard-hint{margin:8px 0 0;font-size:11.5px}
/* invite row — checkbox + button as separate grid cells, aligned with other fields */
.invite-entry{align-items:end}
.invite-entry .f{display:flex;flex-direction:column;justify-content:flex-end}
.invite-check{display:inline-flex !important;align-items:center;gap:5px;margin-bottom:0 !important;
  font-size:10px;letter-spacing:.18em;text-transform:uppercase;min-height:42px}
.invite-check input[type=checkbox]{width:10px !important;height:10px !important;min-width:10px;min-height:10px}
.invite-send .invite-send-spacer{display:block;font-size:10px;line-height:1;margin-bottom:6px;visibility:hidden}
.invite-send .btn{width:100%;min-height:42px;padding:10px 14px;box-sizing:border-box}
.checklabel{font-size:12px;color:var(--muted);display:inline-flex;align-items:center;gap:8px;cursor:pointer;letter-spacing:.04em}
/* custom dark/gold checkbox — hide native, draw a themed box with a gold check */
.checklabel input[type=checkbox]{appearance:none;-webkit-appearance:none;-moz-appearance:none;flex:0 0 auto;
  width:12px;height:12px;margin:0;background:var(--ink);border:1px solid var(--line);border-radius:2px;cursor:pointer;
  transition:border-color .15s ease,background .15s ease}
.checklabel input[type=checkbox]:hover{border-color:var(--gold)}
.checklabel input[type=checkbox]:checked{background:var(--gold);border-color:var(--gold)}
.checklabel input[type=checkbox]:focus-visible{outline:none;box-shadow:0 0 0 2px rgba(201,168,76,.5)}
.access-delete-row{margin-top:16px;padding-top:14px;border-top:1px dashed var(--line);display:flex;flex-direction:column;gap:6px;align-items:flex-start}
.access-delete-row .note{margin:0}

/* Access roster (admin + client owners) */
/* flush on the dark page — no card box / lighter fill (incl. the empty-state strip) */
.roster{margin:12px 0 24px;border:none;background:transparent}
.roster .note{padding:10px 0}
.rosterhead,.rosterrow{display:grid;grid-template-columns:2fr 80px 90px auto;gap:10px;align-items:center;padding:8px 12px;font-size:12px}
.rosterhead{color:var(--muted);border-bottom:1px solid var(--line);letter-spacing:.04em;text-transform:uppercase;font-size:10.5px}
.rosterrow{border-bottom:1px solid var(--line)}
.rosterrow:last-child{border-bottom:none}
.rosterrow.pending{opacity:.85}
.rosteremail{overflow:hidden;text-overflow:ellipsis}
.rosterstatus{font-size:10.5px;letter-spacing:.04em;text-transform:uppercase}
.rosterstatus.ok{color:var(--green)}
.badge-plat,.badge-self{font-size:9px;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);margin-left:6px}
.roster-compact{margin-bottom:20px}
@media(max-width:640px){.rosterhead,.rosterrow{grid-template-columns:1fr;gap:4px}}

/* Phase C · per-client reporting-sheet rows in Admin */
.reporting-toolbar{display:flex;flex-wrap:wrap;gap:14px 18px;align-items:flex-end;margin:14px 0 12px;padding:12px 14px;
  background:var(--surface);border:1px solid var(--line);border-radius:4px}
.reporting-toolbar .f{margin:0}
.reporting-search{flex:1;min-width:220px}
.reporting-search input{width:100%}
.reporting-sort{min-width:200px}
.reporting-count{flex:1 1 100%;margin:0;font-size:11px}
.clientrow2{display:block;padding:12px 14px;background:var(--surface);border:1px solid var(--line);transition:border-color .15s ease;margin-bottom:10px}
.clientrow2:hover{border-color:var(--gold)}
.clientrow2 .ccol{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px}
.clientrow2 .ccol .cname{font-size:15px;letter-spacing:.02em}
/* master workbook (one per client) + one config block per source TAB inside it */
.workbookcfg{display:flex;flex-direction:column;gap:6px;border:1px solid var(--line);border-radius:4px;
  padding:10px 11px;background:var(--ink);margin-bottom:12px}
.workbookcfg .chanlabel{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.workbookcfg .btn{align-self:flex-start}
.wbhint{font-size:11px;opacity:.7}
.wbbtns{display:flex;gap:8px;flex-wrap:wrap}
.wboverride{margin-top:8px}
.wboverride summary{cursor:pointer;font-size:11px;letter-spacing:.06em;color:var(--muted);user-select:none}
.wboverride summary:hover{color:var(--gold)}
.wboverride .cellinput{margin:8px 0 6px}
/* admin sub-tabs */
.admintabs{display:flex;gap:4px;flex-wrap:wrap;border-bottom:1px solid var(--line);margin:18px 0 18px}
.admintabs .atab{appearance:none;background:transparent;border:1px solid transparent;border-bottom:none;
  color:var(--muted);font-family:'Jost';font-size:13px;letter-spacing:.04em;padding:9px 16px;cursor:pointer;
  border-radius:4px 4px 0 0;margin-bottom:-1px;transition:color .15s ease,background .15s ease}
.admintabs .atab:hover{color:var(--cream)}
.admintabs .atab.active{color:var(--gold);border-color:var(--line);border-bottom-color:var(--ink);background:var(--surface)}
.admin-tab{animation:fadein .2s ease}
@keyframes fadein{from{opacity:0}to{opacity:1}}
/* theme the admin "Add source" pickers (.cellinput selects weren't covered by .f select) */
select.cellinput{appearance:none;-webkit-appearance:none;-moz-appearance:none;padding-right:30px;cursor:pointer;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='7' viewBox='0 0 10 7'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%23C9A84C' stroke-width='1.4' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 10px center}
select.cellinput option{background:var(--ink);color:var(--cream)}
.masterfolder{border:1px solid var(--line);border-radius:4px;padding:12px 13px;background:var(--ink);margin:8px 0 14px}
.masterfolder .chanlabel{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.masterfolder .mfrow{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap}
.masterfolder .mfrow .cellinput{flex:1;min-width:240px;background:var(--surface);border:1px solid var(--line);
  color:var(--cream);padding:9px 11px;font-family:'Jost';font-size:12.5px;border-radius:3px}
.masterfolder .mfrow .cellinput:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.detectout{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.detectout:empty{display:none}
/* compact source mappings — scales to many channels without a giant vertical stack */
.srclist{display:flex;flex-direction:column;gap:5px;margin:6px 0 8px}
.srcrow{display:grid;grid-template-columns:150px minmax(0,1fr) auto 28px;align-items:center;gap:10px;
  padding:7px 10px;border:1px solid var(--line);border-radius:3px;background:var(--ink)}
.srcrow .srcname{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--gold)}
.srcrow .srcstatus{font-size:11px;white-space:nowrap;text-align:right}
.srcrow .btn.xs.danger{padding:0 7px;line-height:1.6;justify-self:end}
/* safety net: any select not caught by a specific rule still gets the dark theme */
select{background-color:var(--ink);color:var(--cream);border:1px solid var(--line);border-radius:3px;font-family:'Jost';cursor:pointer}
select option{background:var(--surface2);color:var(--cream)}
/* reusable themed dropdown (custom select — themed button + popup) */
.tsel{position:relative;display:inline-block;min-width:170px}
.tsel-btn{width:100%;display:flex;align-items:center;justify-content:space-between;gap:10px;
  background:var(--ink);border:1px solid var(--line);color:var(--cream);font-family:'Jost';font-size:13px;
  padding:9px 12px;border-radius:3px;cursor:pointer;text-align:left;transition:border-color .15s ease,box-shadow .15s ease}
.tsel-btn:hover{border-color:var(--gold)}
.tsel.open .tsel-btn,.tsel-btn:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.tsel-val.placeholder{color:var(--muted)}
.tsel-caret{color:var(--gold);font-size:11px;transition:transform .15s ease}
.tsel.open .tsel-caret{transform:rotate(180deg)}
.tsel-pop{position:absolute;z-index:50;top:calc(100% + 4px);left:0;right:0;max-height:260px;overflow:auto;
  background:var(--surface2);border:1px solid var(--gold);border-radius:3px;padding:4px;
  box-shadow:0 10px 30px rgba(0,0,0,.5)}
.tsel-opt{padding:8px 11px;font-size:13px;color:var(--cream);border-radius:2px;cursor:pointer;outline:none}
.tsel-opt:hover,.tsel-opt:focus{background:var(--surface)}
.tsel-opt.sel{color:var(--gold)}
.tsel-opt.sel::after{content:'✓';float:right;color:var(--gold)}
.tsel-empty{padding:8px 11px;font-size:12px;color:var(--muted)}
.tsel-wrap{display:block}
.tsel-wrap.tsel{min-width:0}
.drow .tsel-wrap{flex:0 0 auto;min-width:128px}
.tsel-native{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0;opacity:0;pointer-events:none}
.tsel-opt.disabled{color:var(--muted);cursor:default;opacity:.6}
.tsel-opt.disabled:hover{background:transparent}
/* dashboard picker fields with clear labels (Channel / Month) */
.metricpickers{align-items:flex-end}
.mp-field{display:flex;flex-direction:column;gap:4px}
.mp-field.hidden{display:none}
.mp-label{font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.mp-field .tsel,.mp-field .picker{min-width:170px}
#whoami.editable{cursor:pointer;border-bottom:1px dotted transparent}
#whoami.editable:hover{border-bottom-color:var(--gold);color:var(--cream)}
.deployrow{display:flex;align-items:center;gap:10px;margin-top:10px;padding-top:10px;border-top:1px solid var(--line);flex-wrap:wrap}
.deploy-msg{font-size:12.5px;letter-spacing:.02em}
.deploy-msg.pending{color:var(--muted)}
.deploy-msg.ok{color:var(--green)}
.deploy-msg.err{color:#e07070}
.deploy-hint{margin:0}
@media(max-width:640px){.srcrow{grid-template-columns:1fr 1fr;gap:6px}.srcrow .srcname{grid-column:1/-1}}
.dtab{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12.5px;
  padding:6px 9px;border:1px solid var(--line);border-radius:3px;background:var(--ink)}
.dtabwhy{flex-basis:100%;font-size:11px;opacity:.75}
/* add-source row mirrors the source rows above: [source 150px][tab 1fr][button] */
.addsource{display:block;margin-top:10px;padding-top:10px;border-top:1px dashed var(--line)}
.addsrc-label{display:block;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.addsource-row{display:grid;grid-template-columns:150px minmax(0,1fr) auto;align-items:center;gap:10px;margin-top:6px}
.addsource-row .btn{white-space:nowrap}
.addsource .addsourcekey{width:100%;margin-top:8px}
.btn.xs{padding:2px 8px;font-size:10.5px}
.sheetchans{display:block}
.sheetchan{border:1px solid var(--line);border-radius:4px;padding:10px 11px;background:var(--ink)}
.sheetchan-h{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.sheetchan-h .chanlabel{font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--gold)}
.sheetcfg{display:flex;flex-direction:column;gap:6px;min-width:0;margin-bottom:8px}
.clientrow2 .cellinput{width:100%;background:var(--surface);border:1px solid var(--line);color:var(--cream);
  padding:9px 11px;font-family:'Jost';font-size:12.5px;border-radius:3px}
.clientrow2 .cellinput:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.clientrow2 .cellinput::placeholder{color:var(--muted);opacity:.7}
.clientrow2 .sheeturl{opacity:.75}
.ssok{font-size:10.5px;color:var(--green);letter-spacing:.04em}
.ssbad{font-size:10.5px;color:var(--red);letter-spacing:.04em}
.metricpickers{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
@media(max-width:640px){.sheetchans{grid-template-columns:1fr}}

/* ---- sync observability: did the 2-hour automation run? status banner + audit table ---- */
.syncstatus-h{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:17px;margin:26px 0 4px;color:var(--gold)}
.syncstatus{margin:8px 0 6px}
.syncbanner{border:1px solid var(--line);border-left-width:3px;background:var(--surface);padding:12px 15px;border-radius:3px}
.syncbanner .sbtitle{font-size:10px;letter-spacing:.22em;text-transform:uppercase;margin-bottom:5px}
.syncbanner .sbtext{font-size:12.5px;line-height:1.55;color:var(--muted)}
.syncbanner .sbtext b{color:var(--cream);font-weight:500}
.syncbanner.ok{border-left-color:var(--green)}
.syncbanner.ok .sbtitle{color:var(--green)}
.syncbanner.warn{border-left-color:var(--amber)}
.syncbanner.warn .sbtitle{color:var(--amber)}
.syncbanner.err{border-left-color:var(--red)}
.syncbanner.err .sbtitle{color:var(--red)}
.synctable{width:100%;border-collapse:collapse;margin-top:10px;border:1px solid var(--line)}
.synctable th{background:var(--surface2);color:var(--gold);font-weight:400;font-size:9px;letter-spacing:.18em;
  text-transform:uppercase;padding:8px 12px;text-align:left;border-bottom:1px solid var(--line)}
.synctable td{padding:8px 12px;font-size:12px;color:var(--cream);border-bottom:1px solid var(--line);font-variant-numeric:tabular-nums}
.synctable tr:last-child td{border-bottom:none}
.synctable td .ssok,.synctable td .ssbad{font-size:11px}
