@import url('https://fonts.googleapis.com/css2?family=Sora:wght@600;700;800&family=Inter:wght@400;500;600&family=JetBrains+Mono:wght@500;700&display=swap');
:root{
  --bg:#0A0E1A;--surface:#121829;--surface2:#1A2138;--border:#232B45;
  --blue:#2D7FFF;--blueDeep:#006FF5;--violet:#7C3AED;--neon:#1FE3D0;--pink:#FF5C8A;
  --text:#E8ECF5;--muted:#8A93AD;--green:#2BD66A;--red:#FF5C5C;--amber:#FFB23E;
  --sans:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --disp:'Sora',var(--sans);--mono:'JetBrains Mono',ui-monospace,monospace;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);color:var(--text);
  background:radial-gradient(900px 480px at 88% -8%,rgba(124,58,237,.16),transparent 60%),
  radial-gradient(760px 440px at -8% 6%,rgba(45,127,255,.15),transparent 55%),var(--bg);min-height:100vh}
a{color:inherit;text-decoration:none}
.muted{color:var(--muted)}.mono{font-family:var(--mono)}.r{text-align:right}.mt{margin-top:18px}
.pos{color:var(--green)}.neg{color:var(--red)}
.ok{color:var(--green);font-size:13px;margin:0 0 14px}.err{color:var(--red);font-size:13px;margin:0 0 14px}

/* auth */
.auth-bg{display:grid;place-items:center;padding:24px}
.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:18px;padding:28px;width:100%;max-width:380px;margin-top:8vh}
.logo-row{display:flex;align-items:center;gap:12px;margin-bottom:18px}
.logo{width:46px;height:46px;border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--violet));
  display:grid;place-items:center;font-family:var(--disp);font-weight:800;color:#fff;font-size:22px;box-shadow:0 8px 22px rgba(45,127,255,.35)}
.logo.sm{width:26px;height:26px;font-size:14px;border-radius:8px}
.auth-card b{font-family:var(--disp);font-size:16px}

/* nav */
/* sidebar nav */
:root{--side:224px}
.sidebar{position:fixed;top:0;left:0;width:var(--side);height:100vh;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 12px;z-index:40;overflow-y:auto}
.side-top{padding:6px 8px 18px}
.brand{font-family:var(--disp);font-weight:800;display:flex;align-items:center;gap:9px;font-size:15px}
.links{display:flex;flex-direction:column;gap:3px}
.links a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;font-size:13.5px;color:var(--muted);white-space:nowrap}
.links a i{width:18px;text-align:center;font-size:14px;opacity:.9}
.links a:hover{color:var(--text);background:var(--surface2)}
.links a.on{color:#fff;background:var(--blue)}
.links a.on i{opacity:1}
.navuser{margin-top:auto;padding:14px 10px 4px;border-top:1px solid var(--border);font-size:12px;display:flex;flex-direction:column;gap:8px}
.navuser a{color:var(--blue);display:inline-flex;align-items:center;gap:6px}
.mobile-bar{display:none}
.nav-toggle{background:var(--surface2);border:1px solid var(--border);color:var(--text);width:40px;height:40px;border-radius:10px;font-size:17px;cursor:pointer}
.side-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:35}

/* layout */
.wrap{max-width:1120px;margin-left:var(--side);padding:24px 28px 90px}
.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{font-family:var(--disp);font-size:22px;margin:0;letter-spacing:-.3px}
.row-gap{display:flex;gap:8px;flex-wrap:wrap}
.cols{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.cols.det{grid-template-columns:1fr 340px;align-items:start}
.card{background:var(--surface);border:1px solid var(--border);border-radius:16px;padding:18px;margin-bottom:16px}
.card.pad0{padding:0;overflow:hidden}
.card.sticky{position:sticky;top:78px}
.card h2{font-family:var(--disp);font-size:14px;margin:0 0 4px}
.hint{color:var(--muted);font-size:11.5px;line-height:1.5;margin:0 0 12px}
.empty{border:1px dashed var(--border);border-radius:16px;padding:46px;text-align:center;color:var(--muted)}

/* forms */
label{display:block;font-size:11.5px;color:var(--muted);margin:10px 0 5px}
input,select,textarea{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);
  font-family:var(--mono);font-size:13px;border-radius:10px;padding:9px 11px;outline:none;transition:.15s}
select,textarea{font-family:var(--sans);font-size:12.5px}
input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(45,127,255,.18)}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}

/* buttons */
.btn{display:inline-flex;align-items:center;gap:7px;border:0;cursor:pointer;font-family:var(--sans);font-weight:600;
  font-size:13px;border-radius:11px;padding:10px 16px;transition:.15s}
.btn.primary{background:linear-gradient(135deg,var(--blue),var(--blueDeep));color:#fff}
.btn.primary:hover{filter:brightness(1.08)}
.btn.ghost{background:var(--surface2);color:var(--text);border:1px solid var(--border)}
.btn.ghost:hover{border-color:var(--blue)}
.btn.danger{background:transparent;color:var(--red);border:1px solid rgba(255,92,92,.4);width:100%;justify-content:center}
.btn.danger:hover{background:rgba(255,92,92,.1)}
.auth-card .btn{width:100%;justify-content:center;margin-top:18px}

/* kpis */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:18px}
.kpi{background:linear-gradient(180deg,var(--surface),var(--surface2));border:1px solid var(--border);border-radius:15px;padding:15px}
.kpi .lbl{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.kpi .val{font-family:var(--mono);font-weight:700;font-size:23px;margin-top:7px;letter-spacing:-.5px}
.kpi .meta{font-size:11px;color:var(--muted);margin-top:4px}
.kpi.accent{position:relative;overflow:hidden}
.kpi.accent:after{content:"";position:absolute;inset:0;border-radius:15px;padding:1px;
  background:linear-gradient(135deg,var(--blue),var(--violet),var(--neon));
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}

/* bars */
.bar-row{display:flex;align-items:center;gap:10px;margin:9px 0;font-size:12.5px}
.bar-lbl{width:72px;color:var(--muted)}
.bar{flex:1;height:9px;background:var(--surface2);border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--neon));border-radius:99px}
.bar-val{font-family:var(--mono);width:84px;text-align:right}
.cf{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cf .lbl{color:var(--muted);font-size:11px;text-transform:uppercase}
.cf .val{font-family:var(--mono);font-size:22px;font-weight:700;margin-top:5px}

/* stages */
.stage-row{display:flex;gap:8px;flex-wrap:wrap}
.stage-chip{flex:1;min-width:72px;background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:11px;text-align:center}
.stage-chip b{font-family:var(--mono);font-size:20px;display:block}
.stage-chip span{font-size:10.5px;color:var(--muted)}
.od-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px}
.od-row:last-child{border:0}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;color:var(--muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.3px;padding:12px 14px;border-bottom:1px solid var(--border)}
.tbl td{padding:13px 14px;border-bottom:1px solid var(--border)}
.tbl tbody tr{cursor:pointer;transition:.12s}
.tbl tbody tr:hover{background:var(--surface2)}
.tbl tr:last-child td{border-bottom:0}
.tbl.mini td{padding:9px 4px;border-color:var(--border)}
.tag{font-size:9.5px;font-family:var(--mono);color:var(--pink);border:1px solid rgba(255,92,138,.4);padding:1px 6px;border-radius:99px;margin-left:6px}

/* badges */
.badge{font-size:10.5px;font-family:var(--mono);padding:3px 9px;border-radius:99px;border:1px solid var(--border);color:var(--muted);background:transparent;cursor:default}
button.badge{cursor:pointer}
.s-lead{color:var(--muted)} .s-onboarding{color:var(--amber);border-color:rgba(255,178,62,.4)}
.s-active{color:var(--neon);border-color:rgba(31,227,208,.4)} .s-completed{color:var(--green);border-color:rgba(43,214,106,.4)}
.s-churned{color:var(--red);border-color:rgba(255,92,92,.4)}
.ddl{font-family:var(--mono);font-size:11px;padding:2px 7px;border-radius:6px}
.ddl.ok{color:var(--green)} .ddl.warn{color:var(--amber)} .ddl.over{color:var(--red)}

/* kanban */
.kanban{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;align-items:start}
.kcol{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:10px;min-height:80px}
.kcol-head{font-family:var(--disp);font-size:12px;font-weight:700;padding:6px 8px 10px;display:flex;justify-content:space-between}
.kcol-head span{color:var(--muted);font-family:var(--mono)}
.kcard{display:block;background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:11px;margin-bottom:9px;transition:.12s}
.kcard:hover{border-color:var(--blue)}
.kcard b{font-size:13px}.kmeta{font-size:11px;color:var(--muted);margin:4px 0}
.kprofit{font-family:var(--mono);font-size:12.5px;font-weight:700}

/* deliverables / payments */
.deliv{display:flex;align-items:center;gap:9px;padding:7px 10px;background:var(--bg);border:1px solid var(--border);border-radius:9px;margin-bottom:7px;font-size:12.5px}
.deliv.done .dn{color:var(--muted);text-decoration:line-through}
.deliv .dn{flex:1}
.chk{width:20px;height:20px;border-radius:6px;border:1.5px solid var(--border);background:var(--surface2);color:#fff;cursor:pointer;font-size:12px;line-height:1;padding:0}
.chk.on{background:var(--green);border-color:var(--green)}
.x{background:none;border:0;color:var(--muted);cursor:pointer;font-size:16px;padding:0 4px}
.x:hover{color:var(--red)}
.addrow{display:flex;gap:8px;margin-top:6px}.addrow input{flex:1}
.payrow{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:12.5px}
.payrow .muted{flex:1}
.grid-pay{display:grid;grid-template-columns:1fr 1fr 1fr 2fr;gap:8px;margin-top:12px;align-items:end}
.grid-pay .btn{grid-column:1/-1}

/* calc */
.calc{background:var(--bg);border:1px solid var(--border);border-radius:12px;padding:14px}
.calc .ln{display:flex;justify-content:space-between;font-size:12.5px;padding:5px 0;color:var(--muted)}
.calc .ln span:last-child{color:var(--text)}
.calc .ln.total{border-top:1px solid var(--border);margin-top:6px;padding-top:10px;color:var(--text);font-weight:600}
.calc .ln.total span:last-child{font-size:18px;font-weight:700}
.meter{height:8px;background:var(--surface2);border-radius:99px;overflow:hidden}
.meter i{display:block;height:100%;background:linear-gradient(90deg,var(--blue),var(--neon))}
.prog-txt{font-family:var(--mono);font-size:11.5px;color:var(--muted)}
.totline{display:flex;justify-content:space-between;align-items:center;border-top:1px dashed var(--border);margin-top:14px;padding-top:12px;font-size:12.5px}
.totline b{font-size:16px}

@media(max-width:900px){
  .cols,.cols.det{grid-template-columns:1fr}.kpis{grid-template-columns:1fr 1fr}
  .kanban{grid-template-columns:1fr 1fr;overflow-x:visible}.grid3{grid-template-columns:1fr}
  .grid-pay{grid-template-columns:1fr 1fr}
}

/* ===== Phase 1: finance styles ===== */
.runway-big{font-family:var(--mono);font-weight:700;font-size:42px;letter-spacing:-1px;margin:6px 0}
.runway-big span{font-size:16px;color:var(--muted);font-weight:500}
.card.runway.rw-danger{border-color:rgba(255,92,92,.5)} .rw-danger .runway-big{color:var(--red)}
.card.runway.rw-warn .runway-big{color:var(--amber)} .card.runway.rw-ok .runway-big{color:var(--green)}

.aging{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-top:6px}
.age-b{background:var(--bg);border:1px solid var(--border);border-radius:11px;padding:12px}
.age-b .lbl{font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.3px}
.age-b b{font-family:var(--mono);font-size:18px;display:block;margin-top:5px}
.age-b.warn{border-color:rgba(255,178,62,.35)} .age-b.over{border-color:rgba(255,92,92,.4)} .age-b.over b{color:var(--red)}

.items-form input{border-radius:8px}
.actions-bar{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px;align-items:center}

/* invoice sheet */
.invoice-sheet{background:#fff;color:#1a1a1a;border-radius:14px;padding:34px;max-width:820px;font-family:var(--sans)}
.invoice-sheet .sm{font-size:12px}
.invoice-sheet .muted{color:#666}
.inv-top{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid #111;padding-bottom:18px}
.inv-logo{width:40px;height:40px;border-radius:10px;background:linear-gradient(135deg,var(--blue),var(--violet));color:#fff;display:grid;place-items:center;font-family:var(--disp);font-weight:800;font-size:20px}
.inv-co{font-family:var(--disp);font-size:20px;margin:8px 0 4px}
.inv-meta{text-align:right}
.inv-tag{font-family:var(--disp);font-weight:800;letter-spacing:1px;color:#111;font-size:15px;margin-bottom:6px}
.inv-bill{display:flex;justify-content:space-between;margin:20px 0}
.inv-items{width:100%;border-collapse:collapse;margin-top:8px;font-size:13px}
.inv-items th{background:#f3f5f9;color:#333;text-align:left;padding:9px 11px;border-bottom:1px solid #ddd;font-size:11px;text-transform:uppercase;letter-spacing:.3px}
.inv-items td{padding:10px 11px;border-bottom:1px solid #eee}
.inv-items .r,.inv-totals .ln span:last-child{text-align:right}
.inv-totals{margin-left:auto;width:300px;margin-top:14px}
.inv-totals .ln{display:flex;justify-content:space-between;padding:6px 0;font-size:13px;color:#444}
.inv-totals .ln.grand{border-top:2px solid #111;margin-top:6px;padding-top:10px;font-weight:700;font-size:17px;color:#111}
.inv-notes{margin-top:20px;padding-top:14px;border-top:1px solid #eee}
.inv-foot{margin-top:18px;text-align:center}
.invoice-sheet .badge{color:#555;border-color:#ccc}
.invoice-sheet .s-completed{color:#1a7f43;border-color:#9ad9b4}
.invoice-sheet .s-onboarding{color:#9a6500;border-color:#f0cf94}

@media print{
  .sidebar,.mobile-bar,.side-overlay,.no-print,.page-head{display:none!important}
  body{background:#fff}
  .wrap{padding:0;max-width:none;margin-left:0}
  .invoice-sheet{border-radius:0;padding:0;max-width:none}
}

/* ===== Phase 2: board / tasks / shoots ===== */
.filters{margin-bottom:14px}
.chkline{display:inline-flex;align-items:center;gap:7px;color:var(--text);font-size:12.5px}
.chkline input{width:auto}

.board{display:grid;grid-template-columns:repeat(7,minmax(150px,1fr));gap:10px;align-items:start;overflow-x:auto;padding-bottom:8px}
.bcol{background:var(--surface);border:1px solid var(--border);border-radius:13px;padding:9px;min-width:150px}
.bcol-head{font-family:var(--disp);font-size:11.5px;font-weight:700;padding:5px 6px 9px;display:flex;justify-content:space-between}
.bcol-head span{color:var(--muted);font-family:var(--mono)}
.tcard{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:9px;margin-bottom:8px}
.tcard-title{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px}
.tcard-title:hover{color:var(--blue)}
.tmeta{display:flex;align-items:center;gap:7px;flex-wrap:wrap;font-size:10.5px;margin-bottom:5px}
.ttype{font-family:var(--mono);font-size:9.5px;padding:1px 6px;border-radius:99px;border:1px solid var(--border);color:var(--muted)}
.t-shoot{color:var(--pink);border-color:rgba(255,92,138,.4)} .t-edit{color:var(--blue);border-color:rgba(45,127,255,.4)}
.t-post{color:var(--neon);border-color:rgba(31,227,208,.4)} .t-reel{color:var(--violet);border-color:rgba(124,58,237,.5)}
.t-ad{color:var(--amber);border-color:rgba(255,178,62,.4)}
.rev{font-family:var(--mono);font-size:9.5px;color:var(--amber);border:1px solid rgba(255,178,62,.4);border-radius:99px;padding:1px 5px}
.stage-move{margin-top:6px}
.stage-move select{font-size:11px;padding:5px 7px}
.cs-block{margin-top:18px}
.cs-block p{font-size:13px;line-height:1.6;margin:6px 0 0;white-space:pre-wrap}

@media(max-width:900px){.board{grid-template-columns:repeat(7,minmax(140px,1fr))}}

/* ===== FA icons + responsive ===== */
.ok i,.err i{margin-right:5px}
.fa-circle-check{color:var(--green)} .fa-triangle-exclamation{color:var(--amber)} .fa-thumbs-up{color:var(--green)}
.tmeta i{font-size:11px}

/* mobile */
@media(max-width:760px){
  .wrap{padding:18px 14px 90px;margin-left:0}
  .sidebar{transform:translateX(-100%);transition:transform .25s ease;width:252px;box-shadow:0 0 40px rgba(0,0,0,.5)}
  .sidebar.open{transform:translateX(0)}
  .side-overlay.show{display:block}
  .mobile-bar{display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:30;background:rgba(18,24,41,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:10px 14px;margin:-18px -14px 16px}
  .page-head h1{font-size:18px}
  .kpis{grid-template-columns:1fr 1fr}
  .kpi .val{font-size:20px}
  .cols,.cols.det{grid-template-columns:1fr}
  .grid2,.grid3,.grid-pay{grid-template-columns:1fr}
  .aging{grid-template-columns:1fr 1fr}
  .card.pad0{overflow-x:auto}
  .tbl{min-width:560px}
  .board{grid-template-columns:repeat(7,80vw);gap:10px}
  .runway-big{font-size:34px}
  .btn{padding:11px 14px}
  .invoice-sheet{padding:20px}
  .inv-top,.inv-bill{flex-direction:column;gap:10px}
  .inv-totals{width:100%}
}
@media(max-width:420px){ .kpis{grid-template-columns:1fr} }

/* ===== Phase 3: report ===== */
.rep-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:14px;margin:22px 0}
.rep-stat{background:#f3f5f9;border:1px solid #e4e8f0;border-radius:12px;padding:16px;text-align:center}
.rep-num{font-family:var(--mono);font-weight:700;font-size:26px;color:#111;letter-spacing:-.5px}
.rep-num .muted{font-size:15px;color:#888}
.rep-lbl{font-size:11px;color:#666;margin-top:5px;text-transform:uppercase;letter-spacing:.3px}
@media(max-width:760px){ .rep-grid{grid-template-columns:1fr 1fr} }

/* ===== Phase 4: leads / activity ===== */
.sc-hot{color:var(--red);border-color:rgba(255,92,92,.45)}
.sc-warm{color:var(--amber);border-color:rgba(255,178,62,.45)}
.sc-cold{color:#7Fa8ff;border-color:rgba(45,127,255,.4)}
.mini-sel,.mini-date{font-size:11.5px;padding:5px 7px;width:auto}
.mini-date.due{border-color:var(--red);color:var(--red)}
.act{display:flex;gap:11px;align-items:flex-start;padding:10px 0;border-bottom:1px solid var(--border)}
.act:last-child{border-bottom:0}
.act-ic{width:30px;height:30px;flex:0 0 auto;border-radius:8px;background:var(--surface2);display:grid;place-items:center;color:var(--blue);font-size:12px}
.act-body{flex:1;font-size:13px;line-height:1.4}

/* ===== Phase 2.2: calendar / stuck ===== */
.cal-month{font-family:var(--disp);font-weight:700;font-size:14px;min-width:130px;text-align:center;display:inline-block}
table.cal{width:100%;border-collapse:collapse;table-layout:fixed;border:1px solid var(--border);border-radius:14px;overflow:hidden;background:var(--surface)}
table.cal th{background:var(--surface2);padding:9px 6px;font-size:11px;color:var(--muted);font-weight:600;text-align:center;border-bottom:1px solid var(--border)}
table.cal td.cal-cell{vertical-align:top;height:96px;width:14.28%;border:1px solid var(--border);padding:5px;font-size:11px}
.cal-cell.empty{background:rgba(255,255,255,.02)}
.cal-cell.today{background:rgba(45,127,255,.10)}
.cal-d{font-family:var(--mono);color:var(--muted);font-size:11px;margin-bottom:4px}
.cal-ev{display:block;border-radius:6px;padding:3px 6px;margin-bottom:3px;font-size:10.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border:1px solid var(--border);color:var(--text);background:var(--bg)}
.cal-ev.t-post{border-color:rgba(31,227,208,.45)} .cal-ev.t-reel{border-color:rgba(124,58,237,.5)}
.cal-ev.t-shoot{border-color:rgba(255,92,138,.45)} .cal-ev.t-ad{border-color:rgba(255,178,62,.45)}
.tcard.stuck{border-color:rgba(255,92,92,.5)}
@media(max-width:760px){
  .cal-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table.cal{min-width:640px}
  table.cal td.cal-cell{height:80px}
}

/* ===== modern scrollbars (match dark UI) ===== */
html{background:var(--bg)}
*{scrollbar-width:thin;scrollbar-color:#3a4670 #141a2c}
::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:#141a2c}
::-webkit-scrollbar-thumb{background:#3a4670;border-radius:99px;border:3px solid #141a2c}
::-webkit-scrollbar-thumb:hover{background:#4a5688}
::-webkit-scrollbar-corner{background:#141a2c}
.sidebar{scrollbar-color:#2c365a transparent}
.sidebar::-webkit-scrollbar{width:8px}
.sidebar::-webkit-scrollbar-track{background:transparent}
.sidebar::-webkit-scrollbar-thumb{background:#2c365a;border:0;border-radius:99px}
.sidebar::-webkit-scrollbar-thumb:hover{background:#3a4670}

/* delivery gaps */
.gap-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:10px;margin-top:6px}
.gap-item{display:flex;justify-content:space-between;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px 12px;font-size:13px}
.gap-item:hover{border-color:var(--blue)}

/* ===== Drop 3: onboarding checklist ===== */
.chk-row{display:flex;align-items:center;gap:10px;padding:7px 0;border-bottom:1px solid var(--border);font-size:13px}
.chk-row:last-child{border-bottom:0}
.chk-box{width:22px;height:22px;border-radius:6px;border:1.5px solid var(--border);background:var(--bg);color:#fff;cursor:pointer;font-size:11px;flex:0 0 auto;display:flex;align-items:center;justify-content:center}
.chk-box.on{background:var(--neon);border-color:var(--neon);color:#04201c}
.chk-done{color:var(--muted);text-decoration:line-through}
.meter.mb{margin-bottom:12px}

/* ===== Drop 5: chips + template body ===== */
.chip{display:inline-block;padding:6px 12px;border-radius:99px;border:1px solid var(--border);background:var(--surface);color:var(--muted);font-size:12px;font-weight:600}
.chip.on,.chip:hover{border-color:var(--blue);color:var(--text);background:rgba(45,127,255,.1)}
.tpl-body{white-space:pre-wrap;background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:13px;font-family:var(--mono);margin:10px 0;line-height:1.6;max-height:280px;overflow:auto}

/* ===== Drop 6: Gantt / timeline ===== */
.g-legend{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}
.g-key{font-size:11px;padding:3px 9px;border-radius:99px;color:#04121f;font-weight:700}
.gantt-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:14px;background:var(--surface)}
.gantt{min-width:max-content}
.g-head{display:flex;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--surface2);z-index:2}
.g-lbl-h{width:220px;flex:0 0 220px;padding:9px 12px;font-size:11px;color:var(--muted);font-weight:700;border-right:1px solid var(--border)}
.g-track-h{display:flex;position:relative}
.g-day{flex:0 0 auto;text-align:center;font-size:10px;color:var(--muted);padding:9px 0;border-right:1px solid var(--border)}
.g-day.we{background:rgba(255,255,255,.03)}
.g-group{padding:8px 12px;font-size:12px;font-weight:700;background:var(--surface2);border-bottom:1px solid var(--border);color:var(--text)}
.g-row{display:flex;align-items:center;border-bottom:1px solid var(--border);min-height:42px}
.g-lbl{width:220px;flex:0 0 220px;padding:6px 12px;border-right:1px solid var(--border);font-size:12px}
.g-lbl a{color:var(--text);font-weight:600}
.g-track{position:relative;flex:0 0 auto;align-self:stretch}
.g-today{position:absolute;top:0;bottom:0;width:2px;background:var(--blue);opacity:.6;z-index:1}
.g-bar{position:absolute;top:50%;transform:translateY(-50%);height:24px;border-radius:7px;display:flex;align-items:center;padding:0 8px;font-size:10.5px;font-weight:700;color:#04121f;overflow:hidden;white-space:nowrap;z-index:2}
.g-bar span{overflow:hidden;text-overflow:ellipsis}
.g-bar.g-stuck{outline:2px solid #ff5c5c;outline-offset:1px}
.g-to_shoot,.g-key.g-to_shoot{background:#8aa0c6}
.g-shot,.g-key.g-shot{background:#ff8fb0}
.g-editing,.g-key.g-editing{background:#a98bf0}
.g-internal_review,.g-key.g-internal_review{background:#ffc36b}
.g-client_approval,.g-key.g-client_approval{background:#5fa8ff}
.g-scheduled,.g-key.g-scheduled{background:#36d6c4}
.g-published,.g-key.g-published{background:#39d98a}

/* ===== Drop 7: portal layout ===== */
body.portal{background:var(--bg);color:var(--text)}
.portal-top{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--border);background:var(--surface);position:sticky;top:0;z-index:5;flex-wrap:wrap}
.portal-wrap{max-width:880px;margin:0 auto;padding:24px 18px 60px}
.portal-wrap h1{font-size:24px}

/* ===== Drop 8: invoice payment block + words + sheet polish ===== */
.inv-words{margin-top:8px;padding-top:8px;border-top:1px dashed var(--border)}
.inv-pay{display:flex;justify-content:space-between;align-items:flex-start;gap:18px;margin-top:16px;padding:14px;border:1px solid var(--border);border-radius:12px;background:var(--surface2)}
.inv-pay-h{font-size:10px;letter-spacing:.08em;color:var(--muted);font-weight:700;margin-bottom:6px}
.inv-pay-info .sm{margin:2px 0}
.inv-qr{text-align:center;flex:0 0 auto}
.inv-qr #upiqr{display:inline-block;background:#fff;padding:8px;border-radius:10px}
.inv-qr #upiqr img,.inv-qr #upiqr canvas{display:block}
.inv-qr .sm{margin-top:5px}
@media print{
  .inv-pay{background:#f5f7fb !important;border-color:#dfe5f0 !important;-webkit-print-color-adjust:exact;print-color-adjust:exact}
  .inv-pay-h{color:#667 !important}
}
