/* Soul Synthesis – the spectrum almanac.
   Seventies occult-paperback warmth: aged cream paper, deep navy ink, and a
   six-colour spectrum where each colour belongs to one system. Discipline:
   paper + ink are the ground; the spectrum appears only in the mark, the
   system keys, and one moment per band. Quiz band is the ink-navy night room. */

:root {
  --paper: #f2e9d4;
  --paper-deep: #eadfc2;
  --ink: #232c47;          /* deep navy: ground ink AND astrology's band */
  --ink-soft: #46507a;
  --muted: #5b5843;
  --burnt: #c2571b;        /* eyebrow/label accent on paper */
  --sys-astro: #232c47;
  --sys-hd: #35c8c4;
  --sys-gk: #d944c0;
  --sys-enn: #e76b9c;
  --sys-num: #e8722c;
  --sys-depth: #eda53c;
  --amber: #eda53c;        /* action colour inside the night room */
  --text-on-ink: #f2e9d4;
  --serif: 'Young Serif', Georgia, serif;
  --sans: 'Inter', -apple-system, system-ui, sans-serif;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

body {
  font-family: var(--sans);
  color: var(--ink);
  background: var(--paper);
  line-height: 1.6;
  font-size: 17px;
}

h1, h2, h3, legend, .wordmark, .price { font-family: var(--serif); font-weight: 400; }

a { color: inherit; }

/* ---------- header ---------- */
.top {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 1.2rem 6vw;
}
.wordmark { font-size: 1.2rem; letter-spacing: 0.03em; }
.top-promise { font-size: 0.8rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--burnt); font-weight: 500; }

/* ---------- hero ---------- */
.hero { padding: 7vh 6vw 11vh; text-align: center; }
.hero-inner { max-width: 780px; margin: 0 auto; }
.hero-mark { margin: 0 auto 2.2rem; display: block; }
.eyebrow { letter-spacing: 0.22em; text-transform: uppercase; font-size: 0.78rem; color: var(--burnt); font-weight: 500; margin-bottom: 1.3rem; }
h1 { font-size: clamp(2.3rem, 5.6vw, 3.9rem); line-height: 1.12; margin-bottom: 1.6rem; }
.lede { font-size: 1.12rem; max-width: 560px; margin: 0 auto 2rem; color: var(--ink-soft); }
.lede em { font-family: var(--serif); font-style: normal; }

.price-line { margin: 1.4rem 0; }
.price { font-size: 2.1rem; color: var(--ink); }
.price-note { color: var(--muted); font-size: 0.95rem; margin-left: 0.5rem; }

.tiny-trust { font-size: 0.8rem; color: var(--muted); margin-top: 1.1rem; }

/* ---------- buttons ---------- */
.btn {
  display: inline-block; border: none; cursor: pointer;
  font-family: var(--sans); font-weight: 600; font-size: 1rem;
  padding: 0.95rem 2.4rem; border-radius: 2px;
  text-decoration: none; transition: transform .12s ease, box-shadow .12s ease;
}
.btn-primary { background: var(--ink); color: var(--text-on-ink); }
.btn-primary:hover { transform: translateY(-1px); box-shadow: 0 6px 24px rgba(35,44,71,.28); }
.band-ink .btn-primary { background: var(--amber); color: var(--ink); }
.btn-big { font-size: 1.1rem; padding: 1.1rem 3rem; }

/* ---------- bands ---------- */
.band { padding: 10vh 6vw; }
.band-ink { background: var(--ink); color: var(--text-on-ink); }
.band-ink h2, .band-ink h3, .band-ink legend { color: var(--text-on-ink); }
.band-paper { background: var(--paper-deep); }
.narrow { max-width: 640px; margin: 0 auto; }
.wide { max-width: 1020px; margin: 0 auto; }
.centered { text-align: center; }
.narrow-p { max-width: 560px; margin: 0.8rem auto 0; }

h2 { font-size: clamp(1.65rem, 3.4vw, 2.3rem); line-height: 1.22; margin-bottom: 1.4rem; }
.band-ink p { color: var(--text-on-ink); margin-bottom: 1.1rem; }
.standfirst { font-family: var(--serif); font-size: 1.28rem; color: var(--amber) !important; margin-top: 1.6rem; }

/* ---------- systems grid: six cards, each keyed to its band colour ---------- */
.systems {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1.4rem; margin-top: 2.4rem;
}
@media (max-width: 720px) { .systems { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 460px) { .systems { grid-template-columns: 1fr; } }
.system { border-top: 4px solid var(--ink); padding-top: 1rem; }
.system.sys-astro { border-top-color: var(--sys-astro); }
.system.sys-hd    { border-top-color: var(--sys-hd); }
.system.sys-gk    { border-top-color: var(--sys-gk); }
.system.sys-num   { border-top-color: var(--sys-num); }
.system.sys-enn   { border-top-color: var(--sys-enn); }
.system.sys-depth { border-top-color: var(--sys-depth); }
.system h3 { font-size: 1.12rem; margin-bottom: 0.5rem; }
.system p { font-size: 0.92rem; color: var(--ink-soft); }
.synthesis-note { margin-top: 4rem; text-align: center; }
.synthesis-note h3 { font-size: 1.35rem; margin-bottom: 0.8rem; color: var(--burnt); }

/* ---------- steps ---------- */
.steps { list-style: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 2rem; margin-top: 2.5rem; }
.steps li { text-align: center; }
.step-num {
  display: inline-grid; place-items: center; width: 2.6rem; height: 2.6rem;
  border: 2px solid var(--burnt); border-radius: 50%;
  font-family: var(--serif); font-size: 1.15rem; color: var(--burnt); margin-bottom: 0.9rem;
}
.steps h3 { margin-bottom: 0.4rem; }
.steps p { font-size: 0.95rem; color: var(--ink-soft); }

/* ---------- quiz: the night room ---------- */
.quiz-shell { text-align: left; }
.quiz-sub { margin-bottom: 2rem; }
fieldset { border: none; }
legend { font-size: 1.3rem; margin-bottom: 1.4rem; color: var(--amber); }
label { display: block; margin-bottom: 1.2rem; font-weight: 500; font-size: 0.95rem; }
label .soft { font-weight: 400; }
.soft { color: rgba(242,233,212,.62); font-size: 0.88rem; }
.band-paper .soft, .band .soft { color: var(--muted); }

input[type="date"], input[type="time"], input[type="text"], input[type="email"] {
  display: block; width: 100%; margin-top: 0.4rem;
  padding: 0.8rem 1rem; font-size: 1rem; font-family: var(--sans);
  background: rgba(242,233,212,.07); color: #fff;
  border: 1px solid rgba(242,233,212,.3); border-radius: 2px;
}
input:focus { outline: 2px solid var(--amber); outline-offset: 1px; }
.check { display: flex; gap: 0.5rem; align-items: center; font-weight: 400; font-size: 0.9rem; }
.check input { width: auto; }

.likert { margin-bottom: 1.6rem; }
.likert p { margin-bottom: 0.5rem; font-weight: 500; }
.likert-scale { display: flex; gap: 0.4rem; }
.likert-scale label {
  flex: 1; text-align: center; margin: 0; font-weight: 400;
  border: 1px solid rgba(242,233,212,.3); border-radius: 2px;
  padding: 0.55rem 0; cursor: pointer; font-size: 0.95rem;
  transition: background .1s ease;
}
.likert-scale input { position: absolute; opacity: 0; }
.likert-scale label:has(input:checked) { background: var(--amber); color: var(--ink); border-color: var(--amber); font-weight: 600; }
.likert-ends { display: flex; justify-content: space-between; font-size: 0.75rem; color: rgba(242,233,212,.55); margin-top: 0.3rem; }

.qstep .btn { margin-top: 0.8rem; }
.form-error { color: #f0a68e; font-size: 0.9rem; margin-top: 0.8rem; }

/* ---------- insight ---------- */
.insight-card {
  background: rgba(242,233,212,.06); border: 1px solid var(--amber);
  padding: 1.8rem; border-radius: 2px; margin-bottom: 1.2rem;
  font-family: var(--serif); font-size: 1.08rem; line-height: 1.75;
}
.insight-card .insight-heads { font-family: var(--sans); font-size: 0.8rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--amber); margin-bottom: 0.8rem; font-weight: 500; }
.insight-note { font-size: 0.95rem; }
.checkout-box { text-align: center; margin-top: 2rem; padding-top: 1.6rem; border-top: 1px solid rgba(242,233,212,.22); }
.checkout-box .price { color: var(--text-on-ink); }

/* ---------- deepenings ---------- */
.deepenings { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 1.4rem; margin-top: 2.4rem; }
.deep { border: 1px solid rgba(35,44,71,.22); padding: 1.6rem; border-radius: 2px; text-align: center; }
.deep h3 { font-size: 1.08rem; margin-bottom: 0.4rem; }
.deep p { font-size: 0.9rem; color: var(--ink-soft); min-height: 2.6em; }
.deep-price { font-family: var(--serif); font-size: 1.25rem; color: var(--burnt); }
.gift-line { margin-top: 2.4rem; }

/* ---------- faq ---------- */
details { border-bottom: 1px solid rgba(35,44,71,.2); padding: 1rem 0; }
summary { cursor: pointer; font-weight: 600; font-size: 1rem; }
details p { margin-top: 0.7rem; color: var(--ink-soft); font-size: 0.95rem; }

/* ---------- footer ---------- */
.foot { text-align: center; padding: 8vh 6vw; }
.foot p { color: var(--muted); font-size: 0.9rem; margin-top: 0.4rem; }
.foot-strata { display: block; margin: 0 auto 1.2rem; }

@media (max-width: 560px) {
  .likert-scale label { padding: 0.5rem 0; font-size: 0.85rem; }
  .band { padding: 8vh 6vw; }
}
