/* ============================================================================
   ZimanGo — brand stylesheet
   One source of truth for the whole site. Mirrors the iOS/Android app's
   design language: coral #FF6A3C, warm ink, soft light surfaces, rounded
   playful components, a friendly lion mascot, and a "learning road" motif.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   1. Fonts (self-hosted — same families the app ships)
   -------------------------------------------------------------------------- */
@font-face{font-family:"Lato";src:url("/fonts/Lato-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"Lato";src:url("/fonts/Lato-Semibold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Lato";src:url("/fonts/Lato-Bold.ttf") format("truetype");font-weight:700;font-style:normal;font-display:swap}
@font-face{font-family:"Lato";src:url("/fonts/Lato-Black.ttf") format("truetype");font-weight:900;font-style:normal;font-display:swap}
@font-face{font-family:"EB Garamond";src:url("/fonts/EBGaramond-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:"EB Garamond";src:url("/fonts/EBGaramond-Italic.ttf") format("truetype");font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:"EB Garamond";src:url("/fonts/EBGaramond-SemiBold.ttf") format("truetype");font-weight:600;font-style:normal;font-display:swap}
@font-face{font-family:"Dancing Script";src:url("/fonts/DancingScript-Regular.ttf") format("truetype");font-weight:400;font-style:normal;font-display:swap}

/* ----------------------------------------------------------------------------
   2. Design tokens
   -------------------------------------------------------------------------- */
:root{
  /* Brand palette — from the app's Asset Catalog */
  --coral:#FF6A3C;        /* primary action */
  --coral-700:#E8521F;    /* pressed / hover */
  --coral-300:#FF9670;    /* light coral */
  --peach:#FFE3D3;        /* selected tint */
  --ink:#14141A;          /* primary text */
  --ink-soft:#3C3C49;     /* secondary text */
  --ink-mute:#6B6B7B;     /* muted / captions */
  --ink-deep:#0C161B;     /* dark band background (app dark mode) */
  --ink-deep-2:#13212B;   /* dark band raised surface */
  --bg:#F5F7FD;           /* page background */
  --surface:#FFFFFF;      /* cards */
  --surface-2:#EEF1F8;    /* sunken / alt surface */
  --line:#E3E7F1;         /* hairlines / borders */
  --green:#34A853;        /* success / streak */
  --gold:#FFC300;         /* streak gold */
  --blue:#3C7DFF;         /* info accent */
  --purple:#8B5CF6;       /* trivia accent */
  --red:#EA2B2B;

  /* Typography */
  --font-ui:"Lato",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --font-serif:"EB Garamond",Georgia,"Times New Roman",serif;
  --font-script:"Dancing Script",var(--font-ui);

  /* Spacing scale (8px rhythm) */
  --s-1:.25rem; --s-2:.5rem; --s-3:.75rem; --s-4:1rem; --s-5:1.5rem;
  --s-6:2rem;  --s-7:3rem;  --s-8:4rem;  --s-9:6rem;  --s-10:8rem;

  /* Radii */
  --r-sm:10px; --r-md:16px; --r-lg:24px; --r-xl:32px; --r-pill:999px;

  /* Shadows (soft, app-like) */
  --shadow-sm:0 2px 8px rgba(20,20,26,.06);
  --shadow-md:0 10px 30px rgba(20,20,26,.08);
  --shadow-lg:0 24px 60px rgba(20,20,26,.12);
  --shadow-coral:0 12px 28px rgba(255,106,60,.32);

  --container:1160px;
  --container-narrow:760px;
  --header-h:72px;
  --ease:cubic-bezier(.22,.61,.36,1);
}

/* ----------------------------------------------------------------------------
   3. Reset & base
   -------------------------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 16px)}
body{
  margin:0;font-family:var(--font-ui);font-weight:400;font-size:1.0625rem;line-height:1.65;
  color:var(--ink);background:var(--bg);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img,svg,video{max-width:100%;height:auto;display:block}
a{color:var(--coral-700);text-decoration:none}
a:hover{text-decoration:underline}
ul,ol{margin:0;padding:0}
li{list-style:none}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:3px solid var(--coral);outline-offset:2px;border-radius:6px}
::selection{background:var(--peach);color:var(--ink)}
hr{border:none;border-top:1px solid var(--line);margin:var(--s-7) 0}

/* ----------------------------------------------------------------------------
   4. Typography
   -------------------------------------------------------------------------- */
h1,h2,h3,h4{font-weight:900;line-height:1.08;letter-spacing:-.02em;margin:0 0 .5em;color:var(--ink)}
h1,.h1{font-size:clamp(2.4rem,6vw,4rem)}
h2,.h2{font-size:clamp(1.9rem,4vw,2.9rem)}
h3,.h3{font-size:clamp(1.3rem,2.4vw,1.7rem)}
h4,.h4{font-size:1.15rem;font-weight:700;letter-spacing:-.01em}
p{margin:0 0 1rem}
.lead{font-size:clamp(1.1rem,2vw,1.3rem);line-height:1.6;color:var(--ink-soft)}
.muted{color:var(--ink-mute)}
.serif{font-family:var(--font-serif)}
.script{font-family:var(--font-script);font-weight:400}
strong,b{font-weight:700}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5em;
  font-weight:800;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--coral-700);margin-bottom:var(--s-3);
}
.eyebrow::before{content:"";width:22px;height:2px;border-radius:2px;background:var(--coral)}
.text-center{text-align:center}
.measure{max-width:42ch}
.measure-wide{max-width:60ch}
.coral{color:var(--coral-700)}
.no-wrap{white-space:nowrap}

/* gradient/“highlight” text for hero key words */
.hl{position:relative;color:var(--coral-700);white-space:nowrap}
.hl-underline{
  background-image:linear-gradient(120deg,var(--peach),var(--peach));
  background-repeat:no-repeat;background-position:0 88%;background-size:100% .34em;
}

/* ----------------------------------------------------------------------------
   5. Layout
   -------------------------------------------------------------------------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2rem)}
.narrow{max-width:var(--container-narrow)}
.section{padding-block:clamp(3.5rem,8vw,7rem)}
.section--tight{padding-block:clamp(2.5rem,5vw,4rem)}
.section--surface{background:var(--surface)}
.section--alt{background:linear-gradient(180deg,var(--bg),#EAEFFB)}
.section-head{max-width:62ch;margin:0 auto clamp(2rem,5vw,3.5rem)}
.section-head.text-center{margin-inline:auto}
.grid{display:grid;gap:clamp(1rem,2.5vw,1.75rem)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.split--media-first .split__media{order:-1}
.stack-sm>*+*{margin-top:var(--s-3)}
.stack>*+*{margin-top:var(--s-5)}

/* ----------------------------------------------------------------------------
   6. Buttons
   -------------------------------------------------------------------------- */
.btn{
  --btn-shadow:var(--shadow-sm);
  display:inline-flex;align-items:center;justify-content:center;gap:.55em;
  font-weight:800;font-size:1rem;line-height:1;text-decoration:none;
  padding:.95em 1.6em;border-radius:var(--r-pill);border:0;
  transition:transform .12s var(--ease),box-shadow .2s var(--ease),background .2s;
  white-space:nowrap;
}
.btn:hover{text-decoration:none}
.btn:active{transform:translateY(2px)}
.btn-primary{background:var(--coral);color:#fff;box-shadow:0 6px 0 var(--coral-700),var(--shadow-coral)}
.btn-primary:hover{background:var(--coral-700);box-shadow:0 4px 0 var(--coral-700),var(--shadow-coral);transform:translateY(2px)}
.btn-primary:active{box-shadow:0 0 0 var(--coral-700),var(--shadow-coral);transform:translateY(6px)}
.btn-ghost{background:var(--surface);color:var(--ink);box-shadow:inset 0 0 0 2px var(--line)}
.btn-ghost:hover{box-shadow:inset 0 0 0 2px var(--coral);color:var(--coral-700)}
.btn-dark{background:var(--ink);color:#fff}
.btn-dark:hover{background:#000}
.btn-lg{font-size:1.1rem;padding:1.1em 2em}
.btn.is-disabled,.btn[aria-disabled="true"]{opacity:.6;pointer-events:none;background:var(--surface-2);color:var(--ink-mute);box-shadow:none}
.btn-block{display:flex;width:100%}
.btn .ic{width:1.2em;height:1.2em}

/* store badges */
.store-badges{display:flex;flex-wrap:wrap;gap:.85rem;align-items:center}
.store-badge{display:inline-flex;height:54px;transition:transform .15s var(--ease),filter .2s}
.store-badge img{height:100%;width:auto}
.store-badge:hover{transform:translateY(-2px);text-decoration:none}
.store-badge.is-soon{position:relative;opacity:.92;filter:grayscale(.15)}
.store-badge.is-soon::after{
  content:"Soon";position:absolute;top:-8px;right:-8px;
  background:var(--coral);color:#fff;font-size:.62rem;font-weight:900;
  letter-spacing:.04em;padding:.2em .5em;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)
}

/* JS-rendered store pills (custom, consistent across all 3 stores) */
.store-badge-pill{
  position:relative;display:inline-flex;align-items:center;gap:.6rem;
  background:var(--ink);color:#fff;border-radius:14px;padding:.55rem 1.05rem;
  box-shadow:var(--shadow-md);transition:transform .15s var(--ease),box-shadow .2s;text-decoration:none;
}
.store-badge-pill:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg);text-decoration:none}
.store-badge-pill .sb-ic{display:grid;place-items:center;flex:0 0 auto}
.store-badge-pill .sb-tx{display:flex;flex-direction:column;line-height:1.08;text-align:left}
.store-badge-pill .sb-tx small{font-size:.62rem;font-weight:600;opacity:.82}
.store-badge-pill .sb-tx strong{font-size:1.06rem;font-weight:800;letter-spacing:-.01em}
.store-badge-pill .sb-soon{position:absolute;top:-7px;right:-7px;background:var(--coral);color:#fff;font-size:.6rem;font-weight:900;padding:.15em .5em;border-radius:var(--r-pill);box-shadow:var(--shadow-sm)}
.store-badge-pill.is-soon{opacity:.6;cursor:default;box-shadow:var(--shadow-sm)}
.store-badge-pill.is-soon:hover{transform:none;box-shadow:var(--shadow-sm)}
.store-badges--light .store-badge-pill{background:#fff;color:var(--ink)}
.store-badges--light .store-badge-pill.is-soon{opacity:.72}
[dir="rtl"] .store-badge-pill .sb-tx{text-align:right}

/* screenshot image (used un-framed, e.g. the polished App-Store marketing shots) */
.shot{width:100%;border-radius:var(--r-lg);box-shadow:var(--shadow-lg);background:#0b0b10}
.section--dark .shot{box-shadow:0 24px 60px rgba(0,0,0,.5)}

/* ----------------------------------------------------------------------------
   7. Header / navigation
   -------------------------------------------------------------------------- */
.site-header{
  position:sticky;top:0;z-index:50;height:var(--header-h);
  background:rgba(245,247,253,.82);backdrop-filter:saturate(180%) blur(14px);
  border-bottom:1px solid transparent;transition:border-color .3s,background .3s;
}
.site-header.is-scrolled{border-bottom-color:var(--line);box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;height:100%;gap:var(--s-5)}
.brand{display:inline-flex;align-items:center;gap:.6rem;font-weight:900;font-size:1.3rem;color:var(--ink);letter-spacing:-.02em}
.brand:hover{text-decoration:none}
.brand img{width:38px;height:38px;border-radius:10px;box-shadow:var(--shadow-sm)}
.nav-links{display:flex;align-items:center;gap:clamp(.5rem,2vw,1.6rem)}
.nav-links a{color:var(--ink-soft);font-weight:700;font-size:.98rem;padding:.4rem .2rem;position:relative}
.nav-links a:hover{color:var(--ink);text-decoration:none}
.nav-links a[aria-current="page"]{color:var(--coral-700)}
.nav-links a[aria-current="page"]::after{content:"";position:absolute;left:0;right:0;bottom:-2px;height:3px;border-radius:3px;background:var(--coral)}
.nav-right{display:flex;align-items:center;gap:.75rem}
.header-social{display:inline-flex;align-items:center;gap:.1rem}
.header-social a{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--ink-soft);transition:color .2s,background .2s}
.header-social a:hover{color:var(--coral-700);background:var(--surface-2)}
.header-social svg{width:18px;height:18px}
.nav-social{display:none}
.lang-switch{display:inline-flex;align-items:center;gap:.4rem;font-weight:700;font-size:.92rem;color:var(--ink-soft);background:var(--surface);border:1px solid var(--line);border-radius:var(--r-pill);padding:.5rem .9rem}
.lang-switch:hover{border-color:var(--coral);color:var(--coral-700);text-decoration:none}
.nav-toggle{display:none;width:44px;height:44px;border:1px solid var(--line);background:var(--surface);border-radius:12px;align-items:center;justify-content:center}
.nav-toggle span,.nav-toggle span::before,.nav-toggle span::after{content:"";display:block;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s var(--ease),opacity .2s}
.nav-toggle span{position:relative}
.nav-toggle span::before{position:absolute;top:-6px}
.nav-toggle span::after{position:absolute;top:6px}
body.nav-open .nav-toggle span{background:transparent}
body.nav-open .nav-toggle span::before{transform:translateY(6px) rotate(45deg)}
body.nav-open .nav-toggle span::after{transform:translateY(-6px) rotate(-45deg)}

@media(max-width:880px){
  .nav-toggle{display:inline-flex}
  .nav-links{
    position:fixed;inset:var(--header-h) 0 auto 0;flex-direction:column;align-items:stretch;
    background:var(--surface);padding:var(--s-4) clamp(1.1rem,4vw,2rem) var(--s-6);
    gap:.25rem;box-shadow:var(--shadow-lg);border-bottom:1px solid var(--line);
    transform:translateY(-12px);opacity:0;pointer-events:none;transition:transform .25s var(--ease),opacity .25s;
  }
  body.nav-open .nav-links{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a{padding:.85rem .25rem;font-size:1.1rem;border-bottom:1px solid var(--line)}
  .nav-links a[aria-current="page"]::after{display:none}
  .nav-right .lang-switch{display:none}
  .header-social{display:none}
  .nav-social{display:flex;gap:.5rem;padding:.9rem .25rem .25rem;border-bottom:0}
  .nav-social a{width:44px;height:44px;padding:0;border-radius:12px;display:grid;place-items:center;color:var(--ink-soft);background:var(--surface-2);border-bottom:0;font-size:1rem}
  .nav-social a:hover{color:var(--coral-700)}
  .nav-social svg{width:21px;height:21px}
}

/* ----------------------------------------------------------------------------
   8. Hero
   -------------------------------------------------------------------------- */
.hero{position:relative;overflow:hidden;padding-block:clamp(2.5rem,6vw,5rem) clamp(3rem,7vw,6rem)}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(2rem,5vw,4rem);align-items:center}
.hero__title{margin-bottom:var(--s-4)}
.hero__blob{position:absolute;border-radius:50%;filter:blur(40px);opacity:.5;z-index:-1}
.hero__blob--1{width:520px;height:520px;background:radial-gradient(circle,var(--peach),transparent 70%);top:-160px;right:-120px}
.hero__blob--2{width:420px;height:420px;background:radial-gradient(circle,#D9E4FF,transparent 70%);bottom:-180px;left:-140px}
.hero__cta{display:flex;flex-wrap:wrap;gap:1rem;align-items:center;margin-top:var(--s-5)}
.hero__note{display:flex;align-items:center;gap:.5rem;color:var(--ink-mute);font-size:.92rem;font-weight:600;margin-top:var(--s-4)}
.hero__media{position:relative;display:flex;justify-content:center}
@media(max-width:880px){
  .hero__inner{grid-template-columns:1fr;text-align:center}
  .hero__cta,.store-badges,.hero__note{justify-content:center}
  .hero__media{margin-top:var(--s-6)}
  .hero__title{margin-top:var(--s-2)}
}

/* ----------------------------------------------------------------------------
   9. Device image — a single PNG that already includes the phone case.
      (No CSS frame; we just size, round, shadow and gently float it.)
   -------------------------------------------------------------------------- */
.device-img{display:block;width:min(300px,76vw);margin-inline:auto;border-radius:28px;filter:drop-shadow(0 26px 55px rgba(20,20,26,.22));animation:float 6s var(--ease) infinite}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-14px)}}
@media(prefers-reduced-motion:reduce){.device-img{animation:none}}
/* small floating Lottie accents around the hero device (streak flame + XP) */
.hero-accent{position:absolute;width:92px;height:92px;z-index:3;filter:drop-shadow(0 10px 22px rgba(20,20,26,.2));pointer-events:none}
.hero-accent--flame{top:2%;left:5%;animation:float 5s var(--ease) infinite}
.hero-accent--xp{bottom:8%;right:3%;animation:float 6.5s var(--ease) infinite}
@media(max-width:880px){.hero-accent{width:66px;height:66px}}
@media(max-width:560px){.hero-accent{display:none}}

/* ----------------------------------------------------------------------------
   10. Cards & feature blocks
   -------------------------------------------------------------------------- */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);padding:clamp(1.4rem,3vw,2rem);box-shadow:var(--shadow-sm);transition:transform .2s var(--ease),box-shadow .2s}
.card--lift:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.feature-card .ficon{width:56px;height:56px;border-radius:16px;display:grid;place-items:center;margin-bottom:var(--s-4);background:var(--peach);color:var(--coral-700)}
.feature-card .ficon svg{width:28px;height:28px}
.feature-card h3{margin-bottom:.35em;font-size:1.25rem}
.feature-card p{margin:0;color:var(--ink-soft)}
.icon-variant-green{background:#DDF3E4!important;color:var(--green)!important}
.icon-variant-blue{background:#DEE9FF!important;color:var(--blue)!important}
.icon-variant-purple{background:#EBE3FF!important;color:var(--purple)!important}
.icon-variant-gold{background:#FFF1C2!important;color:#B8860B!important}

/* list with check marks */
.check-list li{position:relative;padding-left:2rem;margin-bottom:.7rem;color:var(--ink-soft)}
.check-list li::before{
  content:"";position:absolute;left:0;top:.15rem;width:1.35rem;height:1.35rem;border-radius:50%;
  background:var(--green) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E") center/.85rem no-repeat;
}

/* tag / pill */
.tag{display:inline-flex;align-items:center;gap:.4em;font-weight:800;font-size:.82rem;padding:.4em .85em;border-radius:var(--r-pill);background:var(--surface-2);color:var(--ink-soft)}
.tag--live{background:#DDF3E4;color:#1d7a3a}
.tag--soon{background:var(--surface-2);color:var(--ink-mute)}
.tag--coral{background:var(--peach);color:var(--coral-700)}
.dot{width:.5em;height:.5em;border-radius:50%;background:currentColor;display:inline-block}

/* steps with the "learning road" connector */
.steps{counter-reset:step;display:grid;gap:clamp(1rem,3vw,2rem)}
.step{position:relative;display:flex;gap:1.25rem;align-items:flex-start}
.step__num{flex:0 0 auto;counter-increment:step;width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-weight:900;color:#fff;background:var(--coral);box-shadow:var(--shadow-coral)}
.step__num::before{content:counter(step)}
.step h3{font-size:1.2rem;margin-bottom:.25em}
.step p{margin:0;color:var(--ink-soft)}

/* ----------------------------------------------------------------------------
   11. Dark band (mirrors app dark UI / App Store shots)
   -------------------------------------------------------------------------- */
.section--dark{background:radial-gradient(140% 120% at 80% -10%,#16303d 0%,var(--ink-deep) 55%);color:#E7ECF2}
.section--dark h1,.section--dark h2,.section--dark h3,.section--dark h4{color:#fff}
.section--dark .lead,.section--dark p{color:#AEB9C6}
.section--dark .muted{color:#7f8b9c}
.section--dark .card{background:var(--ink-deep-2);border-color:rgba(255,255,255,.08);box-shadow:none;color:#cfd8e3}
.section--dark .eyebrow{color:var(--coral-300)}
.section--dark .btn-ghost{background:rgba(255,255,255,.06);box-shadow:inset 0 0 0 2px rgba(255,255,255,.16);color:#fff}
.section--dark .btn-ghost:hover{box-shadow:inset 0 0 0 2px var(--coral);color:#fff}

/* ----------------------------------------------------------------------------
   12. Dialect cards
   -------------------------------------------------------------------------- */
.dialect-card{display:flex;flex-direction:column;gap:.4rem}
.dialect-card .dialect-name{font-size:1.35rem;font-weight:900;letter-spacing:-.01em}
.dialect-card .dialect-native{font-family:var(--font-serif);font-style:italic;color:var(--ink-mute);font-size:1.05rem}
.progress{height:10px;border-radius:var(--r-pill);background:var(--surface-2);overflow:hidden;margin-top:.6rem}
.progress>span{display:block;height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--coral),var(--coral-300))}

/* ----------------------------------------------------------------------------
   13. FAQ accordion
   -------------------------------------------------------------------------- */
.faq{max-width:var(--container-narrow);margin-inline:auto}
.faq-item{border:1px solid var(--line);border-radius:var(--r-md);background:var(--surface);margin-bottom:.75rem;overflow:hidden}
.faq-q{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;text-align:left;background:none;border:0;padding:1.15rem 1.3rem;font-weight:800;font-size:1.05rem;color:var(--ink)}
.faq-q .chev{flex:0 0 auto;width:22px;height:22px;transition:transform .25s var(--ease);color:var(--coral-700)}
.faq-item[open] .faq-q .chev{transform:rotate(180deg)}
.faq-a{padding:0 1.3rem 1.25rem;color:var(--ink-soft)}
.faq-a p:last-child{margin-bottom:0}
details.faq-item>summary{list-style:none;cursor:pointer}
details.faq-item>summary::-webkit-details-marker{display:none}

/* ----------------------------------------------------------------------------
   14. Lottie holder
   -------------------------------------------------------------------------- */
.lottie{width:100%;max-width:340px;margin-inline:auto;aspect-ratio:1/1}
.lottie--sm{max-width:180px}

/* ----------------------------------------------------------------------------
   15. CTA / Ko-fi / mascot strip
   -------------------------------------------------------------------------- */
.cta-band{position:relative;overflow:hidden;border-radius:var(--r-xl);padding:clamp(2rem,5vw,3.5rem);background:linear-gradient(135deg,var(--coral),#FF8A4C);color:#fff;box-shadow:var(--shadow-coral)}
.cta-band h2{color:#fff}
.cta-band p{color:rgba(255,255,255,.92)}
.cta-band .btn-primary{background:#fff;color:var(--coral-700);box-shadow:0 6px 0 rgba(0,0,0,.12)}
.cta-band .btn-primary:hover{background:#fff;color:var(--coral-700)}
.mascot-peek{position:absolute;right:-10px;bottom:-10px;width:160px;opacity:.95;pointer-events:none}

/* ----------------------------------------------------------------------------
   16. Footer
   -------------------------------------------------------------------------- */
.site-footer{background:var(--ink-deep);color:#9fb0c0;padding-block:clamp(3rem,6vw,4.5rem) var(--s-6);font-size:.95rem}
.footer-top{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:clamp(1.5rem,4vw,3rem)}
.footer-brand .brand{color:#fff}
.footer-brand p{color:#8295a6;max-width:34ch;margin-top:var(--s-3)}
.footer-col h4{color:#fff;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;margin-bottom:var(--s-4)}
.footer-col a{display:block;color:#9fb0c0;padding:.3rem 0;font-weight:600}
.footer-col a:hover{color:#fff;text-decoration:none}
.footer-social{display:flex;gap:.6rem;margin-top:var(--s-4)}
.footer-social a{width:40px;height:40px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.07);color:#cdd8e2;transition:background .2s,transform .15s}
.footer-social a:hover{background:var(--coral);color:#fff;transform:translateY(-2px)}
.footer-social svg{width:20px;height:20px}
.footer-bottom{margin-top:clamp(2rem,5vw,3rem);padding-top:var(--s-5);border-top:1px solid rgba(255,255,255,.08);display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;align-items:center}
.footer-legal{color:#6f8294;font-size:.86rem;line-height:1.6}
.footer-legal strong{color:#aebccb}
.footer-bottom-links{display:flex;flex-wrap:wrap;gap:1.2rem}
.footer-bottom-links a{color:#9fb0c0;font-weight:600}
.footer-bottom-links a:hover{color:#fff;text-decoration:none}
@media(max-width:760px){.footer-top{grid-template-columns:1fr 1fr}.footer-brand{grid-column:1/-1}}
@media(max-width:480px){.footer-top{grid-template-columns:1fr}}

/* ----------------------------------------------------------------------------
   17. Page hero (interior pages)
   -------------------------------------------------------------------------- */
.page-hero{padding-block:clamp(2.5rem,6vw,4.5rem) clamp(2rem,4vw,3rem);text-align:center;position:relative}
.page-hero .lead{margin-inline:auto;max-width:54ch}
.breadcrumb{display:flex;gap:.5rem;justify-content:center;color:var(--ink-mute);font-size:.9rem;font-weight:600;margin-bottom:var(--s-4)}
.breadcrumb a{color:var(--ink-mute)}
.breadcrumb a:hover{color:var(--coral-700)}

/* prose for legal pages */
.prose{max-width:var(--container-narrow);margin-inline:auto}
.prose h2{font-size:clamp(1.4rem,3vw,1.9rem);margin-top:2.2em}
.prose h2:first-of-type{margin-top:0}
.prose h3{font-size:1.2rem;margin-top:1.6em}
.prose p,.prose li{color:var(--ink-soft)}
.prose ul{margin:0 0 1rem;padding-left:1.3rem}
.prose ul li{list-style:disc;margin-bottom:.4rem}
.prose a{font-weight:700;text-decoration:underline}
.updated-stamp{display:inline-block;background:var(--surface-2);color:var(--ink-mute);font-weight:700;font-size:.85rem;padding:.45em 1em;border-radius:var(--r-pill);margin-bottom:var(--s-5)}

/* social buttons (light surfaces, e.g. Support contact card) */
.social-btns{display:flex;gap:.6rem;justify-content:center;margin-top:.25rem;flex-wrap:wrap}
.social-btns a{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--peach);color:var(--coral-700);transition:transform .15s var(--ease),background .2s,color .2s}
.social-btns a:hover{background:var(--coral);color:#fff;transform:translateY(-2px);text-decoration:none}
.social-btns svg{width:20px;height:20px}

/* contact methods */
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem}
.contact-card{text-align:center}
.contact-card .ficon{margin-inline:auto}
.contact-card a{font-weight:800;font-size:1.1rem}

/* ----------------------------------------------------------------------------
   18. Utilities & motion
   -------------------------------------------------------------------------- */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:-9999px;top:0;z-index:100;background:var(--coral);color:#fff;padding:.7rem 1.1rem;border-radius:0 0 12px 0;font-weight:800}
.skip-link:focus{left:0}
.mt-0{margin-top:0}.mb-0{margin-bottom:0}
/* reveal-on-scroll is a JS enhancement only — without JS (or before it runs)
   the .js class is absent, so content is always visible. Prevents FOUC/blank. */
.js .reveal{opacity:0;transform:translateY(22px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.js .reveal.is-in{opacity:1;transform:none}

@media(max-width:880px){
  .grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}
  .split{grid-template-columns:1fr;gap:2rem}
  .split--media-first .split__media{order:0}
}
@media(max-width:560px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
  .js .reveal{opacity:1;transform:none}
}

/* ----------------------------------------------------------------------------
   19. RTL readiness (used when ckb/ar locale is built)
   -------------------------------------------------------------------------- */
[dir="rtl"] .check-list li{padding-left:0;padding-right:2rem}
[dir="rtl"] .check-list li::before{left:auto;right:0}
[dir="rtl"] .eyebrow::before{order:2}
