/* Ported verbatim from the vetted Lumeva funnel prototype, plus a small block for the in-funnel
   booking picker. Brand colours (--navy / --gold) are overridden at runtime from the client config. */
:root{
  --navy:#16294d; --navy-dk:#0f1d38; --ink:#1f2937; --soft:#4b5563; --muted:#6b7280; --line:#e7e6e1;
  --bg:#fbfaf7; --card:#ffffff; --gold:#b8862f; --gold-lt:#f3ead6;
  --red:#b4402f; --amber:#b7791f; --green:#2f7a4f;
}
*{box-sizing:border-box}
body{margin:0;font:17px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
.serif{font-family:Georgia,"Times New Roman",serif}
.wrap{max-width:760px;margin:0 auto;padding:0 22px}
h1{font-family:Georgia,serif;font-size:clamp(28px,4.4vw,40px);line-height:1.15;letter-spacing:-.01em;color:var(--navy);margin:0 0 .4em}
h2{font-family:Georgia,serif;font-size:23px;color:var(--navy);margin:0 0 .5em}
p{margin:0 0 1em}
.muted{color:var(--muted)}
.btn{display:inline-block;background:var(--navy);color:#fff;text-decoration:none;font-weight:600;padding:14px 24px;border-radius:10px;border:0;cursor:pointer;font-size:16px;transition:background .15s,transform .05s}
.btn:hover{background:var(--navy-dk)} .btn:active{transform:translateY(1px)}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-size:12px;font-weight:700;color:var(--gold);margin-bottom:14px}
header{background:#fff;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;height:60px;gap:12px}
.avatar{width:32px;height:32px;border-radius:99px;background:var(--navy);color:#fff;font-family:Georgia,serif;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid var(--gold)}
.brand{font-family:Georgia,serif;font-weight:700;color:var(--navy);font-size:18px}
.brandlink{display:flex;align-items:center;gap:12px;text-decoration:none}
.brandlink[href]:hover .brand{text-decoration:underline}
.poweredby{margin-top:18px;padding-top:12px;border-top:1px solid var(--line);text-align:right}
.poweredby a{font-size:12px;color:var(--muted);text-decoration:none}
.poweredby a:hover{color:var(--navy);text-decoration:underline}
.poweredby:empty{display:none}
footer a{color:var(--muted)}
main{padding:0}
.card{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:34px}

/* --- split-hero landing: value/credibility (left, swaps to live heatmap) + live check (right) --- */
.wrap--wide{max-width:1120px}
.hero{padding:56px 0 72px}
.split{display:grid;gap:30px;align-items:center;grid-template-columns:1fr}
@media(min-width:940px){.split{grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:52px;align-items:center}}
.hero__value{padding-top:2px;max-width:540px}
.hero__value h1{font-size:clamp(28px,2.7vw,35px);line-height:1.17;letter-spacing:-.015em;margin:.06em 0 .5em}
.hero__sub{color:var(--soft);font-size:16.5px;line-height:1.62;margin:0 0 .2em;max-width:46ch}
.trustpoints{list-style:none;margin:24px 0 0;padding:0;display:grid;gap:13px}
.trustpoints li{display:flex;align-items:flex-start;gap:11px;font-size:15px;color:var(--soft)}
.trustpoints li::before{content:"\2713";color:var(--gold);font-weight:800;font-size:15px;line-height:1.5;flex:0 0 auto}
.panel{background:var(--card);border:1px solid var(--line);border-radius:18px;padding:32px 34px;box-shadow:0 1px 2px rgba(22,41,77,.04),0 12px 30px -18px rgba(22,41,77,.18)}
.assess__head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:18px}
.assess__title{font-family:Georgia,serif;font-weight:700;color:var(--navy);font-size:18px;line-height:1.2}
.assess__step{font-size:13px;white-space:nowrap}
.assess .q{font-size:20px;margin:16px 0 20px;line-height:1.3}
.assess .opt{padding:16px 18px;margin:11px 0}
/* live heatmap panel (left, revealed) */
.livewrap{padding:22px}
.livewrap__head{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:14px}
.livewrap__head h2{font-family:Georgia,serif;font-size:19px;color:var(--navy);margin:0}
.live-prog{font-size:13px;color:var(--muted);white-space:nowrap}
.live-grid{display:grid;gap:8px}
.live-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:10px;padding:11px 13px;background:#fff;transition:border-color .15s,background .15s}
.live-row.set{background:#fefdfa;border-color:#eadfc6}
.live-row .lr-name{font-size:14px;color:var(--soft)}
.live-row .lr-tag{font-size:12px;font-weight:700;padding:3px 9px;border-radius:99px;color:var(--muted);background:#f1efe9}
.live-row .lr-tag.red{background:#f6e7e3;color:var(--red)} .live-row .lr-tag.amber{background:#f6edd8;color:var(--amber)} .live-row .lr-tag.green{background:#e4f0e9;color:var(--green)}
.livewrap__foot{font-size:13px;color:var(--muted);margin:14px 0 0}
.results{padding:34px 0 72px}

/* --- downloadable SOC 2 Readiness Snapshot (the deliverable) --- */
.snapdoc{border:1px solid var(--line);border-radius:14px;background:#fff;padding:26px 28px;margin:26px 0 0}
.snapdoc__head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:16px}
.snapdoc__brand{font-family:Georgia,serif;font-weight:700;color:var(--navy);font-size:15px}
.snapdoc__title{font-family:Georgia,serif;color:var(--navy);font-size:22px;margin:3px 0}
.snapdoc__sub{font-size:13px;color:var(--muted)}
.snapdoc__disc{font-size:13px;color:var(--muted);margin:0 0 16px}
.snap-rows{display:grid;gap:13px}
.snap-row{border:1px solid var(--line);border-radius:10px;padding:14px 16px;background:#fff}
.snap-row__top{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:7px}
.sr-name{font-weight:600;color:var(--navy);font-size:15px}
.sr-cc{font-size:11px;font-weight:700;letter-spacing:.03em;color:var(--muted);background:#f1efe9;border-radius:99px;padding:2px 9px}
.sr-tag{margin-left:auto}
.sr-mean{font-size:14.5px;color:var(--soft);margin:0}
.sr-step{font-size:14px;color:var(--ink);margin:8px 0 0}
.sr-step b{color:var(--navy)}
.snapdoc__foot{font-size:13px;color:var(--muted);border-top:1px solid var(--line);margin:18px 0 0;padding-top:14px}
.dl-row{margin:16px 0 0}
.gatebox{background:#fff;border:1px solid var(--line);border-left:4px solid var(--gold);border-radius:12px;padding:24px 26px;margin:28px 0 0}
.gatebox .eyebrow{margin-bottom:8px}
.emailed{font-size:14px;color:var(--green);font-weight:600}
@media print{
  header,footer,.ctabox,.dl-row,#r-eyebrow,#r-narrative,#r-summary,#r-footnote,#s-results h1{display:none !important}
  body *{visibility:hidden}
  #snapshot-doc,#snapshot-doc *{visibility:visible}
  #snapshot-doc{position:absolute;left:0;top:0;width:100%;border:0;border-radius:0;box-shadow:none;padding:0;margin:0}
  .snap-row{break-inside:avoid}
  @page{margin:16mm}
}
.center{text-align:center}
.trust{font-size:14px;color:var(--muted);margin-top:16px}
.cred{font-size:15px;color:var(--soft);border-left:3px solid var(--gold-lt);padding-left:14px;margin:18px 0 0}
.prog{height:6px;background:var(--line);border-radius:99px;overflow:hidden;margin-bottom:8px}
.prog>i{display:block;height:100%;background:var(--gold);width:0;transition:width .25s}
.step-meta{font-size:13px;color:var(--muted);margin-bottom:20px}
.q{font-size:21px;font-weight:600;color:var(--navy);margin:6px 0 20px;font-family:Georgia,serif}
.opt{display:flex;align-items:center;gap:12px;width:100%;text-align:left;background:#fff;border:1px solid var(--line);border-radius:12px;padding:15px 16px;margin:10px 0;font-size:16px;cursor:pointer;transition:border-color .12s,background .12s}
.opt:hover{border-color:var(--gold);background:#fefdfa}
.dot{width:11px;height:11px;border-radius:99px;flex:0 0 auto;background:#d6d3c9}
.dot.red{background:var(--red)} .dot.amber{background:var(--amber)} .dot.green{background:var(--green)}
.row{display:flex;justify-content:space-between;align-items:center;margin-top:16px}
.btn-ghost{background:transparent;color:var(--navy);border:1px solid var(--line);font-weight:500;padding:12px 18px;border-radius:10px;cursor:pointer;font-size:15px}
label.f{display:block;font-size:14px;font-weight:600;margin:14px 0 6px;color:var(--navy)}
input.f{width:100%;padding:12px 14px;border:1px solid var(--line);border-radius:10px;font-size:16px;font-family:inherit;background:#fff;min-height:42px}
input.f:focus{outline:2px solid var(--gold-lt);border-color:var(--gold)}
.band{display:inline-block;padding:6px 14px;border-radius:99px;font-weight:700;font-size:14px}
.band.high{background:#f6e7e3;color:var(--red)} .band.part{background:#f6edd8;color:var(--amber)} .band.ready{background:#e4f0e9;color:var(--green)}
.heat{display:grid;gap:8px;margin:20px 0}
.hrow{display:flex;align-items:center;justify-content:space-between;border:1px solid var(--line);border-radius:10px;padding:12px 14px;background:#fff}
.tag{font-size:12px;font-weight:700;padding:3px 9px;border-radius:99px}
.tag.red{background:#f6e7e3;color:var(--red)} .tag.amber{background:#f6edd8;color:var(--amber)} .tag.green{background:#e4f0e9;color:var(--green)}
.ctabox{background:var(--gold-lt);border:1px solid #e7d6ad;border-radius:14px;padding:24px;margin-top:24px}
.hidden{display:none}
footer{padding:32px 0;color:var(--muted);font-size:13px}

/* --- in-funnel booking picker (new; matches the prototype's visual language) --- */
.book-days{display:grid;gap:14px;margin:6px 0 4px}
.book-day{border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:#fff}
.book-day h3{font-family:Georgia,serif;font-size:15px;color:var(--navy);margin:0 0 10px}
.slots{display:flex;flex-wrap:wrap;gap:8px}
.slot{background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px 14px;font-size:15px;cursor:pointer;color:var(--navy);font-weight:600;transition:border-color .12s,background .12s}
.slot:hover{border-color:var(--gold);background:#fefdfa}
.slot[disabled]{opacity:.5;cursor:default}
.book-note{font-size:13px;color:var(--muted);margin:8px 0 0}
.booked-ok{background:#e4f0e9;border:1px solid #bfe0cd;border-radius:12px;padding:16px 18px;color:var(--green);font-weight:600}
.spin{display:inline-block;font-size:14px;color:var(--muted)}
.linkish{color:var(--navy);text-decoration:underline;background:none;border:0;cursor:pointer;font-size:15px;padding:0;font-family:inherit}
