/* ===========================================================
   Ayni Gold — Quiz landing
   Tokens come from design-brief.md §3.
   =========================================================== */

:root{
  --bg-base-0:#0a0d18;
  --bg-base-1:#0e1226;
  --surface:#161a2e;
  --surface-2:#1c2138;
  --surface-3:#222848;
  --border-subtle:rgba(255,215,130,0.08);
  --border-soft:rgba(255,255,255,0.06);
  --border-input:rgba(255,255,255,0.10);

  --gold:#F5C76A;
  --gold-hover:#FFD980;
  --gold-deep:#C99846;
  --gold-glow:rgba(245,199,106,0.25);

  --text-primary:rgba(255,255,255,0.92);
  --text-secondary:rgba(255,255,255,0.60);
  --text-muted:rgba(255,255,255,0.40);

  --success:#5DD8A0;
  --danger:#FF6B6B;

  --r-card:16px;
  --r-pill:999px;
  --r-input:10px;

  --font-display:"Tenor Sans", "Inter", system-ui, -apple-system, sans-serif;
  --font-body:"Inter", system-ui, -apple-system, sans-serif;

  --shadow-card:0 8px 40px rgba(245,199,106,0.06), 0 2px 8px rgba(0,0,0,0.35);
  --shadow-hover:0 12px 60px rgba(245,199,106,0.10), 0 4px 12px rgba(0,0,0,0.4);

  --container:1280px;
  --pad-x:48px;

  --t-fast:160ms;
  --t-base:280ms;
  --t-slow:420ms;
  --ease:cubic-bezier(0.4, 0, 0.2, 1);
}

/* ------------------------------------------------------------
   Base
   ------------------------------------------------------------ */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  font-family:var(--font-body);
  font-size:16px;
  line-height:1.55;
  color:var(--text-primary);
  background:
    radial-gradient(1200px 700px at 80% -10%, rgba(245,199,106,0.06), transparent 60%),
    radial-gradient(900px 600px at -10% 30%, rgba(98,124,255,0.05), transparent 60%),
    linear-gradient(180deg, var(--bg-base-0) 0%, var(--bg-base-1) 60%, var(--bg-base-0) 100%);
  background-attachment:fixed;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}

img,svg{display:block;max-width:100%}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
a{color:inherit;text-decoration:none}
ul{list-style:none;margin:0;padding:0}

::selection{background:rgba(245,199,106,0.35);color:#fff}
[hidden]{display:none !important}

/* Focus */
:focus-visible{
  outline:2px solid var(--gold);
  outline-offset:2px;
  border-radius:6px;
}

/* ------------------------------------------------------------
   Background decorative stack
   ------------------------------------------------------------ */
.bg-stack{
  position:fixed;
  inset:0;
  z-index:0;
  pointer-events:none;
  overflow:hidden;
}
.bg-particles{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
}
.bg-paths{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:1800px;
  animation:driftPaths 60s linear infinite;
  opacity:0.9;
}
@keyframes driftPaths{
  0%{transform:translateX(0)}
  100%{transform:translateX(-40px)}
}
.bg-hex{
  position:absolute;
  width:320px;
  height:320px;
  opacity:0.045;
}
.bg-hex--tr{top:64px;right:-40px}
.bg-hex--bl{bottom:120px;left:-60px}

/* Page chrome stacking */
.ticker,.hdr,.hero,.trust,.ft{position:relative;z-index:2}

/* ------------------------------------------------------------
   Top ticker
   ------------------------------------------------------------ */
.ticker{
  background:#06080F;
  border-bottom:1px solid rgba(255,255,255,0.04);
  height:30px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:12.5px;
  letter-spacing:0.02em;
  color:var(--text-secondary);
}
.ticker__inner{
  display:flex;
  align-items:center;
  gap:12px;
}
.ticker__icon{display:inline-flex;align-items:center}
.ticker__pair{color:var(--text-muted);font-weight:500}
.ticker__price{color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}
.ticker__delta{font-variant-numeric:tabular-nums;font-weight:500}
.ticker__delta--up{color:var(--success)}
.ticker__delta--down{color:var(--danger)}
.ticker__dot{
  width:6px;height:6px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 0 var(--gold-glow);
  animation:livePulse 1.8s ease-out infinite;
}
.ticker__live{color:var(--gold);font-weight:600;letter-spacing:0.12em;font-size:10.5px;text-transform:uppercase}
@keyframes livePulse{
  0%  {box-shadow:0 0 0 0 rgba(245,199,106,0.55)}
  100%{box-shadow:0 0 0 10px rgba(245,199,106,0)}
}

/* ------------------------------------------------------------
   Header
   ------------------------------------------------------------ */
.hdr{
  position:sticky;
  top:0;
  z-index:30;
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  background:rgba(10,13,24,0.72);
  border-bottom:1px solid rgba(255,255,255,0.04);
}
.hdr__inner{
  max-width:var(--container);
  margin:0 auto;
  height:72px;
  padding:0 var(--pad-x);
  display:flex;
  align-items:center;
  gap:32px;
}
.hdr__logo{
  display:flex;
  align-items:center;
  gap:10px;
  flex:0 0 auto;
}
.logo-glyph{display:inline-flex}
.logo-word{
  font-family:var(--font-display);
  font-weight:400;
  font-size:22px;
  letter-spacing:0.32em;
  color:var(--gold);
}
.logo-glyph{width:32px;height:32px;display:block}
.hdr__nav{
  display:flex;
  gap:32px;
  align-items:center;
  margin:0 auto;
  font-size:14.5px;
  color:var(--text-secondary);
}
.hdr__nav a{
  transition:color var(--t-fast) var(--ease);
  position:relative;
  padding:6px 0;
}
.hdr__nav a:hover{color:var(--text-primary)}
.hdr__nav a.is-active{color:var(--gold)}
.hdr__nav a.is-active::after{
  content:"";
  position:absolute;
  left:0; right:0; bottom:-2px;
  height:1px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.hdr__right{display:flex;align-items:center;gap:14px;flex:0 0 auto}
.hdr__lang{
  display:inline-flex;
  align-items:center;
  gap:6px;
  color:var(--text-secondary);
  font-size:14px;
  padding:8px 4px;
  border-radius:6px;
}
.hdr__lang:hover{color:var(--text-primary)}

/* ------------------------------------------------------------
   Buttons
   ------------------------------------------------------------ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:var(--r-pill);
  font-weight:600;
  letter-spacing:0.01em;
  padding:12px 22px;
  transition:transform var(--t-fast) var(--ease),
             background-color var(--t-fast) var(--ease),
             box-shadow var(--t-base) var(--ease);
  white-space:nowrap;
}
.btn--gold{
  background:var(--gold);
  color:#0a0d18;
  box-shadow:0 6px 18px var(--gold-glow);
}
.btn--gold:hover{
  background:var(--gold-hover);
  box-shadow:0 8px 28px rgba(245,199,106,0.32);
  transform:translateY(-1px);
}
.btn--gold:active{transform:translateY(0)}
.btn--sm{padding:9px 18px;font-size:14px}
.btn--block{display:flex;width:100%;padding:15px 22px;font-size:15.5px}
.btn--ghost-gold{
  background:transparent;
  color:var(--gold);
  border:1px solid rgba(245,199,106,0.4);
}
.btn--ghost-gold:hover{background:rgba(245,199,106,0.06)}
.btn--locked{
  background:transparent;
  border:1px solid rgba(245,199,106,0.25);
  color:rgba(245,199,106,0.75);
  pointer-events:none;
  box-shadow:none;
}
.btn__arrow{transition:transform var(--t-fast) var(--ease)}
.btn:hover .btn__arrow{transform:translateX(3px)}

/* ------------------------------------------------------------
   Eyebrow / Section heads
   ------------------------------------------------------------ */
.eyebrow{
  display:inline-block;
  font-family:var(--font-body);
  font-weight:600;
  font-size:11.5px;
  letter-spacing:0.16em;
  text-transform:uppercase;
  color:var(--text-muted);
}
.eyebrow--gold{color:var(--gold)}

.section-h{
  font-family:var(--font-display);
  font-weight:400;
  font-size:34px;
  line-height:1.2;
  letter-spacing:0;
  margin:0 0 8px;
  color:var(--text-primary);
  text-align:center;
}
.section-sub{
  text-align:center;
  color:var(--text-secondary);
  font-size:15.5px;
  margin:0 0 40px;
}

/* Gradient highlight on hero keyword */
.grad{
  background:linear-gradient(180deg, #FFFFFF 0%, #F5C76A 90%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}

/* ------------------------------------------------------------
   Hero
   ------------------------------------------------------------ */
.hero{padding:48px 0 64px}
.hero__inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--pad-x);
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(0, 1.18fr);
  gap:64px;
  align-items:start;
}
.hero__col--copy{padding-top:8px}
.hero__h1{
  font-family:var(--font-display);
  font-weight:400;
  font-size:48px;
  line-height:1.12;
  letter-spacing:0;
  margin:14px 0 18px;
  color:var(--text-primary);
  text-wrap:pretty;
}
.hero__sub{
  font-size:16px;
  line-height:1.6;
  color:var(--text-secondary);
  margin:0 0 22px;
  max-width:36em;
}
.hero__bullets{
  display:flex;
  flex-direction:column;
  gap:10px;
  margin:0 0 18px;
}
.hero__bullets li{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:14.5px;
  color:var(--text-primary);
}
.check{
  width:18px;height:18px;
  border-radius:50%;
  background:rgba(245,199,106,0.12);
  border:1px solid rgba(245,199,106,0.4);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex:0 0 18px;
  position:relative;
}
.check::after{
  content:"";
  width:7px;height:4px;
  border-left:1.5px solid var(--gold);
  border-bottom:1.5px solid var(--gold);
  transform:rotate(-45deg) translate(0.5px,-1px);
}
.check--circle{
  width:22px;height:22px;
  flex:0 0 22px;
  background:rgba(245,199,106,0.18);
}
.hero__micro{
  font-size:13px;
  color:var(--text-muted);
  margin:0 0 26px;
  display:flex;
  align-items:center;
  gap:6px;
}
.lock{font-size:13px}
.hero__chips{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.hero__chips li{
  font-size:11.5px;
  font-weight:500;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--text-secondary);
  padding:5px 11px;
  border-radius:var(--r-pill);
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border-soft);
}

/* Mobile CTA — sits between hero copy and quiz card, only on small screens */
.hero__cta{
  display:none;
  position:relative;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  padding:17px 24px;
  border:0;
  border-radius:var(--r-pill);
  color:#0a0d18;
  font-family:var(--font-body);
  font-size:15.5px;
  font-weight:600;
  letter-spacing:0.02em;
  background:linear-gradient(180deg, #FFE8A6 0%, #F5C76A 55%, #C99846 100%);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.55),
    inset 0 -1px 0 rgba(120,80,20,0.25),
    0 0 0 1px rgba(255,224,138,0.35),
    0 10px 30px rgba(245,199,106,0.30),
    0 2px 6px rgba(0,0,0,0.25);
  cursor:pointer;
  overflow:hidden;
  isolation:isolate;
  transition:transform var(--t-fast) var(--ease),
             box-shadow var(--t-base) var(--ease),
             opacity 300ms var(--ease),
             margin 300ms var(--ease),
             max-height 300ms var(--ease),
             padding 300ms var(--ease);
}
.hero__cta-label,
.hero__cta-arrow{position:relative;z-index:2}
.hero__cta-shine{
  position:absolute;
  top:0; left:-60%;
  width:50%;
  height:100%;
  background:linear-gradient(110deg, transparent 0%, rgba(255,255,255,0.55) 50%, transparent 100%);
  filter:blur(2px);
  z-index:1;
  animation:ctaShine 3.4s ease-in-out 1.2s infinite;
}
@keyframes ctaShine{
  0%   {left:-60%}
  60%  {left:130%}
  100% {left:130%}
}
.hero__cta:hover{transform:translateY(-1px)}
.hero__cta:active{transform:translateY(0)}
.hero__cta.is-hidden{
  opacity:0;
  max-height:0;
  padding-top:0;
  padding-bottom:0;
  margin-top:0;
  margin-bottom:0;
  pointer-events:none;
  border-width:0;
}

/* ------------------------------------------------------------
   Quiz card
   ------------------------------------------------------------ */
.qcard{
  position:relative;
  background:linear-gradient(180deg, var(--surface) 0%, #14182a 100%);
  border:1px solid var(--border-subtle);
  border-radius:var(--r-card);
  box-shadow:var(--shadow-card);
  padding:32px;
  min-height:520px;
  display:flex;
  flex-direction:column;
}
.qcard::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  padding:1px;
  background:linear-gradient(180deg, rgba(245,199,106,0.25) 0%, rgba(245,199,106,0) 40%);
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;
          mask-composite:exclude;
  pointer-events:none;
}

.qcard__top{margin-bottom:24px}
.qcard__progress{
  height:2px;
  background:rgba(255,255,255,0.07);
  border-radius:2px;
  overflow:hidden;
}
.qcard__progress-fill{
  height:100%;
  background:linear-gradient(90deg, var(--gold-deep), var(--gold));
  border-radius:2px;
  transition:width 500ms var(--ease);
  box-shadow:0 0 12px rgba(245,199,106,0.5);
}
.qcard__counter{
  display:flex;
  justify-content:space-between;
  align-items:baseline;
  font-size:12px;
  font-weight:500;
  color:var(--gold);
  letter-spacing:0.06em;
  margin-top:10px;
  text-transform:uppercase;
}
.qcard__counter-sub{color:var(--text-muted);text-transform:none;letter-spacing:0.02em}

/* Body swap animations */
.qcard__body{
  flex:1;
  display:flex;
  flex-direction:column;
  min-height:0;
}
.qcard__body.is-leaving{animation:bodyOut 220ms var(--ease) forwards}
.qcard__body.is-entering{animation:bodyIn 320ms var(--ease) 80ms backwards}
.qcard__body.is-leaving-back{animation:bodyOutBack 220ms var(--ease) forwards}
.qcard__body.is-entering-back{animation:bodyInBack 320ms var(--ease) 80ms backwards}
@keyframes bodyOut{from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(-32px)}}
@keyframes bodyIn{from{opacity:0;transform:translateX(32px)} to{opacity:1;transform:translateX(0)}}
@keyframes bodyOutBack{from{opacity:1;transform:translateX(0)} to{opacity:0;transform:translateX(32px)}}
@keyframes bodyInBack{from{opacity:0;transform:translateX(-32px)} to{opacity:1;transform:translateX(0)}}

.qcard__foot{
  margin-top:20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.qcard__back{
  color:var(--text-secondary);
  font-size:13.5px;
  padding:8px 4px;
  display:inline-flex;
  align-items:center;
  gap:6px;
  transition:color var(--t-fast) var(--ease);
}
.qcard__back:hover{color:var(--gold)}
.qcard__step{
  font-size:11.5px;
  color:var(--text-muted);
  font-variant-numeric:tabular-nums;
  letter-spacing:0.06em;
}

/* Question content */
.q__cat{margin-bottom:14px}
.q__text{
  font-family:var(--font-display);
  font-weight:400;
  font-size:23px;
  line-height:1.32;
  margin:0 0 22px;
  color:var(--text-primary);
  text-wrap:balance;
}
.q__sub{
  font-size:14.5px;
  color:var(--text-secondary);
  margin:-12px 0 22px;
}
.q__opts{display:flex;flex-direction:column;gap:11px}
.q__opt{
  display:flex;
  align-items:flex-start;
  gap:14px;
  padding:14px 18px;
  border-radius:12px;
  background:rgba(255,255,255,0.025);
  border:1px solid rgba(255,255,255,0.07);
  cursor:pointer;
  text-align:left;
  width:100%;
  transition:border-color var(--t-fast) var(--ease),
             background-color var(--t-fast) var(--ease),
             transform var(--t-fast) var(--ease);
}
.q__opt:hover{
  border-color:rgba(245,199,106,0.55);
  background:rgba(255,255,255,0.04);
}
.q__opt.is-selected{
  border-color:var(--gold);
  background:rgba(245,199,106,0.06);
}
.q__opt.is-selected .q__letter{
  background:var(--gold);
  color:#0a0d18;
  animation:pulse 420ms var(--ease);
}
@keyframes pulse{
  0%  {transform:scale(1)}
  50% {transform:scale(1.08)}
  100%{transform:scale(1)}
}
.q__letter{
  width:32px;height:32px;
  border-radius:50%;
  border:1px solid rgba(245,199,106,0.55);
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:600;
  font-size:13.5px;
  color:var(--gold);
  flex:0 0 32px;
  transition:background-color var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.q__answer{
  font-size:14.5px;
  line-height:1.5;
  color:var(--text-primary);
  padding-top:5px;
}

/* ------------------------------------------------------------
   Contact form
   ------------------------------------------------------------ */
.cform{display:flex;flex-direction:column;gap:14px;margin-top:8px}
.cform__row{display:flex;flex-direction:column;gap:6px}
.cform__lbl{
  font-size:12px;
  font-weight:500;
  letter-spacing:0.05em;
  color:var(--text-secondary);
  text-transform:uppercase;
}
.cform__in{
  font-family:var(--font-body);
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border-input);
  border-radius:var(--r-input);
  padding:12px 14px;
  color:var(--text-primary);
  font-size:14.5px;
  transition:border-color var(--t-fast) var(--ease), background-color var(--t-fast) var(--ease);
}
.cform__in::placeholder{color:var(--text-muted)}
.cform__in:focus{
  outline:none;
  border-color:rgba(245,199,106,0.65);
  background:rgba(255,255,255,0.045);
}
.cform__in.is-error{border-color:var(--danger);background:rgba(255,107,107,0.05)}

.cform__phone{display:flex;gap:8px}
.cform__cc{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:rgba(255,255,255,0.03);
  border:1px solid var(--border-input);
  border-radius:var(--r-input);
  padding:0 12px;
  font-size:14px;
  color:var(--text-primary);
  flex:0 0 auto;
}
.flag{font-size:16px}
.cc-code{font-variant-numeric:tabular-nums;font-weight:500}
.cform__in--phone{flex:1}

.cform__consent{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:13px;
  color:var(--text-secondary);
  margin:2px 0 4px;
  cursor:pointer;
}
.cform__consent input{
  width:16px;height:16px;
  accent-color:var(--gold);
  margin-top:2px;
  flex:0 0 16px;
}
.link-gold{color:var(--gold);text-decoration:underline;text-underline-offset:2px;text-decoration-color:rgba(245,199,106,0.35)}
.link-gold:hover{text-decoration-color:var(--gold)}

.cform__micro{
  font-size:12px;
  color:var(--text-muted);
  text-align:center;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  margin:6px 0 0;
}

/* Submit states */
#submit-btn.is-loading{
  pointer-events:none;
  background:rgba(245,199,106,0.5);
}
#submit-btn.is-loading .btn__arrow{display:none}
#submit-btn.is-loading .btn__label::before{
  content:"";
  display:inline-block;
  width:14px;height:14px;
  border:2px solid rgba(10,13,24,0.5);
  border-top-color:#0a0d18;
  border-radius:50%;
  margin-right:10px;
  animation:spin 800ms linear infinite;
  vertical-align:-3px;
}
@keyframes spin{to{transform:rotate(360deg)}}

.toast{
  background:rgba(255,107,107,0.10);
  border:1px solid rgba(255,107,107,0.45);
  color:#FFB7B7;
  font-size:13px;
  padding:10px 14px;
  border-radius:10px;
  margin-bottom:14px;
  display:flex;
  align-items:center;
  gap:10px;
}

/* ------------------------------------------------------------
   Result screen
   ------------------------------------------------------------ */
.result__score{
  text-align:center;
  margin:14px 0 18px;
}
.result__score-num{
  display:inline-flex;
  align-items:baseline;
  gap:6px;
  font-family:var(--font-display);
  line-height:1;
}
.result__score-val{
  font-size:72px;
  font-weight:400;
  background:linear-gradient(180deg, #FFFFFF 0%, #F5C76A 85%);
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
  font-variant-numeric:tabular-nums;
  letter-spacing:0;
  padding:0 4px 4px;
  margin:0 -4px -4px;
}
.result__score-max{
  font-size:22px;
  font-weight:400;
  color:var(--text-muted);
  font-variant-numeric:tabular-nums;
}
.result__score-lbl{
  display:block;
  margin-top:6px;
  font-size:11px;
  font-weight:600;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--gold);
}

.result__gauge{margin:0 0 22px}
.result__gauge-track{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:6px;
  border:1px solid var(--border-soft);
  background:rgba(255,255,255,0.02);
  border-radius:10px;
  padding:5px;
}
.result__gauge-seg{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:3px;
  padding:9px 6px;
  border-radius:7px;
  background:transparent;
  border:1px solid transparent;
  transition:background-color var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.result__gauge-lbl{
  font-size:11.5px;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  color:var(--text-muted);
  transition:color var(--t-base) var(--ease);
}
.result__gauge-rng{
  font-size:10.5px;
  font-variant-numeric:tabular-nums;
  color:var(--text-muted);
  opacity:0.7;
  letter-spacing:0.04em;
}
.result__gauge[data-tier="low"]    .result__gauge-seg[data-seg="low"],
.result__gauge[data-tier="medium"] .result__gauge-seg[data-seg="medium"],
.result__gauge[data-tier="high"]   .result__gauge-seg[data-seg="high"]{
  background:linear-gradient(180deg, rgba(245,199,106,0.18), rgba(245,199,106,0.06));
  border-color:rgba(245,199,106,0.45);
  box-shadow:inset 0 0 0 1px rgba(245,199,106,0.08), 0 0 18px rgba(245,199,106,0.10);
}
.result__gauge[data-tier="low"]    .result__gauge-seg[data-seg="low"]    .result__gauge-lbl,
.result__gauge[data-tier="medium"] .result__gauge-seg[data-seg="medium"] .result__gauge-lbl,
.result__gauge[data-tier="high"]   .result__gauge-seg[data-seg="high"]   .result__gauge-lbl{
  color:var(--gold);
}
.result__gauge[data-tier="low"]    .result__gauge-seg[data-seg="low"]    .result__gauge-rng,
.result__gauge[data-tier="medium"] .result__gauge-seg[data-seg="medium"] .result__gauge-rng,
.result__gauge[data-tier="high"]   .result__gauge-seg[data-seg="high"]   .result__gauge-rng{
  color:rgba(245,199,106,0.7);
  opacity:1;
}

.result__h{
  font-family:var(--font-display);
  font-weight:400;
  font-size:24px;
  line-height:1.3;
  text-align:center;
  margin:0 0 6px;
}
.result__tier{font-weight:400}
.result__sub{
  text-align:center;
  color:var(--text-secondary);
  font-size:14px;
  margin:0 0 20px;
  max-width:34em;
  margin-left:auto;
  margin-right:auto;
  text-wrap:pretty;
}

.result__offer{
  background:rgba(255,255,255,0.025);
  border:1px solid var(--border-soft);
  border-radius:12px;
  padding:18px 20px;
  margin-bottom:18px;
}
.result__offer-h{
  font-size:13.5px;
  font-weight:500;
  color:var(--text-primary);
  margin:0 0 12px;
}
.result__offer-list{display:flex;flex-direction:column;gap:9px}
.result__offer-list li{
  display:flex;
  align-items:center;
  gap:11px;
  font-size:14px;
  color:var(--text-primary);
}

.result__contact{
  text-align:center;
  font-size:12.5px;
  color:var(--text-muted);
  margin:14px 0 22px;
}
.result__contact strong{color:var(--text-secondary);font-weight:500}

.result__proof{
  border-top:1px solid var(--border-soft);
  padding-top:18px;
  margin-top:auto;
}
.result__proof-lbl{
  display:block;
  text-align:center;
  font-size:11px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--text-muted);
  margin-bottom:14px;
}
.result__proof-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:18px;
  flex-wrap:wrap;
}
.proof-logo{
  font-size:14px;
  font-weight:600;
  letter-spacing:0.04em;
  color:rgba(255,255,255,0.42);
  font-family:var(--font-body);
  filter:grayscale(1);
}
.proof-logo--serif{font-family:var(--font-display);font-weight:400;font-size:14px;letter-spacing:0.06em}
.proof-logo em{font-style:normal;color:rgba(255,255,255,0.28);font-weight:500}

/* ------------------------------------------------------------
   Trust block
   ------------------------------------------------------------ */
.trust{padding:48px 0 80px;position:relative}
.trust__inner{max-width:var(--container);margin:0 auto;padding:0 var(--pad-x)}
.trust__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:20px;
  margin-top:8px;
}
.tcard{
  background:var(--surface);
  border:1px solid var(--border-subtle);
  border-radius:var(--r-card);
  padding:28px;
  transition:transform var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.tcard:hover{
  transform:translateY(-2px);
  border-color:rgba(245,199,106,0.18);
}
.tcard__icon{
  width:48px;height:48px;
  border-radius:50%;
  background:rgba(245,199,106,0.06);
  border:1px solid rgba(245,199,106,0.3);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
}
.tcard__title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:20px;
  margin:0 0 10px;
  color:var(--text-primary);
  letter-spacing:0.01em;
}
.tcard__body{
  font-size:14px;
  line-height:1.55;
  color:var(--text-secondary);
  margin:0;
}

/* ------------------------------------------------------------
   Footer
   ------------------------------------------------------------ */
.ft{
  background:#06080F;
  border-top:1px solid rgba(255,255,255,0.04);
  padding:64px 0 0;
}
.ft__inner{
  max-width:var(--container);
  margin:0 auto;
  padding:0 var(--pad-x);
  display:grid;
  grid-template-columns:1.2fr 2fr;
  gap:48px;
}
.ft__brand .hdr__logo{margin-bottom:18px}
.ft__desc{
  font-size:13.5px;
  color:var(--text-secondary);
  max-width:34em;
  line-height:1.65;
  margin:0 0 22px;
}

.ft__social{display:flex;gap:10px}
.ft__social a{
  width:36px;
  height:36px;
  border-radius:50%;
  border:1px solid rgba(245,199,106,0.3);
  background:rgba(245,199,106,0.04);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  transition:background-color var(--t-fast) var(--ease),
             border-color var(--t-fast) var(--ease),
             transform var(--t-fast) var(--ease);
}
.ft__social a:hover{
  background:rgba(245,199,106,0.10);
  border-color:rgba(245,199,106,0.55);
  transform:translateY(-1px);
}

.ft__cols{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.ft__col h4{
  font-family:var(--font-body);
  font-size:11.5px;
  letter-spacing:0.14em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
  margin:0 0 14px;
}
.ft__col ul{display:flex;flex-direction:column;gap:9px}
.ft__col a{
  font-size:14px;
  color:var(--text-secondary);
  transition:color var(--t-fast) var(--ease);
}
.ft__col a:hover{color:var(--text-primary)}

.ft__legal-block{
  max-width:var(--container);
  margin:56px auto 0;
  padding:0 var(--pad-x);
  display:flex;
  flex-direction:column;
  gap:14px;
}
.ft__legal-block p{
  font-size:12.5px;
  line-height:1.65;
  color:var(--text-muted);
  margin:0;
}
.ft__disclaimer-lbl{
  color:var(--gold);
  font-weight:600;
  letter-spacing:0.02em;
}

.ft__legal{
  max-width:var(--container);
  margin:32px auto 0;
  padding:22px var(--pad-x);
  border-top:1px solid rgba(255,255,255,0.04);
  display:flex;
  justify-content:space-between;
  font-size:12.5px;
  color:var(--text-muted);
}
.ft__legal-links{display:flex;gap:24px}
.ft__legal-links a{color:var(--text-muted);transition:color var(--t-fast) var(--ease)}
.ft__legal-links a:hover{color:var(--gold)}

/* ------------------------------------------------------------
   Reduced motion
   ------------------------------------------------------------ */
@media (prefers-reduced-motion: reduce){
  *,
  *::before,
  *::after{
    animation-duration:0.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:0.01ms !important;
  }
  .bg-paths{animation:none}
  .ticker__dot{animation:none}
}

/* ------------------------------------------------------------
   Hamburger (mobile)
   ------------------------------------------------------------ */
.hdr__burger{
  display:none;
  width:40px;height:40px;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:5px;
  background:none;
  border:0;
  padding:0;
  margin-left:auto;
}
.hdr__burger span{
  display:block;
  width:20px;height:1.5px;
  background:var(--gold);
  border-radius:1px;
  transition:transform var(--t-base) var(--ease), opacity var(--t-base) var(--ease);
}
.hdr__burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hdr__burger.is-open span:nth-child(2){opacity:0}
.hdr__burger.is-open span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

.hdr__menu{
  position:fixed;
  inset:0;
  top:0;
  background:#06080F;
  background:
    radial-gradient(800px 500px at 80% -10%, rgba(245,199,106,0.06), transparent 60%),
    linear-gradient(180deg, #06080F 0%, #0a0d18 100%);
  z-index:40;
  padding:80px 28px 40px;
  display:flex;
  flex-direction:column;
}
.hdr__menu-close{
  position:absolute;
  top:18px;
  right:18px;
  width:44px;
  height:44px;
  border-radius:50%;
  border:1px solid rgba(245,199,106,0.3);
  background:rgba(245,199,106,0.06);
  display:flex;
  align-items:center;
  justify-content:center;
  transition:background-color var(--t-fast) var(--ease),
             border-color var(--t-fast) var(--ease);
}
.hdr__menu-close:hover{
  background:rgba(245,199,106,0.12);
  border-color:rgba(245,199,106,0.6);
}
.hdr__menu nav{display:flex;flex-direction:column;gap:8px;margin-top:24px}
.hdr__menu nav a{
  font-size:22px;
  font-family:var(--font-display);
  font-weight:400;
  color:var(--text-primary);
  padding:14px 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.hdr__menu nav a:hover{color:var(--gold)}
.hdr__menu-foot{margin-top:auto;padding-top:20px}

/* ------------------------------------------------------------
   Responsive — Tablet & below
   ------------------------------------------------------------ */
@media (max-width: 1024px){
  .hero__inner{grid-template-columns:1fr;gap:40px}
  .trust__grid{grid-template-columns:1fr}
  .ft__inner{grid-template-columns:1fr;gap:32px}
}

/* ------------------------------------------------------------
   Responsive — Mobile (≤767px)
   ------------------------------------------------------------ */
@media (max-width: 767px){
  :root{--pad-x:18px}

  /* Ticker */
  .ticker{height:28px;font-size:11.5px}
  .ticker__inner{gap:8px}
  .ticker__pair{font-size:10.5px}
  .ticker__live{font-size:9.5px}
  .ticker__delta{font-size:11px}

  /* Header */
  .hdr__inner{height:60px;padding:0 16px;gap:12px}
  .hdr__nav{display:none}
  .hdr__right .hdr__lang{display:none}
  .hdr__burger{display:flex}
  .hdr__right{margin-left:0}
  .logo-word{font-size:18px;letter-spacing:0.28em}
  .logo-glyph{width:26px;height:26px}
  .btn--sm{padding:8px 14px;font-size:12.5px}

  /* Hero */
  .hero{padding:24px 0 36px}
  .hero__inner{padding:0 16px;gap:24px;grid-template-columns:1fr}
  .eyebrow{font-size:10.5px;letter-spacing:0.14em}
  .hero__h1{font-size:30px;line-height:1.15;margin:8px 0 12px}
  .hero__sub{font-size:14px;line-height:1.55;margin:0 0 14px}
  .hero__bullets{gap:8px;margin:0 0 14px}
  .hero__bullets li{font-size:13px;gap:10px}
  .check{width:16px;height:16px;flex-basis:16px}
  .check::after{width:6px;height:3px}
  .hero__micro{font-size:12px;margin:0 0 0}
  .hero__chips{display:none}

  /* Mobile CTA — show between hero copy and quiz card */
  .hero__cta{
    display:flex;
    margin:18px 0 8px;
    max-height:60px;
  }

  /* Quiz card */
  .qcard{padding:20px;min-height:auto;border-radius:14px}
  .qcard__top{margin-bottom:16px}
  .qcard__counter{font-size:11px;margin-top:9px}
  .qcard__counter-sub{font-size:10.5px}
  .q__text{font-size:19px;line-height:1.32;margin:0 0 16px}
  .q__sub{font-size:13.5px;margin:-8px 0 16px}
  .q__opts{gap:9px}
  .q__opt{padding:12px 14px;gap:12px;border-radius:10px}
  .q__letter{width:32px;height:32px;flex-basis:32px;font-size:13px}
  .q__answer{font-size:13.5px;padding-top:4px;line-height:1.45}
  .qcard__foot{margin-top:14px}
  .qcard__back{font-size:13px}
  .qcard__step{font-size:11px}

  /* Trust */
  .trust{padding:32px 0 48px}
  .section-h{font-size:26px;line-height:1.2;padding:0 8px}
  .section-sub{font-size:13.5px;margin:0 0 24px;padding:0 8px}
  .trust__grid{gap:12px;grid-template-columns:1fr}
  .tcard{padding:22px}
  .tcard__icon{width:42px;height:42px;margin-bottom:14px}
  .tcard__title{font-size:18px}
  .tcard__body{font-size:13.5px}

  /* Footer */
  .ft{padding:40px 0 0}
  .ft__inner{grid-template-columns:1fr;gap:32px;padding:0 18px}
  .ft__cols{grid-template-columns:1fr 1fr;gap:24px}
  .ft__col h4{font-size:11px}
  .ft__col a{font-size:13.5px}
  .ft__desc{font-size:13px}
  .ft__legal-block{padding:0 18px;margin-top:36px}
  .ft__legal-block p{font-size:11.5px;line-height:1.6}
  .ft__legal{
    flex-direction:column;
    gap:12px;
    align-items:flex-start;
    padding:18px 18px 24px;
    margin-top:20px;
    font-size:11.5px;
  }
  .ft__legal-links{gap:18px}

  /* Result screen */
  .result__score{margin:8px 0 14px}
  .result__score-val{font-size:60px}
  .result__score-max{font-size:18px}
  .result__score-lbl{font-size:10px;letter-spacing:0.16em}
  .result__gauge{margin:0 0 18px}
  .result__gauge-track{gap:4px;padding:4px}
  .result__gauge-seg{padding:8px 4px}
  .result__gauge-lbl{font-size:10.5px;letter-spacing:0.08em}
  .result__gauge-rng{font-size:9.5px}
  .result__h{font-size:20px;line-height:1.3}
  .result__sub{font-size:13.5px;margin:0 0 18px}
  .result__offer{padding:14px 16px;margin-bottom:14px}
  .result__offer-h{font-size:12.5px;margin:0 0 10px}
  .result__offer-list li{font-size:13px;gap:10px}
  .check--circle{width:18px;height:18px;flex-basis:18px}
  .result__contact{font-size:11.5px;margin:12px 0 18px}
  .result__proof-row{gap:10px;flex-wrap:wrap;justify-content:center}
  .proof-logo{font-size:12px}
  .proof-logo--serif{font-size:13px}
  .btn--block{padding:14px 20px;font-size:14.5px}

  /* Form */
  .cform{gap:12px}
  .cform__in{padding:11px 13px;font-size:14.5px}
  .cform__lbl{font-size:11.5px}
  .cform__cc{padding:0 10px;font-size:13.5px}

  /* Background paths smaller */
  .bg-paths{opacity:0.5}
  .bg-hex{width:200px;height:200px}
}

/* ------------------------------------------------------------
   Responsive — Narrow mobile (≤380px)
   ------------------------------------------------------------ */
@media (max-width: 380px){
  .hero__h1{font-size:27px}
  .q__text{font-size:18px}
  .result__score-val{font-size:54px}
  .ft__cols{grid-template-columns:1fr}
}

/* ===========================================================
   intl-tel-input overrides (dark theme)
   =========================================================== */
.iti{width:100%}
.iti__country-list{
  background:var(--surface-2);
  border:1px solid var(--border-input);
  color:var(--text-primary);
  font-family:var(--font-body);
  font-size:14px;
  border-radius:var(--r-input);
  max-height:240px;
  z-index:200;
}
.iti__country.iti__highlight{background:rgba(245,199,106,0.10)}
.iti__divider{border-bottom-color:var(--border-soft)}
.iti--separate-dial-code .iti__selected-flag{
  background:rgba(255,255,255,0.03);
  border-right:1px solid var(--border-input);
}
.iti--separate-dial-code .iti__selected-dial-code{
  color:var(--text-primary);
  font-weight:500;
}
.iti__country-name,.iti__dial-code{color:var(--text-secondary)}
.cform__in--phone{padding-left:96px} /* leaves room for flag + dial code */

/* ---- inline validation errors (Task 7) ---- */
.cform__err{
  font-size:12px;
  color:var(--danger);
  margin-top:4px;
  display:block;
}
.cform__row.is-error .cform__in{
  border-color:var(--danger);
  background:rgba(255,107,107,0.05);
}

/* ===========================================================
   Cookie banner
   =========================================================== */
.ckb{
  position:fixed;
  left:18px; right:18px; bottom:18px;
  max-width:520px;
  margin-left:auto;
  background:rgba(11,14,28,0.95);
  backdrop-filter:blur(12px);
  border:1px solid rgba(245,199,106,0.18);
  border-radius:14px;
  padding:14px 16px;
  display:flex;
  align-items:center;
  gap:14px;
  z-index:50;
  box-shadow:0 16px 48px rgba(0,0,0,0.45);
  animation:ckbIn 320ms var(--ease) 600ms backwards;
}
@keyframes ckbIn{
  from{opacity:0; transform:translateY(20px)}
  to{opacity:1; transform:translateY(0)}
}
.ckb__txt{
  margin:0;
  font-size:12.5px;
  color:var(--text-secondary);
  line-height:1.5;
  flex:1;
}
.ckb .btn{flex:0 0 auto}
@media (max-width:520px){
  .ckb{left:12px;right:12px;bottom:12px;flex-direction:column;align-items:stretch}
  .ckb__txt{font-size:12px}
}

