/* =========================================================
   Daniel Siew — Classical Feng Shui, BaZi & Qi Men Dun Jia
   Premium editorial dark theme
   ========================================================= */

:root{
  --bg:#181818;
  --bg-soft:#1f1f1f;
  --bg-elev:#242424;
  --ink:#ebdcc4;
  --ink-soft:#c9b89a;
  --ink-mute:#8c7d65;
  --line:rgba(235,220,196,.18);
  --line-strong:rgba(235,220,196,.35);
  --accent:#d9b97a;
  --serif:'Cormorant Garamond', 'Playfair Display', Georgia, serif;
  --sans:'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
  --container:1240px;
  --gutter:clamp(1.25rem, 3vw, 2.5rem);
  --radius:2px;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  font-size:16px;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg{display:block;max-width:100%;height:auto}
a{color:var(--ink);text-decoration:none;transition:color .25s ease}
a:hover{color:var(--accent)}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}

::selection{background:var(--ink);color:var(--bg)}

/* ---------- Typography ---------- */
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;color:var(--ink);margin:0 0 .5em;letter-spacing:.005em}
h1{font-size:clamp(2.6rem,6vw,5.2rem);line-height:1.05;letter-spacing:-.01em}
h2{font-size:clamp(2rem,4.2vw,3.6rem);line-height:1.1}
h3{font-size:clamp(1.4rem,2.4vw,2rem);line-height:1.2}
h4{font-size:1.15rem;line-height:1.3;font-family:var(--sans);font-weight:500;letter-spacing:.02em}
p{margin:0 0 1.2em}
.eyebrow{font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--ink-soft);margin:0 0 1.5rem}
.lede{font-family:var(--serif);font-size:clamp(1.25rem,1.8vw,1.6rem);font-weight:300;line-height:1.45;color:var(--ink-soft);font-style:italic}
.rule{display:inline-block;width:60px;height:1px;background:var(--line-strong);vertical-align:middle;margin-right:1rem}

/* ---------- Layout ---------- */
.container{width:100%;max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.section{padding:clamp(4rem,9vw,8rem) 0}
.section-tight{padding:clamp(3rem,6vw,5rem) 0}
.grid{display:grid;gap:clamp(1.5rem,3vw,3rem)}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* ---------- Header ---------- */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:50;
  background:rgba(24,24,24,.6);backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;
  transition:background .3s ease,border-color .3s ease;
}
.site-header.scrolled{background:rgba(24,24,24,.92);border-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px;gap:3rem}
.brand{display:flex;align-items:center;gap:.7rem;font-family:var(--serif);font-size:1.2rem;letter-spacing:.04em;flex-shrink:0;white-space:nowrap;margin-right:auto;padding-right:1.5rem}
.brand .mark{display:inline-block;width:30px;height:30px;border:1px solid var(--ink-soft);position:relative;border-radius:50%;flex-shrink:0}
.brand .mark::before{content:"";position:absolute;inset:5px;border:1px solid var(--ink-soft);border-radius:50%}
.brand .mark::after{content:"";position:absolute;left:50%;top:50%;width:5px;height:5px;background:var(--ink);border-radius:50%;transform:translate(-50%,-50%)}
.brand-text{display:flex;flex-direction:column;line-height:1}
.brand-text strong{font-weight:500;letter-spacing:.06em;font-size:1rem}
.brand-text small{font-family:var(--sans);font-size:.55rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-mute);margin-top:3px;white-space:nowrap}
.nav-links{display:flex;gap:1.4rem;align-items:center;flex-wrap:nowrap}
.nav-links a{font-family:var(--sans);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;color:var(--ink-soft);white-space:nowrap}
.nav-links a:hover,.nav-links a.active{color:var(--ink)}
.nav-cta{padding:.65rem 1.1rem;border:1px solid var(--ink-soft);font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink) !important;transition:all .25s ease;white-space:nowrap}
.nav-cta:hover{background:var(--ink);color:var(--bg) !important;border-color:var(--ink)}
@media (max-width:1280px){
  .brand-text small{display:none}
  .nav-cta{display:none}
  .nav-links{gap:1.2rem}
}
@media (max-width:1100px){
  .nav-links{gap:1rem}
  .nav-links a{font-size:.7rem;letter-spacing:.14em}
}
.nav-toggle{display:none;width:34px;height:24px;position:relative;z-index:60}
.nav-toggle span{display:block;position:absolute;left:0;width:100%;height:1px;background:var(--ink);transition:transform .3s ease,top .3s ease,opacity .3s ease}
.nav-toggle span:nth-child(1){top:4px}
.nav-toggle span:nth-child(2){top:12px}
.nav-toggle span:nth-child(3){top:20px}
body.menu-open .nav-toggle span:nth-child(1){top:12px;transform:rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){top:12px;transform:rotate(-45deg)}

@media (max-width:980px){
  .nav-toggle{display:block}
  .nav-links{
    position:fixed;inset:0;background:var(--bg);
    flex-direction:column;justify-content:center;align-items:center;
    gap:2rem;font-size:1rem;
    transform:translateY(-100%);transition:transform .45s cubic-bezier(.6,.1,.2,1);
  }
  .nav-links a{font-size:.95rem}
  body.menu-open .nav-links{transform:translateY(0)}
}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:1rem 2rem;
  font-family:var(--sans);font-size:.78rem;letter-spacing:.24em;text-transform:uppercase;font-weight:500;
  border:1px solid var(--ink);color:var(--ink);background:transparent;
  transition:all .3s ease;
}
.btn:hover{background:var(--ink);color:var(--bg)}
.btn--solid{background:var(--ink);color:var(--bg)}
.btn--solid:hover{background:transparent;color:var(--ink)}
.btn--ghost{border-color:var(--ink-soft);color:var(--ink-soft)}
.btn--ghost:hover{border-color:var(--ink);color:var(--ink);background:transparent}
.btn .arrow{display:inline-block;transition:transform .3s ease}
.btn:hover .arrow{transform:translateX(4px)}

/* ---------- Hero v2 (full-bleed video, liquid glass card, big bold headline) ---------- */
.hero{
  position:relative;
  min-height:100vh;
  padding:120px 0 5rem;
  background:#070b0a;
  overflow:hidden;
  display:flex;align-items:center;justify-content:center;
  isolation:isolate;
}
.hero__video{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:.6;z-index:0;
  background:#070b0a;
}
.hero__veil{
  position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    linear-gradient(90deg,#070b0a 0%,rgba(7,11,10,.55) 35%,rgba(7,11,10,.05) 70%,transparent 100%),
    linear-gradient(180deg,transparent 35%,rgba(7,11,10,.45) 75%,rgba(7,11,10,.92) 100%);
}
.hero__grid-lines{position:absolute;inset:0;z-index:1;pointer-events:none}
.hero__grid-lines span{
  position:absolute;top:0;bottom:0;width:1px;
  background:rgba(255,255,255,.08);
}
.hero__grid-lines span:nth-child(1){left:25%}
.hero__grid-lines span:nth-child(2){left:50%}
.hero__grid-lines span:nth-child(3){left:75%}
@media (max-width:760px){.hero__grid-lines{display:none}}

.hero__glow{
  position:absolute;left:50%;top:14%;transform:translateX(-50%);
  width:min(1200px,90vw);height:auto;z-index:1;pointer-events:none;
  filter:blur(25px);opacity:.7;
}

.hero__center{
  position:relative;z-index:2;
  text-align:center;
  padding:0 var(--gutter);
  max-width:920px;width:100%;
  display:flex;flex-direction:column;align-items:center;
  color:#fff;
}

/* Hero name marker (same font as headline) */
.hero__name{
  display:inline-flex;align-items:center;justify-content:center;gap:1.4rem;
  font-family:'Inter',var(--sans);
  font-weight:800;
  font-size:clamp(18px,2vw,26px);
  letter-spacing:.22em;
  text-transform:uppercase;
  color:#fff;
  margin:0 0 1.6rem;
  line-height:1;
}
.hero__name::before,
.hero__name::after{
  content:"";
  display:inline-block;
  width:clamp(28px,4vw,56px);
  height:1px;
  background:#d9b97a;
  opacity:.85;
}

/* Eyebrow */
.hero__eyebrow{
  font-family:'Plus Jakarta Sans',var(--sans);
  font-size:11px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;
  color:#d9b97a;margin:0 0 1.6rem;
}

/* Big headline */
.hero__title{
  font-family:'Inter',var(--sans);
  font-weight:800;
  font-size:clamp(40px,7.5vw,72px);
  line-height:.95;letter-spacing:-.02em;
  text-transform:uppercase;
  color:#fff;
  margin:0 0 1.6rem;
  max-width:14ch;
}
.hero__title .dot{color:#d9b97a}

/* Description */
.hero__desc{
  font-family:'Inter',var(--sans);
  font-size:15px;line-height:1.6;
  color:rgba(255,255,255,.72);
  max-width:512px;
  margin:0 0 2.2rem;
}

/* CTA pill button */
.btn-pill{
  display:inline-flex;align-items:center;gap:.7rem;
  padding:14px 30px;
  border-radius:999px;
  background:#d9b97a;color:#181818 !important;
  font-family:'Inter',var(--sans);
  font-weight:700;font-size:13px;letter-spacing:.18em;text-transform:uppercase;
  text-decoration:none;border:none;
  transition:transform .25s ease,box-shadow .25s ease,background .25s ease;
}
.btn-pill:hover{
  background:#f6e3b6;transform:translateY(-1px);
  box-shadow:0 12px 32px rgba(217,185,122,.32);
  color:#181818 !important;
}
.btn-pill svg{width:16px;height:16px}
.hero__cta-row{display:flex;gap:1.2rem;align-items:center;flex-wrap:wrap;justify-content:center}
.hero__cta-row .btn--ghost{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.4)}
.hero__cta-row .btn--ghost:hover{color:#181818;background:#fff;border-color:#fff}

@media (max-width:560px){
  .liquid-card{width:170px;height:170px;padding:1.2rem .9rem}
  .liquid-card__title{font-size:16px}
  .hero__desc{font-size:14px}
}

/* ---------- Marquee strip ---------- */
.strip{
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  padding:1.4rem 0;overflow:hidden;
}
.strip__track{
  display:flex;gap:3.5rem;align-items:center;
  font-family:var(--serif);font-size:1.05rem;font-style:italic;color:var(--ink-soft);
  white-space:nowrap;
  animation:slide 40s linear infinite;
}
.strip__track span{display:inline-flex;align-items:center;gap:3.5rem}
.strip__track span::before{content:"✦";color:var(--accent);font-style:normal}
@keyframes slide{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- About preview ---------- */
.about-preview{display:grid;grid-template-columns:5fr 6fr;gap:clamp(2rem,5vw,5rem);align-items:center}
.about-preview__media{position:relative}
.about-preview__media img{aspect-ratio:4/5;object-fit:cover;width:100%;filter:saturate(.92) contrast(1.02)}
.about-preview__media::after{
  content:"";position:absolute;inset:1.5rem -1.5rem -1.5rem 1.5rem;
  border:1px solid var(--line-strong);z-index:-1;
}
.about-preview__copy h2{margin-bottom:1.5rem}
.about-preview__copy .lede{margin-bottom:1.5rem}
@media (max-width:900px){.about-preview{grid-template-columns:1fr}}

/* ---------- Pillars ---------- */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.pillar{padding:3rem 2rem;border-right:1px solid var(--line);position:relative}
.pillar:last-child{border-right:0}
.pillar__num{font-family:var(--serif);font-size:.95rem;color:var(--ink-mute);margin-bottom:2rem;letter-spacing:.1em}
.pillar h3{margin-bottom:.8rem}
.pillar p{font-size:.92rem;color:var(--ink-soft);margin:0}
@media (max-width:900px){
  .pillars{grid-template-columns:repeat(2,1fr)}
  .pillar:nth-child(2){border-right:0}
  .pillar:nth-child(1),.pillar:nth-child(2){border-bottom:1px solid var(--line)}
}
@media (max-width:560px){
  .pillars{grid-template-columns:1fr}
  .pillar{border-right:0;border-bottom:1px solid var(--line)}
  .pillar:last-child{border-bottom:0}
}

/* ---------- Services ---------- */
.services{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.service{background:var(--bg);padding:clamp(2rem,4vw,3.5rem);transition:background .3s ease}
.service:hover{background:var(--bg-soft)}
.service__num{font-family:var(--serif);color:var(--ink-mute);font-size:.95rem;letter-spacing:.1em;margin-bottom:2rem;display:flex;align-items:center;justify-content:space-between}
.service h3{margin-bottom:1rem}
.service p{color:var(--ink-soft);margin-bottom:2rem;font-size:.95rem}
.service__more{font-family:var(--sans);font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink);border-bottom:1px solid var(--ink-soft);padding-bottom:4px;display:inline-flex;gap:.6rem}
.service__more:hover{color:var(--accent);border-color:var(--accent)}
@media (max-width:760px){.services{grid-template-columns:1fr}}

/* ---------- Countries ---------- */
.countries-hero{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;margin-bottom:5rem}
@media (max-width:900px){.countries-hero{grid-template-columns:1fr}}
.country-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.country{padding:2rem 1.5rem;border-bottom:1px solid var(--line);border-right:1px solid var(--line);display:flex;justify-content:space-between;align-items:baseline}
.country:nth-child(3n){border-right:0}
.country__name{font-family:var(--serif);font-size:1.4rem}
.country__cities{font-size:.78rem;color:var(--ink-mute);letter-spacing:.06em;text-transform:uppercase}
@media (max-width:760px){
  .country-grid{grid-template-columns:1fr}
  .country{border-right:0}
}

/* ---------- Resources ---------- */
.resource-card{
  border:1px solid var(--line);padding:clamp(1.5rem,3vw,2.5rem);
  display:flex;flex-direction:column;height:100%;
  transition:border-color .3s ease,transform .3s ease;
}
.resource-card:hover{border-color:var(--ink-soft);transform:translateY(-4px)}
.resource-card__tag{font-family:var(--sans);font-size:.68rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}
.resource-card h3{margin-bottom:.8rem;font-size:1.45rem}
.resource-card p{color:var(--ink-soft);font-size:.92rem;flex-grow:1}
.resource-card__cta{margin-top:1.5rem;font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;border-top:1px solid var(--line);padding-top:1.2rem;display:inline-flex;justify-content:space-between;align-items:center}
.resource-card--featured{
  background:linear-gradient(135deg,rgba(217,185,122,.08),transparent 60%);
  border-color:var(--ink-soft);
}

/* ---------- Testimonials ---------- */
.quote{
  border-left:1px solid var(--line-strong);padding:1rem 0 1rem 2rem;
  font-family:var(--serif);font-style:italic;font-size:1.25rem;line-height:1.5;
  color:var(--ink-soft);
}
.quote cite{display:block;font-style:normal;font-family:var(--sans);font-size:.72rem;letter-spacing:.24em;text-transform:uppercase;color:var(--ink-mute);margin-top:1.2rem}

/* ---------- Press / Featured in ---------- */
.press{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(1.5rem,5vw,4rem);align-items:center;padding:1rem 0;color:var(--ink-mute)}
.press__label{font-family:var(--sans);font-size:.7rem;letter-spacing:.3em;text-transform:uppercase;color:var(--ink-mute);width:100%;text-align:center;margin-bottom:1.5rem}
.press span{font-family:var(--serif);font-size:1.15rem;letter-spacing:.04em;font-style:italic}

/* Continuous-slide press marquee with brand logos */
.press-marquee{
  position:relative;overflow:hidden;
  padding:1.4rem 0;
  background:var(--bg);
  -webkit-mask-image:linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
  mask-image:linear-gradient(to right, transparent 0, black 6%, black 94%, transparent 100%);
}
.press-marquee__track{
  display:flex;align-items:center;gap:5rem;
  width:max-content;
  animation:pressSlide 38s linear infinite;
}
@keyframes pressSlide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.press-logo{
  display:flex;align-items:center;justify-content:center;
  flex:0 0 auto;
  height:42px;
  color:var(--ink-soft);
  opacity:.78;
  transition:opacity .25s ease, color .25s ease, transform .25s ease;
}
.press-logo:hover{opacity:1;color:var(--ink);transform:translateY(-2px)}
.press-logo img{height:100%;width:auto;display:block;background:transparent}
.press-logo--word{
  font-family:'Inter',var(--sans);
  white-space:nowrap;
  text-transform:uppercase;
  font-size:18px;
  font-weight:700;
  letter-spacing:.22em;
}
.press-logo--bernama{font-weight:800;font-size:18px;letter-spacing:.18em}
.press-logo--thesun{font-family:'Cormorant Garamond',serif;font-style:italic;font-weight:500;font-size:30px;letter-spacing:.005em;text-transform:none}
.press-logo--thesun em{font-style:normal;color:var(--accent)}
.press-logo--ukhr{font-weight:300;letter-spacing:.34em;font-size:14px}
.press-logo--pandora{font-weight:300;letter-spacing:.42em;font-size:18px}
.press-logo--sheda{font-weight:800;letter-spacing:.16em;font-size:16px}

/* ---------- 3D country flag pill ---------- */
.flag-3d{
  display:inline-block;
  width:34px;height:34px;
  border-radius:50%;
  background-size:cover;
  background-position:center;
  background-repeat:no-repeat;
  filter:drop-shadow(0 6px 10px rgba(0,0,0,.55)) drop-shadow(0 0 6px rgba(217,185,122,.18));
  transform:perspective(220px) rotateY(-10deg) rotateX(4deg);
  transition:transform .35s cubic-bezier(.2,.7,.2,1), filter .35s ease;
  flex-shrink:0;
  vertical-align:middle;
  /* glossy spec highlight */
  box-shadow:inset 0 6px 10px rgba(255,255,255,.18), inset 0 -6px 10px rgba(0,0,0,.25);
}
.flag-3d:hover{
  transform:perspective(220px) rotateY(0) rotateX(0) scale(1.18);
  filter:drop-shadow(0 10px 16px rgba(0,0,0,.65)) drop-shadow(0 0 14px rgba(217,185,122,.45));
}
.flag-3d--inline{width:22px;height:22px;margin:0 .35rem;vertical-align:-.3em}
.flag-3d--lg{width:44px;height:44px}

/* Country tile: flag on left | name (top) + cities (below) stacked on right */
.country{
  display:grid;
  grid-template-columns:44px 1fr;
  grid-template-rows:auto auto;
  column-gap:1rem;
  row-gap:.25rem;
  align-items:center;
}
.country .flag-3d{grid-column:1;grid-row:1 / span 2;align-self:center}
.country__name{
  grid-column:2;grid-row:1;
  font-family:var(--serif);
  font-size:1.25rem;
  line-height:1.1;
  letter-spacing:.005em;
  white-space:nowrap;
  margin:0;
}
.country__cities{
  grid-column:2;grid-row:2;
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:400;
  color:var(--ink-mute);
  letter-spacing:.12em;
  text-transform:uppercase;
  line-height:1.45;
  margin:0;
}
@media (max-width:760px){
  .country{grid-template-columns:36px 1fr;column-gap:.85rem;padding:1.3rem 1.1rem}
  .country__name{font-size:1.05rem}
  .country__cities{font-size:.62rem;letter-spacing:.14em}
}

/* ---------- CTA Banner ---------- */
.cta-banner{
  position:relative;padding:clamp(4rem,8vw,7rem) 0;
  background:var(--bg-soft);text-align:center;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
}
.cta-banner h2{max-width:22ch;margin:0 auto 1.5rem}
.cta-banner p{max-width:54ch;margin:0 auto 2.5rem;color:var(--ink-soft)}

/* ---------- Page hero (interior pages) ---------- */
.page-hero{padding:180px 0 5rem;border-bottom:1px solid var(--line)}
.page-hero__inner{max-width:60ch}
.page-hero h1{font-size:clamp(2.4rem,5vw,4.2rem);margin-bottom:1.5rem}

/* ---------- About page ---------- */
.bio{display:grid;grid-template-columns:5fr 7fr;gap:clamp(2rem,5vw,5rem);align-items:start}
.bio__media img{aspect-ratio:4/5;object-fit:cover;width:100%}
.bio__copy h2{margin-top:0}
.bio__copy h3{margin-top:2.5rem;font-size:1.4rem}
@media (max-width:900px){.bio{grid-template-columns:1fr}}

.timeline{margin-top:3rem;border-top:1px solid var(--line)}
.timeline__row{display:grid;grid-template-columns:140px 1fr;gap:2rem;padding:1.5rem 0;border-bottom:1px solid var(--line)}
.timeline__year{font-family:var(--serif);font-size:1.1rem;color:var(--ink-soft);letter-spacing:.04em}
.timeline__text{color:var(--ink-soft);font-size:.95rem;margin:0}
@media (max-width:600px){.timeline__row{grid-template-columns:1fr;gap:.5rem}}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto}
.faq details{border-bottom:1px solid var(--line);padding:1.5rem 0}
.faq summary{
  list-style:none;cursor:pointer;
  font-family:var(--serif);font-size:1.25rem;color:var(--ink);
  display:flex;justify-content:space-between;align-items:center;gap:1rem;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--sans);font-size:1.6rem;font-weight:300;color:var(--ink-soft);transition:transform .3s ease}
.faq details[open] summary::after{content:"−"}
.faq details > p{margin:1rem 0 0;color:var(--ink-soft);font-size:.95rem;line-height:1.7}

/* ---------- Forms ---------- */
.form{display:grid;gap:1.5rem;max-width:640px}
.form__row{display:grid;gap:1.5rem;grid-template-columns:1fr 1fr}
@media (max-width:600px){.form__row{grid-template-columns:1fr}}
.form label{display:block;font-family:var(--sans);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.6rem}
.form input,.form select,.form textarea{
  width:100%;background:transparent;border:0;border-bottom:1px solid var(--line-strong);
  padding:.7rem 0;color:var(--ink);font-family:var(--sans);font-size:1rem;
  transition:border-color .25s ease;
}
.form select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--ink-soft) 50%),linear-gradient(135deg,var(--ink-soft) 50%,transparent 50%);background-position:calc(100% - 18px) 1.4rem,calc(100% - 12px) 1.4rem;background-size:6px 6px,6px 6px;background-repeat:no-repeat;padding-right:2rem}
.form select option{background:var(--bg);color:var(--ink)}
.form textarea{min-height:140px;resize:vertical}
.form input:focus,.form select:focus,.form textarea:focus{outline:0;border-color:var(--ink)}
.form ::placeholder{color:var(--ink-mute)}

/* ---------- Contact info ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem)}
@media (max-width:900px){.contact-grid{grid-template-columns:1fr}}
.contact-info{display:grid;gap:2rem}
.contact-info__row{border-top:1px solid var(--line);padding-top:1.5rem}
.contact-info__label{font-family:var(--sans);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);margin:0 0 .6rem}
.contact-info__value{font-family:var(--serif);font-size:1.4rem;margin:0}
.contact-info__value a{border-bottom:1px solid transparent;transition:border-color .25s ease}
.contact-info__value a:hover{border-color:var(--ink-soft)}

/* ---------- Footer ---------- */
.site-footer{padding:5rem 0 2rem;border-top:1px solid var(--line);margin-top:0;background:var(--bg)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem}
@media (max-width:900px){.footer-grid{grid-template-columns:1fr 1fr;gap:2.5rem}}
@media (max-width:560px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{font-family:var(--sans);font-size:.7rem;letter-spacing:.28em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:1.5rem;font-weight:500}
.footer-grid ul{list-style:none;padding:0;margin:0;display:grid;gap:.7rem}
.footer-grid li a{font-size:.92rem;color:var(--ink-soft)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;padding-top:2rem;border-top:1px solid var(--line);font-size:.78rem;color:var(--ink-mute);font-family:var(--sans)}
.footer-bottom a{color:var(--ink-mute)}
.footer-bottom a:hover{color:var(--ink)}
.footer-tag{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--ink-soft);max-width:38ch}

/* ---------- Reveal animation (scroll zoom-in) ---------- */
.reveal{
  opacity:0;
  transform:scale(.9) translateY(28px);
  transition:opacity 1s ease,transform 1.2s cubic-bezier(.18,.7,.2,1);
  will-change:opacity,transform;
}
.reveal.in{opacity:1;transform:scale(1) translateY(0)}

/* Continuous scroll-driven zoom for headings (Chrome/Edge/Safari 17+) */
@supports (animation-timeline: view()) {
  .zoom-on-scroll{
    animation:zoomReveal linear both;
    animation-timeline:view();
    animation-range:entry 0% cover 45%;
  }
  @keyframes zoomReveal{
    from{opacity:.0;transform:scale(.78);letter-spacing:-.04em;filter:blur(6px)}
    to{opacity:1;transform:scale(1);letter-spacing:-.01em;filter:blur(0)}
  }
}

/* Hero parallax on scroll (subtle fade as content moves up) */
@supports (animation-timeline: scroll()) {
  .hero__center{
    animation:heroParallax linear both;
    animation-timeline:scroll(root);
    animation-range:0 80vh;
  }
  @keyframes heroParallax{
    from{transform:translateY(0);opacity:1;filter:blur(0)}
    to{transform:translateY(-40px);opacity:0;filter:blur(2px)}
  }
  .hero__video{
    animation:heroVideo linear both;
    animation-timeline:scroll(root);
    animation-range:0 100vh;
  }
  @keyframes heroVideo{
    from{transform:scale(1);opacity:.6}
    to{transform:scale(1.05);opacity:.25}
  }
}

/* ---------- 3D tilt on scroll ----------
   Note: do NOT set `perspective` on <body> — it creates a containing block
   for fixed-position descendants and breaks `position: fixed` overlays
   (e.g. the splash). The tilt keyframes already include perspective() in the
   transform, so per-element 3D still works.
*/

@supports (animation-timeline: view()) {
  .tilt-3d{
    animation:tilt3d linear both;
    animation-timeline:view();
    animation-range:entry 0% cover 35%;
    transform-origin:center 90%;
    transform-style:preserve-3d;
    will-change:transform,opacity;
  }
  @keyframes tilt3d{
    from{transform:perspective(1600px) rotateX(22deg) translateY(80px) translateZ(-160px);opacity:0}
    to{transform:perspective(1600px) rotateX(0deg) translateY(0) translateZ(0);opacity:1}
  }

  .float-3d{
    animation:float3d linear both;
    animation-timeline:view();
    animation-range:entry 0% cover 50%;
    will-change:transform,opacity;
  }
  @keyframes float3d{
    from{transform:perspective(1400px) rotateY(8deg) translateX(40px) translateZ(-80px);opacity:0}
    to{transform:perspective(1400px) rotateY(0deg) translateX(0) translateZ(0);opacity:1}
  }

  /* Subtle parallax depth for hero panel image */
  .hero__panel{transform-style:preserve-3d}
}

@media (prefers-reduced-motion: reduce){
  .tilt-3d,.float-3d{animation:none !important;opacity:1 !important;transform:none !important}
}

/* ---------- Launch intro (home only) ---------- */
.intro{
  position:fixed;inset:0;z-index:200;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
  pointer-events:all;
}
.intro__inner{
  position:relative;
  text-align:center;
  color:var(--ink);
  opacity:0;
  transform:translateY(8px);
  animation:introTextIn .9s .2s cubic-bezier(.2,.7,.2,1) forwards, introTextOut .6s 1.7s ease forwards;
}
.intro__name{
  display:block;
  font-family:var(--serif);
  font-size:clamp(2.4rem,7vw,5rem);
  letter-spacing:.08em;
  line-height:1;
}
.intro__sub{
  display:block;margin-top:1.2rem;
  font-family:var(--sans);font-size:.7rem;letter-spacing:.5em;text-transform:uppercase;color:var(--ink-soft);
}
.intro__line{
  display:block;width:60px;height:1px;background:var(--accent);margin:1.6rem auto 0;
  transform-origin:left;
  animation:lineDraw 1s .6s cubic-bezier(.7,.0,.2,1) forwards;
  transform:scaleX(0);
}
@keyframes introTextIn{
  0%{opacity:0;transform:translateY(20px) scale(.96);filter:blur(8px)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}
@keyframes introTextOut{
  0%{opacity:1}
  100%{opacity:0;transform:translateY(-12px) scale(1.02)}
}
@keyframes lineDraw{
  0%{transform:scaleX(0)}
  100%{transform:scaleX(1)}
}
.intro.exit{
  animation:introExit 1s cubic-bezier(.7,.0,.2,1) forwards;
}
@keyframes introExit{
  0%{transform:translateY(0);opacity:1}
  100%{transform:translateY(-100%);opacity:1}
}
body.intro-running{overflow:hidden;height:100vh}
body.intro-running .hero__name,
body.intro-running .hero__eyebrow,
body.intro-running .hero__title,
body.intro-running .hero__desc,
body.intro-running .hero__cta-row{opacity:0}

/* Hero text reveal AFTER intro finishes */
body.intro-done .hero__name{animation:heroIn 1s .05s cubic-bezier(.2,.7,.2,1) both}
body.intro-done .hero__eyebrow{animation:heroIn .9s .25s cubic-bezier(.2,.7,.2,1) both}
body.intro-done .hero__title{animation:heroIn 1.1s .4s cubic-bezier(.2,.7,.2,1) both}
body.intro-done .hero__desc{animation:heroIn .9s .65s cubic-bezier(.2,.7,.2,1) both}
body.intro-done .hero__cta-row{animation:heroIn .8s .85s cubic-bezier(.2,.7,.2,1) both}
@keyframes heroIn{
  0%{opacity:0;transform:translateY(28px) scale(.96);filter:blur(6px)}
  100%{opacity:1;transform:translateY(0) scale(1);filter:blur(0)}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .reveal,.zoom-on-scroll,.intro,.intro__inner,.intro__line,
  body.intro-done .hero__pillars,body.intro-done .hero h1,
  body.intro-done .hero .hero__sub,body.intro-done .hero__cta{
    animation:none !important;transition:none !important;
    opacity:1 !important;transform:none !important;filter:none !important;
  }
  .intro{display:none !important}
  body.intro-running{overflow:auto !important;height:auto !important}
}

/* ---------- I Ching hexagram (vertical stack of six lines) ---------- */
.iching{display:flex;flex-direction:column;gap:8px;width:120px;margin:0 auto 1.5rem}
.iching-line{height:8px;width:100%;background:var(--ink-soft);border-radius:1px}
.iching-line.yin{background:linear-gradient(to right,var(--ink-soft) 0% 42%,transparent 42% 58%,var(--ink-soft) 58% 100%)}

/* ---------- Contact landscape image ---------- */
.contact-image{
  width:100%;
  background:var(--bg);
  padding:0;
  border-bottom:1px solid var(--line);
}
.contact-image img{
  display:block;
  width:100%;height:auto;
  max-height:60vh;
  object-fit:contain;
  margin:0 auto;
  background:var(--bg);
}

/* ---------- 3D Globe ---------- */
.globe-section{
  position:relative;
  background:radial-gradient(ellipse at center,#1f1f1f 0%,#181818 60%,#101010 100%);
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  overflow:hidden;
}
.globe-stage{
  position:relative;
  width:100%;
  height:clamp(520px,75vh,820px);
  display:flex;align-items:center;justify-content:center;
}
.globe-stage canvas{display:block !important}
#globe{position:absolute;inset:0}
.globe-meta{
  position:absolute;
  left:clamp(1.25rem,3vw,3rem);
  top:clamp(1.25rem,3vw,3rem);
  z-index:2;
  max-width:32ch;
  font-family:var(--sans);
}
.globe-meta__eyebrow{font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);margin:0 0 1rem}
.globe-meta__title{font-family:var(--serif);font-size:clamp(1.6rem,2.4vw,2.4rem);line-height:1.15;color:var(--ink);margin:0 0 1rem}
.globe-meta__sub{font-size:.88rem;color:var(--ink-soft);margin:0}

.globe-legend{
  position:absolute;
  right:clamp(1.25rem,3vw,3rem);
  bottom:clamp(1.25rem,3vw,3rem);
  z-index:2;
  font-family:var(--sans);font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);
  display:grid;gap:.7rem;
  background:rgba(24,24,24,.6);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  border:1px solid var(--line);
  padding:1rem 1.2rem;
}
.globe-legend__row{display:flex;align-items:center;gap:.7rem}
.globe-legend__dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);box-shadow:0 0 8px var(--accent)}
.globe-legend__dot--home{background:#f6e3b6;box-shadow:0 0 12px #f6e3b6;width:10px;height:10px}

/* Globe.gl tooltip override */
.scene-tooltip{
  font-family:var(--sans) !important;
  font-size:.78rem !important;
  letter-spacing:.18em !important;
  text-transform:uppercase !important;
  color:var(--ink) !important;
  background:rgba(24,24,24,.92) !important;
  border:1px solid var(--accent) !important;
  padding:.5rem .9rem !important;
  border-radius:0 !important;
}

/* Flag pins on globe */
.flag-pin{
  position:relative;
  font-size:24px;line-height:1;
  cursor:pointer;
  text-align:center;
  filter:drop-shadow(0 0 6px rgba(0,0,0,.7)) drop-shadow(0 0 4px rgba(255,217,122,.45));
  transition:transform .25s ease,filter .25s ease;
  pointer-events:auto;
  user-select:none;
  transform:translate(-50%,-100%);
}
.flag-pin:hover{
  transform:translate(-50%,-105%) scale(1.25);
  filter:drop-shadow(0 0 12px rgba(255,217,122,.95));
}
.flag-pin__label{
  position:absolute;left:50%;bottom:calc(100% + 8px);
  transform:translateX(-50%);
  white-space:nowrap;
  font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink);
  background:rgba(24,24,24,.95);
  border:1px solid var(--accent);
  padding:.45rem .8rem;
  opacity:0;pointer-events:none;
  transition:opacity .2s ease;
}
.flag-pin:hover .flag-pin__label{opacity:1}

@media (max-width:760px){
  .globe-stage{height:clamp(440px,60vh,560px)}
  .globe-meta{position:static;padding:1.5rem var(--gutter) 0}
  .globe-legend{position:static;margin:1.5rem var(--gutter)}
}

/* ---------- Video panels ---------- */
.video-panel{position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;background:var(--bg-elev)}
.video-panel video{width:100%;height:100%;object-fit:cover;display:block}
.video-panel--landscape{aspect-ratio:16/9}
.video-panel__badge{
  position:absolute;left:1rem;top:1rem;z-index:2;
  font-family:var(--sans);font-size:.62rem;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);background:rgba(24,24,24,.6);backdrop-filter:blur(8px);
  padding:.5rem .8rem;border:1px solid var(--line);
}

/* ---------- Utilities ---------- */
.center{text-align:center}
.muted{color:var(--ink-soft)}
.divider{height:1px;background:var(--line);width:100%;margin:0}
.section-head{margin-bottom:clamp(2.5rem,5vw,4.5rem);max-width:60ch}
.section-head--center{margin-left:auto;margin-right:auto;text-align:center}

/* ---------- Mobile typography refinement (cleaner, more minimal) ---------- */
@media (max-width:760px){
  body{font-size:15px;line-height:1.65}
  h1{font-size:clamp(2rem,8vw,2.6rem);line-height:1.1;letter-spacing:-.005em;word-break:keep-all;hyphens:none}
  h2{font-size:clamp(1.55rem,5vw,2rem);line-height:1.15}
  h3{font-size:1.15rem;line-height:1.25}
  .lede{font-size:1.05rem;line-height:1.45}
  .eyebrow{font-size:.66rem;letter-spacing:.28em;margin-bottom:1.1rem}
  p{margin-bottom:1rem}

  /* Hero v2 mobile */
  .hero{padding:90px 0 3.5rem;min-height:auto}
  .hero__center{padding:0 1.4rem;max-width:100%}
  .hero__name{font-size:14px;letter-spacing:.28em;gap:.9rem;margin-bottom:1.3rem}
  .hero__name::before,
  .hero__name::after{width:24px}
  .hero__eyebrow{font-size:9.5px;letter-spacing:.26em;margin-bottom:1.2rem}
  .hero__title{font-size:clamp(36px,11vw,52px);line-height:.96;margin-bottom:1.2rem;letter-spacing:-.01em}
  .hero__desc{font-size:13px;line-height:1.6;margin-bottom:1.6rem}
  .btn-pill{padding:14px 26px;font-size:11.5px;letter-spacing:.22em}
  .hero__cta-row{gap:.8rem;flex-direction:column;width:100%}
  .hero__cta-row .btn,.hero__cta-row .btn-pill{width:100%;justify-content:center}

  /* Section padding */
  .section{padding:3.2rem 0}
  .section-tight{padding:2.2rem 0}

  /* About preview stack tightly */
  .about-preview{gap:2rem}
  .about-preview__copy h2{margin-bottom:1rem}

  /* Pillars / services stacks */
  .pillar{padding:2rem 1.4rem}
  .service{padding:1.8rem 1.4rem}

  /* Press marquee — smaller logos */
  .press-marquee__track{gap:3rem}
  .press-logo{height:32px}
  .press-logo--word{font-size:14px;letter-spacing:.18em}
  .press-logo--thesun{font-size:22px}
  .press-logo--bernama{font-size:14px}
  .press-logo--ukhr{font-size:11px;letter-spacing:.26em}
  .press-logo--pandora{font-size:14px;letter-spacing:.32em}
  .press-logo--sheda{font-size:13px}

  /* FAQ summary */
  .faq summary{font-size:1.08rem}

  /* Footer */
  .footer-grid{gap:2rem}
  .footer-grid h4{font-size:.62rem;letter-spacing:.22em}

  /* Header — tighten brand on small */
  .nav{height:72px;gap:1rem}
  .brand{font-size:1rem}
  .brand-text strong{font-size:.9rem;letter-spacing:.05em}

  /* CTA banner */
  .cta-banner{padding:3rem 0}
  .cta-banner h2{margin-bottom:1rem}

  /* Forms */
  .form{gap:1.2rem}
  .form input,.form select,.form textarea{font-size:.95rem;padding:.6rem 0}

  /* Splash */
  .splash__cta{bottom:6vh;padding:14px 36px;font-size:11px;letter-spacing:.32em}
  .splash__cta::before{inset:-8px}

  /* Audio toggle + WhatsApp FAB tighter */
  .audio-toggle{width:42px;height:42px;bottom:1.1rem;right:calc(1.1rem + 50px + 10px)}
  .fab{width:50px;height:50px;bottom:1.1rem;right:1.1rem}
  .fab svg{width:22px;height:22px}
}

@media (max-width:560px){
  h1{font-size:clamp(1.85rem,9vw,2.3rem)}
  .hero__title{font-size:clamp(32px,12vw,46px)}
  .container{padding:0 1.1rem}
  .hero__center{padding:0 1.1rem}
}

/* ---------- Floating WhatsApp ---------- */
.fab{
  position:fixed;bottom:1.6rem;right:1.6rem;z-index:40;
  width:56px;height:56px;border-radius:50%;
  background:var(--ink);color:var(--bg);display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.4);transition:transform .25s ease;
}
.fab:hover{transform:translateY(-3px);background:var(--accent);color:var(--bg)}
.fab svg{width:26px;height:26px}

/* ---------- Audio toggle ---------- */
.audio-toggle{
  position:fixed;bottom:1.6rem;right:calc(1.6rem + 56px + 12px);z-index:40;
  width:48px;height:48px;border-radius:50%;
  background:var(--ink);color:var(--bg);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 10px 30px rgba(0,0,0,.4);
  transition:transform .25s ease, background .25s ease, opacity .25s ease;
  cursor:pointer;border:0;font:inherit;line-height:1;
}
.audio-toggle:hover{transform:translateY(-3px);background:var(--accent)}
.audio-toggle.muted{opacity:.55}
.audio-toggle svg{width:20px;height:20px;fill:currentColor}
.audio-toggle::after{
  content:"";position:absolute;inset:-3px;border-radius:50%;
  border:1px solid rgba(217,185,122,.5);
  opacity:0;transition:opacity .3s ease, transform .3s ease;
}
.audio-toggle.playing::after{opacity:1;animation:audioPulse 2.4s ease-in-out infinite}
@keyframes audioPulse{
  0%,100%{opacity:.6;transform:scale(1)}
  50%{opacity:0;transform:scale(1.4)}
}

/* ---------- Splash (entry layer for home) ---------- */
.splash{
  position:fixed;inset:0;z-index:300;
  background:var(--bg);
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;isolation:isolate;
}
.splash__image{
  position:absolute;inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  z-index:0;user-select:none;-webkit-user-drag:none;
  background:transparent;
}
.splash::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:
    radial-gradient(ellipse at center, transparent 35%, rgba(7,7,7,.45) 90%),
    linear-gradient(180deg, transparent 55%, rgba(7,7,7,.7) 100%);
}
.splash__overlay{
  position:relative;z-index:2;
  text-align:center;pointer-events:none;
  padding:0 var(--gutter);
}
.splash__name{
  display:inline-flex;align-items:center;justify-content:center;gap:1.4rem;
  font-family:'Inter',var(--sans);
  font-weight:800;
  font-size:clamp(20px,2.4vw,28px);
  letter-spacing:.32em;
  text-transform:uppercase;
  color:#fff;
  margin:0 0 1.4rem;
  text-shadow:0 2px 24px rgba(0,0,0,.55);
}
.splash__name::before,
.splash__name::after{
  content:"";display:inline-block;
  width:clamp(28px,4vw,56px);height:1px;
  background:var(--accent);opacity:.85;
}
.splash__tag{
  font-family:'Cormorant Garamond',serif;
  font-style:italic;
  font-size:clamp(15px,1.5vw,20px);
  color:var(--ink-soft);
  text-shadow:0 2px 16px rgba(0,0,0,.6);
  margin:0;
  max-width:48ch;
  line-height:1.5;
  margin-left:auto;margin-right:auto;
}
.splash__cta{
  position:absolute;bottom:8.5vh;left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:inline-flex;align-items:center;gap:.9rem;
  padding:18px 56px;
  border:1px solid var(--accent);
  background:rgba(217,185,122,.06);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  font-family:'Inter',var(--sans);
  font-weight:700;font-size:13px;
  letter-spacing:.42em;
  text-transform:uppercase;
  color:var(--ink);
  cursor:pointer;
  transition:background .35s ease, color .35s ease, letter-spacing .35s ease, box-shadow .35s ease;
}
.splash__cta::before{
  content:"";
  position:absolute;inset:-12px;
  border:1px solid rgba(217,185,122,.35);
  pointer-events:none;
  animation:splashCtaPulse 2.4s ease-in-out infinite;
}
@keyframes splashCtaPulse{
  0%,100%{opacity:.45;transform:scale(1)}
  50%{opacity:0;transform:scale(1.18)}
}
.splash__cta:hover{
  background:var(--accent);
  color:var(--bg);
  letter-spacing:.5em;
  box-shadow:0 0 60px rgba(217,185,122,.5);
}
.splash__cta svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2.4}

/* Futuristic zoom-in exit */
.splash.exiting{
  pointer-events:none;
  animation:splashFlash 1.5s cubic-bezier(.7,.0,.2,1) forwards;
}
.splash.exiting .splash__image{
  animation:splashImgZoom 1.5s cubic-bezier(.7,.0,.2,1) forwards;
}
.splash.exiting .splash__overlay{animation:splashFade .55s ease forwards}
.splash.exiting .splash__cta{animation:splashFade .35s ease forwards}
@keyframes splashImgZoom{
  0%{transform:scale(1);filter:blur(0) brightness(1)}
  60%{transform:scale(2.2);filter:blur(10px) brightness(1.15)}
  100%{transform:scale(4.5);filter:blur(36px) brightness(2.4);opacity:.1}
}
@keyframes splashFade{to{opacity:0}}
@keyframes splashFlash{
  0%{background:var(--bg)}
  60%{background:var(--bg)}
  82%{background:#fff3cf}
  100%{opacity:0;background:#fff3cf;visibility:hidden}
}
body.splash-active{overflow:hidden;height:100vh}

@media (prefers-reduced-motion: reduce){
  .splash__cta::before{animation:none}
  .splash.exiting{animation:splashFade .4s ease forwards}
  .splash.exiting .splash__image{animation:splashFade .4s ease forwards}
}
