/* Pineway Releases — app styles.
 * Phone-first structure borrowed from Pineway Miles; brand palette (purple +
 * cream + Georgia wordmark + green/amber/red status) borrowed from the Pineway
 * storefront. One visual family. Promoted from the approved mockup. */

:root {
  --purple: #6d54a3;
  --purple-hover: #5a4589;
  --purple-light: #8b78b8;
  --purple-wash: #f3eef9;
  --cream: #f7f6f4;
  --text: #2b2b2b;
  --text-light: #6b6b72;
  --border: #e3e1ea;
  --bg: #f5f4f7;
  --card: #fff;
  --green: #1e9e54;
  --green-wash: #e7f6ee;
  --amber: #d98a00;
  --amber-wash: #fff4dc;
  --red: #d63a3a;
  --red-wash: #fce8e8;
  --radius: 12px;
  --shadow: 0 1px 3px rgba(40,30,70,0.08);
  --shadow-lift: 0 6px 22px rgba(40,30,70,0.16);
  --font: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  --serif: Georgia, 'Times New Roman', serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html { font-size: 16px; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--font);
  color: var(--text);
  background: var(--bg);
  line-height: 1.45;
}
button { font-family: inherit; cursor: pointer; }
a { color: var(--purple); text-decoration: none; }

/* Phone frame — centers the app and gives it a device feel on desktop. */
.phone {
  max-width: 460px;
  margin: 0 auto;
  min-height: 100vh;
  background: var(--bg);
  position: relative;
  display: flex;
  flex-direction: column;
  box-shadow: 0 0 40px rgba(0,0,0,0.06);
}

/* === Top bar === */
.topbar {
  background: var(--cream);
  border-bottom: 1px solid var(--border);
  padding: 14px 16px 12px;
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; gap: 10px;
}
.topbar .wordmark {
  font-family: var(--serif);
  font-size: 1.18rem;
  color: var(--text);
  font-weight: 400;
  line-height: 1.1;
}
.topbar .wordmark b { color: var(--purple); font-weight: 600; }
.topbar .sub { font-size: 0.72rem; color: var(--text-light); letter-spacing: .02em; }
.topbar .back {
  background: none; border: none; color: var(--purple);
  font-size: 1.5rem; line-height: 1; padding: 0 4px 0 0; margin-right: 2px;
}
.topbar .spacer { flex: 1; }
.topbar .build-pill {
  font-size: 0.62rem; color: var(--text-light); font-family: ui-monospace, Menlo, monospace;
  background: #fff; border: 1px solid var(--border);
  border-radius: 999px; padding: 3px 9px;
}

/* === Boot / load-error overlay === */
.boot { padding: 40px 18px; flex: 1; }
.boot-card {
  background: var(--card); border: 1px solid var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow); padding: 22px 18px; text-align: center; max-width: 360px; margin: 30px auto;
}
.boot-h { font-weight: 700; font-size: 1.02rem; margin-bottom: 6px; }
.boot-m { color: var(--text-light); font-size: 0.86rem; margin-bottom: 14px; }

/* === Screens === */
.screen { display: none; padding: 14px 16px 90px; flex: 1; }
.screen.active { display: block; animation: fade .18s ease; }
@keyframes fade { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: none; } }

.screen h2 { font-size: 1.18rem; font-weight: 700; margin-bottom: 2px; }
.screen .lede { color: var(--text-light); font-size: 0.86rem; margin-bottom: 14px; }

/* === Summary strip (pipeline top) === */
.summary {
  display: flex; gap: 8px; margin-bottom: 14px;
}
.summary .stat {
  flex: 1; background: var(--card); border-radius: 10px; padding: 10px 8px;
  text-align: center; box-shadow: var(--shadow); border: 1px solid var(--border);
}
.summary .stat .n { font-size: 1.35rem; font-weight: 800; line-height: 1; }
.summary .stat .l { font-size: 0.66rem; color: var(--text-light); margin-top: 4px; text-transform: uppercase; letter-spacing: .03em; }
.summary .stat.red .n { color: var(--red); }
.summary .stat.amber .n { color: var(--amber); }
.summary .stat.green .n { color: var(--green); }

/* === Filter chips === */
.chips { display: flex; gap: 7px; overflow-x: auto; padding-bottom: 10px; margin-bottom: 4px; -webkit-overflow-scrolling: touch; }
.chips::-webkit-scrollbar { display: none; }
.chip {
  flex: 0 0 auto; border: 1px solid var(--border); background: #fff;
  color: var(--text-light); border-radius: 999px; padding: 6px 13px;
  font-size: 0.8rem; white-space: nowrap; transition: all .12s;
}
.chip.active { background: var(--purple); border-color: var(--purple); color: #fff; font-weight: 600; }
.chip.attn.active { background: var(--red); border-color: var(--red); }

/* === Release card === */
.rcard {
  background: var(--card); border-radius: var(--radius); padding: 12px 13px;
  margin-bottom: 10px; box-shadow: var(--shadow); border: 1px solid var(--border);
  border-left: 4px solid var(--series, var(--purple));
  transition: transform .1s, box-shadow .12s;
}
.rcard:active { transform: scale(.992); box-shadow: var(--shadow-lift); }
.rcard .rtop { display: flex; align-items: baseline; justify-content: space-between; gap: 8px; }
.rcard .rtitle { font-size: 0.98rem; font-weight: 700; }
.rcard .rrel { font-size: 0.78rem; color: var(--text-light); white-space: nowrap; }
.rcard .rrel b { color: var(--text); font-weight: 600; }
.rcard .rmeta { display: flex; align-items: center; gap: 8px; margin: 5px 0 9px; flex-wrap: wrap; }
.badge {
  font-size: 0.66rem; font-weight: 700; padding: 2px 8px; border-radius: 999px;
  color: #fff; background: var(--series, var(--purple)); letter-spacing: .02em;
}
.badge.ghost { background: #fff; color: var(--text-light); border: 1px solid var(--border); font-weight: 600; }
.tag-tentative { font-size: 0.66rem; color: var(--amber); border: 1px dashed var(--amber); border-radius: 999px; padding: 1px 7px; }

/* milestone dot strip on cards */
.dots { display: flex; gap: 6px; flex-wrap: wrap; }
.dot {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 0.68rem; color: var(--text-light);
  background: var(--bg); border-radius: 7px; padding: 3px 7px 3px 5px; border: 1px solid var(--border);
}
.dot .pip { width: 9px; height: 9px; border-radius: 50%; background: #cfcdd6; flex: 0 0 auto; }
.dot.done .pip   { background: var(--green); }
.dot.soon .pip   { background: var(--amber); }
.dot.due .pip    { background: var(--red); }
.dot.done { background: var(--green-wash); border-color: #cde9d9; }
.dot.soon { background: var(--amber-wash); border-color: #f0dca6; color: #8a5b00; }
.dot.due  { background: var(--red-wash); border-color: #f1c5c5; color: #a82b2b; }
.dot.done .pip::after { content: ''; }

/* === Detail screen === */
.detail-head { background: var(--card); border-radius: var(--radius); padding: 14px; box-shadow: var(--shadow); border: 1px solid var(--border); border-left: 4px solid var(--series, var(--purple)); margin-bottom: 14px; }
.detail-head h2 { font-size: 1.25rem; margin-bottom: 6px; }
.detail-head .row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }
.detail-head .anchor { font-size: 0.85rem; color: var(--text-light); }
.detail-head .anchor b { color: var(--text); }
.platforms { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 8px; }
.platforms .pf { font-size: 0.68rem; background: var(--purple-wash); color: var(--purple); border-radius: 6px; padding: 3px 8px; font-weight: 600; }

.section-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: .05em; color: var(--text-light); margin: 18px 2px 8px; font-weight: 700; }

/* milestone timeline */
.timeline { position: relative; }
.mile {
  background: var(--card); border: 1px solid var(--border); border-radius: 10px;
  padding: 11px 12px; margin-bottom: 8px; box-shadow: var(--shadow);
  display: flex; align-items: center; gap: 11px;
}
.mile[data-toggle] { cursor: pointer; }
.mile .check {
  width: 26px; height: 26px; border-radius: 50%; border: 2px solid #cfcdd6;
  flex: 0 0 auto; display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem; color: #fff; background: #fff; transition: all .12s;
}
.mile.done .check { background: var(--green); border-color: var(--green); }
.mile .check::after { content: '✓'; opacity: 0; }
.mile.done .check::after { opacity: 1; }
.mile .mbody { flex: 1; min-width: 0; }
.mile .mname { font-size: 0.92rem; font-weight: 600; }
.mile .mdate { font-size: 0.78rem; color: var(--text-light); }
.mile .mstate {
  font-size: 0.66rem; font-weight: 700; padding: 2px 8px; border-radius: 999px; white-space: nowrap;
}
.mile.done  { border-left: 3px solid var(--green); }
.mile.soon  { border-left: 3px solid var(--amber); }
.mile.due   { border-left: 3px solid var(--red); }
.mile.future{ border-left: 3px solid var(--border); }
.mile.release-row { background: var(--purple-wash); border-left: 3px solid var(--purple); }
.mstate.s-done   { background: var(--green-wash); color: #1a7a43; }
.mstate.s-soon   { background: var(--amber-wash); color: #8a5b00; }
.mstate.s-due    { background: var(--red-wash); color: #a82b2b; }
.mstate.s-future { background: var(--bg); color: var(--text-light); }
.mile .mdone { font-size: 0.74rem; color: var(--green); font-weight: 600; margin-top: 3px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.mile .vr { font-size: 0.62rem; font-weight: 700; padding: 1px 6px; border-radius: 8px; }
.mile .vr.late { background: var(--amber-wash); color: #8a5b00; }
.mile .vr.early, .mile .vr.ontime { background: var(--green-wash); color: #1a7a43; }

/* hard platform deadlines (KDP / Audible) — immovable, penalty if missed */
.hard-badge {
  font-size: 0.58rem; font-weight: 800; text-transform: uppercase; letter-spacing: .03em;
  color: #7a2a2a; background: #fbeaea; border: 1px solid #f1c5c5;
  border-radius: 999px; padding: 1px 7px; white-space: nowrap; vertical-align: 1px;
}
.hard-note { font-size: 0.7rem; color: #a82b2b; margin-top: 4px; line-height: 1.35; }
.dot .lk { font-size: 0.6rem; margin-left: 2px; }

/* catalog & checks (Publisher / ISBN / List<Upload validation) */
.catalog { background: var(--card); border: 1px solid var(--border); border-radius: 10px; box-shadow: var(--shadow); overflow: hidden; }
.catalog .crow { display: flex; justify-content: space-between; align-items: center; gap: 10px; padding: 9px 12px; border-bottom: 1px solid var(--border); font-size: 0.82rem; }
.catalog .crow:last-child { border-bottom: none; }
.catalog .ck { color: var(--text-light); }
.catalog .cv { font-weight: 600; text-align: right; }
.ok-chip { font-size: 0.66rem; font-weight: 700; color: #1a7a43; background: var(--green-wash); border-radius: 999px; padding: 1px 8px; }
.warn-chip { font-size: 0.66rem; font-weight: 700; color: #a82b2b; background: var(--red-wash); border-radius: 999px; padding: 1px 8px; }

/* reschedule hard-deadline guard banner */
.hard-warn { background: var(--red-wash); border: 1px solid #f1c5c5; border-radius: 10px; padding: 11px 12px; margin-bottom: 14px; }
.hard-warn .hw-h { font-weight: 800; font-size: 0.8rem; color: #a82b2b; margin-bottom: 5px; }
.hard-warn .hw-i { font-size: 0.74rem; color: #7a2a2a; line-height: 1.4; margin-top: 4px; }

/* === Buttons === */
.btn {
  display: block; width: 100%; text-align: center; padding: 13px;
  border: none; border-radius: 12px; background: var(--purple); color: #fff;
  font-size: 0.95rem; font-weight: 600; margin-top: 8px; transition: background .12s;
}
.btn:active { background: var(--purple-hover); }
.btn:disabled { opacity: .6; }
.btn.ghost { background: #fff; color: var(--purple); border: 1.5px solid var(--purple); }
.btn.sm { padding: 9px; font-size: 0.85rem; }
.btn-row { display: flex; gap: 8px; }
.btn-row .btn { margin-top: 0; }

/* === Reschedule === */
.resched-card { background: var(--card); border-radius: var(--radius); padding: 14px; box-shadow: var(--shadow); border: 1px solid var(--border); margin-bottom: 14px; }
.resched-card label { font-size: 0.78rem; color: var(--text-light); font-weight: 600; display: block; margin-bottom: 6px; }
.resched-card input[type=date] {
  width: 100%; padding: 11px 12px; border: 1.5px solid var(--purple-light);
  border-radius: 10px; font-size: 1rem; background: #fff; color: var(--text);
}
.diff { margin-top: 4px; }
.diff-row {
  display: flex; align-items: center; gap: 8px; padding: 10px 12px;
  background: var(--card); border: 1px solid var(--border); border-radius: 10px;
  margin-bottom: 7px; box-shadow: var(--shadow);
}
.diff-row.changed { background: #fbfaff; border-color: var(--purple-light); }
.diff-row .dn { flex: 1; font-size: 0.86rem; font-weight: 600; }
.diff-row .dn small { display: block; font-weight: 400; color: var(--text-light); font-size: 0.72rem; }
.diff-row .old { font-size: 0.76rem; color: var(--text-light); text-decoration: line-through; }
.diff-row .arrow { color: var(--purple); font-weight: 700; }
.diff-row .new { font-size: 0.82rem; font-weight: 700; color: var(--purple); white-space: nowrap; }
.diff-row .same { font-size: 0.8rem; color: var(--text-light); }
.chain-head { display: flex; align-items: center; gap: 8px; margin: 16px 2px 8px; }
.chain-head .cseries { font-size: 0.72rem; font-weight: 700; text-transform: uppercase; letter-spacing: .04em; color: var(--text-light); }
.flash { animation: flash 1s ease; }
@keyframes flash { 0%,100% { background: #fbfaff; } 30% { background: #ece4fb; } }
.callout { background: var(--purple-wash); border: 1px solid var(--purple-light); border-radius: 10px; padding: 11px 12px; font-size: 0.82rem; color: var(--text); margin-bottom: 14px; }
.callout b { color: var(--purple); }

/* === Newsletters === */
.nl-card { background: var(--card); border-radius: var(--radius); padding: 13px; margin-bottom: 10px; box-shadow: var(--shadow); border: 1px solid var(--border); }
.nl-card .nl-top { display: flex; justify-content: space-between; align-items: baseline; }
.nl-card .nl-date { font-weight: 700; font-size: 0.98rem; }
.nl-card .nl-when { font-size: 0.74rem; color: var(--text-light); }
.nl-rel { display: inline-block; font-size: 0.7rem; background: var(--purple); color: #fff; border-radius: 6px; padding: 2px 8px; margin-top: 8px; font-weight: 600; }
.nl-swaps { margin-top: 10px; border-top: 1px solid var(--border); padding-top: 9px; }
.nl-swap { display: flex; gap: 8px; font-size: 0.8rem; padding: 5px 0; }
.nl-swap .sw-au { font-weight: 600; flex: 0 0 38%; }
.nl-swap .sw-bk { color: var(--text-light); flex: 1; }
.nl-swap .sw-iou { font-size: 0.7rem; color: var(--green); }
.nl-empty { font-size: 0.78rem; color: var(--text-light); font-style: italic; }

/* === Authors === */
.searchbar { width: 100%; padding: 11px 13px; border: 1px solid var(--border); border-radius: 10px; font-size: 0.92rem; margin-bottom: 12px; background: #fff; }
.au-pending { background: var(--amber-wash); border: 1px solid #f0dca6; border-radius: var(--radius); padding: 13px; margin-bottom: 10px; box-shadow: var(--shadow); }
.au-pending .ph { display: flex; align-items: center; gap: 8px; }
.au-pending .pn { font-weight: 700; font-size: 0.98rem; }
.au-pending .pg { font-size: 0.76rem; color: var(--text-light); }
.au-pending .psub { font-size: 0.74rem; color: #8a5b00; margin: 6px 0; }
.au-pending .pnote { font-size: 0.82rem; color: var(--text); background: #fff; border-radius: 8px; padding: 8px 10px; margin-bottom: 10px; border: 1px solid #f0dca6; }
.au-pending .ribbon { font-size: 0.64rem; font-weight: 800; text-transform: uppercase; letter-spacing: .05em; color: #fff; background: var(--amber); border-radius: 999px; padding: 2px 8px; }
.au-actions { display: flex; gap: 7px; }
.au-actions .btn { flex: 1; margin-top: 0; }
.btn.approve { background: var(--green); }
.btn.approve:active { background: #18814a; }
.btn.deny { background: #fff; color: var(--red); border: 1.5px solid var(--red); }
.btn.comment { background: #fff; color: var(--text-light); border: 1.5px solid var(--border); }
.au-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; background: var(--card); border: 1px solid var(--border); border-radius: 9px; padding: 9px 12px; margin-bottom: 6px; box-shadow: var(--shadow); }
.au-row .an { font-weight: 600; font-size: 0.9rem; }
.au-row .ag { font-size: 0.72rem; color: var(--text-light); }
.au-row .ok { color: var(--green); font-size: 1.05rem; }
.resolved-note { font-size: 0.8rem; padding: 9px 11px; border-radius: 9px; margin-bottom: 10px; }
.resolved-note.ap { background: var(--green-wash); color: #1a7a43; border: 1px solid #cde9d9; }
.resolved-note.dn { background: var(--red-wash); color: #a82b2b; border: 1px solid #f1c5c5; }

/* === Alert email preview === */
.email {
  background: #fff; border: 1px solid var(--border); border-radius: var(--radius);
  box-shadow: var(--shadow); overflow: hidden; margin-bottom: 14px;
}
.email .ehead { background: var(--cream); padding: 12px 14px; border-bottom: 1px solid var(--border); }
.email .esubj { font-weight: 700; font-size: 0.95rem; }
.email .emeta { font-size: 0.74rem; color: var(--text-light); margin-top: 3px; }
.email .ebody { padding: 14px; font-size: 0.86rem; }
.email .ebody p { margin-bottom: 11px; }
.email .egroup { font-weight: 700; font-size: 0.8rem; margin: 14px 0 6px; display: flex; align-items: center; gap: 7px; }
.email .egroup .pip { width: 9px; height: 9px; border-radius: 50%; }
.eitem { display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 8px; margin-bottom: 6px; }
.eitem.due { background: var(--red-wash); }
.eitem.soon { background: var(--amber-wash); }
.eitem .et { flex: 1; font-size: 0.82rem; }
.eitem .et b { display: block; }
.eitem .et small { color: var(--text-light); }
.eitem .nudge { font-size: 0.7rem; font-weight: 700; color: var(--purple); background: #fff; border: 1px solid var(--purple-light); border-radius: 999px; padding: 4px 10px; white-space: nowrap; }
.sig { color: var(--text-light); font-size: 0.82rem; }

/* === Bottom nav === */
.tabbar {
  position: sticky; bottom: 0; left: 0; right: 0; z-index: 50;
  background: rgba(255,255,255,0.96); backdrop-filter: blur(8px);
  border-top: 1px solid var(--border);
  display: flex; max-width: 460px; margin: 0 auto;
}
.tabbar .tab {
  flex: 1; background: none; border: none; padding: 9px 4px 8px;
  display: flex; flex-direction: column; align-items: center; gap: 3px;
  color: var(--text-light); font-size: 0.66rem;
}
.tabbar .tab .ic { font-size: 1.18rem; line-height: 1; }
.tabbar .tab.active { color: var(--purple); font-weight: 700; }

/* toast */
.toast {
  position: fixed; left: 50%; bottom: 78px; transform: translateX(-50%) translateY(20px);
  background: #2b2b2b; color: #fff; padding: 11px 18px; border-radius: 999px;
  font-size: 0.85rem; opacity: 0; transition: all .25s; z-index: 100; pointer-events: none;
  max-width: 90%; text-align: center; box-shadow: var(--shadow-lift);
}
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }

.muted { color: var(--text-light); font-size: 0.8rem; }
.center { text-align: center; }
