/* =====================================================
   THE HERITAGE ATLAS — Design system
   Palette: oxblood, parchment, antique gold, ink, vert
   Type:    Cinzel (display), Cormorant (body), EB Garamond (long-form)
   ===================================================== */

:root{
  --ink:        #1A1410;
  --ink-soft:   #2B221C;
  --ink-mute:   #4A3F35;
  --parch-1:    #F4E8D0;
  --parch-2:    #E8D9B8;
  --parch-3:    #C9B68C;
  --gold:       #C9A961;
  --gold-deep:  #8B6F2E;
  --oxblood:    #5B0A1A;
  --oxblood-2:  #2A0508;
  --vert:       #1B3B2F;
  --azure:      #1F3A5F;
  --line:       rgba(201,169,97,0.25);
  --line-strong:rgba(201,169,97,0.55);

  --shadow-deep: 0 30px 60px -20px rgba(0,0,0,.6), 0 8px 24px -8px rgba(0,0,0,.4);
  --shadow-soft: 0 20px 40px -15px rgba(0,0,0,.45);

  --font-display: 'Cinzel', 'Times New Roman', serif;
  --font-body:    'Cormorant Garamond', 'Garamond', serif;
  --font-prose:   'EB Garamond', 'Garamond', serif;

  --max:        1240px;
  --r-sm:       6px;
  --r-md:       12px;
  --r-lg:       20px;

  --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}

/* Make sure the HTML5 [hidden] attribute always wins over CSS display rules.
   Without this, `display: grid` on .stage--summoning overrides [hidden]. */
[hidden]{ display: none !important; }
html{scroll-behavior:smooth; -webkit-text-size-adjust:100%}
body{
  background:
    radial-gradient(ellipse at 20% 0%, rgba(91,10,26,.20), transparent 55%),
    radial-gradient(ellipse at 90% 100%, rgba(31,58,95,.15), transparent 55%),
    linear-gradient(180deg, #14100C 0%, #0E0A07 100%);
  color: var(--parch-1);
  font-family: var(--font-body);
  font-size: 18px;
  line-height: 1.55;
  font-weight: 400;
  min-height: 100vh;
  overflow-x: hidden;
  letter-spacing: 0.005em;
}
img,svg{display:block; max-width:100%}
button{font:inherit; color:inherit; background:none; border:0; cursor:pointer}
a{color:inherit}
ul{list-style:none; padding:0; margin:0}

/* ---------- ambient layer ---------- */
.parchment-grain{
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background-image:
    radial-gradient(circle at 30% 40%, rgba(201,169,97,.04) 0, transparent 40%),
    radial-gradient(circle at 70% 60%, rgba(244,232,208,.03) 0, transparent 40%);
  mix-blend-mode: overlay;
  opacity: .9;
}
.parchment-grain::after{
  content:""; position:absolute; inset:0;
  background-image:
    repeating-linear-gradient(0deg, rgba(255,255,255,.012) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(0,0,0,.05) 0 1px, transparent 1px 3px);
  mix-blend-mode: overlay;
}
.vignette{
  position:fixed; inset:0; pointer-events:none; z-index:0;
  background: radial-gradient(ellipse at center, transparent 50%, rgba(0,0,0,.55) 100%);
}

.floating-motes{position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden}
.floating-motes span{
  position:absolute; width:3px; height:3px; border-radius:50%;
  background: rgba(201,169,97,.55);
  filter: blur(1px);
  animation: drift 14s linear infinite;
}
.floating-motes span:nth-child(1){left:8%;  top:80%; animation-delay:0s}
.floating-motes span:nth-child(2){left:22%; top:90%; animation-delay:-2s}
.floating-motes span:nth-child(3){left:38%; top:75%; animation-delay:-4s}
.floating-motes span:nth-child(4){left:55%; top:95%; animation-delay:-6s; width:2px; height:2px}
.floating-motes span:nth-child(5){left:68%; top:80%; animation-delay:-8s}
.floating-motes span:nth-child(6){left:82%; top:88%; animation-delay:-10s}
.floating-motes span:nth-child(7){left:91%; top:72%; animation-delay:-12s; width:4px; height:4px}
.floating-motes span:nth-child(8){left:14%; top:85%; animation-delay:-7s}

@keyframes drift{
  0%{ transform: translateY(0) translateX(0); opacity:0 }
  10%{opacity:.8}
  90%{opacity:.4}
  100%{ transform: translateY(-120vh) translateX(40px); opacity:0 }
}

/* ---------- layout primitives ---------- */
.site-header,
.stage,
.site-footer{ position:relative; z-index:1 }

.site-header{
  display:flex; align-items:center; justify-content:space-between;
  padding: 28px 48px;
  max-width: var(--max);
  margin: 0 auto;
  color: var(--parch-1);
}
.brand{
  display:inline-flex; align-items:center; gap:12px;
  text-decoration: none;
  color: inherit;
  transition: opacity .2s var(--ease);
}
.brand:hover{ opacity: .85 }
.brand:hover .brand-name__accent{ color: var(--parch-1) }
.brand-mark{
  width: 36px;
  height: 36px;
  object-fit: contain;
  color: var(--gold);                /* used by any remaining SVG brand-marks */
  mix-blend-mode: screen;            /* drops the black bg of dragon.png */
  filter: drop-shadow(0 0 6px rgba(201,169,97,.25));
  flex-shrink: 0;
  transition: filter .25s var(--ease);
}
.brand:hover .brand-mark{
  filter: drop-shadow(0 0 12px rgba(201,169,97,.55));
}
.brand-name__accent{
  color: var(--gold);
  transition: color .2s var(--ease);
}

/* Loader dragon — make it cleanly clickable */
.summoning__dragon-link{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  text-decoration: none;
  cursor: pointer;
}
.brand-name{
  font-family: var(--font-display);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 13px;
  color: var(--parch-1);
}
.header-meta__pill{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  border:1px solid var(--line);
  padding: 8px 16px;
  border-radius: 999px;
  background: rgba(201,169,97,0.04);
}

/* =====================================================
   STAGE 1 — ENTRANCE
   ===================================================== */
.stage--entrance{ padding-bottom: 80px }

.hero{
  max-width: var(--max);
  margin: 0 auto;
  padding: 16px 48px 64px;
  display: flex;
  flex-direction: column;
  gap: 28px;
}

/* top row: form (left) + dragon (right) */
.hero__top{
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 48px;
  align-items: start;
}
.hero__form-col{ position: relative }

/* centered headline + subhead block */
.hero__copy{
  text-align: center;
  max-width: 880px;
  margin: 0 auto;
  position: relative;
}
.hero__copy::before,
.hero__copy::after{
  content:"";
  display:block;
  margin: 0 auto 28px;
  width: 80px; height: 1px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
}
.hero__copy::after{ margin: 28px auto 0 }
.hero__copy .hero__lede{ margin-left: auto; margin-right: auto }

.hero__eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 28px;
}
.hero__eyebrow .dot{
  width: 36px; height:1px; background: var(--gold); display:inline-block;
}
.hero__eyebrow--free{
  flex-wrap: wrap;
  gap: 14px;
}
.hero__eyebrow-text{
  color: var(--parch-3);
  letter-spacing: .25em;
  font-size: 11px;
}
.free-pill{
  display:inline-flex; align-items:center; gap: 8px;
  padding: 7px 14px;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .25em;
  font-weight: 600;
  color: #14100C;
  background: linear-gradient(180deg, #E0C580 0%, #C9A961 50%, #8B6F2E 100%);
  border-radius: 999px;
  border: 1px solid rgba(255,235,180,.4);
  box-shadow:
    0 4px 12px -2px rgba(201,169,97,.4),
    inset 0 1px 0 rgba(255,255,255,.4),
    inset 0 -1px 0 rgba(0,0,0,.2);
  position: relative;
}
.free-pill::before{
  content:"✦";
  font-size: 10px;
  color: #14100C;
}

.hero__title{
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(40px, 5.6vw, 80px);
  line-height: 1.05;
  letter-spacing: -0.005em;
  margin: 0 0 28px;
  color: var(--parch-1);
}
.hero__title .line{ display:block }
.hero__title em{
  font-family: var(--font-body);
  font-style: italic;
  font-weight: 500;
  color: var(--gold);
}
.hero__title .line--accent{
  font-family: var(--font-body);
  font-style: italic;
  font-weight: 500;
  color: var(--gold);
  font-size: .9em;
}

.hero__lede{
  font-size: 20px;
  line-height: 1.6;
  color: var(--parch-2);
  max-width: 560px;
  margin: 0 0 36px;
  font-weight: 400;
}

/* ---------- form ---------- */
.heritage-form{
  background: linear-gradient(180deg, rgba(244,232,208,0.04), rgba(244,232,208,0.015));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 28px;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: var(--shadow-soft), inset 0 1px 0 rgba(255,255,255,.04);
  max-width: 640px;
}
.heritage-form__row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.field{ display:flex; flex-direction:column; gap:8px; position:relative }
.field__label{
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
}
.field input{
  font-family: var(--font-body);
  font-size: 20px;
  font-weight: 500;
  background: rgba(0,0,0,0.25);
  color: var(--parch-1);
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  padding: 14px 16px;
  transition: border-color .25s var(--ease), background .25s var(--ease);
  outline: none;
}
.field input::placeholder{
  color: var(--ink-mute);
  font-style: italic;
}
.field input:focus{
  border-color: var(--gold);
  background: rgba(0,0,0,0.35);
  box-shadow: 0 0 0 3px rgba(201,169,97,.12);
}
.field__hint{
  font-size: 13px;
  color: var(--parch-3);
  font-style: italic;
  opacity: .8;
}
.field input.is-error{ border-color: #B8513A }

/* ---------- CTA ---------- */
.cta{
  margin-top: 22px;
  width:100%;
  display:inline-flex; align-items:center; justify-content:center;
  gap: 14px;
  padding: 18px 28px;
  background: linear-gradient(180deg, #6E0F22 0%, #3F0712 100%);
  color: #F4E8D0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: .25em;
  text-transform: uppercase;
  border-radius: 8px;
  border: 1px solid var(--gold);
  position: relative;
  overflow: hidden;
  transition: transform .25s var(--ease), box-shadow .25s var(--ease);
  box-shadow:
    0 16px 32px -10px rgba(91,10,26,.6),
    inset 0 1px 0 rgba(255,235,180,.18),
    inset 0 -1px 0 rgba(0,0,0,.5);
}
.cta::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 50% 0%, rgba(255,235,180,.18), transparent 60%);
  pointer-events:none;
}
.cta:hover{
  transform: translateY(-1px);
  box-shadow:
    0 22px 40px -12px rgba(91,10,26,.7),
    inset 0 1px 0 rgba(255,235,180,.25),
    inset 0 -1px 0 rgba(0,0,0,.5);
}
.cta:active{ transform: translateY(0) }
.cta__seal{ color: var(--gold); display:inline-flex }
.cta__chev{ font-family: var(--font-display); transition: transform .25s var(--ease) }
.cta:hover .cta__chev{ transform: translateX(4px) }
.cta[disabled]{ opacity:.7; cursor: progress }

.cta-subtext{
  display:flex; align-items:center; justify-content:center;
  gap: 8px;
  margin: 14px 0 0;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--gold);
  text-align: center;
}
.cta-subtext svg{ flex-shrink: 0; }

.heritage-form__legal{
  font-size: 13px;
  color: var(--parch-3);
  margin: 14px 0 0;
  font-style: italic;
  line-height: 1.55;
  opacity: .7;
  text-align: center;
}

/* ---------- proof strip ---------- */
.proof{
  display:flex; align-items:center; gap: 22px;
  margin-top: 32px;
  padding-top: 28px;
  border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.proof__count strong{
  font-family: var(--font-display);
  font-size: 24px;
  color: var(--parch-1);
  display:block;
  line-height: 1;
}
.proof__count span{
  font-size: 12px;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--parch-3);
}
.proof__avatars{ display:flex }
.proof__avatars li{
  width: 30px; height: 30px; border-radius: 50%;
  display:grid; place-items:center;
  background: var(--c, var(--gold));
  color: var(--parch-1);
  font-family: var(--font-display);
  font-size: 12px;
  border: 2px solid #14100C;
  margin-left: -8px;
}
.proof__avatars li:first-child{ margin-left: 0 }
.proof__stars{
  font-size: 14px;
  color: var(--gold);
  letter-spacing: .15em;
}
.proof__stars em{
  color: var(--parch-2);
  font-style: italic;
  letter-spacing: 0;
  margin-left: 8px;
}

/* ---------- hero crest (crowned dragon image) ---------- */
.hero__crest{
  position:relative;
  display:grid;
  place-items:center;
  align-self: start;             /* sit at top of its grid row */
  animation: crest-float 8s ease-in-out infinite;
}
.hero__crest img{
  width: min(294px, 70%);        /* 30% smaller than before */
  height: auto;
  display: block;
  /* drop the pure-black background of the source PNG */
  mix-blend-mode: screen;
  filter:
    drop-shadow(0 30px 40px rgba(0,0,0,.6))
    drop-shadow(0 0 30px rgba(201,169,97,.18));
  position: relative;
  z-index: 2;
}
.hero__crest-glow{
  position: absolute;
  inset: 8% 8% 8% 8%;
  background:
    radial-gradient(circle at 50% 45%,
      rgba(201,169,97,.22) 0%,
      rgba(91,10,26,.18) 35%,
      rgba(0,0,0,0) 70%);
  filter: blur(20px);
  z-index: 1;
  pointer-events: none;
  animation: crest-glow-pulse 8s ease-in-out infinite;
}
@keyframes crest-float{
  /* Includes a -28px static offset so the crest sits visibly higher,
     so the headline below clears the fold on a 1080p viewport. */
  0%,100%{ transform: translateY(-28px) rotate(-1deg) }
  50%{   transform: translateY(-42px) rotate(1deg) }
}
@keyframes crest-glow-pulse{
  0%,100%{ opacity: .8; transform: scale(1) }
  50%{ opacity: 1; transform: scale(1.05) }
}

/* ---------- story strip ---------- */
.story-strip{
  max-width: var(--max);
  margin: 0 auto;
  padding: 80px 48px 0;
  display:grid; grid-template-columns: repeat(3, 1fr); gap: 48px;
}
.story-strip__col h3{
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 600;
  letter-spacing: .04em;
  margin: 0 0 12px;
  color: var(--parch-1);
}
.story-strip__col p{
  margin: 0;
  font-size: 16px;
  color: var(--parch-2);
  line-height: 1.65;
}

/* =====================================================
   STAGE 2 — SUMMONING
   ===================================================== */
.stage--summoning{
  display:grid; place-items:center;
  min-height: 100vh;
  padding: 60px 32px;
}
.summoning{
  max-width: 600px;
  text-align: center;
  position: relative;
}
.summoning__ring{
  width: 360px; height: 360px;
  margin: 0 auto;
  position: relative;
  display: grid; place-items:center;
}
.summoning__ring svg{ width: 100%; height: 100%; }
.summoning__dragon{
  width: 200px; height: 200px;
  object-fit: contain;
  mix-blend-mode: screen;
  filter:
    drop-shadow(0 0 20px rgba(201,169,97,.4))
    drop-shadow(0 8px 16px rgba(0,0,0,.6));
  animation: dragon-breathe 4s ease-in-out infinite;
  transition: transform .25s var(--ease);
}
.summoning__dragon-link:hover .summoning__dragon{
  transform: scale(1.05);
}

/* ---------- 15s countdown ---------- */
#countdown-arc{
  /* JS animates stroke-dashoffset from 0 → 100 over 15s */
  transition: stroke-dashoffset 1s linear;
  filter: drop-shadow(0 0 6px rgba(201,169,97,.5));
}

.summoning__countdown{
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  gap: 10px;
  margin: 32px auto 0;
  font-family: var(--font-display);
}
.summoning__countdown-number{
  font-size: 64px;
  line-height: 1;
  font-weight: 700;
  color: var(--gold);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 0 28px rgba(201,169,97,.45);
  display: inline-block;
  min-width: 88px;
  text-align: right;
}
.summoning__countdown-number.is-ticking{
  animation: countdown-tick .45s ease-out;
}
.summoning__countdown-number.is-done{
  color: var(--parch-2);
  font-size: 22px;
  letter-spacing: .25em;
  text-transform: uppercase;
  text-align: center;
  min-width: 0;
}
.summoning__countdown-unit{
  font-size: 13px;
  letter-spacing: .3em;
  color: var(--parch-3);
  text-transform: uppercase;
}
.summoning__countdown-unit.is-hidden{ display: none }

.summoning__label{
  margin: 18px 0 0;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .3em;
  text-transform: uppercase;
  color: var(--parch-3);
}

@keyframes countdown-tick{
  0%   { transform: scale(1.18); color: var(--parch-1); text-shadow: 0 0 32px rgba(255,235,180,.7) }
  100% { transform: scale(1);    color: var(--gold);    text-shadow: 0 0 28px rgba(201,169,97,.45) }
}
@keyframes dragon-breathe{
  0%,100%{ transform: scale(1); opacity: .85 }
  50%{ transform: scale(1.06); opacity: 1 }
}
.ring-spin{ transform-origin: 150px 150px; animation: spin 16s linear infinite }
.ring-spin-rev{ transform-origin: 150px 150px; animation: spin 22s linear infinite reverse }
@keyframes spin{ to{ transform: rotate(360deg) } }

.summoning__title{
  font-family: var(--font-display);
  font-size: 36px;
  letter-spacing: .04em;
  margin: 0 0 28px;
  color: var(--parch-1);
}
.summoning__steps{
  display:flex; flex-direction:column; gap:14px;
  text-align:left;
  max-width: 380px;
  margin: 0 auto;
}
.summoning__steps li{
  display:flex; align-items:center; gap:14px;
  padding: 12px 18px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: rgba(244,232,208,0.02);
  font-size: 15px;
  color: var(--parch-3);
  transition: background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.summoning__steps li.is-active{
  color: var(--parch-1);
  border-color: var(--gold);
  background: rgba(201,169,97,0.06);
}
.summoning__steps li.is-done .bullet{
  background: var(--gold);
  border-color: var(--gold);
}
.summoning__steps li.is-done .bullet::after{
  content: "✓";
  position:absolute; inset:0;
  display:grid; place-items:center;
  color: var(--ink);
  font-weight: 800;
  font-size: 11px;
}
.bullet{
  width: 14px; height:14px; border-radius:50%;
  border: 1.5px solid var(--gold);
  position:relative;
  flex-shrink:0;
}
.summoning__steps li.is-active .bullet{
  background: rgba(201,169,97,.4);
  animation: pulse 1.2s ease-in-out infinite;
}
@keyframes pulse{
  0%,100%{ box-shadow: 0 0 0 0 rgba(201,169,97,.5) }
  50%{ box-shadow: 0 0 0 8px rgba(201,169,97,0) }
}

/* =====================================================
   STAGE 3 — REVEAL
   ===================================================== */
.stage--reveal{
  max-width: var(--max);
  margin: 0 auto;
  padding: 60px 48px 100px;
}

/* ---------- AI ancestral landscape ---------- */
.ancestral-image{
  position: relative;
  margin: 0 0 56px;
  border-radius: var(--r-lg);
  overflow: hidden;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--line);
  box-shadow: var(--shadow-deep);
  background:
    radial-gradient(ellipse at 50% 30%, rgba(91,10,26,.4), rgba(20,16,12,1) 75%);
}
.ancestral-image::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    linear-gradient(180deg, transparent 60%, rgba(20,16,12,0.7) 100%),
    radial-gradient(ellipse at center, transparent 60%, rgba(20,16,12,0.4) 100%);
}
.ancestral-image img{
  width: 100%; height: 100%; object-fit: cover; display:block;
  opacity: 0;
  transition: opacity 1.6s var(--ease);
  filter: saturate(1.05) contrast(1.05);
}
.ancestral-image.is-loaded img{ opacity: 1 }
.ancestral-image figcaption{
  position:absolute;
  bottom: 16px; left: 24px; right: 24px;
  font-family: var(--font-body);
  font-style: italic;
  font-size: 14px;
  color: var(--parch-2);
  text-shadow: 0 2px 6px rgba(0,0,0,.8);
  letter-spacing: .02em;
  z-index: 2;
}
.ancestral-image__loading{
  position:absolute; inset:0;
  display:grid; place-items:center; place-content:center;
  z-index: 1;
  text-align:center;
  transition: opacity .8s var(--ease);
}
.ancestral-image.is-loaded .ancestral-image__loading{
  opacity: 0; pointer-events:none;
}
.ancestral-image__loading p{
  margin-top: 16px;
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .3em;
  color: var(--gold);
  text-transform: uppercase;
}
.ancestral-image__loading span{
  display:inline-block;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--gold);
  margin: 0 4px;
  animation: load-dots 1.2s ease-in-out infinite;
}
.ancestral-image__loading span:nth-child(2){ animation-delay: .2s }
.ancestral-image__loading span:nth-child(3){ animation-delay: .4s }
@keyframes load-dots{
  0%,100%{ opacity: .3; transform: translateY(0) }
  50%{ opacity: 1; transform: translateY(-6px) }
}

/* confidence pill */
.reveal-header__confidence{
  display:inline-block;
  margin: 14px 0 0;
  padding: 4px 12px;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-family: var(--font-display);
  font-size: 10px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--parch-3);
  background: rgba(244,232,208,0.03);
}
.reveal-header__confidence.is-high  { color: var(--gold); border-color: var(--gold) }
.reveal-header__confidence.is-low   { color: #B8853A; border-color: rgba(184,133,58,.5) }

/* sources list */
.reveal-block--sources{
  margin-top: 32px;
  padding-top: 32px;
  border-top: 1px solid var(--line);
  text-align: center;
}
.sources-list{
  display:flex; flex-wrap:wrap; justify-content:center; gap: 10px;
  margin: 18px auto 0; max-width: 760px;
}
.sources-list li{
  flex: 0 1 auto;
}
.sources-list a{
  display:inline-flex; align-items:center; gap: 8px;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(244,232,208,0.02);
  color: var(--parch-2);
  font-family: var(--font-body);
  font-size: 13px;
  text-decoration: none;
  max-width: 320px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  transition: border-color .25s var(--ease), color .25s var(--ease);
}
.sources-list a:hover{
  border-color: var(--gold);
  color: var(--parch-1);
}
.sources-list a::before{
  content: "↗";
  color: var(--gold);
  font-size: 12px;
}

.reveal-header{
  text-align:center;
  padding: 32px 0 56px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 64px;
  position: relative;
}
.reveal-header::after{
  content:"❦";
  position:absolute;
  bottom: -14px; left:50%; transform:translateX(-50%);
  background: #14100C;
  padding: 0 18px;
  color: var(--gold);
  font-size: 22px;
  letter-spacing: .2em;
}
.reveal-header__kicker{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 12px;
}
.reveal-header__name{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: clamp(56px, 9vw, 120px);
  line-height: 1;
  margin: 0 0 20px;
  color: var(--parch-1);
  letter-spacing: -0.01em;
}
.reveal-header__motto{
  font-family: var(--font-body);
  font-style: italic;
  font-size: 22px;
  color: var(--gold);
  margin: 0;
  letter-spacing: .03em;
}

/* ---------- crest stage ---------- */
.reveal-block{
  margin-bottom: 96px;
  position: relative;
}
.reveal-block--crest{
  display: flex;
  justify-content: center;
}
.reveal-block--crest .crest-stage{
  width: 100%;
  max-width: 620px;
}

.crest-stage__plate{
  background: linear-gradient(180deg, rgba(244,232,208,0.04), rgba(244,232,208,0.01));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 8px 32px;
  position:relative;
}
.crest-stage__plate::before,
.crest-stage__plate::after{
  content:""; position:absolute; left:24px; right:24px;
  height:1px; background: var(--line);
}
.crest-stage__plate::before{ top:0 } .crest-stage__plate::after{ bottom:0 }
.plate-row{
  display:grid; grid-template-columns: 140px 1fr;
  align-items:center;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
  gap: 24px;
}
.plate-row:last-child{ border-bottom: 0 }
.plate-label{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
}
.plate-value{
  font-family: var(--font-prose);
  font-size: 19px;
  color: var(--parch-1);
}

/* ---------- reveal blocks generic ---------- */
.reveal-block--meaning,
.reveal-block--map,
.reveal-block--role{
  display:grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items:center;
}
.reveal-block--map{ grid-template-columns: 1fr 1.05fr }
.reveal-block--role{ grid-template-columns: 1fr; max-width: 880px; margin-left:auto; margin-right:auto; text-align:center }

.reveal-block__eyebrow{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--gold);
  display:block;
  margin-bottom: 16px;
}
.reveal-block__title{
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.15;
  margin: 0 0 22px;
  color: var(--parch-1);
}
.reveal-block__body{
  font-family: var(--font-prose);
  font-size: 19px;
  line-height: 1.7;
  color: var(--parch-2);
  margin: 0;
}
.reveal-block__rune{
  display:grid; place-items:center;
  font-family: var(--font-display);
  font-size: clamp(120px, 18vw, 220px);
  color: var(--gold);
  opacity: .35;
  text-shadow: 0 4px 20px rgba(201,169,97,.2);
  font-weight: 700;
  letter-spacing: -.05em;
}

/* ---------- map block ---------- */
.reveal-block__map{
  position:relative;
  display:grid; place-items:center;
  filter: drop-shadow(0 20px 30px rgba(0,0,0,.4));
}
.reveal-block__map svg{ width:100%; max-width: 480px; height:auto }
.region-legend{
  margin: 24px 0 0;
  display:flex; flex-direction:column; gap: 8px;
}
.region-legend li{
  display:flex; align-items:center; gap: 12px;
  font-size: 15px; color: var(--parch-2);
}
.region-legend .swatch{
  width: 18px; height:10px; border-radius: 2px;
  border: 1px solid rgba(0,0,0,.4);
}
.region-legend .pct{
  margin-left:auto;
  font-family: var(--font-display);
  font-size: 12px;
  color: var(--gold);
  letter-spacing: .1em;
}

/* ---------- share card ---------- */
.reveal-block--share{ margin-bottom: 48px }
.share-card{
  background:
    radial-gradient(ellipse at top, rgba(201,169,97,.08), transparent 60%),
    linear-gradient(180deg, rgba(244,232,208,0.04), rgba(244,232,208,0.01));
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 48px;
  text-align: center;
}
.share-card h3{
  font-family: var(--font-display);
  font-size: 32px;
  margin: 0 0 12px;
  color: var(--parch-1);
}
.share-card p{
  margin: 0 0 28px;
  color: var(--parch-2);
  font-size: 17px;
}
.share-card__actions{
  display:flex; justify-content:center; gap: 14px; flex-wrap: wrap;
}
.share-btn{
  display:inline-flex; align-items:center; gap:10px;
  padding: 14px 22px;
  border: 1px solid var(--line-strong);
  border-radius: 8px;
  background: rgba(0,0,0,.25);
  color: var(--parch-1);
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .2em;
  text-transform: uppercase;
  text-decoration:none;
  transition: background .25s var(--ease), border-color .25s var(--ease), transform .2s var(--ease);
}
.share-btn:hover{
  background: rgba(201,169,97,.08);
  border-color: var(--gold);
  transform: translateY(-1px);
}
.share-btn--x{ background: linear-gradient(180deg, #1a1a1a, #0a0a0a) }

/* ---------- "Going Deeper" / White Dragon flag card ---------- */
.next-card{
  display: grid;
  grid-template-columns: minmax(180px, 280px) 1fr;
  gap: 36px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 40px;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(91,10,26,.22), transparent 60%),
    linear-gradient(135deg, rgba(91,10,26,.10), rgba(20,16,12,.6));
  max-width: 880px;
  margin: 0 auto;
  text-decoration: none;
  color: inherit;
  transition: border-color .3s var(--ease), transform .3s var(--ease), box-shadow .3s var(--ease);
  position: relative;
  overflow: hidden;
}
.next-card::before{
  content:"";
  position: absolute; inset: 0;
  background: radial-gradient(ellipse at 20% 20%, rgba(201,169,97,0.08), transparent 60%);
  opacity: 0;
  transition: opacity .4s var(--ease);
  pointer-events: none;
}
.next-card:hover{
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: 0 30px 60px -25px rgba(91,10,26,.6);
}
.next-card:hover::before{ opacity: 1 }

.next-card__visual{
  display: grid; place-items: center;
  position: relative;
}
.next-card__dragon{
  width: 100%;
  max-width: 240px;
  height: auto;
  mix-blend-mode: screen;
  filter:
    drop-shadow(0 0 30px rgba(201,169,97,.35))
    drop-shadow(0 16px 24px rgba(0,0,0,.6));
  transition: transform .5s var(--ease), filter .4s var(--ease);
}
.next-card:hover .next-card__dragon{
  transform: scale(1.05) rotate(-2deg);
  filter:
    drop-shadow(0 0 40px rgba(201,169,97,.55))
    drop-shadow(0 16px 24px rgba(0,0,0,.6));
}

.next-card__copy{ position: relative; z-index: 1 }
.next-card__eyebrow{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .4em;
  text-transform: uppercase;
  color: var(--gold);
  display:block; margin-bottom: 14px;
}
.next-card h3{
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 32px;
  margin: 0 0 18px;
  color: var(--parch-1);
  letter-spacing: -0.005em;
}
.next-card__lede{
  font-family: var(--font-body);
  font-style: italic;
  font-size: 22px !important;
  color: var(--gold) !important;
  margin: 0 0 16px !important;
}
.next-card p{
  color: var(--parch-2);
  margin: 0 0 14px;
  font-size: 16px;
  line-height: 1.65;
}
.next-card p:last-of-type{ margin-bottom: 22px }
.next-card__cta{
  display:inline-block;
  padding: 14px 28px;
  border: 1px solid var(--gold);
  border-radius: 8px;
  color: var(--gold);
  font-family: var(--font-display);
  font-size: 12px;
  letter-spacing: .25em;
  text-transform: uppercase;
  text-decoration: none;
  transition: background .25s var(--ease), color .25s var(--ease);
}
.next-card:hover .next-card__cta{
  background: var(--gold);
  color: var(--ink);
}

/* anglo.jpg below the CTA, spanning full card width */
.next-card__anglo{
  grid-column: 1 / -1;
  width: 100%;
  height: auto;
  margin-top: 12px;
  border-radius: var(--r-md);
  border: 1px solid var(--line);
  box-shadow: 0 20px 40px -20px rgba(0,0,0,.6);
  display: block;
  filter: saturate(1.05);
  transition: transform .5s var(--ease), box-shadow .4s var(--ease);
}
.next-card:hover .next-card__anglo{
  transform: translateY(-2px);
  box-shadow: 0 28px 50px -22px rgba(0,0,0,.7);
}

@media (max-width: 720px){
  .next-card{
    grid-template-columns: 1fr;
    text-align: center;
    padding: 32px 24px;
    gap: 24px;
  }
  .next-card__dragon{ max-width: 180px }
}

.reveal-disclaimer{
  margin-top: 56px;
  font-size: 14px;
  font-style: italic;
  color: var(--parch-3);
  line-height: 1.7;
  text-align:center;
  max-width: 720px;
  margin-left:auto; margin-right:auto;
  opacity: .85;
}

/* =====================================================
   FOOTER
   ===================================================== */
.site-footer{
  border-top: 1px solid var(--line);
  margin-top: 60px;
  padding: 64px 48px 28px;
  max-width: var(--max);
  margin-left:auto; margin-right:auto;
  display:grid; grid-template-columns: 1.4fr 1fr 1fr; gap: 48px;
}
.site-footer__col p{ color: var(--parch-3); font-size: 15px; margin: 16px 0 0 }
.site-footer__col h4{
  font-family: var(--font-display);
  font-size: 11px;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--gold);
  margin: 0 0 16px;
}
.site-footer__col ul li{
  font-size: 14px; color: var(--parch-3); padding: 4px 0;
  border-bottom: 1px dashed rgba(201,169,97,.15);
}
.site-footer__col ul li:last-child{ border:0 }
.site-footer__bar{
  grid-column: 1 / -1;
  margin-top: 40px;
  padding-top: 24px;
  border-top: 1px solid var(--line);
  display:flex; justify-content:space-between;
  font-size: 13px; color: var(--parch-3);
  letter-spacing: .05em;
}

/* =====================================================
   ANIMATIONS — reveal stage
   ===================================================== */
[data-stage="reveal"] .reveal-block,
[data-stage="reveal"] .reveal-header,
[data-stage="reveal"] .ancestral-image{
  opacity: 0;
  transform: translateY(28px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
[data-stage="reveal"].is-revealed .ancestral-image{ opacity:1; transform:none; transition-delay: 0s }
[data-stage="reveal"].is-revealed .reveal-header{ opacity:1; transform:none; transition-delay: .15s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(1){ opacity:1; transform:none; transition-delay: .30s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(2){ opacity:1; transform:none; transition-delay: .50s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(3){ opacity:1; transform:none; transition-delay: .70s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(4){ opacity:1; transform:none; transition-delay: .90s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(5){ opacity:1; transform:none; transition-delay: 1.10s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(6){ opacity:1; transform:none; transition-delay: 1.30s }
[data-stage="reveal"].is-revealed .reveal-block:nth-of-type(7){ opacity:1; transform:none; transition-delay: 1.50s }

/* Map regions */
.uk-region{
  fill: #2A221A;
  stroke: #5B4A30;
  stroke-width: 1.2;
  transition: fill .8s var(--ease), filter .3s var(--ease);
  cursor: default;
}
.uk-region.is-lit-1{ fill: #6B4014; }
.uk-region.is-lit-2{ fill: #8E5418; }
.uk-region.is-lit-3{ fill: #B5701F; }
.uk-region.is-lit-4{ fill: #D49236; }
.uk-region.is-lit-5{ fill: #EBB766; }
.uk-region:hover{ filter: brightness(1.15) }
.uk-label{
  font-family: var(--font-display);
  font-size: 10px;
  fill: rgba(244,232,208,.55);
  letter-spacing: .1em;
  pointer-events: none;
  text-anchor: middle;
}
.uk-pin{
  fill: var(--gold);
  filter: drop-shadow(0 0 8px rgba(201,169,97,.7));
  animation: pin-pulse 2.4s ease-in-out infinite;
  transform-box: fill-box;
  transform-origin: center;
}
@keyframes pin-pulse{
  0%,100%{ transform: scale(1); opacity: .9 }
  50%{ transform: scale(1.15); opacity: 1 }
}

/* =====================================================
   RESPONSIVE
   ===================================================== */
@media (max-width: 980px){
  .site-header{ padding: 22px 24px }
  .header-meta__pill{ display:none }
  .hero{
    padding: 24px 24px 60px;
    gap: 40px;
  }
  .hero__top{
    grid-template-columns: 1fr;
    gap: 28px;
  }
  .hero__crest{ order: -1 }   /* dragon above form on mobile */
  .hero__crest img{ width: 240px }
  .hero__copy::before,
  .hero__copy::after{ width: 50px }
  .hero__lede{ font-size: 18px }
  .heritage-form{ padding: 22px }
  .heritage-form__row{ grid-template-columns: 1fr; gap: 14px }
  .story-strip{ grid-template-columns: 1fr; padding: 48px 24px 0; gap: 32px }

  .stage--reveal{ padding: 40px 24px 60px }
  .reveal-block{ margin-bottom: 64px }
  .reveal-block--crest,
  .reveal-block--meaning,
  .reveal-block--map{
    grid-template-columns: 1fr; gap: 32px;
  }
  .crest-stage__plate{ padding: 0 24px }
  .plate-row{ grid-template-columns: 110px 1fr; padding: 18px 0 }
  .plate-value{ font-size: 17px }
  .share-card{ padding: 32px 22px }
  .next-card{ padding: 28px 22px }

  .site-footer{ grid-template-columns: 1fr; padding: 48px 24px 24px; gap: 32px }
  .site-footer__bar{ flex-direction:column; gap: 8px; text-align:center }

  .stage--summoning{ padding: 40px 24px }
  .summoning__ring{ width: 240px; height: 240px }
  .summoning__title{ font-size: 26px }
}

@media (max-width: 480px){
  body{ font-size: 17px }
  .hero__title{ font-size: 38px }
  .reveal-header__name{ font-size: 48px }
  .cta{ font-size: 13px; padding: 16px 20px; letter-spacing: .15em }
  .proof{ gap: 14px }
  .proof__stars em{ display:block; margin: 6px 0 0 }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration: 0.001ms !important;
    transition-duration: 0.001ms !important;
  }
  .floating-motes{ display:none }
}
