:root {
  --bg: #0c1813;
  --panel: #12241c;
  --panel-2: #18302550;
  --line: #2a4438;
  --ink: #eef5f0;
  --muted: #93b0a3;
  --gold: #e8c87a;
  --green: #46c08a;
  --red: #e8806f;
  --blue: #7fb6e8;
  --radius: 14px;
  --tap: 48px;
  color-scheme: dark;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body { margin: 0; height: 100%; }
body {
  background: var(--bg);
  color: var(--ink);
  font: 16px/1.45 -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, system-ui, sans-serif;
  overscroll-behavior-y: contain;
}
.hidden { display: none !important; }
.muted { color: var(--muted); }
.error { color: var(--red); min-height: 1.2em; margin: 8px 0 0; font-size: 14px; }

/* ---- Login ---- */
.login { min-height: 100dvh; display: grid; place-items: center; padding: 24px; }
.login-card { width: 100%; max-width: 360px; background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 22px; text-align: center; }
.login-card h1 { margin: 0 0 4px; font-size: 26px; color: var(--gold); }
.login-card input { width: 100%; margin: 18px 0 12px; padding: 14px; font-size: 18px; text-align: center; letter-spacing: 2px; border-radius: 10px; border: 1px solid var(--line); background: #0b1611; color: var(--ink); }

/* ---- App shell ---- */
.app { min-height: 100dvh; display: flex; flex-direction: column; max-width: 640px; margin: 0 auto; }
.topbar { position: sticky; top: 0; z-index: 5; background: linear-gradient(var(--bg), #0c1813ee); border-bottom: 1px solid var(--line); padding: max(8px, env(safe-area-inset-top)) 12px 8px; }
.topbar-row { display: flex; align-items: center; gap: 10px; }
.brand { color: var(--gold); font-size: 17px; }
.pill { margin-left: auto; background: var(--panel-2); border: 1px solid var(--line); border-radius: 999px; padding: 3px 10px; font-size: 13px; color: var(--muted); }
.icon-btn { width: 38px; height: 38px; border-radius: 10px; border: 1px solid var(--line); background: var(--panel); color: var(--ink); font-size: 18px; }
.chips { display: flex; gap: 7px; overflow-x: auto; padding: 10px 0 2px; scrollbar-width: none; }
.chips::-webkit-scrollbar { display: none; }
.chip { flex: 0 0 auto; padding: 8px 13px; border-radius: 999px; border: 1px solid var(--line); background: var(--panel); color: var(--muted); font-size: 14px; white-space: nowrap; }
.chip[aria-pressed="true"] { background: var(--gold); color: #1a1206; border-color: var(--gold); font-weight: 600; }
.chip .n { opacity: .7; margin-left: 5px; font-variant-numeric: tabular-nums; }
.search { width: 100%; margin-top: 8px; padding: 11px 13px; border-radius: 10px; border: 1px solid var(--line); background: #0b1611; color: var(--ink); font-size: 16px; }

/* ---- Stage / card ---- */
.stage { flex: 1; padding: 14px 12px 24px; }
.card { background: var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 16px; }
.card-head { display: flex; align-items: flex-start; gap: 10px; }
.biz { font-size: 22px; font-weight: 700; line-height: 1.2; margin: 0; }
.sub { color: var(--muted); font-size: 14px; margin: 3px 0 0; }
.badges { margin-left: auto; text-align: right; display: flex; flex-direction: column; gap: 5px; align-items: flex-end; }
.badge { font-size: 12px; padding: 3px 9px; border-radius: 999px; border: 1px solid var(--line); white-space: nowrap; }
.badge.status { font-weight: 700; }
.badge.tier { color: var(--gold); }
.cardtype { display: inline-block; margin-top: 12px; font-size: 12px; letter-spacing: .12em; color: var(--gold); font-weight: 700; }
.hook { margin: 10px 0 0; padding: 10px 12px; background: var(--panel-2); border-left: 3px solid var(--gold); border-radius: 8px; font-size: 15px; }

/* action grid */
.actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 14px; }
.action { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 3px; min-height: 60px; border-radius: 12px; border: 1px solid var(--line); background: #0e1c16; color: var(--ink); text-decoration: none; font-size: 13px; padding: 8px 4px; }
.action .em { font-size: 20px; line-height: 1; }
.action.call { background: #123a28; border-color: #1f5c3f; color: #cdeede; }
.action.disabled { opacity: .35; pointer-events: none; }

/* prewritten text */
.texts { margin-top: 16px; }
.label { font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); margin: 0 0 6px; }
.textbox { background: #0b1611; border: 1px solid var(--line); border-radius: 10px; padding: 11px 12px; font-size: 14px; white-space: pre-wrap; }
.textbtns { display: flex; gap: 8px; margin-top: 8px; }
.textbtns .btn { flex: 1; }
.more-texts { margin-top: 8px; }
.more-texts summary { cursor: pointer; color: var(--muted); font-size: 13px; }
.more-texts .textbox { margin-top: 8px; }

/* script accordion */
.script { margin-top: 14px; border-top: 1px solid var(--line); }
.script details { border-bottom: 1px solid var(--line); }
.script summary { padding: 12px 2px; cursor: pointer; font-weight: 600; font-size: 15px; }
.script .body { padding: 0 2px 14px; font-size: 14px; color: #d6e6dd; }
.script .body .q { color: var(--gold); }
.script ul { margin: 6px 0; padding-left: 20px; }

/* disposition */
.dispo { margin-top: 16px; padding-top: 14px; border-top: 1px solid var(--line); }
.dispo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 7px; }
.dchip { min-height: 46px; border-radius: 10px; border: 1px solid var(--line); background: #0e1c16; color: var(--ink); font-size: 13px; padding: 6px 4px; }
.dchip[aria-pressed="true"] { background: var(--gold); color: #1a1206; border-color: var(--gold); font-weight: 600; }
.form { margin-top: 12px; display: grid; gap: 10px; }
.form label { font-size: 12px; color: var(--muted); display: block; margin-bottom: 4px; }
.form input, .form select, .form textarea { width: 100%; padding: 11px; border-radius: 10px; border: 1px solid var(--line); background: #0b1611; color: var(--ink); font-size: 16px; }
.form .two { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.save-row { display: flex; gap: 8px; margin-top: 4px; }

/* buttons */
.btn { min-height: var(--tap); border-radius: 12px; border: 1px solid var(--line); background: var(--panel); color: var(--ink); font-size: 16px; font-weight: 600; padding: 0 16px; cursor: pointer; }
.btn-primary { background: var(--green); border-color: var(--green); color: #06150d; }
.btn-block { width: 100%; }
.btn-ghost { background: transparent; color: var(--muted); }
.btn:active { transform: translateY(1px); }
.btn:disabled { opacity: .5; }

/* nav bar */
.navbar { position: sticky; bottom: 0; display: flex; align-items: center; gap: 10px; padding: 10px 12px calc(10px + env(safe-area-inset-bottom)); background: #0c1813ee; border-top: 1px solid var(--line); backdrop-filter: blur(6px); }
.navbar .btn { flex: 1; }
.position { font-variant-numeric: tabular-nums; color: var(--muted); font-size: 14px; min-width: 64px; text-align: center; }

.empty { text-align: center; padding: 60px 20px; color: var(--muted); }
.empty .big { font-size: 40px; }

/* toast */
.toast { position: fixed; left: 50%; bottom: calc(84px + env(safe-area-inset-bottom)); transform: translateX(-50%); background: #04302099; border: 1px solid var(--green); color: #d8f6e7; padding: 10px 16px; border-radius: 999px; font-size: 14px; z-index: 50; max-width: 90vw; }

/* status colors (mirror the call-sheet palette) */
.s-to_call { color: var(--blue); border-color: #2c4a63; }
.s-no_answer { color: #d9c07a; border-color: #5a4d27; }
.s-sent_link { color: #b69ce8; border-color: #443a63; }
.s-reviewing { color: #b69ce8; border-color: #443a63; }
.s-interested { color: var(--green); border-color: #1f5c3f; }
.s-quoted { color: var(--green); border-color: #1f5c3f; }
.s-won { background: #123a28; color: #cdeede; border-color: var(--green); }
.s-lost { color: var(--red); border-color: #5c2f2a; }
.s-not_now { color: var(--muted); }
.s-disqualified { color: var(--muted); text-decoration: line-through; }
