/* =====================================================================
   THE VEYLITH — bespoke "recovered field archive" series microsite
   Clinical sci-fi horror: near-black, violet bioluminescence, scanlines,
   redacted/monospace archive type. An interactive ascending hierarchy
   (CSS-only tier selector). Built from the Veylith Hierarchy archive.
   ===================================================================== */
@font-face{font-family:'Fraunces';font-style:italic;font-weight:400;font-display:swap;src:url('/assets/fonts/fraunces-400-italic.woff2') format('woff2');}

body[data-page="veylith"]{
  --void:#060509; --panel:#0d0a14; --panel-2:#120d1c; --line:rgba(160,120,255,.16);
  --ink:#ece8f5; --muted:#8e85a6; --violet:#9b6bff; --violet-2:#c4a6ff; --cyan:#5ad7ff;
  --sans:'Archivo',system-ui,sans-serif; --mono:ui-monospace,'Cascadia Code',Consolas,monospace; --serif:'Fraunces',Georgia,serif;
  background:var(--void); color:var(--ink); padding-top:var(--nav-h); font-family:var(--sans);
  line-height:1.7; overflow-x:hidden;
}
body[data-page="veylith"]::before{
  content:"";position:fixed;inset:0;z-index:-2;pointer-events:none;
  background:radial-gradient(60vw 55vh at 70% -10%,rgba(155,107,255,.22),transparent 60%),
    radial-gradient(45vw 45vh at 0% 30%,rgba(90,215,255,.10),transparent 60%),var(--void);
}
/* faint scanlines — archive monitor feel */
body[data-page="veylith"]::after{
  content:"";position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.5;
  background:repeating-linear-gradient(180deg,transparent 0 3px,rgba(0,0,0,.18) 3px 4px)}
.vy{max-width:1180px;margin-inline:auto;padding-inline:clamp(18px,4vw,44px)}
.vy-narrow{max-width:760px}
body[data-page="veylith"] h1,body[data-page="veylith"] h2,body[data-page="veylith"] h3{font-weight:800;text-transform:uppercase;letter-spacing:.02em;line-height:1.02}
.vy-tag{font-family:var(--mono);text-transform:uppercase;letter-spacing:.26em;font-size:.72rem;color:var(--violet-2);display:inline-flex;align-items:center;gap:.6em}
.vy-tag::before{content:"▣";color:var(--violet)}
.vy-quote-line{font-family:var(--serif);font-style:italic;color:var(--violet-2)}

/* ---- HERO ---------------------------------------------------------- */
.vy-hero{position:relative;min-height:min(94vh,880px);display:flex;align-items:center;overflow:hidden}
.vy-hero .bg{position:absolute;inset:0;z-index:-1}
.vy-hero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 20%}
.vy-hero .bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(90deg,var(--void) 8%,rgba(6,5,9,.55) 45%,rgba(6,5,9,.2) 100%),
  linear-gradient(0deg,var(--void),transparent 40%)}
.vy-hero .inner{position:relative;z-index:1;max-width:680px}
.vy-hero .crumb a{color:var(--violet-2);font-weight:600;font-size:.85rem}
.vy-hero .classified{font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;color:var(--muted);margin:1rem 0 .4rem;text-transform:uppercase}
.vy-hero h1{font-size:clamp(3rem,10vw,7rem);letter-spacing:.04em}
.vy-hero .sub{font-family:var(--mono);color:var(--violet-2);letter-spacing:.12em;text-transform:uppercase;font-size:.82rem;margin-top:.6rem}
.vy-hero .lead{font-family:var(--serif);font-style:italic;font-size:clamp(1.2rem,2.4vw,1.8rem);color:var(--ink);margin-top:1.4rem;max-width:24ch}
.vy-hero .cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:2rem}
.btn-vy{display:inline-flex;align-items:center;gap:.5em;background:var(--violet);color:#0a0612;font-weight:700;
  font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em;font-size:.82rem;padding:.95em 1.6em;border-radius:4px;
  box-shadow:0 12px 40px -12px rgba(155,107,255,.7);transition:transform .18s,box-shadow .18s}
.btn-vy:hover{transform:translateY(-2px);box-shadow:0 20px 54px -14px rgba(155,107,255,.9)}
.btn-vy.ghost{background:transparent;border:1px solid var(--line);color:var(--ink);box-shadow:none}
.btn-vy.ghost:hover{border-color:var(--violet);color:var(--violet-2)}

/* ---- INTRO --------------------------------------------------------- */
.vy-intro{padding:clamp(56px,8vw,120px) 0;text-align:center}
.vy-intro h2{font-size:clamp(1.9rem,4.4vw,3rem);margin:1rem auto;max-width:22ch}
.vy-intro p{color:var(--muted);max-width:62ch;margin:0 auto;font-size:1.08rem}
.vy-intro .em{color:var(--violet-2)}

/* ---- quote band ---------------------------------------------------- */
.vy-band{padding:clamp(48px,8vw,110px) 0;text-align:center;background:linear-gradient(180deg,var(--panel),var(--void));border-block:1px solid var(--line)}
.vy-band blockquote{font-family:var(--serif);font-style:italic;font-size:clamp(1.5rem,3.6vw,2.6rem);line-height:1.3;max-width:26ch;margin:0 auto}
.vy-band cite{display:block;font-family:var(--mono);font-style:normal;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-top:1.2rem}

/* ---- HIERARCHY (CSS tier selector) --------------------------------- */
.vy-hier{padding:clamp(56px,8vw,120px) 0}
.vy-head{text-align:center;max-width:680px;margin:0 auto clamp(28px,4vw,48px)}
.vy-head h2{font-size:clamp(2rem,4.6vw,3.4rem);margin:.8rem 0}
.vy-head p{color:var(--muted)}
.tiers input{position:absolute;opacity:0;pointer-events:none}
.tier-rail{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem;margin-bottom:2rem}
.tier-rail label{cursor:pointer;font-family:var(--mono);font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;
  padding:.65em 1em;border:1px solid var(--line);border-radius:4px;color:var(--muted);transition:.2s;display:flex;gap:.5em;align-items:center}
.tier-rail label .rn{color:var(--violet)}
.tier-rail label:hover{color:var(--violet-2);border-color:var(--violet)}
.tier-panel{display:none;animation:vyfade .5s ease}
@keyframes vyfade{from{opacity:0;transform:translateY(12px)}}
.tier-panel .inner{display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(28px,5vw,60px);align-items:center}
.tier-panel .fig{position:relative;display:grid;place-items:center;min-height:380px}
.tier-panel .fig::before{content:"";position:absolute;width:70%;aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,rgba(155,107,255,.35),transparent 65%);filter:blur(10px)}
.tier-panel .fig img{position:relative;max-height:520px;width:auto;filter:drop-shadow(0 20px 50px rgba(0,0,0,.7))}
.tier-panel .desig{font-family:var(--mono);color:var(--violet);letter-spacing:.16em;font-size:.8rem;text-transform:uppercase}
.tier-panel h3{font-size:clamp(1.8rem,4vw,2.8rem);margin:.3rem 0 .4rem}
.tier-panel .epithet{font-family:var(--serif);font-style:italic;color:var(--violet-2);font-size:1.3rem;margin-bottom:1rem}
.tier-panel p.desc{color:var(--muted);max-width:54ch;margin-bottom:1.2rem}
.tier-panel .obs{border-left:2px solid var(--violet);padding:.4rem 0 .4rem 1rem;font-family:var(--serif);font-style:italic;color:var(--ink);margin-bottom:1.2rem}
.tier-panel .traits{display:flex;flex-wrap:wrap;gap:.5rem}
.tier-panel .traits span{font-family:var(--mono);font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--violet-2);border:1px solid var(--line);padding:.4em .7em;border-radius:3px}
.tiers > input:nth-of-type(1):checked ~ .tier-panels .tier-panel:nth-child(1),
.tiers > input:nth-of-type(2):checked ~ .tier-panels .tier-panel:nth-child(2),
.tiers > input:nth-of-type(3):checked ~ .tier-panels .tier-panel:nth-child(3),
.tiers > input:nth-of-type(4):checked ~ .tier-panels .tier-panel:nth-child(4),
.tiers > input:nth-of-type(5):checked ~ .tier-panels .tier-panel:nth-child(5),
.tiers > input:nth-of-type(6):checked ~ .tier-panels .tier-panel:nth-child(6){display:block}
.tiers > input:nth-of-type(1):checked ~ .tier-rail label:nth-child(1),
.tiers > input:nth-of-type(2):checked ~ .tier-rail label:nth-child(2),
.tiers > input:nth-of-type(3):checked ~ .tier-rail label:nth-child(3),
.tiers > input:nth-of-type(4):checked ~ .tier-rail label:nth-child(4),
.tiers > input:nth-of-type(5):checked ~ .tier-rail label:nth-child(5),
.tiers > input:nth-of-type(6):checked ~ .tier-rail label:nth-child(6){background:var(--violet);color:#0a0612;border-color:transparent}
.tiers > input:nth-of-type(1):checked ~ .tier-rail label:nth-child(1) .rn,
.tiers > input:nth-of-type(2):checked ~ .tier-rail label:nth-child(2) .rn,
.tiers > input:nth-of-type(3):checked ~ .tier-rail label:nth-child(3) .rn,
.tiers > input:nth-of-type(4):checked ~ .tier-rail label:nth-child(4) .rn,
.tiers > input:nth-of-type(5):checked ~ .tier-rail label:nth-child(5) .rn,
.tiers > input:nth-of-type(6):checked ~ .tier-rail label:nth-child(6) .rn{color:#0a0612}
@media(max-width:760px){.tier-panel .inner{grid-template-columns:1fr}.tier-panel .fig{order:-1;min-height:300px}}

/* ---- ASCENSION STRIP ----------------------------------------------- */
.vy-strip{padding:clamp(48px,7vw,100px) 0;background:linear-gradient(180deg,var(--panel),var(--void));border-block:1px solid var(--line)}
.strip-row{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;align-items:end}
@media(max-width:760px){.strip-row{grid-template-columns:repeat(3,1fr)}}
.strip-row figure{text-align:center}
.strip-row img{height:clamp(110px,16vw,190px);width:auto;margin:0 auto;filter:drop-shadow(0 10px 24px rgba(155,107,255,.3));transition:transform .3s,filter .3s}
.strip-row figure:hover img{transform:translateY(-6px);filter:drop-shadow(0 16px 30px rgba(155,107,255,.7))}
.strip-row figcaption{font-family:var(--mono);font-size:.66rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-top:.6rem}
.strip-row figcaption b{color:var(--violet-2);display:block}

/* ---- CTA ----------------------------------------------------------- */
.vy-cta{padding:clamp(60px,9vw,130px) 0;text-align:center}
.vy-cta h2{font-size:clamp(2rem,5vw,3.4rem);margin:1rem 0}
.vy-cta p{color:var(--muted);max-width:50ch;margin:0 auto 2rem}
.vy-cta .cta{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* =====================================================================
   MULTI-PAGE EXTENSION — series home, per-book pages, world, characters,
   about. Reuses the tokens + aesthetic of body[data-page="veylith"].
   ===================================================================== */

/* ---- shared interior bits ----------------------------------------- */
.vy-intro h2,.vy-cta h2,.vy-hero h1,.vy-phero h1,.book-hero h1,.feature h2,.form-reveal h2{overflow-wrap:break-word}
.vy-sec{padding:clamp(48px,7vw,100px) 0}
.vy-sec--alt{background:linear-gradient(180deg,var(--panel),var(--void));border-block:1px solid var(--line)}
.vy-crumb{font-family:var(--mono);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;color:var(--muted)}
.vy-crumb a{color:var(--violet-2);font-weight:600}
.badge{display:inline-block;font-family:var(--mono);font-size:.6rem;letter-spacing:.14em;text-transform:uppercase;color:var(--cyan);border:1px solid rgba(90,215,255,.4);border-radius:3px;padding:.3em .6em;vertical-align:middle}
.vy-emblem{width:clamp(92px,13vw,150px);height:auto;filter:drop-shadow(0 0 28px rgba(155,107,255,.55));margin:0 auto 1.1rem}

/* ---- local sub-nav (move between Veilfall pages) ------------------- */
.vy-localnav{position:sticky;top:var(--nav-h);z-index:50;background:rgba(13,10,20,.82);backdrop-filter:saturate(150%) blur(12px);-webkit-backdrop-filter:saturate(150%) blur(12px);border-bottom:1px solid var(--line)}
.vy-localnav .in{max-width:1180px;margin-inline:auto;display:flex;align-items:center;gap:clamp(.9rem,2.2vw,2rem);padding:.7rem clamp(18px,4vw,44px);overflow-x:auto;font-family:var(--mono);font-size:.73rem;letter-spacing:.08em;text-transform:uppercase}
.vy-localnav .home{color:var(--violet-2);font-weight:700}
.vy-localnav a{color:var(--muted);white-space:nowrap;padding:.2em 0;border-bottom:2px solid transparent;transition:color .2s,border-color .2s}
.vy-localnav a:hover{color:var(--violet-2)}
.vy-localnav a[aria-current]{color:var(--ink);border-bottom-color:var(--violet)}

/* ---- compact interior hero (book / world / characters / about) ----- */
.vy-phero{position:relative;display:flex;align-items:flex-end;min-height:min(64vh,560px);overflow:hidden}
.vy-phero.center{align-items:center;text-align:center}
.vy-phero .bg{position:absolute;inset:0;z-index:-1}
.vy-phero .bg img{width:100%;height:100%;object-fit:cover;object-position:center 22%}
.vy-phero .bg::after{content:"";position:absolute;inset:0;background:
  linear-gradient(0deg,var(--void) 3%,rgba(6,5,9,.45) 55%,rgba(6,5,9,.7) 100%),
  radial-gradient(70vw 60vh at 80% -10%,rgba(155,107,255,.18),transparent 60%)}
.vy-phero .inner{position:relative;z-index:1;padding-block:clamp(34px,6vw,76px);max-width:780px}
.vy-phero.center .inner{margin-inline:auto}
.vy-phero h1{font-size:clamp(2.3rem,7vw,5rem);letter-spacing:.03em}
.vy-phero .sub{font-family:var(--mono);color:var(--violet-2);letter-spacing:.12em;text-transform:uppercase;font-size:.8rem;margin-top:.7rem}
.vy-phero .lead{font-family:var(--serif);font-style:italic;font-size:clamp(1.1rem,2.2vw,1.6rem);color:var(--ink);margin-top:1.2rem;max-width:36ch}
.vy-phero.center .lead{margin-inline:auto}
.vy-phero .cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:1.8rem}
.vy-phero.center .cta{justify-content:center}

/* ---- book grid (home + listings) ---------------------------------- */
.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(255px,1fr));gap:clamp(20px,3vw,34px)}
.book-card{position:relative;display:flex;flex-direction:column;background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:transform .25s,border-color .25s,box-shadow .25s}
.book-card:hover{transform:translateY(-6px);border-color:var(--violet);box-shadow:0 26px 60px -26px rgba(155,107,255,.55)}
.book-card .cover{aspect-ratio:2/3;overflow:hidden;background:#000}
.book-card .cover img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.book-card:hover .cover img{transform:scale(1.045)}
.book-card .bc-body{padding:1.05rem 1.2rem 1.35rem;display:flex;flex-direction:column;gap:.45rem;flex:1}
.book-card .bnum{font-family:var(--mono);font-size:.68rem;letter-spacing:.18em;color:var(--violet);text-transform:uppercase}
.book-card h3{font-size:1.45rem}
.book-card .form{font-family:var(--mono);font-size:.7rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.book-card .tagline{font-family:var(--serif);font-style:italic;color:var(--violet-2);font-size:1rem;line-height:1.35}
.book-card .more{margin-top:auto;font-family:var(--mono);font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;color:var(--violet-2);padding-top:.4rem}

/* ---- book detail -------------------------------------------------- */
.book-hero{display:grid;grid-template-columns:minmax(220px,320px) 1fr;gap:clamp(28px,5vw,62px);align-items:start}
.book-hero .cover-wrap img{width:100%;border-radius:8px;box-shadow:0 30px 70px -24px rgba(0,0,0,.9),0 0 0 1px var(--line)}
.book-hero .bnum{font-family:var(--mono);letter-spacing:.18em;text-transform:uppercase;color:var(--violet);font-size:.78rem}
.book-hero h1{font-size:clamp(2.4rem,6vw,4.2rem);margin:.5rem 0 .3rem}
.book-hero .epi{font-family:var(--serif);font-style:italic;color:var(--violet-2);font-size:1.3rem;margin-bottom:1.3rem}
.book-blurb p{color:var(--ink);font-size:1.06rem;margin-bottom:1rem}
.book-blurb p:first-child{font-family:var(--serif);font-style:italic;color:var(--violet-2);font-size:1.18rem}
.spec-list{display:flex;flex-wrap:wrap;gap:1.6rem;font-family:var(--mono);font-size:.82rem;color:var(--ink);border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:1.05rem 0;margin:1.5rem 0}
.spec-list b{display:block;color:var(--violet-2);font-weight:400;letter-spacing:.1em;font-size:.64rem;text-transform:uppercase;margin-bottom:.25rem}
.book-cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-top:.4rem}
@media(max-width:640px){.book-hero{grid-template-columns:1fr;max-width:380px;margin-inline:auto}}

/* form reveal block on a book page */
.form-reveal{display:grid;grid-template-columns:1fr .92fr;gap:clamp(24px,5vw,56px);align-items:center}
.form-reveal .fig{position:relative;display:grid;place-items:center;min-height:340px}
.form-reveal .fig::before{content:"";position:absolute;width:68%;aspect-ratio:1;border-radius:50%;background:radial-gradient(circle,rgba(155,107,255,.34),transparent 65%);filter:blur(12px)}
.form-reveal .fig img{position:relative;max-height:460px;width:auto;filter:drop-shadow(0 20px 50px rgba(0,0,0,.7))}
.form-reveal .desig{font-family:var(--mono);color:var(--violet);letter-spacing:.16em;font-size:.78rem;text-transform:uppercase}
.form-reveal h2{font-size:clamp(1.7rem,4vw,2.6rem);margin:.3rem 0 .5rem}
.form-reveal p{color:var(--muted);max-width:52ch}
@media(max-width:680px){.form-reveal{grid-template-columns:1fr}.form-reveal .fig{order:-1;min-height:280px}}

/* next-in-series teaser */
.next-book{display:flex;flex-wrap:wrap;align-items:center;gap:clamp(18px,4vw,40px);justify-content:center;text-align:center}
.next-book .nb-cover{width:120px;border-radius:6px;box-shadow:0 18px 40px -16px rgba(0,0,0,.9)}
.next-book .nb-txt{max-width:42ch;text-align:left}
.next-book .nb-k{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--violet)}
.next-book h3{font-size:1.7rem;margin:.2rem 0 .5rem}
.next-book p{color:var(--muted);font-size:.95rem}
@media(max-width:520px){.next-book .nb-txt{text-align:center}}

/* ---- cast grid (characters) --------------------------------------- */
.cast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(215px,1fr));gap:clamp(16px,2.5vw,28px)}
.cast-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:.25s;display:flex;flex-direction:column}
.cast-card:hover{border-color:var(--violet);transform:translateY(-4px)}
.cast-card .por{aspect-ratio:3/4;overflow:hidden;background:#000}
.cast-card .por img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.cast-card .cc-body{padding:1rem 1.1rem 1.2rem}
.cast-card h3{font-size:1.15rem;margin-bottom:.2rem}
.cast-card .role{font-family:var(--mono);font-size:.66rem;text-transform:uppercase;letter-spacing:.1em;color:var(--violet);margin-bottom:.55rem}
.cast-card .role .age{color:var(--muted)}
.cast-card p{color:var(--muted);font-size:.85rem;line-height:1.55}
.cast-card.lead{grid-column:span 2}
.cast-card.lead .por{aspect-ratio:auto}
@media(max-width:620px){.cast-card.lead{grid-column:span 1}}

/* ---- media grid (bestiary / vessels / locations / flora / tech) --- */
.media-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:clamp(16px,2.4vw,26px)}
.media-card{background:var(--panel);border:1px solid var(--line);border-radius:10px;overflow:hidden;transition:.25s}
.media-card:hover{border-color:var(--violet);transform:translateY(-4px)}
.media-card .ph{aspect-ratio:3/2;overflow:hidden;background:#000}
.media-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .45s}
.media-card:hover .ph img{transform:scale(1.05)}
.media-card .mc-body{padding:.9rem 1.05rem 1.15rem}
.media-card .mc-k{font-family:var(--mono);font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;color:var(--violet)}
.media-card h3{font-size:1.12rem;margin:.2rem 0 .4rem}
.media-card p{color:var(--muted);font-size:.84rem;line-height:1.5}

/* ---- lore term grid ----------------------------------------------- */
.lore-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:12px}
.lore-grid > div{background:var(--panel);border:1px solid var(--line);border-radius:9px;padding:1.3rem 1.4rem;transition:border-color .2s}
.lore-grid > div:hover{border-color:var(--violet)}
.lore-grid h4{font-family:var(--mono);text-transform:uppercase;letter-spacing:.1em;font-size:.8rem;color:var(--violet-2);margin-bottom:.45rem}
.lore-grid p{color:var(--muted);font-size:.88rem}

/* ---- reading-order ladder ----------------------------------------- */
.ladder{display:flex;flex-direction:column;gap:.5rem;max-width:720px;margin-inline:auto}
.ladder a{display:flex;align-items:center;gap:1rem;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:.85rem 1.2rem;transition:.2s}
.ladder a:hover{border-color:var(--violet);background:var(--panel-2)}
.ladder .rn{font-family:var(--mono);color:var(--violet);font-size:.9rem;min-width:2.4ch}
.ladder b{font-size:1.05rem}
.ladder .lf{margin-left:auto;font-family:var(--mono);font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted)}

/* ---- prose (about) ------------------------------------------------ */
.vy-prose{max-width:70ch;margin-inline:auto}
.vy-prose p{color:var(--muted);margin-bottom:1.1rem;font-size:1.05rem}
.vy-prose p.em{font-family:var(--serif);font-style:italic;color:var(--violet-2);font-size:1.2rem}
.vy-prose h2{font-size:clamp(1.5rem,3.4vw,2.1rem);margin:2.2rem 0 1rem}
.vy-prose h2:first-child{margin-top:0}

/* ---- very narrow screens: stack button rows ----------------------- */
@media(max-width:460px){
  .vy-hero .cta,.vy-phero .cta,.book-cta,.vy-cta .cta{flex-direction:column;align-items:stretch}
  .vy-hero .cta .btn-vy,.vy-phero .cta .btn-vy,.book-cta .btn-vy,.vy-cta .cta .btn-vy{justify-content:center;width:100%}
}

/* ---- two-up feature (home world/cast teasers) --------------------- */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,60px);align-items:center}
.feature.flip > .ft-media{order:2}
.feature .ft-media img{width:100%;border-radius:10px;border:1px solid var(--line)}
.feature h2{font-size:clamp(1.8rem,4vw,2.8rem);margin-bottom:1rem}
.feature p{color:var(--muted);margin-bottom:1.2rem;max-width:54ch}
@media(max-width:760px){.feature{grid-template-columns:1fr}.feature.flip > .ft-media{order:-1}}
