/* Touring — design system. Dark / cream / gold. All color via custom properties. */
:root{
  --bg:#0f0f0f; --panel:#161513; --panel-2:#1c1b18; --head:#13120f;
  --line:#2a2825; --line-2:#383531;
  --fg:#f4f1ea; --muted:#9b958a; --faint:#615c52;
  --accent:#c8a24a; --accent-dim:#8a6f2f; --accent-soft:rgba(200,162,74,.12);
  --proj:#9aa7c4; --act:#c8a24a; --fin:#7fae8a;
  --show:#7fae8a; --travel:#6f93b8; --reh:#b88a6f; --off:#6b6660;
  --neg:#cf7d6e; --pos:#85b791;
  --r:11px;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"SF Mono",ui-monospace,Menlo,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--fg);font-family:var(--sans);
  -webkit-font-smoothing:antialiased;font-size:13px;line-height:1.45}
a{color:inherit;text-decoration:none}
.num{font-family:var(--mono)}
.dim{color:var(--faint)} .muted{color:var(--muted)}
.pos{color:var(--pos)} .neg{color:var(--neg)}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;
  padding:12px 22px;border-bottom:1px solid var(--line);background:var(--head);
  position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:600;letter-spacing:.3px}
.topbar .brand .gold{color:var(--accent)}
.topbar nav{display:flex;gap:18px;font-size:12.5px}
.topbar nav a{color:var(--muted);padding:4px 0;border-bottom:2px solid transparent}
.topbar nav a.on,.topbar nav a:hover{color:var(--fg);border-color:var(--accent)}
.topbar .who{color:var(--faint);font-size:12px}
.wrap{padding:26px 30px 70px;max-width:1320px;margin:0 auto}

/* headings */
.page-h{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4px}
.page-h h1{font-size:18px;font-weight:600;margin:0}
.page-h h1 small{color:var(--muted);font-weight:400;font-size:13px;margin-left:8px}
.crumbs{color:var(--faint);font-size:12px;margin-bottom:20px}
.crumbs b{color:var(--muted);font-weight:500}

/* scenario toggle */
.scn{display:inline-flex;border:1px solid var(--line-2);border-radius:7px;overflow:hidden}
.scn a{font-size:11px;padding:5px 12px;color:var(--muted)}
.scn a.on{background:var(--accent);color:#1a1407;font-weight:600}

/* summary cards */
.summary{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.scard{flex:1;min-width:150px;background:var(--panel);border:1px solid var(--line);
  border-radius:var(--r);padding:13px 15px}
.scard.lead{border-color:var(--accent-soft);
  background:linear-gradient(180deg,rgba(200,162,74,.06),transparent)}
.scard .cl{font-size:10.5px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted)}
.scard .cv{font-family:var(--mono);font-size:22px;font-weight:600;margin-top:5px}
.scard .cv.pos{color:var(--pos)} .scard .cv.neg{color:var(--neg)}
.scard .sub{font-size:11px;color:var(--faint);margin-top:3px}

/* sections + tables */
section.card{background:var(--panel);border:1px solid var(--line);border-radius:12px;
  margin-bottom:20px;overflow:hidden}
.sh{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;
  border-bottom:1px solid var(--line);background:var(--head)}
.sh h2{font-size:12.5px;font-weight:600;letter-spacing:.3px;margin:0}
.sh .note{font-size:11px;color:var(--faint)}
table{width:100%;border-collapse:collapse}
th,td{padding:8px 12px;text-align:right;border-bottom:1px solid var(--line);white-space:nowrap}
th{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:600}
td.l,th.l{text-align:left}
td.num{font-size:12.5px}
tbody tr:hover{background:var(--panel-2)}
th.sep,td.sep{border-left:1px solid var(--line-2)}
.grp-proj{color:var(--proj)} .grp-act{color:var(--act)} .grp-fin{color:var(--fin)}
tr.tot td{border-top:2px solid var(--line-2);font-weight:600;background:var(--panel-2)}

/* tags */
.tag{display:inline-block;font-size:9.5px;text-transform:uppercase;letter-spacing:.5px;
  padding:1px 6px;border-radius:4px;border:1px solid var(--line-2);color:var(--muted)}
.tag.settled{color:var(--fin);border-color:rgba(127,174,138,.4)}
.tag.pending{color:var(--faint)}
.tag.show{color:var(--show);border-color:rgba(127,174,138,.4)}
.tag.travel{color:var(--travel);border-color:rgba(111,147,184,.4)}
.tag.rehearsal{color:var(--reh);border-color:rgba(184,138,111,.4)}
.tag.off{color:var(--off)}

/* layout helpers */
.pair{display:flex;gap:20px;margin-bottom:20px;flex-wrap:wrap}
.pair>section.card{flex:1;min-width:340px;margin:0}

/* P&L waterfall */
.wf{padding:14px 16px}
.wf .line{display:flex;justify-content:space-between;padding:6px 0;
  border-bottom:1px solid var(--line);font-size:12.5px}
.wf .line.net{border-bottom:0;border-top:2px solid var(--line-2);margin-top:4px;
  padding-top:10px;font-weight:600;font-size:15px}
.wf .line .v{font-family:var(--mono)}

/* tour list */
.tourlist{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px}
.tourcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);
  padding:16px 17px;transition:border-color .12s}
.tourcard:hover{border-color:var(--accent-soft)}
.tourcard .nm{font-weight:600;font-size:14px}
.tourcard .dt{color:var(--muted);font-size:12px;margin-top:3px}
.tourcard .links{display:flex;gap:14px;margin-top:12px;font-size:12px}
.tourcard .links a{color:var(--accent)}

/* login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login{width:320px;background:var(--panel);border:1px solid var(--line);border-radius:14px;
  padding:26px 24px}
.login h1{font-size:17px;margin:0 0 4px}.login h1 .gold{color:var(--accent)}
.login p{color:var(--muted);font-size:12px;margin:0 0 18px}
.login label{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted)}
.login input{width:100%;margin:7px 0 16px;padding:11px 12px;background:var(--panel-2);
  border:1px solid var(--line-2);border-radius:8px;color:var(--fg);font:inherit}
.login input:focus{outline:none;border-color:var(--accent)}
.login button{width:100%;padding:12px;background:var(--accent);color:#1a1407;border:0;
  border-radius:8px;font:inherit;font-weight:600;cursor:pointer}
.login .err{color:var(--neg);font-size:12px;margin-bottom:12px}

.draftbar{display:flex;gap:10px;margin-bottom:22px}
.draftbar input{flex:1;max-width:340px;padding:10px 12px;background:var(--panel-2);
  border:1px solid var(--line-2);border-radius:8px;color:var(--fg);font:inherit}
.draftbar input:focus{outline:none;border-color:var(--accent)}
.draftbar button{padding:10px 16px;background:var(--panel-2);border:1px solid var(--accent);
  color:var(--accent);border-radius:8px;font:inherit;font-weight:600;cursor:pointer}
.draftbar button:hover{background:var(--accent-soft)}
.syncbar{display:flex;align-items:center;gap:12px;margin:-6px 0 20px}
.syncbar button{padding:7px 13px;background:var(--panel-2);border:1px solid var(--accent);
  color:var(--accent);border-radius:8px;font:inherit;font-weight:600;font-size:12px;cursor:pointer}
.syncbar button:hover{background:var(--accent-soft)}
.syncbar .muted{font-size:11.5px}
.empty{color:var(--muted);padding:40px;text-align:center}
.ver{position:fixed;right:14px;bottom:11px;color:var(--faint);font-size:11px;font-family:var(--mono)}

/* ---- roadbook (document column, mobile-first) ---- */
.doc{max-width:760px;margin:0 auto}
.rbhead{margin-bottom:18px}
.rbhead .art{font-size:20px;font-weight:600}
.rbhead .run{color:var(--muted);font-size:13px;margin-top:2px}
/* run switcher / look-ahead */
.runs{display:flex;gap:8px;overflow-x:auto;padding:4px 0 14px;margin-bottom:18px;border-bottom:1px solid var(--line)}
.runs a{flex:0 0 auto;padding:8px 12px;border:1px solid var(--line);border-radius:9px;
  background:var(--panel);min-width:140px}
.runs a.on{border-color:var(--accent);background:var(--accent-soft)}
.runs a .rn{font-size:12.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}
.runs a .rd{font-size:11px;color:var(--muted);margin-top:2px}
.runs a .nx{font-size:9px;text-transform:uppercase;letter-spacing:.6px;color:var(--accent)}
/* roster */
.roster{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:22px}
.roster .p{font-size:12px;padding:4px 9px;border:1px solid var(--line);border-radius:20px;
  background:var(--panel);cursor:pointer}
.roster .p .r{color:var(--faint);font-size:10px;text-transform:uppercase;margin-left:4px}
.roster .p.on{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}
.roster .p.on .r{color:var(--accent-dim)}
/* per-person "your trip" summary + highlighting */
.mytrip{background:var(--accent-soft);border:1px solid rgba(200,162,74,.4);border-radius:11px;
  padding:13px 15px;margin-bottom:20px}
.mytrip .mt-h{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--accent);
  font-weight:600;margin-bottom:8px}
.mytrip .mt-row{font-size:12.5px;padding:3px 0}
.mytrip .mt-d{font-family:var(--mono);color:var(--muted);margin-right:6px}
.mytrip .cf{font-family:var(--mono);color:var(--accent-dim);font-size:11px}
.srow.mine{background:var(--accent-soft);box-shadow:inset 3px 0 0 var(--accent)}
.trav.mine{color:var(--accent);font-weight:600}
.trav.mine .cf{color:var(--accent)}
/* day blocks */
.day{background:var(--panel);border:1px solid var(--line);border-radius:12px;margin-bottom:14px;overflow:hidden}
.day.is-show{border-color:rgba(127,174,138,.28)}
.dayhead{display:flex;align-items:baseline;gap:10px;padding:12px 15px;border-bottom:1px solid var(--line);
  background:var(--head)}
.dayhead .dn{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.dayhead .dd{font-size:17px;font-weight:600}
.dayhead .ti{color:var(--fg);font-size:13px;flex:1}
.daybody{padding:6px 15px 14px}
.venue{margin:10px 0 6px;font-size:13px}
.venue .vn{font-weight:600}
.venue .vm{color:var(--muted);font-size:12px}
.kv{display:flex;gap:7px;font-size:12px;color:var(--muted);margin-top:3px}
.kv b{color:var(--fg);font-weight:500}
.srow{display:flex;gap:11px;padding:7px 0;border-top:1px solid var(--line)}
.srow .t{font-family:var(--mono);font-size:12px;color:var(--accent);flex:0 0 58px}
.srow .k{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);flex:0 0 64px;padding-top:2px}
.srow .x{font-size:13px}
.srow .x small{display:block;color:var(--muted);font-size:11px}
.sub{margin-top:10px;padding-top:8px;border-top:1px dashed var(--line)}
.sub .lbl{font-size:9.5px;text-transform:uppercase;letter-spacing:.7px;color:var(--faint);margin-bottom:5px}
.trav{font-size:12.5px;padding:3px 0}
.trav .who{color:var(--accent)}
.trav .cf{color:var(--faint);font-family:var(--mono);font-size:11px}
.mine{color:var(--accent);font-weight:600}

/* ---- actuals (mobile entry) ---- */
.mform{max-width:440px;margin:0 auto}
.flash{background:var(--accent-soft);border:1px solid rgba(200,162,74,.4);color:var(--accent);
  border-radius:9px;padding:10px 13px;font-size:13px;margin-bottom:16px}
.flash.err{background:rgba(207,125,110,.12);border-color:rgba(207,125,110,.4);color:var(--neg)}
.amt{display:flex;align-items:center;justify-content:center;gap:2px;margin:8px 0 20px}
.amt .cur{font-family:var(--mono);font-size:30px;color:var(--faint)}
.amt input{font-family:var(--mono);font-size:46px;font-weight:600;width:200px;text-align:center;
  background:transparent;border:0;color:var(--fg);border-bottom:2px solid var(--line-2)}
.amt input:focus{outline:none;border-color:var(--accent)}
.fld{margin-bottom:16px}
.fld .fl{font-size:11px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:8px}
.chips{display:flex;flex-wrap:wrap;gap:8px}
.chips input{position:absolute;opacity:0;width:0;height:0}
.chip{display:inline-block;font-size:13px;padding:9px 14px;border-radius:9px;
  border:1px solid var(--line-2);background:var(--panel-2);color:var(--fg);cursor:pointer}
.chips input:checked + .chip{border-color:var(--accent);background:var(--accent-soft);
  color:var(--accent);font-weight:600}
.row2{display:flex;gap:12px}.row2 .fld{flex:1}
input.ti,select.ti{width:100%;padding:11px 12px;background:var(--panel-2);border:1px solid var(--line-2);
  border-radius:8px;color:var(--fg);font:inherit}
input.ti:focus,select.ti:focus{outline:none;border-color:var(--accent)}
.save-btn{width:100%;padding:15px;background:var(--accent);color:#1a1407;border:0;border-radius:10px;
  font:inherit;font-weight:600;font-size:15px;cursor:pointer;margin-top:6px}
.recent{margin-top:30px}
.recent h3{font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin:0 0 10px}
.exp{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--line)}
.exp .cat{font-size:9px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);
  border:1px solid var(--line-2);border-radius:5px;padding:2px 7px}
.exp .desc{flex:1;font-size:13px}.exp .desc small{display:block;color:var(--faint);font-size:11px}
.exp .amt2{font-family:var(--mono);font-size:15px;font-weight:600}

/* ---- budget edit mode ---- */
.editbar{display:flex;align-items:center;gap:14px;margin:4px 0 18px;padding:11px 15px;
  background:var(--accent-soft);border:1px solid var(--accent-dim);border-radius:var(--r);font-size:13px}
.editbar .dot{color:var(--accent);font-weight:600;letter-spacing:.02em;white-space:nowrap}
.editbar .muted{color:var(--muted);flex:1}
.editbar .editdone{color:var(--accent);text-decoration:none;border:1px solid var(--accent-dim);
  border-radius:7px;padding:5px 13px;white-space:nowrap}
.editbar .editdone:hover{background:rgba(200,162,74,.18)}
input.cell{width:74px;text-align:right;font-family:var(--mono);font-size:13px;
  background:var(--panel-2);color:var(--fg);border:1px solid var(--line-2);
  border-radius:6px;padding:4px 7px;outline:none}
input.cell.s{width:58px}
input.cell::placeholder{color:var(--faint)}
input.cell:hover{border-color:var(--accent-dim)}
input.cell:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
input.cell.med{background:rgba(154,167,196,.07)}
select.daysel{width:auto;min-width:150px;text-align:left;font-family:var(--sans)}
td.editable{padding-top:5px;padding-bottom:5px}
.addrow-edit td{padding-top:7px;padding-bottom:7px}
.savebar{position:fixed;left:0;right:0;bottom:0;z-index:40;display:flex;align-items:center;gap:16px;
  padding:13px 26px;background:var(--head);border-top:1px solid var(--line-2);
  box-shadow:0 -8px 24px rgba(0,0,0,.4)}
.savebar .status{color:var(--accent);font-size:13px;font-weight:500;display:flex;align-items:center;gap:7px}
.savebar .status::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--accent)}
.savebar .recalc{color:var(--muted);font-size:12px}
.savebar .spacer{flex:1}
.btn-save{background:var(--accent);color:#1a1710;border:none;border-radius:8px;
  padding:8px 20px;font-size:13px;font-weight:600;cursor:pointer;font-family:var(--sans)}
.btn-save:hover{background:#d8b257}
.btn-cancel{background:transparent;color:var(--muted);border:1px solid var(--line-2);
  border-radius:8px;padding:8px 18px;font-size:13px;cursor:pointer;font-family:var(--sans);text-decoration:none}
.btn-cancel:hover{color:var(--fg)}
body:has(.savebar){padding-bottom:72px}
