/* ============================================================
   Agentic AI Design Canvas — critic
   Restyled to the Design the Agent identity (designtheagent.com):
   navy + cream, Newsreader display, IBM Plex Sans/Mono,
   corner-triangle group accents, navy hairlines.

   Drop-in replacement for public/styles.css — every class hook
   from app.js / index.html is preserved. Requires the fonts
   linked in index.html (Newsreader, IBM Plex Sans, IBM Plex Mono).
   ============================================================ */

:root {
  --ink: #0B1F3A;
  --navy: #0B1F3A;
  --muted: #5b6b7d;
  --line: #DCD3C3;       /* warm hairline */
  --rule: #0B1F3A;       /* structural navy rule */
  --bg: #FAF7F2;         /* cream paper */
  --card: #FFFFFF;

  --purpose: #FF6B35;    /* orange */
  --capability: #C9A227; /* readable gold (triangle uses pure yellow) */
  --capability-tri: #F4D35E;
  --governance: #06A77D; /* green */

  --green: #06A77D;
  --amber: #9A7B0E;
  --red: #C0392B;
  --grey: #9aa0a6;

  --radius: 6px;
  --shadow: 0 1px 2px rgba(11,31,58,0.04), 0 10px 30px rgba(11,31,58,0.06);

  --serif: "Newsreader", Georgia, serif;
  --sans: "IBM Plex Sans", system-ui, -apple-system, sans-serif;
  --mono: "IBM Plex Mono", ui-monospace, Menlo, monospace;
  font-family: var(--sans);
}

* { box-sizing: border-box; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  line-height: 1.55;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
}

.wrap { max-width: 1200px; margin: 0 auto; padding: 0 32px; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header { border-bottom: 1.5px solid var(--rule); background: var(--card); }
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px; padding: 22px 32px; flex-wrap: wrap; max-width: 1200px; margin: 0 auto;
}
.brand { display: flex; align-items: center; gap: 11px; text-decoration: none; margin-bottom: 10px; }
.brand .glyph { width: 26px; height: 26px; flex: none; }
.brand .bn { font-family: var(--serif); font-weight: 600; font-size: 15px; color: var(--ink);
  letter-spacing: -0.01em; line-height: 1; white-space: nowrap; }
.titles h1 {
  margin: 0; font-family: var(--serif); font-weight: 600;
  font-size: 30px; letter-spacing: -0.02em; line-height: 1;
}
.titles h1 em { font-style: italic; font-weight: 400; }
.subtitle { margin: 6px 0 0; color: var(--muted); font-family: var(--mono);
  font-size: 11.5px; letter-spacing: 0.12em; text-transform: uppercase; }
.legend { display: flex; gap: 18px; flex-wrap: wrap; }
.legend .swatch { display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em;
  text-transform: uppercase; color: var(--muted); }
/* turn the JS-set background dot into a corner triangle via border trick:
   app.js sets style="background:<colour>" on .dot, so we also honour a square. */
.legend .dot { width: 11px; height: 11px; border: none; border-radius: 2px; }

/* ============================================================
   TOOLBAR
   ============================================================ */
.toolbar {
  background: var(--card); border: 1.2px solid var(--ink); border-radius: var(--radius);
  padding: 18px; margin: 26px 0; box-shadow: var(--shadow);
}
.toolbar-row { display: flex; gap: 18px; align-items: flex-end; flex-wrap: wrap; }
.toolbar-row.actions { margin-top: 16px; align-items: center; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field.grow { flex: 1 1 360px; }
.field label { font-family: var(--mono); font-size: 11px; font-weight: 500;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); }
.muted { color: var(--muted); font-weight: 400; text-transform: none; letter-spacing: 0; }
.token-line { display: flex; gap: 8px; }

input[type="text"], input[type="email"], textarea {
  font-family: var(--sans); font-size: 15px; color: var(--ink); background: #fff;
  border: 1px solid var(--line); border-radius: 5px; padding: 9px 11px; width: 100%;
}
textarea { resize: vertical; }
input[type="text"]:focus, input[type="email"]:focus, textarea:focus {
  outline: 2px solid var(--purpose); outline-offset: 0; border-color: transparent;
}

button, .filebtn {
  font-family: var(--mono); font-size: 12px; letter-spacing: 0.03em; cursor: pointer;
  border: 1px solid var(--ink); background: #fff; color: var(--ink);
  border-radius: 5px; padding: 9px 15px; white-space: nowrap; transition: background 0.14s, transform 0.1s;
}
button:hover, .filebtn:hover { background: #f4efe6; }
button.primary {
  background: var(--purpose); color: var(--navy); border-color: var(--purpose);
  font-weight: 600; text-transform: uppercase; letter-spacing: 0.05em;
}
button.primary:hover { background: #ff7d4d; transform: translateY(-1px); }
button:disabled { opacity: 0.5; cursor: default; transform: none; }
.spacer { flex: 1 1 auto; }
.status { font-size: 13px; color: var(--muted); margin: 0; min-height: 1em; font-family: var(--sans); }
.status.error { color: var(--red); }
.status.ok { color: var(--green); }
.round-info { font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em; color: var(--muted); }
.round-reset { font-family: var(--mono); font-size: 11px; color: var(--muted); }
.toolbar-row.review-status-row { margin-top: 8px; gap: 12px; align-items: center; }
#clearBtn:hover { color: var(--red); border-color: var(--red); }
.plan-bar { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; font-size: 13px;
  color: var(--ink); background: var(--card); border: 1px solid var(--line);
  border-radius: var(--radius); padding: 9px 13px; margin-bottom: 16px; }
.plan-bar[hidden] { display: none; } /* the hidden attribute must beat display:flex */
.plan-bar .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--purpose); flex: none; }
.plan-bar .plan-text { margin-right: auto; }
.plan-bar .plan-link { color: var(--purpose); font-weight: 600; text-decoration: none; }
.plan-bar .plan-link:hover { text-decoration: underline; }
.plan-bar .plan-link.plan-signup { background: var(--purpose); color: #fff; padding: 4px 12px; border-radius: 999px; }
.plan-bar .plan-link.plan-signup:hover { filter: brightness(0.94); text-decoration: none; }

/* Privacy / data notice shown at the point of entry */
.privacy-note { margin: 24px 0 18px; padding: 12px 16px; border-radius: var(--radius);
  background: #FFF6F1; border: 1px solid #F6D6C6; border-left: 3px solid var(--purpose);
  color: var(--ink); font-size: 13.5px; line-height: 1.5; }
.privacy-note strong { font-weight: 600; }
.enterprise-list { margin: 0 0 18px; padding-left: 18px; font-size: 14px; line-height: 1.5; color: var(--ink); }
.enterprise-list li { margin-bottom: 6px; }
.modal a.cta { display: block; width: fit-content; margin: 16px auto 0; background: var(--purpose); color: #fff; text-decoration: none;
  padding: 10px 18px; border-radius: var(--radius); font-weight: 600; }
.modal a.cta:hover { filter: brightness(0.94); }
.northstar-field { position: relative; overflow: hidden; border: 1.2px solid var(--ink); border-radius: var(--radius);
  background: var(--card); box-shadow: var(--shadow); padding: 16px 18px; margin-bottom: 18px; }
.northstar-field::before { content: ""; position: absolute; top: 0; left: 0; width: 26px; height: 26px;
  clip-path: polygon(0 0, 100% 0, 0 100%); background: var(--purpose); }
.northstar-field label { display: block; font-family: var(--serif); font-style: italic; font-weight: 600;
  font-size: 18.5px; line-height: 1.14; letter-spacing: -0.01em; color: var(--ink); margin-bottom: 8px; padding-left: 16px; }
.northstar-field .ns-star { color: var(--purpose); font-style: normal; margin-right: 3px; }
.northstar-field .muted { font-style: italic; font-weight: 400; font-size: 14.5px; color: var(--muted); }
.northstar-field textarea { width: 100%; }

/* ============================================================
   OVERALL RESULTS
   ============================================================ */
.results {
  background: var(--card); border: 1.2px solid var(--ink); border-radius: var(--radius);
  padding: 26px 28px; margin-bottom: 26px; box-shadow: var(--shadow);
}
.results h2 { margin: 0 0 10px; font-family: var(--serif); font-weight: 600; font-size: 26px; letter-spacing: -0.01em; }
.readiness {
  display: inline-block; font-family: var(--mono); font-size: 11px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase; padding: 4px 12px;
  border-radius: 999px; margin-bottom: 12px;
}
.readiness.good { background: #e7f3ec; color: var(--green); }
.readiness.warn { background: #fdf2e2; color: var(--amber); }
.readiness.bad { background: #fbeae8; color: var(--red); }
.results .summary { margin: 6px 0 16px; font-family: var(--serif); font-size: 18px; line-height: 1.5; }
.results h3 {
  font-family: var(--mono); font-size: 11px; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--muted); margin: 20px 0 10px; font-weight: 600;
}
.results ul { margin: 0; padding-left: 18px; }
.results li { margin: 5px 0; }
.crossflag { border-left: 3px solid var(--amber); padding: 6px 0 6px 14px; margin: 10px 0; }
.crossflag .cells { font-family: var(--mono); font-weight: 600; font-size: 11px;
  letter-spacing: 0.06em; text-transform: uppercase; color: var(--amber); }
.crossflag .why { color: var(--muted); font-size: 14px; margin-top: 2px; }
.tailoring { margin-top: 16px; font-size: 13px; color: var(--muted);
  border-top: 1px dashed var(--line); padding-top: 12px; }

/* Pre-review checklist — soft, non-blocking nudges shown before the first review. */
.precheck-list { list-style: none; margin: 12px 0 4px; padding: 0; }
.precheck-item { display: flex; gap: 10px; align-items: flex-start;
  padding: 9px 0; border-top: 1px solid var(--line); }
.precheck-item:first-child { border-top: 0; }
.precheck-chip { flex: none; font-family: var(--mono); font-size: 10px; line-height: 1.6;
  letter-spacing: 0.06em; text-transform: uppercase; padding: 2px 8px; border-radius: 999px; }
.precheck-chip.risk { background: #FBE6E1; color: var(--red); }
.precheck-chip.gap { background: #FCEFD6; color: var(--amber); }
.precheck-text { font-size: 14px; line-height: 1.5; color: var(--ink); }
.precheck-actions { display: flex; gap: 10px; margin-top: 16px; }

/* Next edits — the pinned, actionable to-do list (the hero of a review). */
.next-edits { margin: 16px 0 4px; padding: 15px 18px; border: 1px solid var(--line);
  border-left: 4px solid var(--purpose); border-radius: var(--radius); background: #FFF9F4; }
.next-edits-title { margin: 0 0 9px; font-family: var(--sans); font-size: 12px; font-weight: 700;
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--ink); }
.next-edits-list { list-style: none; margin: 0; padding: 0; }
.next-edit { display: flex; gap: 10px; align-items: baseline; padding: 8px 0; }
.next-edit + .next-edit { border-top: 1px solid var(--line); }
.edit-chip { flex: none; font-family: var(--mono); font-size: 11px; font-weight: 600; letter-spacing: 0.03em;
  color: #fff; background: var(--chip, var(--ink)); border: 0; padding: 3px 9px; border-radius: 999px; cursor: pointer; }
.edit-chip:hover { filter: brightness(0.92); }
.edit-chip:focus-visible { outline: 2px solid var(--ink); outline-offset: 2px; }
.edit-text { font-size: 14.5px; line-height: 1.5; color: var(--ink); }

/* Since-last-round delta strip (deterministic). */
.round-delta { display: flex; flex-wrap: wrap; gap: 7px 10px; align-items: center; margin: 14px 0 2px; font-size: 13px; color: var(--muted); }
.round-delta .rd-label { font-family: var(--mono); font-size: 11px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); }
.rd-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.rd-chip { font-size: 12px; padding: 2px 9px; border-radius: 999px; border: 1px solid transparent; }
.rd-chip.up { background: #E7F6F0; color: #0B6E54; border-color: #BFE6D8; }
.rd-chip.down { background: #FBE6E1; color: var(--red); border-color: #F2C9BF; }
.rd-chip.risk { background: #FCEFD6; color: var(--amber); border-color: #F0DCAE; }

/* Full-breakdown disclosure (keeps the actions leading). */
.fb-detail { margin-top: 16px; border-top: 1px dashed var(--line); padding-top: 8px; }
.fb-detail > summary { cursor: pointer; font-family: var(--mono); font-size: 12px; letter-spacing: 0.04em; color: var(--muted); padding: 4px 0; }
.fb-detail > summary:hover { color: var(--ink); }
.fb-detail[open] > summary { margin-bottom: 4px; }

/* Brief highlight when a Do-this-next chip jumps you to a cell. */
@keyframes cellflash {
  0% { box-shadow: 0 0 0 0 rgba(255,107,53,0); }
  20% { box-shadow: 0 0 0 3px rgba(255,107,53,0.55); }
  100% { box-shadow: 0 0 0 0 rgba(255,107,53,0); }
}
.cell-flash { animation: cellflash 1.3s ease; }

/* Pinned feedback bar (fixed to the bottom of the viewport, shown after a review). */
.fb-bar { position: fixed; left: 0; right: 0; bottom: 0; z-index: 50; background: var(--card);
  border-top: 1.2px solid var(--ink); box-shadow: 0 -6px 24px rgba(11,31,58,0.12); }
.fb-bar[hidden] { display: none; }
.fb-bar .fb-bar-inner { max-width: 1200px; margin: 0 auto; padding: 10px 32px; }
.fb-bar .fb-row { display: flex; align-items: center; gap: 10px; }
@media (max-width: 640px) { .fb-bar .fb-row { flex-wrap: wrap; } }
.fb-rate-label { font-size: 13.5px; font-weight: 600; color: var(--ink); }
.fb-thumb { padding: 4px 10px; font-size: 16px; line-height: 1; background: var(--card);
  border: 1px solid var(--line); border-radius: 8px; cursor: pointer; }
.fb-thumb:hover { border-color: var(--ink); }
.fb-thumb.on { border-color: var(--purpose); background: #FFF1EA; }
.fb-note { flex: 1 1 80px; min-width: 120px; } /* single-line, fills the row; shrinks so Send + ✕ stay on the right */
.fb-submit { flex: none; }
.fb-msg { font-size: 13px; }
.fb-close { flex: none; background: var(--card); border: 1px solid var(--line); border-radius: var(--radius);
  color: var(--muted); padding: 7px 11px; font-size: 14px; line-height: 1; cursor: pointer; }
.fb-close:hover { border-color: var(--ink); color: var(--ink); }
.fb-privacy { font-size: 11.5px; color: var(--muted); margin: 7px 0 0; line-height: 1.4; }

/* ============================================================
   CANVAS GROUPS + CELLS
   ============================================================ */
.group { margin-bottom: 34px; }
.group-head { display: flex; align-items: baseline; gap: 12px; margin: 0 0 16px;
  padding-bottom: 8px; border-bottom: 1.2px solid var(--ink); }
.group-head .name { font-family: var(--serif); font-size: 24px; font-weight: 600; letter-spacing: -0.01em; }
.group-head .tag { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--muted); white-space: nowrap; }
.cells-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); grid-auto-rows: 1fr; gap: 16px; }

.cell {
  position: relative; background: var(--card);
  border: 1.2px solid var(--ink); border-radius: var(--radius);
  padding: 18px 18px 16px; box-shadow: var(--shadow);
  display: flex; flex-direction: column; gap: 8px; overflow: hidden;
  min-height: 300px; /* floor so all nine cells are uniform height across the three groups */
}
.cell::before {
  content: ""; position: absolute; top: 0; left: 0;
  width: 26px; height: 26px; clip-path: polygon(0 0, 100% 0, 0 100%);
  background: var(--grp, var(--ink));
}
.cell .cell-head { display: flex; align-items: flex-start; gap: 9px; padding-left: 16px; padding-right: 46px; }
.cell .num { position: absolute; top: 13px; right: 16px;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em;
  color: var(--muted); text-transform: uppercase; white-space: nowrap; }
.cell .title { font-family: var(--serif); font-style: italic; font-weight: 600;
  font-size: 18.5px; line-height: 1.14; letter-spacing: -0.01em; }
.cell .prompt { color: var(--muted); font-family: var(--serif); font-size: 15.5px;
  font-style: italic; line-height: 1.4; margin: 4px 0 2px; padding-left: 16px; }
.cell textarea { min-height: 92px; flex: 1 1 auto; }
.cell-print { display: none; }

/* autonomy rung picker */
.rung-picker { display: flex; flex-wrap: wrap; gap: 5px; margin: 2px 0 8px; padding-left: 16px; }
.rung {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.02em; padding: 4px 10px;
  border: 1px solid rgba(11,31,58,0.3); background: #fff; border-radius: 999px;
  cursor: pointer; text-transform: lowercase; color: var(--ink);
}
.rung:hover { background: #f4efe6; }
.rung.selected {
  background: var(--capability-tri); color: var(--navy);
  border-color: var(--capability-tri); font-weight: 600;
}
/* Floating rung tooltip — appended to <body>, so it is never clipped by the cell. */
.rung-tip { position: fixed; z-index: 60; max-width: 280px; background: var(--ink); color: #fff;
  font-size: 12.5px; line-height: 1.4; padding: 8px 11px; border-radius: 6px;
  box-shadow: 0 8px 24px rgba(11,31,58,0.25); pointer-events: none; }
.rung-tip[hidden] { display: none; }

/* ============================================================
   PER-CELL FEEDBACK
   ============================================================ */
.cell-fb { border-top: 1px dashed var(--line); padding-top: 12px; margin-top: 4px;
  display: none; margin-left: 16px; }
.cell-fb.show { display: block; }
.badge {
  display: inline-block; font-family: var(--mono); font-size: 10px; font-weight: 600;
  letter-spacing: 0.05em; text-transform: uppercase; padding: 3px 9px; border-radius: 999px;
}
.badge.clear { background: #e7f3ec; color: var(--green); }
.badge.needs-detail { background: #fdf2e2; color: var(--amber); }
.badge.empty { background: #eef0f2; color: var(--grey); }
.badge.at-risk { background: #fbeae8; color: var(--red); }
.cell-fb ul { margin: 8px 0 0; padding-left: 18px; }
.cell-fb li { font-size: 14px; margin: 3px 0; }
.cell-fb .gap { margin: 10px 0 0; font-size: 14px; line-height: 1.45; }
.cell-fb .q { margin: 10px 0 0; font-family: var(--serif); font-style: italic; font-size: 16px; line-height: 1.4; }
.cell-fb .sugg { margin: 6px 0 0; font-size: 13px; color: var(--muted); }

/* ============================================================
   FOOTER
   ============================================================ */
.foot { color: var(--muted); font-size: 13px; border-top: 1.2px solid var(--ink);
  margin: 34px 0; padding-top: 18px; }
.foot a { color: var(--ink); }

/* ============================================================
   PRINT / PDF
   ============================================================ */
@media print {
  :root { --bg: #fff; }
  .no-print { display: none !important; }
  .site-header { border: none; }
  .legend { display: none; }
  body { background: #fff; }
  .cells-grid { grid-template-columns: 1fr 1fr; }
  .cell, .results { box-shadow: none; break-inside: avoid; }
  .cell-fb { display: block; }
  .cell textarea { display: none; }
  .rung-picker { display: none; }
  .cell-print { display: block; white-space: pre-wrap; font-size: 14px;
    line-height: 1.45; color: var(--ink); padding-left: 16px; }
  a[href]::after { content: ""; }
}

/* ============================================================
   REVIEW-SUMMARY PDF (print-only report, built from the last review)
   ============================================================ */
#review-summary { display: none; }
@media print {
  /* When saving the review, swap the whole page for the report. */
  body.printing-summary > *:not(#review-summary) { display: none !important; }
  body.printing-summary #review-summary {
    display: block; color: var(--ink); font-family: var(--sans);
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  #review-summary .rs-head { display: flex; justify-content: space-between; align-items: flex-start;
    border-bottom: 1.5px solid var(--ink); padding-bottom: 10px; margin-bottom: 16px; }
  #review-summary .rs-title { font-family: var(--serif); font-weight: 600; font-size: 26px; margin: 0; }
  #review-summary .rs-sub { font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
    text-transform: uppercase; color: var(--muted); margin: 4px 0 0; }
  #review-summary .rs-meta { text-align: right; font-family: var(--mono); font-size: 11px; color: var(--muted); line-height: 1.5; }
  #review-summary .rs-meta .rs-brand { color: var(--purpose); font-weight: 600; }
  #review-summary .rs-ns { border-left: 3px solid var(--purpose); background: #FFF9F4; padding: 8px 12px; margin: 0 0 16px; break-inside: avoid; }
  #review-summary .rs-ns-label { font-family: var(--mono); font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--purpose); display: block; }
  #review-summary .rs-ns-text { font-family: var(--serif); font-size: 16px; }
  #review-summary h2 { font-family: var(--serif); font-size: 18px; margin: 0; }
  #review-summary h3 { font-family: var(--sans); font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--ink); margin: 18px 0 8px; }
  #review-summary .rs-overall { break-inside: avoid; }
  #review-summary .rs-overall-head { display: flex; align-items: center; gap: 12px; }
  #review-summary .rs-summary { font-size: 14px; line-height: 1.5; margin: 8px 0 0; }
  #review-summary .rs-coherence { font-size: 13px; line-height: 1.5; margin: 8px 0 0; color: var(--muted); }
  #review-summary .rs-next { break-inside: avoid; }
  #review-summary .rs-next-list { list-style: none; margin: 0; padding: 0; }
  #review-summary .rs-next-list li { display: flex; gap: 8px; align-items: baseline; padding: 5px 0; }
  #review-summary .rs-chip { flex: none; font-family: var(--mono); font-size: 10px; font-weight: 600; color: #fff;
    background: var(--chip, var(--ink)); padding: 2px 8px; border-radius: 999px; }
  #review-summary .rs-edit { font-size: 13.5px; line-height: 1.45; }
  #review-summary .rs-risks ul { margin: 0; padding-left: 18px; font-size: 13.5px; line-height: 1.5; }
  #review-summary .rs-crossflag { border-left: 3px solid var(--amber); padding: 3px 0 3px 12px; margin: 8px 0; break-inside: avoid; }
  #review-summary .rs-cross-cells { font-family: var(--mono); font-size: 10px; letter-spacing: 0.05em; text-transform: uppercase; color: var(--amber); }
  #review-summary .rs-cross-why { color: var(--muted); font-size: 12.5px; }
  #review-summary .rs-cell { break-inside: avoid; border-top: 1px solid var(--line); padding: 10px 0; }
  #review-summary .rs-cell-head { display: flex; align-items: center; gap: 10px; justify-content: space-between; }
  #review-summary .rs-cell-title { font-family: var(--serif); font-weight: 600; font-size: 15px; }
  #review-summary .rs-answer-label,
  #review-summary .rs-fb-label { display: inline-block; font-family: var(--mono); font-size: 9px; letter-spacing: 0.09em;
    text-transform: uppercase; margin: 6px 0 3px; }
  #review-summary .rs-answer-label { color: var(--muted); }
  /* the participant's words: a boxed transcription, clearly their input */
  #review-summary .rs-answer { font-size: 13.5px; line-height: 1.5; white-space: pre-wrap; color: var(--ink);
    background: #f4f1ea; border: 1px solid var(--line); border-radius: 4px; padding: 7px 10px; }
  #review-summary .rs-answer.empty { color: var(--grey); font-style: italic; background: transparent; border-style: dashed; }
  /* the coach's feedback: an accented block with a label, distinct from the answer */
  #review-summary .rs-fb { border-left: 3px solid var(--purpose); padding-left: 11px; margin-top: 9px; }
  #review-summary .rs-fb-label { color: var(--purpose); margin-top: 0; }
  #review-summary .rs-fb-gap { font-size: 13px; color: var(--ink); margin: 0; }
  #review-summary .rs-fb-q { font-size: 13px; color: var(--muted); margin: 3px 0 0; font-style: italic; }
  #review-summary .rs-foot { display: flex; justify-content: space-between; gap: 16px; flex-wrap: wrap;
    border-top: 1.2px solid var(--ink); margin-top: 18px; padding-top: 10px; font-size: 10.5px; color: var(--muted); }
}

/* ---- sign-up modal + access walls (free tier) ---- */
.overlay { position: fixed; inset: 0; background: rgba(11,31,58,0.55); display: flex;
  align-items: center; justify-content: center; padding: 24px; z-index: 100; }
.modal { background: var(--card); border: 1.2px solid var(--ink); border-radius: var(--radius);
  padding: 28px; max-width: 440px; width: 100%; box-shadow: 0 30px 80px rgba(11,31,58,0.35); }
.modal h2 { font-family: var(--serif); font-weight: 600; font-size: 24px; margin: 0 0 6px; }
.modal .modal-sub { font-family: var(--serif); font-size: 16px; color: var(--muted); margin: 0 0 18px; line-height: 1.45; }
.modal .modal-label { display: block; font-family: var(--mono); font-size: 11px; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--ink); margin: 0 0 6px; }
.modal input[type="email"], .modal input[type="text"] { margin-bottom: 12px; }
.modal .modal-consent { display: flex; gap: 9px; align-items: flex-start; font-size: 14px;
  color: var(--ink); margin: 4px 0 16px; line-height: 1.4; cursor: pointer; }
.modal .modal-consent input { margin-top: 3px; flex: none; }
.modal button.primary { width: 100%; }
.modal .modal-fine { font-size: 12.5px; color: var(--muted); margin: 14px 0 0; text-align: center; }

/* email/text inputs in the modal fill the width (the base rule missed type=email) */
.modal input[type="email"], .modal input[type="text"] { width: 100%; }
