/* ============================================================
   Language Link Up — landing page
   Brand: speech-bubble motif · Open Sans body · Aptly Bold titles
   ============================================================ */
@font-face{font-family:'Aptly'; src:url(fonts/AptlyBold.otf) format('opentype'); font-weight:700; font-style:normal; font-display:swap}
@font-face{font-family:'Aptly'; src:url(fonts/AptlyExtraBold.otf) format('opentype'); font-weight:800; font-style:normal; font-display:swap}
@font-face{font-family:'Open Sans'; src:url(fonts/OpenSans-Regular.ttf) format('truetype'); font-weight:400; font-style:normal; font-display:swap}
@font-face{font-family:'Open Sans'; src:url(fonts/OpenSans-SemiBold.ttf) format('truetype'); font-weight:600; font-style:normal; font-display:swap}
@font-face{font-family:'Open Sans'; src:url(fonts/OpenSans-Bold.ttf) format('truetype'); font-weight:700; font-style:normal; font-display:swap}
@font-face{font-family:'Open Sans'; src:url(fonts/OpenSans-Italic.ttf) format('truetype'); font-weight:400; font-style:italic; font-display:swap}

/* ---- Tokens (tweakable + direction-driven) ---- */
:root{
  /* bubble palette (from the designer's exact assets) */
  --blue:#0066A4;
  --blue-ink:#0167A4;
  --green:#00A86B;
  --red:#CC2B11;
  --yellow:#FEBE00;

  /* defaults — overridden per [data-direction] */
  --bg:#FAF7F1;
  --bg-alt:#F1 EAE0;
  --surface:#FFFFFF;
  --ink:#15222F;
  --muted:#5C6B78;
  --line:rgba(21,34,47,.12);
  --primary:#0066A4;
  --primary-deep:#054E7D;
  --on-primary:#FFFFFF;

  --radius:18px;
  --radius-lg:28px;
  --bubble-scale:1;
  --bubble-opacity:1;
  --display-weight:800;
  --display-tracking:-0.02em;
  --h1:clamp(2.6rem,6.4vw,5.3rem);
  --h2:clamp(2.4rem,5vw,4rem);
  --section-pad:clamp(72px,9vw,140px);
  --maxw:1200px;

  --font-display:'Aptly', system-ui, sans-serif;
  --font-body:'Open Sans', system-ui, sans-serif;

  --shadow-sm:0 2px 10px rgba(21,34,47,.06);
  --shadow:0 18px 50px -22px rgba(21,34,47,.35);
  --shadow-lg:0 40px 90px -40px rgba(8,40,70,.55);
  --motion:1; /* 0 disables bubble float */
}

/* fix typo'd token via fallback */
:root{ --bg-alt:#F2EBE0; }

/* === DIRECTION 1 · WARM (recommended default) ============= */
[data-direction="warm"]{
  --bg:#FAF7F1; --bg-alt:#F2EBDF; --surface:#FFFFFF;
  --ink:#1A2733; --muted:#5C6B78;
  --primary:#0066A4; --primary-deep:#054E7D;
  --radius:18px; --radius-lg:30px;
  --bubble-scale:1; --bubble-opacity:1;
  --display-weight:800;
  --h2:clamp(2.8rem,5.6vw,4.7rem);
}

/* === DIRECTION 2 · VIBRANT ================================= */
[data-direction="vibrant"]{
  --bg:#FFFBEF; --bg-alt:#EAF4FB; --surface:#FFFFFF;
  --ink:#13202C; --muted:#566472;
  --primary:#0067A6; --primary-deep:#024D7C;
  --radius:24px; --radius-lg:38px;
  --bubble-scale:1.18; --bubble-opacity:1;
  --display-weight:800; --display-tracking:-0.025em;
  --h1:clamp(2.7rem,6.8vw,5.8rem);
  --h2:clamp(3rem,6.2vw,5.2rem);
}

/* === DIRECTION 3 · POLISHED =============================== */
[data-direction="polished"]{
  --bg:#FAFBFC; --bg-alt:#EEF3F7; --surface:#FFFFFF;
  --ink:#10202E; --muted:#5A6976;
  --primary:#0A5C92; --primary-deep:#063F66;
  --radius:8px; --radius-lg:12px;
  --bubble-scale:.82; --bubble-opacity:.92;
  --display-weight:700; --display-tracking:-0.015em;
  --h1:clamp(2.4rem,5.4vw,4.6rem);
  --h2:clamp(2.4rem,4.8vw,4rem);
  --section-pad:clamp(64px,8vw,120px);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){ html{scroll-behavior:auto} }
body{
  margin:0; background:var(--bg); color:var(--ink);
  font-family:var(--font-body); font-size:17px; line-height:1.6;
  -webkit-font-smoothing:antialiased; overflow-x:clip;
}
img{display:block; max-width:100%}
a{color:inherit; text-decoration:none}
h1,h2,h3,h4{font-family:var(--font-display); font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking); line-height:1.02; margin:0; text-wrap:balance}
p{margin:0}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 clamp(20px,5vw,48px)}
.section{padding:var(--section-pad) 0; position:relative}
.eyebrow{font-family:var(--font-display); font-weight:700; font-size:1.04rem;
  letter-spacing:.14em; text-transform:uppercase; color:var(--primary)}

/* ---- buttons ---- */
.btn{display:inline-flex; align-items:center; gap:.55em; font-family:var(--font-display);
  font-weight:700; font-size:1.02rem; padding:.92em 1.55em; border-radius:999px;
  border:2px solid transparent; cursor:pointer; transition:transform .18s ease, box-shadow .18s ease, background .18s; white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--primary); color:var(--on-primary); box-shadow:0 14px 30px -12px color-mix(in srgb,var(--primary) 70%,transparent)}
.btn-primary:hover{transform:translateY(-2px); box-shadow:0 20px 38px -14px color-mix(in srgb,var(--primary) 75%,transparent)}
.btn-ghost{background:transparent; color:var(--ink); border-color:var(--line)}
.btn-ghost:hover{border-color:var(--primary); color:var(--primary); transform:translateY(-2px)}
.btn-light{background:#fff; color:var(--primary)}
.btn-light:hover{transform:translateY(-2px)}
.btn svg{width:1.05em; height:1.05em}

/* ---- nav ---- */
.nav{position:sticky; top:0; z-index:60; background:color-mix(in srgb,var(--bg) 82%, transparent);
  backdrop-filter:blur(12px); border-bottom:1px solid transparent; transition:border-color .3s, background .3s}
.nav.scrolled{border-color:var(--line); background:color-mix(in srgb,var(--bg) 92%, transparent)}
.nav-inner{display:flex; align-items:center; gap:24px; height:74px}
.brand{display:inline-flex; align-items:center; gap:11px}
.brand img.logo{height:62px; width:auto; display:block}
.footer .brand img.logo{height:76px}
.nav-links{display:flex; gap:26px; margin-left:auto; font-weight:600; font-size:.96rem; color:var(--muted)}
.nav-links a{transition:color .15s}
.nav-links a:hover{color:var(--ink)}
.nav-cta{display:flex; gap:10px; align-items:center}
.nav-toggle{display:none; margin-left:auto; background:none; border:0; cursor:pointer; padding:8px}
.nav-toggle span{display:block; width:24px; height:2.5px; background:var(--ink); border-radius:2px; margin:5px 0; transition:.25s}
@media(max-width:920px){
  .nav-links{display:none}
  .nav-cta .btn-ghost{display:none}
  .nav-toggle{display:block}
  .nav-links.open{display:flex; position:absolute; top:74px; left:0; right:0; flex-direction:column;
    background:var(--surface); padding:18px 28px; gap:18px; border-bottom:1px solid var(--line); box-shadow:var(--shadow)}
}

/* ---- speech bubble component (real designer assets) ---- */
.bubble{position:relative; display:inline-grid; place-items:center; text-align:center;
  background-repeat:no-repeat; background-size:100% 100%; color:#fff;
  font-family:var(--font-display); font-weight:800; line-height:1.05;
  filter:drop-shadow(0 16px 26px rgba(8,40,70,.18))}
.bubble.blue{background-image:url(media/bubble-blue.png)}
.bubble.green{background-image:url(media/bubble-green.png)}
.bubble.red{background-image:url(media/bubble-red.png)}
.bubble.yellow{background-image:url(media/bubble-yellow.png); color:#1A2733}
/* text sits in the upper rounded body, clear of the tail */
.bubble .b-txt{padding:14% 17% 26%; display:block; width:100%}
.bubble .b-sub{display:block; font-family:var(--font-body); font-weight:600; opacity:.9; margin-top:.3em; font-size:.5em}

/* floating decorative bubbles */
.floaties{position:absolute; inset:0; overflow:visible; pointer-events:none; z-index:1}
.floaty{position:absolute; opacity:var(--bubble-opacity);
  animation:bob calc(7s / var(--motion,1)) ease-in-out infinite; will-change:transform}
.floaty:nth-child(2n){animation-duration:8.5s; animation-delay:-1.5s}
.floaty:nth-child(3n){animation-duration:9.5s; animation-delay:-3s}
@keyframes bob{0%,100%{transform:translateY(0) rotate(var(--rot,0deg)) scale(var(--fx,1),var(--fy,1))}
  50%{transform:translateY(-16px) rotate(calc(var(--rot,0deg) + 2deg)) scale(var(--fx,1),var(--fy,1))}}
@media (prefers-reduced-motion:reduce){ .floaty{animation:none} }
/* keep decorative bubbles strictly behind text, and ease them back on small screens for legibility */
@media(max-width:640px){ .floaty{opacity:calc(var(--bubble-opacity) * .55)} }

/* ===================== HERO ===================== */
.hero{position:relative; padding-top:clamp(40px,6vw,72px); overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(28px,4vw,60px); align-items:center; position:relative; z-index:2}
@media(max-width:900px){ .hero-grid{grid-template-columns:1fr; gap:36px} }
.hero .tag{display:inline-flex; align-items:center; gap:9px; font-family:var(--font-display);
  font-weight:700; font-size:.9rem; color:var(--primary); background:color-mix(in srgb,var(--primary) 12%, #fff);
  padding:.5em 1em; border-radius:999px; margin-bottom:22px}
.hero h1{font-size:var(--h1); margin-bottom:.32em}
.hero h1 .hl{color:var(--primary); position:relative; white-space:nowrap}
.hero .lede{font-size:clamp(1.08rem,1.5vw,1.28rem); color:var(--muted); max-width:33ch; margin-bottom:30px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap; align-items:center}
.hero-note{margin-top:18px; font-size:.94rem; color:var(--muted); display:flex; align-items:center; gap:8px}
.hero-note b{color:var(--ink)}
.hero-media{position:relative}
.hero-media .photo{border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg);
  aspect-ratio:4/3.05; background:var(--bg-alt) center/cover; transform:rotate(-1.2deg)}
.hero-media .photo img{width:100%; height:100%; object-fit:cover}
[data-hero="solid"] .hero-media .photo{display:none}
.hero-solid{display:none}
[data-hero="solid"] .hero-solid{display:grid; place-items:center; border-radius:var(--radius-lg);
  aspect-ratio:4/3.05; background:var(--primary); position:relative; overflow:hidden; box-shadow:var(--shadow-lg); padding:7%}
.hero-solid .logoart{width:62%; max-width:340px; position:relative; z-index:2}

/* ===================== STATS ===================== */
.stats{background:var(--primary); color:#fff; position:relative; overflow:hidden}
.stats .wrap{position:relative; z-index:2}
.stats-head{display:flex; flex-wrap:wrap; align-items:end; justify-content:space-between; gap:16px; margin-bottom:38px}
.stats-head h2{color:#fff; font-size:var(--h2); max-width:16ch}
.stats-head p{color:rgba(255,255,255,.82); max-width:34ch}
.stat-grid{display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(18px,3vw,40px)}
@media(max-width:760px){ .stat-grid{grid-template-columns:repeat(2,1fr); gap:30px 24px} }
.stat{position:relative}
.stat .num{font-family:var(--font-display); font-weight:800; font-size:clamp(2.8rem,5.5vw,4.4rem); line-height:1; letter-spacing:-.03em}
.stat .lbl{margin-top:8px; color:rgba(255,255,255,.82); font-weight:600; font-size:1rem}
.stat .num .suf{color:var(--yellow)}
.stats .deco{position:absolute; right:-40px; top:-30px; width:230px; opacity:.16; transform:rotate(8deg)}

/* ===================== ABOUT ===================== */
.about-grid{display:grid; grid-template-columns:.92fr 1.08fr; gap:clamp(30px,5vw,72px); align-items:center}
@media(max-width:900px){ .about-grid{grid-template-columns:1fr} }
.about-media{position:relative}
.about-media .main{border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow); aspect-ratio:3/3.4; background:var(--bg-alt) center/cover}
.about-media .main img{width:100%;height:100%;object-fit:cover}
.about-media .inset{position:absolute; bottom:-28px; right:-22px; width:46%; border-radius:var(--radius);
  overflow:hidden; box-shadow:var(--shadow-lg); border:5px solid var(--surface); transform:rotate(3deg)}
.about-media .inset img{width:100%; aspect-ratio:1.3/1; object-fit:cover}
@media(max-width:560px){ .about-media .inset{display:none} }
.lead-h{font-size:var(--h2); margin:.4em 0 .55em}
.about-copy p + p{margin-top:1.05em; color:var(--muted)}
.pill-row{display:flex; flex-wrap:wrap; gap:10px; margin-top:26px}
.pill{display:inline-flex; align-items:center; gap:8px; padding:.5em 1em; border-radius:999px;
  background:var(--surface); border:1px solid var(--line); font-weight:600; font-size:.92rem; box-shadow:var(--shadow-sm)}
.pill .dot{width:9px;height:9px;border-radius:50%}

/* ===================== HOW IT WORKS ===================== */
.how{background:var(--bg-alt)}
.section-head{text-align:center; max-width:62ch; margin:0 auto clamp(40px,5vw,64px)}
.section-head h2{font-size:var(--h2); margin:.3em 0 .42em}
.section-head p{color:var(--muted); font-size:clamp(1.1rem,1.5vw,1.28rem)}
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:20px}
@media(max-width:880px){ .steps{grid-template-columns:repeat(2,1fr)} }
@media(max-width:480px){ .steps{grid-template-columns:1fr} }
.step{background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:30px 26px 30px; position:relative; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s}
.step:hover{transform:translateY(-5px); box-shadow:var(--shadow)}
.step .badge{width:60px; height:60px; border-radius:50%; display:grid; place-items:center; color:#fff; font-family:var(--font-display);
  font-weight:800; font-size:1.7rem; margin-bottom:18px; box-shadow:var(--shadow-sm)}
.step:nth-child(1) .badge{background:var(--blue)}
.step:nth-child(2) .badge{background:var(--green)}
.step:nth-child(3) .badge{background:var(--red)}
.step:nth-child(4) .badge{background:var(--yellow); color:#1A2733}
.step h3{font-size:1.32rem; margin-bottom:.4em}
.step p{color:var(--muted); font-size:.98rem}

/* ===================== LANGUAGES ===================== */
.lang-marquee{overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.marquee-track{display:flex; gap:14px; width:max-content; animation:scroll calc(38s / var(--motion,1)) linear infinite}
@media (prefers-reduced-motion:reduce){ .marquee-track{animation:none; flex-wrap:wrap; width:auto; justify-content:center} }
@keyframes scroll{to{transform:translateX(-50%)}}
.lang-chip{display:inline-flex; align-items:center; gap:12px; padding:.7em 1.2em; border-radius:999px;
  background:var(--surface); border:1px solid var(--line); box-shadow:var(--shadow-sm); white-space:nowrap}
.lang-chip .hello{font-family:var(--font-display); font-weight:800; font-size:1.12rem}
.lang-chip .name{color:var(--muted); font-weight:600; font-size:.92rem}
.lang-chip .flagdot{width:10px;height:10px;border-radius:50%}

/* ===================== GALLERY ===================== */
.gallery{columns:3; column-gap:16px}
@media(max-width:860px){ .gallery{columns:2} }
@media(max-width:520px){ .gallery{columns:1} }
.gcard{break-inside:avoid; margin-bottom:16px; border-radius:var(--radius); overflow:hidden;
  position:relative; cursor:pointer; box-shadow:var(--shadow-sm); background:var(--bg-alt)}
.gcard img{width:100%; transition:transform .5s cubic-bezier(.2,.7,.2,1)}
.gcard:hover img{transform:scale(1.06)}
.gcard .cap{position:absolute; inset:auto 0 0 0; padding:34px 16px 14px; color:#fff; font-weight:700;
  font-family:var(--font-display); font-size:1rem; background:linear-gradient(transparent,rgba(8,20,32,.82));
  opacity:0; transform:translateY(8px); transition:.25s}
.gcard:hover .cap{opacity:1; transform:none}

/* lightbox */
.lb{position:fixed; inset:0; z-index:120; background:rgba(8,16,26,.92); display:none; place-items:center; padding:24px}
.lb.open{display:grid}
.lb img{max-width:92vw; max-height:82vh; border-radius:12px; box-shadow:var(--shadow-lg)}
.lb .lb-cap{position:absolute; bottom:26px; left:0; right:0; text-align:center; color:#fff; font-family:var(--font-display); font-weight:700}
.lb button{position:absolute; background:rgba(255,255,255,.14); border:0; color:#fff; width:52px; height:52px;
  border-radius:50%; font-size:1.5rem; cursor:pointer; display:grid; place-items:center; transition:background .15s}
.lb button:hover{background:rgba(255,255,255,.28)}
.lb .lb-close{top:22px; right:22px}
.lb .lb-prev{left:18px; top:50%; transform:translateY(-50%)}
.lb .lb-next{right:18px; top:50%; transform:translateY(-50%)}

/* ===================== VOICES (real bubble phrases) ===================== */
.voices{background:var(--ink); color:#fff; position:relative; overflow:hidden}
.voices .section-head h2{color:#fff}
.voices .section-head p{color:rgba(255,255,255,.72)}
.voice-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:clamp(20px,3vw,34px);
  justify-items:center; max-width:980px; margin:0 auto}
.voice{width:100%; max-width:230px}
.voice .bubble{width:100%; aspect-ratio:586/511; font-size:clamp(1.1rem,2vw,1.45rem)}
.voice .tr{text-align:center; margin-top:14px; color:rgba(255,255,255,.78); font-size:.92rem}
.voice .tr b{color:#fff; font-family:var(--font-display)}
.tcards{display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:clamp(44px,6vw,66px)}
@media(max-width:880px){ .tcards{grid-template-columns:1fr; max-width:640px; margin-inline:auto} }
.tcard{background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.13); border-radius:var(--radius-lg);
  padding:30px 28px; margin:0; position:relative}
.tcard .qmark{width:44px; height:38px; background-size:100% 100%; background-repeat:no-repeat; margin-bottom:16px; filter:drop-shadow(0 8px 14px rgba(0,0,0,.3))}
.tcard .qmark.blue{background-image:url(media/bubble-blue.png)}
.tcard .qmark.green{background-image:url(media/bubble-green.png)}
.tcard .qmark.red{background-image:url(media/bubble-red.png)}
.tcard .qmark.yellow{background-image:url(media/bubble-yellow.png)}
.tcard p{font-size:1.04rem; line-height:1.52; color:#fff}
.tcard cite{display:block; margin-top:20px; font-style:normal; font-family:var(--font-display); font-weight:800; color:#fff}
.tcard cite span{display:block; font-family:var(--font-body); font-weight:600; font-size:.84rem; color:rgba(255,255,255,.6); margin-top:3px}
.phrase-strip{display:flex; flex-wrap:wrap; gap:clamp(14px,2vw,26px); justify-content:center; align-items:start}
.phrase-strip .voice{width:clamp(116px,15vw,150px)}
.phrase-strip .voice .bubble{font-size:clamp(.82rem,1.4vw,1.02rem)}
.phrase-strip .tr{font-size:.8rem; margin-top:8px}

/* ===================== HOST ===================== */
.host-grid{display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(30px,5vw,68px); align-items:center}
@media(max-width:840px){ .host-grid{grid-template-columns:1fr} }
.host-media{border-radius:50%; overflow:hidden; box-shadow:var(--shadow); aspect-ratio:1/1;
  background:var(--bg-alt) center/cover; max-width:400px; margin:0 auto}
.host-media img{width:100%;height:100%;object-fit:cover; object-position:center 14%}
.host h2{font-size:var(--h2); margin:.35em 0 .1em}
.host .role{color:var(--primary); font-family:var(--font-display); font-weight:700; margin-bottom:1em}
.host p + p{margin-top:1em; color:var(--muted)}
.host .sig{margin-top:22px; font-family:var(--font-display); font-weight:800; font-size:1.15rem}
.award{margin-top:clamp(40px,5vw,60px); display:grid; grid-template-columns:.82fr 1.18fr; gap:clamp(24px,4vw,52px);
  align-items:center; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(20px,3vw,34px); box-shadow:var(--shadow)}
@media(max-width:760px){ .award{grid-template-columns:1fr} }
.award-photo{border-radius:var(--radius); overflow:hidden; aspect-ratio:4/3.6; background:var(--bg-alt) center/cover}
.award-photo img{width:100%; height:100%; object-fit:cover; object-position:center 18%}
.award-badge{display:inline-flex; align-items:center; gap:8px; font-family:var(--font-display); font-weight:800;
  color:var(--primary-deep); background:color-mix(in srgb,var(--yellow) 30%,#fff); padding:.5em 1em;
  border-radius:999px; font-size:.82rem; letter-spacing:.01em; margin-bottom:16px}
.award h3{font-size:clamp(1.45rem,2.5vw,2.1rem); margin-bottom:.45em}
.award p{color:var(--muted)}
.award .src{margin-top:16px; font-size:.9rem}
.award .src a{color:var(--primary); font-weight:700; text-decoration:underline; text-underline-offset:3px}
.hero-award{margin-top:14px; display:inline-flex; align-items:center; gap:9px; font-size:.9rem; color:var(--muted);
  background:color-mix(in srgb,var(--yellow) 26%,#fff); border:1px solid color-mix(in srgb,var(--yellow) 50%,#fff);
  padding:.5em .95em; border-radius:999px; font-weight:600}
.hero-award b{color:var(--ink); font-family:var(--font-display)}

/* ===================== PARTNERS ===================== */
.partners{text-align:center}
.logo-row{display:grid; grid-template-columns:repeat(4,1fr); gap:22px 18px; margin-top:38px}
@media(max-width:760px){ .logo-row{grid-template-columns:repeat(2,1fr)} }
.logo-card{aspect-ratio:5/2.6; border-radius:var(--radius); background:#fff; border:1px solid var(--line);
  display:grid; place-items:center; padding:18px 22px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s}
.logo-card:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.logo-card img{max-height:70px; max-width:100%; width:auto; object-fit:contain}
.logo-card .vlabel{position:absolute}
.partner-cell{position:relative}
.partner-cell .tagk{display:block; margin-top:10px; font-size:.74rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--muted)}
.logo-slot{aspect-ratio:5/2.6; border-radius:var(--radius); border:2px dashed color-mix(in srgb,var(--primary) 55%,transparent);
  display:grid; place-items:center; background:linear-gradient(135deg,color-mix(in srgb,var(--blue) 12%,#fff),color-mix(in srgb,var(--yellow) 16%,#fff));
  color:var(--primary); font-family:var(--font-display); font-weight:700; font-size:.96rem; letter-spacing:0; padding:12px; text-align:center}

/* ===================== FAQ ===================== */
.faq{max-width:820px; margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa button{width:100%; display:flex; justify-content:space-between; align-items:center; gap:20px;
  background:none; border:0; padding:24px 4px; cursor:pointer; text-align:left;
  font-family:var(--font-display); font-weight:700; font-size:1.18rem; color:var(--ink)}
.qa .ic{flex:none; width:30px; height:30px; border-radius:50%; display:grid; place-items:center;
  background:color-mix(in srgb,var(--primary) 12%,#fff); color:var(--primary); transition:transform .25s; font-size:1.2rem}
.qa[aria-expanded="true"] .ic{transform:rotate(45deg)}
.qa .ans{max-height:0; overflow:hidden; transition:max-height .3s ease; color:var(--muted)}
.qa .ans p{padding:0 4px 24px; max-width:64ch}

/* ===================== CONTACT / CTA ===================== */
.cta{position:relative; overflow:hidden}
.cta-card{background:linear-gradient(140deg,var(--primary),var(--primary-deep)); color:#fff;
  border-radius:var(--radius-lg); padding:clamp(40px,6vw,80px); text-align:center; position:relative; overflow:hidden; box-shadow:var(--shadow-lg)}
.cta-card h2{color:#fff; font-size:var(--h2); max-width:18ch; margin:0 auto .5em}
.cta-card.alt{background:linear-gradient(140deg,var(--green),#066B45)}
.cta-card p{color:rgba(255,255,255,.88); max-width:46ch; margin:0 auto 32px; font-size:1.1rem}
.cta-card .hero-cta{justify-content:center}
.social-row{display:flex; gap:16px; justify-content:center; margin-top:30px; flex-wrap:wrap}
.social-row a{display:inline-flex; align-items:center; gap:9px; color:#fff; font-weight:600;
  background:rgba(255,255,255,.14); padding:.6em 1.1em; border-radius:999px; transition:background .15s}
.social-row a:hover{background:rgba(255,255,255,.26)}
.social-row svg{width:18px;height:18px}

/* ===================== FOOTER ===================== */
.footer{padding:54px 0 40px; border-top:1px solid var(--line); color:var(--muted); font-size:.95rem}
.footer-grid{display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:center}
.footer .brand{color:var(--ink)}
.footer .fnote{font-size:.84rem; max-width:48ch}

/* ---- host speech-bubble intro (after Antonio's PDF element) ---- */
.hostbubble{display:flex; align-items:flex-start; gap:15px; margin-bottom:26px}
.hostbubble .avatar{width:90px; height:90px; border-radius:50%; flex:none; overflow:hidden;
  border:4px solid var(--surface); box-shadow:var(--shadow-sm); background:var(--bg-alt)}
.hostbubble .avatar img{width:100%; height:100%; object-fit:cover; object-position:center 20%}
.hostbubble .sb{position:relative; background:var(--yellow); color:#1A2733; border-radius:20px 20px 20px 5px;
  padding:15px 19px; font-family:var(--font-body); font-weight:600; font-size:1.02rem; line-height:1.4;
  box-shadow:var(--shadow-sm); max-width:430px; margin-top:6px}
.hostbubble .sb:after{content:''; position:absolute; left:-10px; bottom:10px; width:0; height:0;
  border:8px solid transparent; border-right-color:var(--yellow); border-left:0}
.hostbubble .sb em{font-style:normal; color:var(--primary-deep); font-weight:700}

/* ---- community database / whatsapp join ---- */
.join{background:var(--bg-alt)}
.join-card{position:relative; overflow:hidden; max-width:780px; margin:0 auto; background:var(--surface);
  border:1px solid var(--line); border-radius:var(--radius-lg); padding:clamp(28px,4vw,56px); box-shadow:var(--shadow)}
.join-card .eyebrow{display:block; margin-bottom:.7em}
.join-card h2{font-size:var(--h2); margin-bottom:.35em; max-width:18ch}
.join-card .sub{color:var(--muted); margin-bottom:28px; font-size:clamp(1.05rem,1.4vw,1.2rem); max-width:52ch}
.join-form{display:grid; gap:15px; position:relative; z-index:2}
.join-form .row{display:grid; grid-template-columns:1fr 1fr; gap:15px}
.field{display:flex; flex-direction:column; gap:6px}
.field label{font-family:var(--font-display); font-weight:700; font-size:.86rem}
.field input,.field select{font:inherit; padding:.82em 1em; border:1.5px solid var(--line);
  border-radius:12px; background:var(--bg); color:var(--ink); width:100%}
.field input:focus,.field select:focus{outline:none; border-color:var(--primary); box-shadow:0 0 0 3px color-mix(in srgb,var(--primary) 16%,transparent)}
.check{display:flex; align-items:center; gap:10px; font-size:.96rem; color:var(--muted); cursor:pointer}
.check input{width:19px; height:19px; accent-color:var(--primary); flex:none}
.join-form .btn{justify-content:center; margin-top:4px}
.gate-note{font-size:.82rem; color:var(--muted); margin-top:14px; text-align:center}
.join-volunteer{max-width:780px; margin:22px auto 0; text-align:center; color:var(--muted); font-size:1.04rem;
  display:flex; flex-wrap:wrap; gap:12px 16px; align-items:center; justify-content:center}
.join-volunteer .btn{flex:none}
.join-success{display:none; text-align:center; padding:8px 0; position:relative; z-index:2}
.join-success.show{display:block; animation:popin .5s cubic-bezier(.2,.8,.2,1)}
@keyframes popin{from{opacity:0; transform:scale(.94)} to{opacity:1; transform:none}}
.join-success .bub{width:96px; margin:0 auto 18px; filter:drop-shadow(0 14px 22px rgba(8,40,70,.2))}
.join-success h3{font-size:clamp(1.5rem,2.6vw,2.1rem); margin-bottom:.4em}
.join-success p{color:var(--muted); max-width:42ch; margin:0 auto 24px}
.join-form.hide{display:none}

/* ---- mobile polish ---- */
@media(max-width:560px){
  body{font-size:16px}
  .section{padding:clamp(56px,13vw,90px) 0}
  .hero{padding-top:26px}
  .hero .lede{max-width:none}
  .hero-cta .btn{width:100%; justify-content:center}
  .stat-grid{gap:26px 18px}
  .about-media .inset{position:static; width:64%; margin:14px auto 0; transform:none}
  .card-fan{height:230px}
  .hostbubble .avatar{width:74px; height:74px}
  .hostbubble .sb{font-size:.96rem}
  .award-photo{aspect-ratio:4/3}
  .logo-row{grid-template-columns:1fr 1fr}
  .lb button{width:44px; height:44px}
}

/* ---- colored emphasis in headings ---- */
.hl-red{color:var(--red)}
.hl-green{color:var(--green)}
.hl-amber{color:#D89B00}

/* ---- extra translucent bubbles in the stats banner ---- */
.stats .deco2{position:absolute; right:15%; bottom:20px; width:94px; opacity:.08; transform:rotate(-12deg); pointer-events:none}
.stats .deco3{position:absolute; left:9%; top:26px; width:82px; opacity:.07; transform:rotate(16deg) scaleX(-1); pointer-events:none}

/* ---- marquee chip colour accents ---- */
.lang-chip:nth-child(4n+1) .hello{color:var(--blue)}
.lang-chip:nth-child(4n+2) .hello{color:var(--green)}
.lang-chip:nth-child(4n+3) .hello{color:var(--red)}
.lang-chip:nth-child(4n) .hello{color:#D89B00}

/* ---- dedicated socials section ---- */
.socials{text-align:center}
.social-cards{display:grid; grid-template-columns:repeat(2,1fr); gap:18px; max-width:680px; margin:clamp(34px,4vw,46px) auto 0}
@media(max-width:560px){ .social-cards{grid-template-columns:1fr} }
.scard{display:flex; align-items:center; gap:15px; text-align:left; background:var(--surface); border:1px solid var(--line);
  border-radius:var(--radius); padding:18px 22px; box-shadow:var(--shadow-sm); transition:transform .2s, box-shadow .2s; color:var(--ink)}
.scard:hover{transform:translateY(-4px); box-shadow:var(--shadow)}
.scard .ic{width:48px; height:48px; flex:none; border-radius:14px; display:grid; place-items:center; color:#fff;
  background:linear-gradient(135deg,#F58529,#DD2A7B 55%,#8134AF)}
.scard .ic svg{width:25px; height:25px}
.scard .h{font-family:var(--font-display); font-weight:800; font-size:1.1rem}
.scard .s{color:var(--muted); font-size:.9rem}

/* ---- footer socials ---- */
.footer-social{display:flex; gap:11px; align-items:center}
.footer-social a{width:42px; height:42px; border-radius:50%; display:grid; place-items:center; color:#fff;
  background:var(--primary); transition:transform .15s, background .15s}
.footer-social a:hover{transform:translateY(-3px); background:var(--primary-deep)}
.footer-social svg{width:21px; height:21px}

/* ===================== CONVERSATION CARDS BAND ===================== */
.cards-band .inner{display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(30px,5vw,72px); align-items:center}
@media(max-width:860px){ .cards-band .inner{grid-template-columns:1fr; gap:20px} }
.card-fan{position:relative; height:clamp(250px,30vw,340px); width:100%; max-width:500px; margin:0 auto; display:flex; align-items:center; justify-content:center}
.pcard{position:absolute; top:50%; left:50%; width:min(70%,330px); aspect-ratio:1050/600;
  border-radius:16px; box-shadow:var(--shadow); transform-origin:center bottom; overflow:hidden;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .3s; will-change:transform; cursor:pointer}
.pcard img{width:100%; height:100%; object-fit:cover; display:block}
.pcard:nth-child(1){transform:translate(-50%,-56%) rotate(-15deg); z-index:1}
.pcard:nth-child(2){transform:translate(-50%,-52%) rotate(-5deg); z-index:2}
.pcard:nth-child(3){transform:translate(-50%,-52%) rotate(5deg); z-index:3}
.pcard:nth-child(4){transform:translate(-50%,-56%) rotate(15deg); z-index:2}
.card-fan:hover .pcard:nth-child(1){transform:translate(calc(-50% - 122px),-55%) rotate(-15deg)}
.card-fan:hover .pcard:nth-child(2){transform:translate(calc(-50% - 44px),-60%) rotate(-5deg)}
.card-fan:hover .pcard:nth-child(3){transform:translate(calc(-50% + 44px),-60%) rotate(5deg)}
.card-fan:hover .pcard:nth-child(4){transform:translate(calc(-50% + 122px),-55%) rotate(15deg)}
.cards-copy .eyebrow{display:block; margin-bottom:.7em}
.cards-copy h2{font-size:var(--h2); margin-bottom:.5em}
.cards-copy p{color:var(--muted)}
.cards-copy .credit{margin-top:18px; font-size:.9rem; color:var(--muted)}
.cards-copy .credit b{color:var(--ink)}

/* ---- scroll reveal ---- */
.reveal{opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){ .reveal{opacity:1; transform:none; transition:none} }
[data-motion="off"] .floaty,[data-motion="off"] .marquee-track{animation-play-state:paused}

/* helper: build-note banner */
.buildnote{background:color-mix(in srgb,var(--yellow) 26%, #fff); color:#5a4a00; border:1px solid color-mix(in srgb,var(--yellow) 55%,#fff);
  font-size:.86rem; text-align:center; padding:9px 16px; font-weight:600}
.buildnote a{color:var(--primary); text-decoration:underline}
