/* =============================================================
   uDiscover — "Spectrum of You" design system
   Soft lilac canvas · ink · a violet→magenta→coral brand spectrum.
   Fraunces (display) + Inter (body). Friendly, premium, optimistic.
   ============================================================= */

:root {
  --canvas:   #f7f5fb;
  --canvas-2: #efeaf8;
  --card:     #ffffff;
  --ink:      #211d2e;
  --ink-2:    #4f4860;
  --ink-3:    #6a6280;
  --muted:    #6a6280;
  --line:     #e7e2f0;
  --line-2:   #ddd5ec;

  --primary:      #6b4ef0;
  --primary-deep: #5536d6;
  --primary-ink:  #5736d0;
  --primary-soft: rgba(107,78,240,0.10);
  --primary-faint:rgba(107,78,240,0.06);

  --magenta: #e0489e;
  --coral:   #ff7a59;
  --amber:   #f2b441;
  --teal:    #1ec8b0;
  --blue:    #3b82f6;
  --green:   #34c46e;

  --grad: linear-gradient(100deg, #6b4ef0 0%, #e0489e 55%, #ff7a59 100%);
  --grad-soft: linear-gradient(100deg, rgba(107,78,240,0.14), rgba(224,72,158,0.12) 55%, rgba(255,122,89,0.12));

  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body:    'Inter', system-ui, -apple-system, sans-serif;

  --radius-1: 12px;
  --radius-2: 20px;
  --radius-3: 28px;
  --ease: cubic-bezier(.2,.7,.2,1);
  --transition: 240ms var(--ease);
  --container: 1140px;
  --measure: 680px;
  --shadow-1: 0 2px 14px rgba(33,29,46,0.06);
  --shadow-2: 0 18px 46px rgba(33,29,46,0.14);
  --shadow-glow: 0 14px 30px rgba(107,78,240,0.30);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0; background: var(--canvas); color: var(--ink-2);
  font-family: var(--font-body); font-size: 17px; line-height: 1.65;
  -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; overflow-x: hidden;
}
img, svg { max-width: 100%; height: auto; display: block; }
a { color: var(--primary-ink); text-decoration: none; transition: color var(--transition); }
a:hover { color: var(--primary-deep); }
:where(a, button, input, select, textarea, [tabindex]):focus-visible { outline: 3px solid var(--primary); outline-offset: 2px; border-radius: 4px; }

h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 600; color: var(--ink); letter-spacing: -0.01em; line-height: 1.1; margin: 0 0 0.5em; }
h1 { font-size: clamp(2.5rem, 5.4vw, 4rem); font-weight: 600; line-height: 1.02; }
h2 { font-size: clamp(1.9rem, 3.6vw, 2.8rem); }
h3 { font-size: 1.4rem; }
p { margin: 0 0 1.1em; }
strong { color: var(--ink); font-weight: 600; }
.muted { color: var(--muted); }
.lede { font-size: 1.24rem; line-height: 1.55; color: var(--ink-2); }
::selection { background: var(--primary); color: #fff; }
.grad-text { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; }

/* layout */
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 24px; }
.container--narrow { max-width: var(--measure); }
.section { padding: clamp(52px, 7vw, 96px) 0; position: relative; }
.section--tight { padding: clamp(38px, 5vw, 64px) 0; }
.section--alt { background: var(--canvas-2); }
.section--ink { background: var(--ink); color: #cfc8dd; }
.section--ink h1, .section--ink h2, .section--ink h3 { color: #fff; }
.section__header { max-width: var(--measure); margin-bottom: clamp(30px,4vw,48px); }
.section__header.is-center { margin-left:auto; margin-right:auto; text-align:center; }
.section__header p { color: var(--ink-3); font-size: 1.1rem; margin-bottom: 0; }
.section--ink .section__header p { color:#a99fc0; }

/* eyebrow + sticker */
.eyebrow { font-family: var(--font-body); font-size: 0.74rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--primary-ink); display: inline-flex; align-items: center; gap: 9px; margin-bottom: 14px; }
.eyebrow::before { content:''; width: 20px; height: 3px; border-radius: 3px; background: var(--grad); }
.is-center .eyebrow { justify-content: center; }
.eyebrow--on-dark { color: #cbb6ff; }
.sticker { display:inline-flex; align-items:center; gap:8px; font-size:0.8rem; font-weight:600; padding:7px 15px; border-radius:999px; margin-bottom:18px; background: var(--primary-soft); color: var(--primary-ink); border:1px solid var(--line-2); }

.visually-hidden, .skip-link { position:absolute; left:-9999px; }
.skip-link:focus { position:fixed; left:16px; top:16px; z-index:9999; background:var(--primary); color:#fff; padding:10px 16px; font-weight:600; border-radius:var(--radius-1); }

/* ── ribbon (thin top accent) ── */
.brandbar { height: 4px; background: var(--grad); }

/* ── header ── */
.site-header { position: sticky; top: 0; z-index: 50; padding: 14px 0 2px; background: linear-gradient(var(--canvas) 66%, transparent); }
.site-header__inner { display:flex; align-items:center; justify-content:space-between; gap:20px; background: var(--card); border:1px solid var(--line); border-radius:999px; padding:9px 12px 9px 18px; box-shadow: 0 8px 26px rgba(33,29,46,0.08); }
.brand { display:inline-flex; align-items:center; gap:11px; color:var(--ink); }
.brand:hover { color: var(--ink); }
.brand__mark { display:inline-flex; transition: transform var(--transition); }
.brand:hover .brand__mark { transform: rotate(12deg) scale(1.08); }
.brand__word { font-family: var(--font-display); font-weight:600; font-size:1.4rem; letter-spacing:-0.01em; }
.brand__word b { font-weight:600; }
.site-nav__list { display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0; }
.site-nav__list > li > a { color:var(--ink-2); font-weight:600; font-size:0.94rem; padding:9px 16px; border-radius:999px; display:block; transition: background var(--transition), color var(--transition); }
.site-nav__list > li > a:hover { color:var(--primary-ink); background:var(--canvas-2); }
.site-nav__list > li > a.is-active { color:var(--primary-ink); background:var(--primary-soft); }
.site-nav__cta > a { color:#fff; }
.site-nav__toggle { display:none; width:46px; height:46px; background:var(--card); border:1px solid var(--line); border-radius:50%; flex-direction:column; align-items:center; justify-content:center; gap:4px; cursor:pointer; }
.site-nav__toggle-bar { width:18px; height:2px; border-radius:2px; background:var(--ink); }
@media (max-width: 860px) {
  .site-nav__toggle { display:inline-flex; }
  .site-nav__pill { position:fixed; inset:0; background:var(--canvas); padding:96px 24px 40px; transform:translateY(-110%); visibility:hidden; transition: transform var(--transition), visibility var(--transition); overflow-y:auto; }
  .site-nav.is-open .site-nav__pill { transform:none; visibility:visible; }
  .site-nav__list { flex-direction:column; align-items:stretch; gap:6px; }
  .site-nav__list > li > a { font-family:var(--font-display); font-size:1.5rem; padding:12px 18px; border-radius:var(--radius-2); background:var(--card); border:1px solid var(--line); }
  .site-nav__cta { margin-top:12px; } .site-nav__cta > a { width:100%; justify-content:center; }
}

/* buttons */
.btn { display:inline-flex; align-items:center; gap:9px; padding:13px 24px; font-weight:600; font-size:0.98rem; background:transparent; color:var(--ink); border:1.5px solid var(--line-2); border-radius:999px; cursor:pointer; transition: all var(--transition); }
.btn--primary { background: var(--grad); border:0; color:#fff; box-shadow: var(--shadow-glow); padding:14px 26px; }
.btn--primary:hover { filter:brightness(1.06); transform: translateY(-2px); color:#fff; }
.btn--ink { background:var(--ink); border-color:var(--ink); color:#fff; }
.btn--ink:hover { background:#322b45; border-color:#322b45; color:#fff; transform:translateY(-2px); }
.btn--ghost { border-color:var(--line-2); color:var(--ink); }
.btn--ghost:hover { border-color:var(--primary); color:var(--primary-ink); transform:translateY(-2px); }
.btn--ghost-light { border-color:rgba(255,255,255,0.35); color:#fff; }
.btn--ghost-light:hover { border-color:#fff; background:rgba(255,255,255,0.08); color:#fff; }
.btn--lg { padding:16px 32px; font-size:1.05rem; }
.btn--sm { padding:9px 18px; font-size:0.88rem; }
.btn .arrow { transition: transform var(--transition); }
.btn:hover .arrow { transform: translateX(3px); }

/* ── hero ── */
.hero { position:relative; overflow:hidden; }
.hero::before { content:''; position:absolute; width:680px; height:680px; border-radius:50%; background: var(--grad); opacity:0.12; filter: blur(60px); top:-280px; right:-160px; z-index:0; }
.hero__inner { position:relative; z-index:1; text-align:center; max-width:820px; margin:0 auto; padding: clamp(44px,6vw,84px) 0 clamp(36px,4vw,56px); }
.hero__spark { width:54px; height:54px; margin:0 auto 22px; }
.hero h1 { margin-bottom:0; }
.hero__lede { margin:22px auto 0; max-width:600px; font-size:1.26rem; color:var(--ink-2); }
.hero__actions { margin-top:32px; display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.hero__trust { margin-top:22px; font-size:0.92rem; color:var(--ink-3); font-weight:500; }

/* ── quiz cards grid ── */
.quiz-grid { display:grid; grid-template-columns: repeat(auto-fill, minmax(min(300px,100%),1fr)); gap:22px; }
.qcard-link { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); overflow:hidden; display:flex; flex-direction:column; box-shadow:var(--shadow-1); transition: transform var(--transition), box-shadow var(--transition); }
.qcard-link:hover { transform: translateY(-5px); box-shadow:var(--shadow-2); color:var(--ink-2); }
.qcard-link__top { position:relative; aspect-ratio: 16/9; overflow:hidden; background: var(--grad-soft); display:flex; align-items:center; justify-content:center; }
.qcard-link__top img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.qcard-link__emoji { font-size:3rem; position:relative; z-index:1; filter: drop-shadow(0 6px 10px rgba(33,29,46,0.18)); }
.qcard-link__cat { position:absolute; top:12px; left:12px; z-index:2; font-size:0.66rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:#fff; background:rgba(33,29,46,0.62); backdrop-filter:blur(3px); padding:5px 11px; border-radius:999px; }
.qcard-link__body { padding:22px 24px 24px; display:flex; flex-direction:column; flex:1; }
.qcard-link__title { font-family:var(--font-display); font-size:1.5rem; font-weight:600; color:var(--ink); line-height:1.1; }
.qcard-link__tagline { color:var(--ink-3); font-size:0.96rem; margin:8px 0 0; }
.qcard-link__foot { margin-top:auto; padding-top:18px; display:flex; align-items:center; justify-content:space-between; gap:10px; }
.qcard-link__meta { font-size:0.82rem; color:var(--ink-3); font-weight:500; }
.qcard-link__go { font-weight:700; font-size:0.9rem; color:var(--primary-ink); display:inline-flex; gap:6px; }
.qcard-link:hover .qcard-link__go .arrow { transform: translateX(3px); }

/* ── how it works / steps ── */
.step-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(min(240px,100%),1fr)); gap:20px; counter-reset:step; }
.step { counter-increment:step; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:28px 26px; box-shadow:var(--shadow-1); }
.step::before { content:counter(step); font-family:var(--font-display); font-weight:600; font-size:1.3rem; color:#fff; background:var(--grad); width:44px; height:44px; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; margin-bottom:14px; }
.step h3 { font-size:1.25rem; margin-bottom:6px; }
.step p { color:var(--ink-3); font-size:0.96rem; margin:0; }
.section--ink .step { background:#2b2540; border-color:#3a3357; }
.section--ink .step p { color:#a99fc0; }

/* feature/benefit cards */
.feature-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(min(260px,100%),1fr)); gap:20px; }
.feature { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:26px 26px; box-shadow:var(--shadow-1); }
.feature__icon { font-size:1.7rem; margin-bottom:10px; }
.feature h3 { font-size:1.2rem; margin-bottom:6px; }
.feature p { color:var(--ink-3); font-size:0.95rem; margin:0; }

/* ── page head ── */
.page-head { padding: clamp(38px,5vw,64px) 0 clamp(20px,3vw,30px); }
.page-head__inner { max-width:720px; }
.page-head__lede { font-size:1.18rem; color:var(--ink-2); margin:14px 0 0; }
.crumbs { font-size:0.8rem; color:var(--muted); margin-bottom:14px; }
.crumbs a { color:var(--ink-3); } .crumbs a:hover { color:var(--primary-ink); } .crumbs span { color:var(--ink); }

/* ── quiz intro ── */
.quiz-intro { text-align:center; max-width:680px; margin:0 auto; }
.quiz-intro__emoji { font-size:3.4rem; }
.quiz-intro__meta { display:inline-flex; gap:8px; flex-wrap:wrap; justify-content:center; margin:16px 0 4px; }
.pill { font-size:0.8rem; font-weight:600; padding:6px 13px; border-radius:999px; background:var(--card); border:1px solid var(--line-2); color:var(--ink-2); }

/* ── quiz form ── */
.qprogress { position:sticky; top:8px; z-index:30; margin: 0 auto 26px; max-width:760px; background:var(--card); border:1px solid var(--line); border-radius:999px; padding:8px 8px 8px 18px; display:flex; align-items:center; gap:14px; box-shadow:var(--shadow-1); }
.qprogress__track { flex:1; height:8px; border-radius:999px; background:var(--canvas-2); overflow:hidden; }
.qprogress__fill { height:100%; width:0; background:var(--grad); border-radius:999px; transition: width 280ms var(--ease); }
.qprogress__count { font-weight:700; font-size:0.86rem; color:var(--ink-2); font-variant-numeric:tabular-nums; white-space:nowrap; }
.qform { max-width:760px; margin:0 auto; }
.qcard { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 24px; margin-bottom:16px; box-shadow:var(--shadow-1); scroll-margin-top:90px; }
.qcard.is-unanswered.is-flagged { border-color:var(--magenta); box-shadow:0 0 0 3px rgba(224,72,158,0.12); }
.qcard__n { font-size:0.74rem; font-weight:700; letter-spacing:0.08em; text-transform:uppercase; color:var(--primary-ink); }
.qcard__q { font-family:var(--font-display); font-size:1.3rem; font-weight:600; color:var(--ink); margin:6px 0 16px; line-height:1.2; }
/* archetype options */
.qopts { display:grid; gap:10px; }
.qopt { display:flex; align-items:center; gap:12px; padding:13px 16px; border:1.5px solid var(--line-2); border-radius:var(--radius-1); cursor:pointer; transition: border-color var(--transition), background var(--transition); }
.qopt:hover { border-color:var(--primary); background:var(--primary-faint); }
.qopt input { position:absolute; opacity:0; width:0; height:0; }
.qopt__dot { width:20px; height:20px; border-radius:50%; border:2px solid var(--line-2); flex:none; transition: all var(--transition); }
.qopt input:checked ~ .qopt__dot { border-color:var(--primary); background:var(--primary); box-shadow: inset 0 0 0 3px #fff; }
.qopt:has(input:checked) { border-color:var(--primary); background:var(--primary-soft); }
.qopt:has(input:focus-visible) { outline:3px solid var(--primary); outline-offset:2px; }
.qopt__t { color:var(--ink); font-size:0.98rem; }
/* likert */
.likert { display:flex; align-items:stretch; gap:8px; }
.likert__end { font-size:0.78rem; color:var(--ink-3); align-self:center; width:74px; flex:none; }
.likert__end--hi { text-align:right; }
.likert__scale { display:flex; gap:8px; flex:1; justify-content:center; }
.likert__opt { flex:1; max-width:64px; }
.likert__opt input { position:absolute; opacity:0; width:0; height:0; }
.likert__btn { display:flex; align-items:center; justify-content:center; height:46px; border:1.5px solid var(--line-2); border-radius:12px; cursor:pointer; font-weight:700; color:var(--ink-3); transition: all var(--transition); }
.likert__opt:hover .likert__btn { border-color:var(--primary); }
.likert__opt input:checked + .likert__btn { background:var(--grad); border:0; color:#fff; }
.likert__opt input:focus-visible + .likert__btn { outline:3px solid var(--primary); outline-offset:2px; }
@media (max-width:520px){ .likert__end{ width:54px; font-size:0.72rem;} .likert__btn{ height:42px; } }
.qsubmit { text-align:center; margin-top:8px; }
.qsubmit .form-note { font-size:0.85rem; color:var(--ink-3); margin-top:12px; }
.form-err { max-width:760px; margin:0 auto 16px; background:rgba(224,72,158,0.1); border:1px solid var(--magenta); color:#b3266f; padding:13px 18px; border-radius:var(--radius-1); font-weight:600; }

/* ── result: archetype ── */
.result-hero { text-align:center; max-width:720px; margin:0 auto; }
.result-hero__badge { width:120px; height:120px; border-radius:30px; margin:0 auto 18px; display:flex; align-items:center; justify-content:center; font-size:3.6rem; box-shadow:var(--shadow-2); }
.result-hero__kicker { font-weight:700; font-size:0.82rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); }
.result-hero h1 { margin:8px 0 0; }
.result-hero__tagline { font-family:var(--font-display); font-style:italic; font-size:1.3rem; color:var(--ink-2); margin:8px 0 0; }
.result-hero__summary { font-size:1.14rem; color:var(--ink-2); margin:18px auto 0; max-width:600px; }
.result-blend { display:inline-block; margin-top:16px; font-size:0.92rem; color:var(--ink-2); background:var(--card); border:1px solid var(--line-2); border-radius:999px; padding:8px 16px; }

.result-cols { display:grid; grid-template-columns:1fr 1fr; gap:22px; max-width:840px; margin:0 auto; }
@media (max-width:680px){ .result-cols { grid-template-columns:1fr; } }
.result-box { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 26px; box-shadow:var(--shadow-1); }
.result-box h3 { font-size:1.05rem; text-transform:uppercase; letter-spacing:0.06em; font-family:var(--font-body); font-weight:700; color:var(--ink-3); margin-bottom:14px; }
.result-list { list-style:none; padding:0; margin:0; }
.result-list li { position:relative; padding-left:26px; margin-bottom:10px; color:var(--ink-2); }
.result-list li::before { content:'✦'; position:absolute; left:0; top:1px; color:var(--primary); }
.result-list--minus li::before { content:'›'; color:var(--magenta); font-weight:700; }

/* blend spectrum bar (archetypes) */
.blendbar { max-width:680px; margin:0 auto; }
.blendrow { display:grid; grid-template-columns:120px 1fr 44px; align-items:center; gap:14px; margin-bottom:12px; }
.blendrow__name { font-weight:600; color:var(--ink); font-size:0.95rem; }
.blendrow__track { height:14px; border-radius:999px; background:var(--canvas-2); overflow:hidden; }
.blendrow__fill { height:100%; border-radius:999px; }
.blendrow__pct { font-variant-numeric:tabular-nums; font-weight:700; color:var(--ink-2); font-size:0.9rem; text-align:right; }
@media (max-width:520px){ .blendrow{ grid-template-columns:96px 1fr 38px; gap:10px; } }

/* ── result: dimensions (spectrum bars) ── */
.spectrum { max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:26px; }
.spec { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 26px; box-shadow:var(--shadow-1); }
.spec__head { display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap; }
.spec__name { font-family:var(--font-display); font-size:1.35rem; font-weight:600; color:var(--ink); }
.spec__score { font-weight:700; font-variant-numeric:tabular-nums; color:var(--ink-2); }
.spec__ends { display:flex; justify-content:space-between; font-size:0.8rem; font-weight:600; color:var(--ink-3); margin:14px 0 7px; text-transform:uppercase; letter-spacing:0.04em; }
.spec__bar { position:relative; height:14px; border-radius:999px; background: linear-gradient(90deg, var(--canvas-2), var(--canvas-2)); overflow:visible; }
.spec__track { position:absolute; inset:0; border-radius:999px; opacity:0.22; }
.spec__marker { position:absolute; top:50%; width:24px; height:24px; border-radius:50%; transform:translate(-50%,-50%); border:3px solid #fff; box-shadow:0 2px 8px rgba(33,29,46,0.25); }
.spec__band { margin:16px 0 0; color:var(--ink-2); font-size:0.99rem; }

/* share box */
.share { max-width:680px; margin:0 auto; background:var(--card); border:1px solid var(--line); border-radius:var(--radius-2); padding:24px 26px; box-shadow:var(--shadow-1); text-align:center; }
.share h3 { font-size:1.4rem; margin-bottom:6px; }
.share__row { display:flex; gap:10px; max-width:520px; margin:16px auto 0; }
.share__row input { flex:1; font-family:var(--font-body); font-size:0.95rem; color:var(--ink-2); background:var(--canvas); border:1px solid var(--line-2); border-radius:var(--radius-1); padding:12px 14px; }
.share__note { font-size:0.82rem; color:var(--ink-3); margin-top:12px; }

/* email capture */
.signup { max-width:560px; margin:0 auto; text-align:center; }
.signup__row { display:flex; gap:10px; margin-top:14px; }
.signup__row input { flex:1; font-family:var(--font-body); font-size:1rem; color:var(--ink); background:var(--card); border:1px solid var(--line-2); border-radius:999px; padding:13px 18px; }
.signup__ok { color:var(--teal); font-weight:600; }

/* ── FAQ ── */
.faq { max-width:760px; }
.faq__item { border-bottom:1px solid var(--line); }
.faq__q { width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:22px 44px 22px 0; position:relative; font-family:var(--font-display); font-size:1.25rem; font-weight:600; color:var(--ink); }
.faq__q::after { content:'+'; position:absolute; right:6px; top:50%; transform:translateY(-50%); font-size:1.5rem; color:var(--primary); transition: transform var(--transition); }
.faq__item.is-open .faq__q::after { transform:translateY(-50%) rotate(45deg); }
.faq__a { max-height:0; overflow:hidden; transition:max-height 320ms var(--ease); }
.faq__a-inner { padding:0 0 22px; color:var(--ink-2); }
.faq__a-inner p { margin:0; }

/* prose */
.prose { max-width:var(--measure); }
.prose > * + * { margin-top:1.05em; }
.prose h2 { margin-top:1.4em; margin-bottom:0.3em; }
.prose p, .prose li { color:var(--ink-2); }
.prose a { text-decoration:underline; text-decoration-color:rgba(107,78,240,0.4); text-underline-offset:2px; }
.prose ul { padding-left:1.2em; } .prose li { margin-bottom:0.4em; }

/* CTA band */
.cta-band { background:var(--ink); color:#cfc8dd; position:relative; overflow:hidden; }
.cta-band::before { content:''; position:absolute; width:420px; height:420px; border-radius:50%; background:var(--grad); opacity:0.5; filter:blur(80px); top:-160px; right:-80px; }
.cta-band__inner { position:relative; display:flex; align-items:center; justify-content:space-between; gap:28px; padding:clamp(44px,6vw,72px) 0; flex-wrap:wrap; }
.cta-band h2 { color:#fff; margin-bottom:8px; }
.cta-band p { color:#a99fc0; margin:0; max-width:440px; }

.panel { background:var(--card); border:1px solid var(--line); border-radius:var(--radius-3); padding:clamp(26px,4vw,44px); box-shadow:var(--shadow-1); }

/* ── footer ── */
.site-footer { background:var(--card); border-top:1px solid var(--line); padding-top:52px; }
.site-footer__inner { display:grid; grid-template-columns:1.8fr 1fr 1fr; gap:36px; padding-bottom:40px; }
@media (max-width:760px){ .site-footer__inner { grid-template-columns:1fr 1fr; } }
@media (max-width:480px){ .site-footer__inner { grid-template-columns:1fr; } }
.site-footer__tag { color:var(--ink-3); margin-top:12px; font-size:0.94rem; max-width:340px; }
.site-footer h3 { font-size:0.72rem; letter-spacing:0.1em; text-transform:uppercase; color:var(--ink-3); font-family:var(--font-body); font-weight:700; margin-bottom:12px; }
.link-list { list-style:none; padding:0; margin:0; }
.link-list li { padding:5px 0; } .link-list a { color:var(--ink-2); font-size:0.95rem; } .link-list a:hover { color:var(--primary-ink); }
.site-footer__base { border-top:1px solid var(--line); padding:20px 0; }
.site-footer__base-inner { display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px; font-size:0.84rem; color:var(--ink-3); }
.site-footer__base p { margin:0; }
.disclaimer { max-width:var(--measure); margin:0 auto; color:var(--ink-3); font-size:0.82rem; text-align:center; padding:0 24px 30px; }

/* utilities */
.center { text-align:center; }
.mt-s{margin-top:14px;} .mt-m{margin-top:26px;} .mt-l{margin-top:40px;}
.reveal { opacity:0; transform:translateY(16px); transition:opacity 600ms var(--ease), transform 600ms var(--ease); }
.reveal.is-in { opacity:1; transform:none; }
.reveal[data-delay="1"]{transition-delay:80ms;} .reveal[data-delay="2"]{transition-delay:160ms;} .reveal[data-delay="3"]{transition-delay:240ms;}
@media (prefers-reduced-motion: reduce){ *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important;} .reveal{opacity:1;transform:none;} html{scroll-behavior:auto;} }
