/* ===================================================================
   THE CLOSER LAB: shared design system (Archivo + Newsreader, ice accent)
   Reference build by Sarah. Drives both /analyse-my-call and /results.
   To recolor the whole site, swap the 3 --accent lines in :root.
   =================================================================== */
:root{
  /* surfaces */
  --bg:        #0d0c0b;
  --bg-grad-1: #161412;
  --bg-grad-2: #0b0a09;
  --card:      #131210;
  --card-top:  #1a1815;

  /* ink */
  --ink:       #f3efe8;
  --ink-soft:  rgba(243,239,232,0.66);
  --ink-faint: rgba(243,239,232,0.40);
  --ink-ghost: rgba(243,239,232,0.26);
  --line:      rgba(243,239,232,0.11);
  --line-soft: rgba(243,239,232,0.07);

  /* accent: ice blue (swap as a set to recolor)
       amber : #e3a94b / #c4913a / rgba(227,169,75,0.16)
       ember : #d7593a / #b8472c / rgba(215,89,58,0.16)
       ice   : #7fa9c9 / #5f87a6 / rgba(127,169,201,0.18)  ← active */
  --accent:     #7fa9c9;
  --accent-deep:#5f87a6;
  --accent-glow:rgba(127,169,201,0.18);

  /* form fields */
  --field:     #1c1a17;
  --field-line:rgba(243,239,232,0.13);

  /* type */
  --sans: "Archivo", "Helvetica Neue", Helvetica, Arial, sans-serif;
  --serif:"Newsreader", Georgia, "Times New Roman", serif;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
body{
  font-family:var(--sans);
  background:var(--bg);
  color:var(--ink);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  min-height:100vh;
  position:relative;
  overflow-x:hidden;
}

/* layered atmosphere */
body::before{
  content:""; position:fixed; inset:0; z-index:0; pointer-events:none;
  background:
    radial-gradient(125% 125% at 50% 35%, transparent 56%, rgba(0,0,0,0.55) 100%),
    radial-gradient(120% 80% at 50% -10%, var(--bg-grad-1) 0%, transparent 55%),
    radial-gradient(90% 70% at 50% 120%, var(--bg-grad-2) 0%, transparent 60%),
    var(--bg);
}
.spotlight{
  position:fixed; top:-12vh; left:50%; transform:translateX(-50%);
  width:min(1100px,130vw); height:520px; z-index:0; pointer-events:none;
  background:radial-gradient(58% 60% at 50% 28%, rgba(243,239,232,0.045) 0%, transparent 66%);
  filter:blur(10px);
}
body::after{
  content:""; position:fixed; inset:0; z-index:1; pointer-events:none; opacity:0.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

.wrap{ position:relative; z-index:2; }

/* ── header ─────────────────────────────────────────── */
header.top{
  display:flex; flex-direction:column; align-items:center; gap:0;
  padding:38px 24px 0;
}
.wordmark{
  font-family:var(--serif); font-weight:400; font-size:30px;
  letter-spacing:0.01em; color:var(--ink); text-decoration:none;
}
.wordmark .dot{ color:var(--accent); }
.rule{
  width:100%; max-width:760px; height:1px;
  background:linear-gradient(90deg,transparent,var(--line) 18%,var(--line) 82%,transparent);
  margin-top:30px;
}

/* ── layout + state machine ─────────────────────────── */
main{ max-width:760px; margin:0 auto; padding:64px 28px 90px; }
.col{ max-width:760px; margin:0 auto; padding:0 28px; }
.state{ display:none; }
.state.active{ display:block; animation:fadeUp .45s ease both; }
@keyframes fadeUp{ from{opacity:0; transform:translateY(12px);} to{opacity:1; transform:translateY(0);} }

/* ── eyebrow / headline / sub ───────────────────────── */
.eyebrow{
  display:flex; align-items:center; gap:13px;
  font-size:12px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:30px;
}
.eyebrow::before{ content:""; width:26px; height:1px; background:var(--accent); display:block; }

h1{
  font-family:var(--sans); font-weight:800;
  font-size:clamp(42px,7.2vw,68px); line-height:1.02; letter-spacing:-0.025em;
  color:var(--ink); max-width:14ch;
}
h1 .em{ font-family:var(--sans); font-weight:800; font-style:normal; letter-spacing:-0.025em; color:var(--accent); }

.sub{
  margin-top:26px; font-size:clamp(17px,2.1vw,20px); line-height:1.55;
  color:var(--ink-soft); max-width:54ch;
}
.sub b{ color:var(--ink); font-weight:600; }

/* ── the three promises ─────────────────────────────── */
.promises{
  margin-top:52px; display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line-soft); border-top:1px solid var(--line); border-bottom:1px solid var(--line);
}
.promise{ background:var(--bg); padding:24px 22px 26px; display:flex; flex-direction:column; gap:11px; }
.promise .num{ font-family:var(--serif); font-style:italic; font-size:22px; color:var(--accent); line-height:1; }
.promise .lbl{ font-size:14.5px; line-height:1.42; color:var(--ink-soft); max-width:22ch; }
.promise .lbl b{ color:var(--ink); font-weight:600; }

/* ── form card ──────────────────────────────────────── */
.card{
  margin-top:46px;
  background:linear-gradient(180deg,var(--card-top),var(--card));
  border:1px solid var(--line); border-radius:10px; padding:38px 38px 34px;
  box-shadow:0 1px 0 rgba(243,239,232,0.04) inset, 0 30px 60px -30px rgba(0,0,0,0.7);
}
.field-group{ margin-bottom:24px; }
.field-group:last-of-type{ margin-bottom:0; }
label{
  display:block; font-size:11.5px; font-weight:600; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--ink-faint); margin-bottom:11px;
}
input[type=email], textarea{
  width:100%; font-family:var(--sans); font-size:16px; color:var(--ink);
  background:var(--field); border:1px solid var(--field-line); border-radius:7px;
  padding:15px 16px; transition:border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
input[type=email]{ height:52px; }
textarea{ min-height:152px; resize:vertical; line-height:1.5; }
::placeholder{ color:var(--ink-ghost); font-style:italic; }
input[type=email]:focus, textarea:focus{
  outline:none; border-color:var(--accent); background:#211e1a; box-shadow:0 0 0 3px var(--accent-glow);
}
.help{ margin-top:10px; font-size:13px; line-height:1.5; color:var(--ink-faint); }
.help.tiny{ color:var(--ink-ghost); margin-top:4px; }
.email-error{ display:none; margin-top:8px; font-size:12.5px; color:#d7593a; }
.email-error.visible{ display:block; }

/* CTA: accent-fill, warms to bone on hover */
.cta{
  margin-top:28px; width:100%; height:60px; border:none; cursor:pointer;
  font-family:var(--sans); font-size:16px; font-weight:700; letter-spacing:0.005em;
  border-radius:8px; display:flex; align-items:center; justify-content:center; gap:12px;
  background:var(--accent); color:#11161a;
  transition:transform .16s ease, box-shadow .2s ease, background .2s ease, color .2s ease, opacity .2s ease;
  box-shadow:0 14px 34px -12px var(--accent-glow);
}
.cta .arrow{ transition:transform .2s ease; display:inline-block; }
.cta:not(:disabled):hover{ background:var(--ink); color:#11161a; box-shadow:0 14px 34px -10px rgba(243,239,232,0.28); transform:translateY(-1px); }
.cta:not(:disabled):hover .arrow{ transform:translateX(5px); }
.cta:active{ transform:translateY(0); }
.cta:disabled{ background:var(--field); color:var(--ink-ghost); cursor:not-allowed; box-shadow:none; }

.reassure{ margin-top:20px; display:flex; flex-wrap:wrap; gap:7px 18px; font-size:12.5px; color:var(--ink-faint); }
.reassure span{ display:flex; align-items:center; gap:8px; }
.reassure span::before{ content:""; width:4px; height:4px; border-radius:50%; background:var(--accent); display:block; opacity:.8; }

/* ── footer trust line ──────────────────────────────── */
footer{ max-width:760px; margin:0 auto; padding:0 28px 70px; text-align:center; }
.trust{
  font-size:11.5px; font-weight:500; letter-spacing:0.13em; text-transform:uppercase;
  color:var(--ink-ghost); display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:9px 14px;
}
.trust .sep{ width:3px; height:3px; border-radius:50%; background:var(--ink-ghost); display:inline-block; }

/* ── loading + error states ─────────────────────────── */
.center-state{ text-align:center; padding:120px 0; }
.loading-line{ font-size:12px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); }
.loading-bar{ width:180px; height:1.5px; background:var(--line); margin:20px auto 0; overflow:hidden; position:relative; }
.loading-bar::after{ content:""; position:absolute; left:-100%; top:0; width:100%; height:100%; background:var(--accent); animation:scan 1.4s ease-in-out infinite; }
@keyframes scan{ from{left:-100%;} to{left:100%;} }
.error-msg{ font-family:var(--serif); font-size:18px; line-height:1.6; color:var(--ink-soft); margin:0 auto 26px; max-width:46ch; }
.link-btn{ background:none; border:none; cursor:pointer; font-family:var(--sans); font-size:13px; letter-spacing:0.04em; color:var(--accent); border-bottom:1px solid transparent; transition:border-color .2s; }
.link-btn:hover{ border-bottom-color:var(--accent); }

/* ===================================================================
   RESULTS PAGE COMPONENTS (same system)
   =================================================================== */
.step-label{
  display:flex; align-items:center; gap:13px;
  font-size:12px; font-weight:600; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--accent); margin-bottom:8px;
}
.step-label::before{ content:""; width:26px; height:1px; background:var(--accent); display:block; }

.grade-block{ display:flex; align-items:center; gap:26px; padding:26px 0 30px; border-bottom:1px solid var(--line); margin-bottom:34px; }
.grade-letter{ font-family:var(--sans); font-weight:800; font-size:76px; line-height:1; letter-spacing:-0.04em; color:var(--accent); min-width:58px; }
.grade-meta{ display:flex; flex-direction:column; gap:5px; }
.grade-label{ font-size:11.5px; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-faint); }
.grade-caption{ font-family:var(--serif); font-style:italic; font-size:18px; color:var(--ink-soft); line-height:1.5; }

.pattern-block{ padding-bottom:30px; border-bottom:1px solid var(--line); margin-bottom:30px; }
.pattern-badge{
  display:inline-block; font-size:11px; font-weight:700; letter-spacing:0.14em; text-transform:uppercase;
  color:var(--accent); background:var(--accent-glow); border:1px solid rgba(127,169,201,0.4);
  border-radius:999px; padding:6px 14px; margin-bottom:16px;
}
.pattern-block h3{ font-family:var(--sans); font-weight:700; font-size:23px; letter-spacing:-0.015em; color:var(--ink); margin-bottom:12px; }
.pattern-block p{ font-size:17px; line-height:1.7; color:var(--ink-soft); }

.mismatch-block, .fix-block{ border-left:2px solid var(--accent); padding:16px 22px; margin-bottom:24px; background:rgba(243,239,232,0.02); border-radius:0 8px 8px 0; }
.mismatch-label, .needed-label, .fix-label, .verdict-label, .turning-reframe-label{
  display:block; font-size:11.5px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); margin-bottom:10px;
}
.mismatch-block p, .fix-block p{ font-size:17px; line-height:1.7; color:var(--ink); }

.needed-block, .verdict-block{
  background:linear-gradient(180deg,var(--card-top),var(--card)); border:1px solid var(--line);
  border-radius:10px; padding:22px 26px; margin-bottom:38px;
  box-shadow:0 30px 60px -34px rgba(0,0,0,0.7);
}
.needed-block p{ font-size:17px; line-height:1.7; color:var(--ink); font-weight:500; }
.verdict-text{ font-family:var(--serif); font-style:italic; font-size:20px; line-height:1.5; color:var(--ink); }

.findings-label, .turning-label{ display:block; font-size:11.5px; font-weight:700; letter-spacing:0.2em; text-transform:uppercase; color:var(--ink-faint); margin-bottom:16px; }
.findings{ list-style:none; margin-bottom:42px; }
.findings li{ display:grid; grid-template-columns:16px 1fr; gap:14px; align-items:baseline; padding:13px 0; font-size:17px; color:var(--ink); line-height:1.6; border-bottom:1px solid var(--line-soft); }
.findings li:first-child{ border-top:1px solid var(--line-soft); }
.findings li::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--accent); margin-top:9px; }

.turning-point{ margin-bottom:48px; }
.turning-quote{ font-family:var(--serif); font-style:italic; font-size:18px; line-height:1.6; color:var(--ink-soft); border-left:2px solid var(--line); padding-left:18px; margin:0 0 20px; }
.turning-reframe{ background:rgba(127,169,201,0.06); border-left:2px solid var(--accent); padding:16px 20px; border-radius:0 8px 8px 0; }
.turning-reframe-text{ font-size:17px; line-height:1.6; color:var(--ink); }

/* calendar / book-a-call */
.calendar-section{ padding:48px 0 0; border-top:1px solid var(--line); }
.calendar-section h3{ font-family:var(--sans); font-weight:700; font-size:clamp(22px,3.5vw,30px); letter-spacing:-0.02em; color:var(--ink); margin-bottom:12px; }
.calendar-section p{ font-size:16px; line-height:1.65; color:var(--ink-soft); margin-bottom:24px; }
.btn-link{
  display:inline-flex; align-items:center; gap:10px; font-family:var(--sans); font-weight:700; font-size:15px;
  color:#11161a; background:var(--accent); border-radius:8px; padding:16px 30px; text-decoration:none;
  box-shadow:0 14px 34px -12px var(--accent-glow); transition:transform .16s ease, box-shadow .2s, background .2s;
}
.btn-link:hover{ background:var(--ink); transform:translateY(-1px); box-shadow:0 14px 34px -10px rgba(243,239,232,0.28); }

.retry{ display:inline-block; margin-top:18px; font-size:13px; letter-spacing:0.04em; color:var(--ink-faint); cursor:pointer; text-decoration:none; border-bottom:1px solid transparent; transition:color .2s, border-color .2s; }
.retry:hover{ color:var(--ink); border-bottom-color:var(--ink); }

/* method / founder block */
.method-section{ padding:52px 0; border-top:1px solid var(--line); margin-top:48px; }
.method-label{ display:block; font-size:12px; font-weight:600; letter-spacing:0.2em; text-transform:uppercase; color:var(--accent); margin-bottom:14px; }
.method-title{ font-family:var(--sans); font-weight:800; font-size:clamp(24px,4vw,34px); letter-spacing:-0.02em; color:var(--ink); margin-bottom:16px; }
.method-body{ font-size:16px; line-height:1.7; color:var(--ink-soft); margin-bottom:36px; max-width:60ch; }
.method-stats{ display:grid; grid-template-columns:repeat(3,1fr); border-top:1px solid var(--line); border-bottom:1px solid var(--line); margin-bottom:28px; }
.method-stat{ padding:24px 16px; text-align:center; border-right:1px solid var(--line); }
.method-stat:last-child{ border-right:none; }
.method-stat-num{ display:block; font-family:var(--sans); font-weight:800; font-size:clamp(26px,4vw,34px); letter-spacing:-0.03em; color:var(--ink); }
.method-stat-label{ display:block; margin-top:6px; font-size:10.5px; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-faint); }
.method-foot{ font-family:var(--serif); font-style:italic; font-size:15px; line-height:1.6; color:var(--ink-soft); max-width:60ch; }

/* ── responsive ─────────────────────────────────────── */
@media (max-width:680px){
  main{ padding:48px 22px 64px; }
  .col{ padding:0 22px; }
  .promises{ grid-template-columns:1fr; background:transparent; border-bottom:none; }
  .promise{ padding:20px 4px; border-bottom:1px solid var(--line-soft); }
  .promise:last-child{ border-bottom:none; }
  .card{ padding:28px 22px 26px; border-radius:9px; }
  .cta{ height:56px; }
  .grade-letter{ font-size:60px; }
  .method-stats{ grid-template-columns:1fr; }
  .method-stat{ border-right:none; border-bottom:1px solid var(--line); }
  .method-stat:last-child{ border-bottom:none; }
}
