@font-face{
  font-family:'Recoleta';
  src:url('/fonts/Recoleta-SemiBold.otf') format('opentype');
  font-weight:100 900;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Acumin Variable';
  src:url('/fonts/AcuminVariableConcept.otf') format('opentype-variations'),
      url('/fonts/AcuminVariableConcept.otf') format('opentype');
  font-weight:100 900;
  font-stretch:50% 200%;
  font-style:normal;
  font-display:swap;
}

:root{
  --teal:#14a3b8;
  --blue:#1c85b8;
  --cyan:#29ccff;
  --yellow:#f0f540;
  --lavender:#e8a8ff;

  --ink:#0b1f29;
  --ink-2:#28424f;
  --muted:#5f7682;
  --line:#dde6ea;
  --paper:#f6f9fa;
  --bg:#ffffff;

  --primary:var(--teal);
  --primary-2:var(--blue);
  --primary-soft:#e6f5f8;

  --type-scale:1;

  --serif:'Recoleta', 'Newsreader', ui-serif, Georgia, serif;
  --sans:'Acumin Variable', 'Inter', ui-sans-serif, system-ui, -apple-system, sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg); color:var(--ink); font-family:var(--sans);
  font-size:calc(16px * var(--type-scale)); line-height:1.55;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
::selection{background:color-mix(in oklab, var(--primary) 30%, white);color:var(--ink)}

.serif{font-family:var(--serif);font-weight:500;letter-spacing:-0.012em}
h1,h2,h3{font-family:var(--serif);font-weight:500;color:var(--ink);margin:0;text-wrap:balance;letter-spacing:-0.018em}
h1{font-size:clamp(1.95rem,7.4vw,5rem);line-height:1.05}
h2{font-size:clamp(1.6rem,4.6vw,3.2rem);line-height:1.1}
h3{font-size:clamp(1.15rem,2.4vw,1.6rem);line-height:1.25}
p{margin:0;text-wrap:pretty}
.eyebrow{font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}

.wrap{max-width:1280px;margin:0 auto;padding:0 18px}
@media (min-width:721px){.wrap{padding:0 32px}}

.btn{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--sans);font-size:.92rem;font-weight:500;
  padding:.85rem 1.25rem;border-radius:999px;cursor:pointer;border:1px solid transparent;text-decoration:none;
  transition:transform .15s ease,background .2s ease,border-color .2s ease,color .2s ease}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--ink);color:#fff}
.btn-primary:hover{background:#000}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink-2);background:var(--paper)}
.btn .arr{transition:transform .2s ease}
.btn:hover .arr{transform:translateX(3px)}

.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(160%) blur(14px);-webkit-backdrop-filter:saturate(160%) blur(14px);
  background:color-mix(in oklab, var(--bg) 78%, transparent);border-bottom:1px solid color-mix(in oklab, var(--line) 70%, transparent)}
.nav-inner{display:flex;align-items:center;gap:32px;height:80px;position:relative;z-index:2}
.nav-logo{text-decoration:none;display:inline-flex;align-items:center;flex-shrink:0}
.nav-logo img{height:54px;width:auto;display:block}
.nav-desktop-cta{padding:.6rem 1rem;font-size:.85rem}
.nav-desktop-cta .arr{font-size:.95rem}
.nav-links{display:flex;gap:28px;margin-left:auto}
.nav-links a{color:var(--ink-2);text-decoration:none;font-size:.93rem;font-weight:500;padding:6px 0}
.nav-links a:hover{color:var(--ink)}
.nav-links .nav-mobile-cta{display:none}
.nav-right{display:flex;align-items:center;gap:14px}
.nav-burger{display:none;appearance:none;background:transparent;border:0;cursor:pointer;
  width:42px;height:42px;padding:0;border-radius:10px;
  align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav-burger:hover{background:var(--paper)}
.nav-burger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;
  transition:transform .3s cubic-bezier(.2,.7,.2,1), opacity .2s ease}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0;transform:translateX(8px)}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.nav-scrim{display:none}

@media (max-width:860px){
  .nav-inner{gap:14px;height:64px}
  .nav-logo img{height:44px}
  .nav-burger{display:inline-flex}
  .nav-desktop-cta{display:none}
  .nav-links .nav-mobile-cta{display:inline-flex}
  .nav-links{
    position:fixed;left:0;right:0;top:64px;
    flex-direction:column;gap:0;margin:0;
    background:#fff;border-bottom:1px solid var(--line);
    box-shadow:0 28px 48px -28px rgba(11,31,41,.22);
    padding:12px 18px 24px;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:transform .25s cubic-bezier(.2,.7,.2,1), opacity .2s ease;
    z-index:51;
  }
  .nav-links.open{transform:translateY(0);opacity:1;pointer-events:auto}
  .nav-links a:not(.btn){
    padding:14px 4px;font-size:1.05rem;color:var(--ink);
    border-bottom:1px solid var(--paper);
  }
  .nav-links a:not(.btn):last-of-type{border-bottom:0}
  .nav-links .nav-mobile-cta{
    margin-top:14px;padding:.95rem 1.25rem;justify-content:center;
    font-size:.95rem;color:#fff;
  }
  .nav-scrim{
    display:block;position:fixed;inset:64px 0 0 0;background:rgba(11,31,41,.32);
    opacity:0;pointer-events:none;transition:opacity .25s ease;z-index:1;
  }
  .nav-scrim.open{opacity:1;pointer-events:auto}
}

.lang{display:inline-flex;align-items:center;gap:2px;font-size:.78rem;font-weight:600;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:3px}
.lang a, .lang button{appearance:none;border:0;background:transparent;color:inherit;font:inherit;padding:4px 10px;border-radius:999px;cursor:pointer;letter-spacing:.04em;text-decoration:none;display:inline-block}
.lang a.on, .lang button.on{background:var(--ink);color:#fff}

/* HERO */
.hero{position:relative;overflow:hidden;padding:36px 0 56px}
@media (min-width:721px){.hero{padding:64px 0 96px}}
.hero::before{content:'';position:absolute;inset:-20% -10% auto auto;width:75%;height:120%;
  background:radial-gradient(closest-side, color-mix(in oklab, var(--primary) 22%, transparent), transparent 70%),
             radial-gradient(closest-side, color-mix(in oklab, var(--primary-2) 18%, transparent), transparent 65%);
  background-position:30% 30%,70% 60%;background-repeat:no-repeat;background-size:70% 70%,80% 80%;
  filter:blur(40px);pointer-events:none;z-index:0}
.hero::after{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:0;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 28%,transparent) 1.4px, transparent 1.6px);
  background-size:22px 22px;
  mask-image:radial-gradient(ellipse 70% 60% at 15% 90%, black 30%, transparent 75%);
  -webkit-mask-image:radial-gradient(ellipse 70% 60% at 15% 90%, black 30%, transparent 75%);
  opacity:.55;
}
.hero>*{position:relative;z-index:1}

.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:64px;align-items:center}
@media (max-width:980px){.hero-grid{grid-template-columns:1fr;gap:40px}}
.hero h1 .accent{color:var(--primary);font-style:italic;font-weight:400}
.hero-sub{margin-top:28px;max-width:50ch;color:var(--ink-2);font-size:clamp(1.05rem,1.2vw,1.18rem);line-height:1.6}
.hero-cta{display:flex;gap:14px;margin-top:36px;flex-wrap:wrap}
.hero-meta{display:flex;gap:36px;margin-top:56px;padding-top:28px;border-top:1px solid var(--line)}
.hero-meta .stat .n{font-family:var(--serif);font-size:2rem;font-weight:500;color:var(--ink);line-height:1;letter-spacing:-0.02em}
.hero-meta .stat .l{font-size:.8rem;color:var(--muted);margin-top:6px;letter-spacing:.02em}
.hero-visual{position:relative;aspect-ratio:1/1;width:100%;max-width:560px;margin-left:auto}

.strip{border-top:1px solid var(--line);border-bottom:1px solid var(--line);background:var(--paper);padding:18px 0;overflow:hidden}
.strip-track{display:flex;gap:56px;align-items:center;color:var(--muted);font-size:.85rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase;
  animation:marq 40s linear infinite;white-space:nowrap}
.strip-track .dot{width:5px;height:5px;border-radius:50%;background:var(--primary);flex-shrink:0}
@keyframes marq{to{transform:translateX(-50%)}}

section{padding:64px 0;position:relative}
@media (min-width:721px){section{padding:96px 0}}
@media (min-width:1100px){section{padding:120px 0}}
.section-head{display:flex;justify-content:space-between;align-items:end;gap:32px;margin-bottom:64px}
.section-head h2{max-width:18ch}
.section-head p{max-width:42ch;color:var(--ink-2);font-size:1.02rem}
@media (max-width:720px){.section-head{flex-direction:column;align-items:start;margin-bottom:40px}}

/* About */
.about{background:var(--paper);position:relative;overflow:hidden}
.about::before{
  content:'';position:absolute;left:-10%;top:-15%;width:50%;height:60%;
  background:radial-gradient(closest-side, color-mix(in oklab,var(--primary) 14%,transparent), transparent 70%);
  filter:blur(50px);pointer-events:none;
}
.about > *{position:relative;z-index:1}
.about-grid{display:grid;grid-template-columns:1.05fr 1fr;gap:72px;align-items:start}
@media (max-width:980px){.about-grid{grid-template-columns:1fr;gap:48px}}

.about-lead-row{
  display:flex;align-items:center;gap:14px;margin-top:20px;
  color:var(--muted);font-size:.85rem;letter-spacing:.04em;
}
.about-lead-row .pip{width:28px;height:1px;background:var(--primary)}

.mv-tabs{
  display:flex;gap:6px;margin-top:36px;padding:6px;
  background:#fff;border:1px solid var(--line);border-radius:999px;width:fit-content;
}
.mv-tab{
  appearance:none;border:0;cursor:pointer;font:inherit;
  padding:9px 18px;border-radius:999px;color:var(--ink-2);font-size:.85rem;font-weight:500;
  letter-spacing:.02em;transition:background .2s ease, color .2s ease;
  display:inline-flex;align-items:center;gap:8px;
}
.mv-tab .num{font-family:var(--serif);font-size:.78rem;color:var(--muted);font-weight:600}
.mv-tab.on{background:var(--ink);color:#fff}
.mv-tab.on .num{color:var(--cyan)}
.mv-tab:hover:not(.on){background:var(--paper)}

.mv-panel{
  margin-top:28px;padding:36px;background:#fff;border:1px solid var(--line);border-radius:20px;
  min-height:240px;display:flex;flex-direction:column;gap:14px;
  box-shadow:0 24px 48px -32px rgba(11,31,41,.18);
  animation:mvIn .35s ease;
}
@keyframes mvIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.mv-panel .lbl{display:flex;align-items:center;gap:10px;font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--primary)}
.mv-panel .lbl::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--primary)}
.mv-panel h3{font-size:1.7rem;line-height:1.15}
.mv-panel p{color:var(--ink-2);font-size:1rem;line-height:1.65;max-width:54ch}

.about-visual{position:sticky;top:96px;display:flex;flex-direction:column;gap:20px}
@media (max-width:980px){.about-visual{position:static}}
.about-img{
  aspect-ratio:4/5;border-radius:24px;overflow:hidden;position:relative;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));
  box-shadow:0 32px 64px -32px color-mix(in oklab,var(--primary) 60%,transparent);
}
.about-img::after{
  content:'';position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.22) 1.2px,transparent 1.4px);
  background-size:14px 14px;mix-blend-mode:overlay;pointer-events:none;
}
.about-img .placeholder{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.65);
  font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;font-weight:600;
}
.since-pill{
  position:absolute;left:24px;top:24px;
  display:inline-flex;align-items:center;gap:10px;
  background:rgba(255,255,255,.95);backdrop-filter:blur(8px);
  color:var(--ink);padding:8px 14px;border-radius:999px;
  font-size:.8rem;font-weight:600;letter-spacing:.04em;
  box-shadow:0 12px 24px -16px rgba(11,31,41,.3);
}
.since-pill .dot{width:6px;height:6px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 0 4px color-mix(in oklab,var(--primary) 22%,transparent)}

.timeline-card{
  position:absolute;right:-12px;bottom:-12px;
  background:#fff;border:1px solid var(--line);border-radius:18px;
  padding:18px 22px;width:240px;
  box-shadow:0 24px 48px -24px rgba(11,31,41,.25);
}
.timeline-card .ttl{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:14px}
.tl-row{display:flex;gap:12px;font-size:.85rem;color:var(--ink-2);padding:6px 0;align-items:flex-start}
.tl-row .yr{font-family:var(--serif);font-weight:600;color:var(--primary);min-width:42px;font-variant-numeric:tabular-nums}
.tl-row .ev{flex:1;line-height:1.4}

.about-mini-stats{
  display:grid;grid-template-columns:repeat(3,1fr);gap:0;
  background:#fff;border:1px solid var(--line);border-radius:18px;padding:20px 8px;
}
.about-mini-stats .stat{text-align:center;padding:6px 8px;border-right:1px solid var(--line)}
.about-mini-stats .stat:last-child{border-right:0}
.about-mini-stats .n{font-family:var(--serif);font-size:1.5rem;font-weight:500;color:var(--ink);line-height:1;letter-spacing:-0.01em}
.about-mini-stats .l{font-size:.72rem;color:var(--muted);margin-top:6px;letter-spacing:.04em;text-transform:uppercase;font-weight:600}

/* DNA helix backdrop (renders inside .about-img when no photo is set) */
.dna-stage{position:absolute;inset:0;overflow:hidden;border-radius:inherit;pointer-events:none;z-index:0}
.dna-svg{position:absolute;inset:0;width:100%;height:100%;display:block}
.dna-flow{will-change:transform;animation:dnaFlow 11s linear infinite}
@keyframes dnaFlow{
  from{transform:translateY(0)}
  to  {transform:translateY(-220px)} /* exactly one wave-period — seamless loop */
}
.dna-rung{
  filter:drop-shadow(0 0 3px rgba(255,255,255,.55));
  animation:dnaRungPulse 3.6s ease-in-out infinite;
  animation-delay:var(--rd,0s);
}
@keyframes dnaRungPulse{
  0%,100%{opacity:.55}
  50%    {opacity:1}
}
.dna-spark{
  transform-box:fill-box;transform-origin:center;
  filter:drop-shadow(0 0 4px rgba(255,255,255,.9));
  animation:dnaSpark 5.2s ease-in-out infinite;
  animation-delay:var(--sd,0s);
}
@keyframes dnaSpark{
  0%,100%{opacity:.18;transform:scale(.55)}
  45%    {opacity:1;transform:scale(1.15)}
  60%    {opacity:.85;transform:scale(1)}
}
.dna-halo{
  transform-box:fill-box;transform-origin:center;
  mix-blend-mode:screen;
  animation:dnaHalo 6s ease-in-out infinite;
}
@keyframes dnaHalo{
  0%,100%{opacity:.55;transform:scale(1)}
  50%    {opacity:.9;transform:scale(1.08)}
}
.dna-logo-wrap{
  position:absolute;left:50%;top:50%;
  width:46%;max-width:240px;aspect-ratio:1/1;
  display:flex;align-items:center;justify-content:center;
  transform:translate(-50%,-50%);
  z-index:1;pointer-events:none;
}
.dna-logo-disc{
  position:absolute;inset:14%;border-radius:50%;
  background:radial-gradient(closest-side,
              rgba(11,31,41,.45) 0%,
              rgba(11,31,41,.18) 55%,
              rgba(11,31,41,0) 100%);
  filter:blur(6px);
}
.dna-logo-ring{
  position:absolute;inset:0;border-radius:50%;
  border:1px solid rgba(255,255,255,.42);
  animation:dnaRing 4s ease-out infinite;
}
.dna-logo-ring--2{animation-delay:1.6s;border-color:rgba(255,255,255,.22)}
@keyframes dnaRing{
  0%  {transform:scale(.7);opacity:0}
  20% {opacity:.65}
  100%{transform:scale(1.45);opacity:0}
}
.dna-logo{
  position:relative;width:78%;height:auto;object-fit:contain;
  filter:drop-shadow(0 18px 36px rgba(11,31,41,.45)) drop-shadow(0 0 22px rgba(255,255,255,.28));
  animation:dnaLogoBob 6s ease-in-out infinite;
}
@keyframes dnaLogoBob{
  0%,100%{transform:translateY(0) scale(1)}
  50%    {transform:translateY(-4px) scale(1.025)}
}
@media (prefers-reduced-motion:reduce){
  .dna-flow,.dna-rung,.dna-spark,.dna-halo,.dna-logo,.dna-logo-ring{animation:none}
}

/* Pillars */
.pillars{position:relative;overflow:hidden;padding:96px 0}
.pillars::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 22%,transparent) 1.2px, transparent 1.4px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 50% 70% at 100% 50%, black 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 50% 70% at 100% 50%, black 20%, transparent 70%);
  opacity:.45;
}
.pillars > *{position:relative;z-index:1}
.pillars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:860px){.pillars-grid{grid-template-columns:1fr}}
.pillar{position:relative;background:#fff;border:1px solid var(--line);border-radius:20px;padding:36px;display:flex;flex-direction:column;gap:18px;min-height:360px;
  transition:transform .25s ease,box-shadow .25s ease,border-color .25s ease;overflow:hidden}
.pillar:hover{transform:translateY(-3px);box-shadow:0 20px 48px -24px rgba(11,31,41,.18);border-color:color-mix(in oklab,var(--primary) 35%,var(--line))}
.pillar .num{font-family:var(--serif);font-size:.95rem;color:var(--primary);font-weight:600;letter-spacing:.04em}
.pillar h3{font-size:1.5rem}
.pillar p{color:var(--ink-2);font-size:.95rem;line-height:1.6}
.pillar ul{margin:0;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.pillar li{font-size:.88rem;color:var(--ink-2);padding-left:18px;position:relative}
.pillar li::before{content:'';position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--primary)}
.pillar .icon{margin-top:auto;width:64px;height:64px}

/* Services */
.services{background:var(--paper);position:relative;overflow:hidden}
.services::before{
  content:'';position:absolute;left:50%;top:50%;
  transform:translate(-50%,-50%) rotate(0deg);
  width:min(900px,140%);aspect-ratio:1;
  background-image:url('/assets/brand-arc-tint.svg');
  background-size:contain;background-position:center;background-repeat:no-repeat;
  pointer-events:none;
  transform-origin:center center;
  animation:arcSpin 80s linear infinite;
  will-change:transform;
}
@keyframes arcSpin{
  from{transform:translate(-50%,-50%) rotate(0deg)}
  to{transform:translate(-50%,-50%) rotate(360deg)}
}
@media (prefers-reduced-motion:reduce){
  .services::before{animation:none}
}
.services > *{position:relative;z-index:1}
.services .section-head{justify-content:center;text-align:center;flex-direction:column;align-items:center;gap:18px}
.services .section-head .eyebrow-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:8px 16px;border-radius:999px;
  background:color-mix(in oklab,var(--primary) 14%,white);
  color:var(--primary);font-size:.74rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
}
.services .section-head h2{font-size:clamp(2.4rem,4.2vw,3.6rem);font-weight:600;letter-spacing:-0.02em;font-family:var(--sans)}
.services .section-head p{max-width:48ch;color:var(--ink-2);font-size:1.05rem;text-align:center}

.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
@media (max-width:860px){.svc-grid{grid-template-columns:1fr}}
.svc-card{
  background:color-mix(in oklab,var(--primary) 8%,white);
  border-radius:24px;padding:36px 32px;
  display:flex;flex-direction:column;gap:20px;min-height:260px;
  transition:transform .25s ease, box-shadow .25s ease;
  position:relative;overflow:hidden;
}
.svc-card:hover{transform:translateY(-3px);box-shadow:0 24px 48px -28px rgba(11,31,41,.18)}
.svc-tile{
  width:64px;height:64px;border-radius:18px;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 8px 18px -10px color-mix(in oklab,var(--primary) 70%,transparent);
}
.svc-card h3{font-family:var(--sans);font-weight:600;font-size:1.35rem;letter-spacing:-0.012em}
.svc-card p{color:var(--ink-2);font-size:.95rem;line-height:1.6}

/* Gallery */
.gallery{position:relative;overflow:hidden;padding:96px 0;background:var(--paper)}
.gallery::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 20%,transparent) 1.2px, transparent 1.4px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 60% 80% at 100% 0%, black 10%, transparent 60%);
  -webkit-mask-image:radial-gradient(ellipse 60% 80% at 100% 0%, black 10%, transparent 60%);
  opacity:.4;
}
.gallery > *{position:relative;z-index:1}
.gallery .section-head{margin-bottom:48px}

.gal-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr;
  grid-template-rows:repeat(3, 200px);
  gap:18px;
}
@media (max-width:860px){
  .gal-grid{grid-template-columns:1fr;grid-template-rows:auto;gap:14px}
}

.gal-tile{
  position:relative;border-radius:22px;overflow:hidden;cursor:pointer;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));
  transition:transform .5s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease;
  box-shadow:0 14px 32px -22px color-mix(in oklab,var(--primary) 60%,transparent);
  isolation:isolate;
}
.gal-tile .gal-bg{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.22) 1.2px,transparent 1.4px);
  background-size:14px 14px;mix-blend-mode:overlay;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
  will-change:transform;
}
.gal-tile .gal-img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:transform .8s cubic-bezier(.2,.7,.2,1);
  will-change:transform;
}
.gal-tile .gal-overlay{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:24px;color:#fff;
  background:linear-gradient(180deg, transparent 30%, rgba(11,31,41,.55) 100%);
  z-index:2;
  transition:background .35s ease;
}
.gal-tile:hover{transform:translateY(-4px);box-shadow:0 28px 56px -22px color-mix(in oklab,var(--primary) 70%,transparent)}
.gal-tile:hover .gal-bg, .gal-tile:hover .gal-img{transform:scale(1.08)}
.gal-tile:hover .gal-overlay{background:linear-gradient(180deg, transparent 10%, rgba(11,31,41,.7) 100%)}

.gal-tile .gal-tag{
  position:absolute;top:18px;left:18px;
  background:rgba(255,255,255,.95);color:var(--ink);
  padding:5px 12px;border-radius:999px;
  font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  z-index:3;
  transition:transform .35s ease;
}
.gal-tile:hover .gal-tag{transform:translateY(-2px)}

.gal-tile .gal-cap{
  font-size:.95rem;line-height:1.4;color:#fff;
  text-shadow:0 1px 8px rgba(0,0,0,.3);
  transform:translateY(8px);opacity:.85;
  transition:transform .35s ease, opacity .35s ease;
  position:relative;z-index:3;
}
.gal-tile:hover .gal-cap{transform:translateY(0);opacity:1}

.gal-tile .gal-arr{
  position:absolute;right:18px;bottom:18px;z-index:3;
  width:38px;height:38px;border-radius:50%;
  background:rgba(255,255,255,.95);color:var(--ink);
  display:flex;align-items:center;justify-content:center;font-size:.95rem;
  transform:translate(8px,8px) scale(.85);opacity:0;
  transition:transform .4s cubic-bezier(.2,.7,.2,1), opacity .35s ease;
}
.gal-tile:hover .gal-arr{transform:translate(0,0) scale(1);opacity:1}

.gal-tile.t1{grid-column:1;grid-row:1 / span 3}
.gal-tile.t2{grid-column:2;grid-row:1}
.gal-tile.t3{grid-column:2;grid-row:2}
.gal-tile.t4{grid-column:2;grid-row:3}
@media (max-width:860px){
  .gal-tile.t1{grid-column:1;grid-row:auto;height:280px}
  .gal-tile.t2,.gal-tile.t3,.gal-tile.t4{grid-column:1;grid-row:auto;height:180px}
}

.gal-tile{opacity:0;transform:translateY(24px) scale(.985);
  transition:opacity .9s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1), box-shadow .5s ease}
.gal-tile.in{opacity:1;transform:none}
.gal-tile.in:hover{transform:translateY(-4px)}

.gal-foot{
  display:flex;justify-content:space-between;align-items:center;margin-top:36px;
  color:var(--muted);font-size:.9rem;flex-wrap:wrap;gap:12px;
}
.gal-foot a{color:var(--primary);font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:8px;
  transition:gap .25s ease, color .2s ease}
.gal-foot a:hover{color:var(--primary-2);gap:14px}

/* Stats band */
.band{background:var(--ink);color:#fff;border-radius:0;padding:80px 0;position:relative;overflow:hidden}
.band::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.12) 1.2px,transparent 1.4px);background-size:18px 18px;
  mask-image:linear-gradient(to right,transparent,black 30%,black 70%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 30%,black 70%,transparent);opacity:.6;pointer-events:none}
.band > *{position:relative;z-index:1}
.band-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:32px}
@media (max-width:860px){.band-grid{grid-template-columns:repeat(2,1fr)}}
.band-grid .stat .n{font-family:var(--serif);font-size:clamp(2.4rem,4vw,3.6rem);font-weight:500;color:#fff;line-height:1;letter-spacing:-0.02em}
.band-grid .stat .l{font-size:.85rem;color:rgba(255,255,255,.65);margin-top:10px;letter-spacing:.04em}

/* Promise */
.promise{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;position:relative;overflow:hidden}
.promise::before{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.18) 1.2px,transparent 1.4px);background-size:14px 14px;
  mask-image:linear-gradient(to right,transparent,black 30%,black 70%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 30%,black 70%,transparent);opacity:.6;pointer-events:none}
.promise::after{
  content:'';position:absolute;left:-8%;top:50%;transform:translateY(-50%);
  width:560px;height:560px;border-radius:50%;
  background:
    radial-gradient(circle at center, transparent 36%, rgba(255,255,255,.12) 36.5%, rgba(255,255,255,.12) 38%, transparent 38.5%),
    radial-gradient(circle at center, transparent 44%, rgba(255,255,255,.08) 44.5%, rgba(255,255,255,.08) 47%, transparent 47.5%);
  pointer-events:none;
}
.promise-inner{padding:120px 0;text-align:center;position:relative;z-index:1}
.promise h2{color:#fff;font-size:clamp(2.5rem,6vw,5rem);font-style:italic;font-weight:400;letter-spacing:-0.02em;line-height:1.05}
.promise h2 .quote{font-style:normal;opacity:.5;font-weight:400}
.promise p{margin:24px auto 0;max-width:50ch;color:rgba(255,255,255,.85);font-size:1.05rem}

/* Contact */
.contact-section{position:relative;overflow:hidden;padding:96px 0}
.contact-section::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 22%,transparent) 1.2px, transparent 1.4px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 55% 75% at 0% 50%, black 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 55% 75% at 0% 50%, black 20%, transparent 70%);
  opacity:.4;
}
.contact-section > *{position:relative;z-index:1}
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:start}
@media (max-width:860px){.contact-grid{grid-template-columns:1fr;gap:32px}}
.contact-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:36px;display:flex;flex-direction:column;gap:20px}
.contact-row{display:flex;gap:16px;align-items:flex-start}
.contact-row .ci{
  flex-shrink:0;width:40px;height:40px;border-radius:12px;
  background:color-mix(in oklab,var(--primary) 12%,white);
  display:flex;align-items:center;justify-content:center;color:var(--primary);
}
.contact-row .lbl{font-size:.78rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:4px}
.contact-row .val{font-size:1rem;color:var(--ink);line-height:1.5}

.contact-form{display:flex;flex-direction:column;gap:14px}
.contact-form label{display:flex;flex-direction:column;gap:6px}
.contact-form .label{font-size:.78rem;font-weight:600;letter-spacing:.06em;color:var(--muted)}
.contact-form input, .contact-form textarea{
  width:100%;padding:14px 16px;border-radius:12px;border:1px solid var(--line);
  background:#fff;color:var(--ink);font:inherit;outline:none;
  transition:border-color .15s ease, box-shadow .15s ease;
}
.contact-form input:focus, .contact-form textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px color-mix(in oklab,var(--primary) 18%,transparent)}
.contact-form .error{color:#c0392b;font-size:.78rem;margin-top:4px}
.flash-success{padding:14px 18px;border-radius:12px;background:color-mix(in oklab,var(--primary) 12%,white);color:var(--primary);font-weight:500;margin-bottom:18px}

/* Footer */
footer{background:#0b1f29;color:#a6b7c0;padding:80px 0 28px}
footer h4{font-family:var(--serif);font-weight:500;color:#fff;font-size:1.1rem;margin:0 0 16px}
.foot-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px}
@media (max-width:860px){.foot-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.foot-grid{grid-template-columns:1fr}}
.foot-col a{color:#a6b7c0;text-decoration:none;font-size:.92rem;display:block;padding:6px 0}
.foot-col a:hover{color:#fff}
.foot-bot{margin-top:64px;padding-top:24px;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:space-between;align-items:center;color:#7a8c95;font-size:.82rem;flex-wrap:wrap;gap:16px}
.foot-mark{font-family:var(--serif);font-size:1.3rem;color:#fff;font-weight:500;letter-spacing:-0.01em}
.foot-mark .x{color:var(--cyan)}

.foot-col a.foot-cta{
  display:inline-flex;align-items:center;gap:14px;width:fit-content;
  margin-top:28px;padding:14px 14px 14px 28px;
  background:rgba(255,255,255,.06);color:#fff;
  border:1px solid rgba(255,255,255,.18);
  border-radius:999px;text-decoration:none;
  font-family:var(--sans);font-weight:500;font-size:.95rem;letter-spacing:-0.005em;
  transition:transform .2s ease, background .2s ease, border-color .2s ease;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.foot-col a.foot-cta:hover{transform:translateY(-2px);background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.32);color:#fff}
.foot-cta-arr{
  display:inline-flex;align-items:center;justify-content:center;
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));color:#fff;
  transition:transform .25s ease;font-size:.95rem;line-height:1;
  box-shadow:0 6px 14px -6px color-mix(in oklab,var(--primary) 70%,transparent);
}
.foot-cta:hover .foot-cta-arr{transform:translateX(2px)}

@keyframes spin-slow{to{transform:rotate(360deg)}}
@keyframes spin-rev{to{transform:rotate(-360deg)}}
@keyframes pulse{0%,100%{opacity:.4;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}

.reveal{opacity:0;transform:translateY(18px);transition:opacity .8s ease,transform .8s ease}
.reveal.in{opacity:1;transform:none}

/* Page header (for /careers, /leaders, /gallery, /partners) */
.page-head{padding:100px 0 60px;position:relative;overflow:hidden;background:var(--paper)}
.page-head::after{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 22%,transparent) 1.2px, transparent 1.6px);
  background-size:22px 22px;
  mask-image:radial-gradient(ellipse 60% 70% at 90% 10%, black 20%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 60% 70% at 90% 10%, black 20%, transparent 70%);
  opacity:.5;
}
.page-head > *{position:relative;z-index:1}
.page-head .eyebrow{margin-bottom:14px}
.page-head h1{font-size:clamp(2.4rem,5vw,4.4rem)}
.page-head .lead{margin-top:24px;color:var(--ink-2);font-size:1.05rem;max-width:60ch}

/* Cards / lists shared */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.leader-card-grid{grid-template-columns:repeat(auto-fill,minmax(400px,1fr))}
.card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:28px;display:flex;flex-direction:column;gap:14px;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease}
.card:hover{transform:translateY(-3px);box-shadow:0 20px 48px -24px rgba(11,31,41,.18);border-color:color-mix(in oklab,var(--primary) 35%,var(--line))}
.card .meta{display:flex;flex-wrap:wrap;gap:10px;font-size:.78rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.card .meta span{padding:4px 10px;border-radius:999px;background:var(--paper);border:1px solid var(--line)}
.card h3{font-size:1.3rem}
.card p{color:var(--ink-2);font-size:.95rem;line-height:1.55}
.card .more{margin-top:auto;color:var(--primary);font-weight:500;text-decoration:none;display:inline-flex;align-items:center;gap:8px;transition:gap .2s ease}
.card:hover .more{gap:12px}

/* Filter bar */
.filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.filter-bar button,.filter-btn{appearance:none;display:inline-block;border:1px solid var(--line);background:#fff;color:var(--ink-2);
  padding:8px 16px;border-radius:999px;font:inherit;font-size:.85rem;font-weight:500;cursor:pointer;text-decoration:none;
  transition:background .2s ease, border-color .2s ease, color .2s ease}
.filter-bar button.on,.filter-btn.on{background:var(--ink);color:#fff;border-color:var(--ink)}
.filter-bar button:hover:not(.on),.filter-btn:hover:not(.on){border-color:var(--ink-2)}

/* Leader cards */
.leader-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:14px;padding:32px 24px}
.leader-photo{width:140px;height:140px;border-radius:50%;overflow:hidden;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));position:relative;flex-shrink:0;
  box-shadow:0 16px 32px -20px color-mix(in oklab,var(--primary) 60%,transparent)}
.leader-photo img{width:100%;height:100%;object-fit:cover}
.leader-photo::after{content:'';position:absolute;inset:0;background-image:radial-gradient(rgba(255,255,255,.18) 1px,transparent 1.2px);
  background-size:10px 10px;mix-blend-mode:overlay;pointer-events:none}
.leader-name{font-family:var(--serif);font-size:1.3rem;font-weight:500;color:var(--ink);margin:0}
.leader-title{font-size:.74rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}
.leader-bio{font-size:.92rem;color:var(--ink-2);line-height:1.55}

/* Partner logos */
.partner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:18px}
.partner-tile{background:#fff;border:1px solid var(--line);border-radius:18px;padding:24px;
  display:flex;align-items:center;justify-content:center;aspect-ratio:3/2;
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease}
.partner-tile:hover{transform:translateY(-3px);border-color:color-mix(in oklab,var(--primary) 35%,var(--line));box-shadow:0 20px 40px -24px rgba(11,31,41,.18)}
.partner-tile img{max-width:120px;max-height:60px;object-fit:contain;filter:grayscale(100%);opacity:.75;transition:filter .25s ease, opacity .25s ease}
.partner-tile:hover img{filter:none;opacity:1}
.partner-tile .ph{font-family:var(--serif);font-size:1.2rem;color:var(--ink);font-weight:500}

/* Career detail */
.career-hero{padding:100px 0 40px}
.career-hero .meta{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.career-hero .meta span{padding:6px 14px;border-radius:999px;border:1px solid var(--line);font-size:.78rem;font-weight:500;color:var(--ink-2);background:#fff}
.career-actions{display:flex;flex-wrap:wrap;gap:14px;margin:32px 0 60px}
.career-body{display:grid;grid-template-columns:2fr 1fr;gap:64px;padding:40px 0 100px}
@media (max-width:860px){.career-body{grid-template-columns:1fr}}
.career-body h3{font-size:1.4rem;margin-top:32px;margin-bottom:14px}
.career-body ul{padding-left:20px;color:var(--ink-2);line-height:1.7}
.career-body p{color:var(--ink-2);line-height:1.7;margin-top:14px}
.career-side{background:var(--paper);border:1px solid var(--line);border-radius:20px;padding:28px;align-self:start;position:sticky;top:96px}
.career-side .lbl{font-size:.74rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.career-side .val{color:var(--ink);font-size:.95rem;margin-bottom:18px}

.empty-state{text-align:center;padding:80px 20px;color:var(--muted)}
.empty-state h3{font-family:var(--serif);font-size:1.4rem;color:var(--ink);margin-bottom:8px}

/* ===== Mobile-first overrides (≤720px / portrait phones) ===== */
@media (max-width:720px){
  body{font-size:15px;line-height:1.55}

  /* Nav */
  .nav-inner{height:64px;gap:14px}
  .nav-logo img{height:44px}
  .nav-right{gap:8px;margin-left:auto}
  .lang{padding:2px}
  .lang a, .lang button{padding:3px 8px;font-size:.72rem}

  /* Hero */
  .hero-grid{gap:28px}
  .hero h1{margin-top:14px !important}
  .hero-sub{margin-top:18px;font-size:1rem}
  .hero-cta{margin-top:24px;gap:10px}
  .hero-cta .btn{flex:1 1 auto;justify-content:center;padding:.85rem 1rem;font-size:.88rem}
  .hero-meta{margin-top:32px;padding-top:20px;gap:14px;display:grid;grid-template-columns:repeat(3,1fr)}
  .hero-meta .stat .n{font-size:1.4rem}
  .hero-meta .stat .l{font-size:.7rem;margin-top:4px;line-height:1.3}
  .hero-visual{max-width:340px;margin:0 auto}

  /* Trust strip */
  .strip{padding:14px 0}
  .strip-track{gap:36px;font-size:.72rem}

  /* Section heads */
  .section-head{margin-bottom:32px;gap:12px}
  .section-head p{font-size:.95rem}

  /* About */
  .about-grid{gap:32px}
  .about-visual{gap:14px}
  .about-img{aspect-ratio:auto;min-height:200px;border-radius:18px;padding:56px 14px 14px;display:flex;flex-direction:column;justify-content:flex-end}
  .about-img .placeholder{display:none}
  .dna-stage{display:none}
  .timeline-card{position:relative;right:auto;bottom:auto;width:100%;padding:14px 16px;border-radius:14px;box-shadow:0 12px 24px -16px rgba(11,31,41,.25)}
  .timeline-card .ttl{margin-bottom:10px}
  .tl-row{font-size:.82rem;padding:4px 0}
  .since-pill{left:14px;top:14px;padding:6px 12px;font-size:.72rem}
  .about-mini-stats{padding:14px 4px;border-radius:14px}
  .about-mini-stats .n{font-size:1.2rem}
  .about-mini-stats .l{font-size:.62rem;letter-spacing:.06em}

  .mv-tabs{margin-top:24px;width:100%;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;padding:5px;flex-wrap:nowrap}
  .mv-tabs::-webkit-scrollbar{display:none}
  .mv-tab{padding:8px 14px;font-size:.78rem;flex-shrink:0}
  .mv-panel{margin-top:18px;padding:24px 22px;border-radius:16px;min-height:auto;gap:10px}
  .mv-panel h3{font-size:1.4rem}
  .mv-panel p{font-size:.95rem;line-height:1.6}

  /* Pillars */
  .pillars{padding:64px 0}
  .pillars-grid{gap:14px}
  .pillar{padding:24px;min-height:auto;border-radius:16px;gap:14px}
  .pillar h3{font-size:1.25rem}
  .pillar p{font-size:.92rem}
  .pillar .icon{width:52px;height:52px}

  /* Services */
  .services::before{width:min(560px,160%)}
  .services .section-head .eyebrow-pill{padding:6px 12px;font-size:.68rem}
  .services .section-head h2{font-size:clamp(1.7rem,6vw,3rem)}
  .svc-grid{gap:14px}
  .svc-card{padding:24px 22px;min-height:auto;border-radius:18px;gap:14px}
  .svc-tile{width:52px;height:52px;border-radius:14px}
  .svc-card h3{font-size:1.2rem}
  .svc-card p{font-size:.92rem}

  /* Gallery */
  .gallery{padding:64px 0}
  .gallery .section-head{margin-bottom:28px}
  .gal-grid{gap:12px}
  .gal-tile.t1{height:240px;border-radius:18px}
  .gal-tile.t2,.gal-tile.t3,.gal-tile.t4{height:160px;border-radius:18px}
  .gal-tile .gal-overlay{padding:18px}
  .gal-tile .gal-tag{top:14px;left:14px;padding:4px 10px;font-size:.62rem}
  .gal-tile .gal-cap{font-size:.85rem}
  .gal-foot{margin-top:24px;font-size:.85rem}

  /* Leaders home */
  .leaders-home{padding:64px 0}
  .leaders-home .section-head{margin-bottom:28px}
  .lead-rail{gap:14px}
  .lead-card{aspect-ratio:4/5;border-radius:20px}
  .lead-pill{top:12px;left:12px;padding:5px 10px;font-size:.62rem}
  .lead-body{padding:18px 18px 20px}
  .lead-name{font-size:1.2rem}
  .lead-title{font-size:.66rem;letter-spacing:.12em}
  .lead-bio{margin-top:10px;font-size:.85rem;line-height:1.5}
  .lead-link{margin-top:12px;padding:7px 12px;font-size:.74rem}
  .lead-photo-fallback{font-size:4.5rem}
  .lead-foot{margin-top:28px;font-size:.85rem}

  /* Stats band */
  .band{padding:60px 0}
  .band-grid{gap:20px}
  .band-grid .stat .l{font-size:.75rem;margin-top:6px}

  /* Promise */
  .promise-inner{padding:64px 0}
  .promise h2{font-size:clamp(1.7rem,8vw,5rem);line-height:1.1}
  .promise p{margin-top:18px;font-size:.95rem;padding:0 4px}
  .promise::after{width:340px;height:340px;left:-30%}

  /* Contact */
  .contact-section{padding:64px 0}
  .contact-grid{gap:24px}
  .contact-card{padding:24px;border-radius:16px;gap:16px}
  .contact-row{gap:12px}
  .contact-row .ci{width:36px;height:36px;border-radius:10px}
  .contact-form input, .contact-form textarea{padding:12px 14px;border-radius:10px;font-size:1rem}
  .flash-success{padding:12px 14px;font-size:.9rem}

  /* Footer */
  footer{padding:56px 0 24px}
  .foot-grid{gap:32px}
  .foot-col a.foot-cta{margin-top:18px;padding:10px 12px 10px 22px;font-size:.88rem;gap:10px}
  .foot-cta-arr{width:30px;height:30px;font-size:.85rem}
  .foot-bot{margin-top:40px;font-size:.78rem;flex-direction:column;align-items:flex-start;gap:8px}

  /* Page heads (careers/leaders/gallery/partners list pages) */
  .page-head{padding:56px 0 36px}
  .page-head .lead{font-size:.95rem;margin-top:16px}

  /* Card grids */
  .card-grid{grid-template-columns:1fr;gap:14px}
  .card{padding:22px;border-radius:16px;gap:12px}
  .card h3{font-size:1.15rem}
  .card p{font-size:.9rem}

  /* Filter bar */
  .filter-bar{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;-ms-overflow-style:none;margin-left:-18px;margin-right:-18px;
    padding:0 18px 4px;margin-bottom:24px}
  .filter-bar::-webkit-scrollbar{display:none}
  .filter-bar button,.filter-btn{flex-shrink:0;padding:7px 14px;font-size:.8rem}

  /* Leader cards */
  .leader-card{padding:24px 18px;gap:12px}
  .leader-photo{width:108px;height:108px}
  .leader-name{font-size:1.15rem}
  .leader-bio{font-size:.88rem}

  /* Partners */
  .partner-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .partner-tile{padding:18px;border-radius:14px;aspect-ratio:4/3}
  .partner-tile img{max-width:90px;max-height:46px}

  /* Career detail */
  .career-hero{padding:56px 0 24px}
  .career-actions{gap:10px;margin:22px 0 36px}
  .career-actions .btn{flex:1 1 calc(50% - 5px);justify-content:center}
  .career-body{gap:32px;padding:24px 0 60px}
  .career-body h3{font-size:1.2rem;margin-top:24px}
  .career-side{position:static;padding:22px;border-radius:16px}

  .empty-state{padding:48px 16px}
  .empty-state h3{font-size:1.2rem}
}

/* ===== Mobile-first homepage refinements ===== */

/* Products — Core hero (mobile-first: stack; ≥860px: 2-col) */
.product-core{
  grid-column:1/-1;
  display:grid;
  grid-template-columns:1fr;
  gap:28px;
  align-items:center;
  padding:20px;
  margin-bottom:28px;
}
.product-core-visual{
  border-radius:14px;overflow:hidden;background:var(--paper);
  min-height:220px;display:flex;align-items:center;justify-content:center;
}
.product-core-img{width:100%;height:100%;object-fit:cover;display:block}
.product-core-body{padding:0 4px}
.product-core-body .num{font-family:var(--serif);font-size:.95rem;color:var(--primary);font-weight:600;letter-spacing:.04em}
.product-core-body h3{margin-top:10px;font-size:clamp(1.25rem,4.5vw,1.6rem);line-height:1.25}
.product-core-body p{margin-top:14px;color:var(--ink-2);font-size:.95rem;line-height:1.6}
.product-core-body ul{margin-top:18px;padding:0;list-style:none;display:flex;flex-direction:column;gap:8px}
.product-core-body li{font-size:.92rem;color:var(--ink-2);padding-left:18px;position:relative}
.product-core-body li::before{content:'';position:absolute;left:0;top:.55em;width:6px;height:6px;border-radius:50%;background:var(--primary)}
@media (min-width:860px){
  .product-core{grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);gap:48px;padding:32px;margin-bottom:32px}
  .product-core-visual{min-height:320px;border-radius:18px}
  .product-core-body h3{margin-top:10px}
  .product-core-body p{font-size:1rem}
  .product-core-body li{font-size:.95rem}
}

/* Products — Other products list (mobile-first: stacked head + 1-col list; ≥720px: 2-col list; ≥860px: side-by-side head/list) */
.other-products-row{
  margin-top:36px;
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  align-items:start;
}
.other-products-head h3{margin-top:8px;font-size:clamp(1.15rem,4.4vw,1.5rem);line-height:1.25}
.other-products{margin:0;padding:0;list-style:none;display:grid;grid-template-columns:1fr;gap:14px}
.other-products li{
  font-size:.95rem;color:var(--ink);padding-left:20px;position:relative;line-height:1.5;
}
.other-products li .bullet{position:absolute;left:0;top:.45em;width:8px;height:8px;border-radius:50%;background:var(--primary)}
.other-products li strong{font-weight:600}
.other-products li .desc{display:block;color:var(--ink-2);font-size:.86rem;margin-top:2px}
@media (min-width:720px){
  .other-products{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px 28px}
}
@media (min-width:860px){
  .other-products-row{grid-template-columns:minmax(0,1fr) minmax(0,2fr);gap:32px;margin-top:48px}
  .other-products{gap:14px 32px}
  .other-products li{font-size:1rem}
}

/* About — Mission cards (mobile-first: 1-col; ≥720px: 2-col; ≥980px: 3-col) */
.missions-grid{
  margin-top:48px;
  display:grid;
  grid-template-columns:1fr;
  gap:18px;
}
.mission-card{
  text-align:center;padding:24px 20px;border-radius:16px;
  background:#fff;border:1px solid var(--line);
}
.mission-icon{
  width:60px;height:60px;border-radius:50%;
  background:rgba(28,133,184,.08);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;color:var(--primary);
}
.mission-icon svg{width:30px;height:30px}
.mission-card h3{font-size:1.05rem;color:var(--primary);margin-bottom:10px;line-height:1.3}
.mission-card p{color:var(--ink-2);font-size:.92rem;line-height:1.55}
@media (min-width:720px){
  .missions-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;margin-top:60px}
  .mission-card{padding:28px 22px}
}
@media (min-width:980px){
  .missions-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:32px;margin-top:80px}
  .mission-card{padding:32px 24px;border-radius:18px}
  .mission-icon{width:72px;height:72px;margin-bottom:18px}
  .mission-icon svg{width:36px;height:36px}
  .mission-card h3{font-size:1.15rem;margin-bottom:14px}
  .mission-card p{font-size:.95rem;line-height:1.6}
}

/* Featured partner card (mobile-first: stack; ≥860px: 2-col) */
.featured-partner-section{padding:32px 0}
.featured-partner-card{
  display:grid;
  grid-template-columns:1fr;
  gap:24px;
  align-items:center;
  padding:24px;
  border-radius:18px;
  background:#fff;
  border:1px solid var(--line);
}
.featured-partner-logo{
  display:flex;align-items:center;justify-content:center;
  min-height:140px;background:var(--paper);
  border-radius:14px;padding:22px;
}
.featured-partner-logo img{max-width:100%;max-height:120px;height:auto}
.featured-partner-name-fallback{font-size:1.4rem;font-weight:700;color:var(--primary);text-align:center}
.featured-partner-body .eyebrow{margin-bottom:8px}
.featured-partner-body h2{margin-bottom:6px;font-size:clamp(1.4rem,5.5vw,2.1rem);line-height:1.2}
.featured-partner-tagline{color:var(--primary);font-weight:600;font-size:.95rem;margin-bottom:14px}
.featured-partner-desc{color:var(--ink-2);font-size:.95rem;line-height:1.65;white-space:pre-line}
.featured-partner-cta{margin-top:18px;display:inline-block}
@media (min-width:720px){
  .featured-partner-section{padding:40px 0}
  .featured-partner-card{padding:32px;gap:32px;border-radius:20px}
  .featured-partner-logo{min-height:170px;border-radius:16px;padding:28px}
  .featured-partner-logo img{max-height:140px}
  .featured-partner-desc{font-size:1rem;line-height:1.7}
}
@media (min-width:860px){
  .featured-partner-section{padding:48px 0}
  .featured-partner-card{
    grid-template-columns:minmax(0,1fr) minmax(0,1.5fr);
    gap:48px;padding:48px;border-radius:24px;
  }
  .featured-partner-logo{min-height:200px;border-radius:18px;padding:32px}
  .featured-partner-logo img{max-height:160px}
  .featured-partner-tagline{font-size:1rem;margin-bottom:18px}
}

/* Leaders — homepage showcase */
.leaders-home{
  position:relative;overflow:hidden;padding:96px 0;
  background:
    radial-gradient(120% 90% at 100% 0%, color-mix(in oklab,var(--primary) 8%,transparent), transparent 60%),
    radial-gradient(80% 80% at 0% 100%, color-mix(in oklab,var(--primary-2) 7%,transparent), transparent 60%),
    var(--paper);
}
.leaders-home::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background-image:radial-gradient(color-mix(in oklab,var(--primary) 22%,transparent) 1.2px, transparent 1.4px);
  background-size:24px 24px;
  mask-image:radial-gradient(ellipse 60% 70% at 0% 0%, black 10%, transparent 65%);
  -webkit-mask-image:radial-gradient(ellipse 60% 70% at 0% 0%, black 10%, transparent 65%);
  opacity:.4;
}
.leaders-home::after{
  content:'';position:absolute;right:-10%;top:-15%;width:55%;height:60%;pointer-events:none;
  background:radial-gradient(closest-side, color-mix(in oklab,var(--primary) 14%,transparent), transparent 70%);
  filter:blur(60px);
}
.leaders-home > *{position:relative;z-index:1}
.leaders-home .section-head{margin-bottom:56px}
.leaders-home h2 em{color:var(--primary);font-style:italic;font-weight:400;font-family:'Newsreader',var(--serif)}

.lead-rail{
  display:grid;
  grid-template-columns:repeat(4, minmax(0,1fr));
  gap:18px;
}
@media (max-width:1100px){.lead-rail{grid-template-columns:repeat(2, minmax(0,1fr));gap:18px}}
@media (max-width:520px){.lead-rail{grid-template-columns:1fr;gap:16px}}

.lead-card{
  position:relative;aspect-ratio:3/4;border-radius:24px;overflow:hidden;
  background:linear-gradient(160deg,var(--primary),var(--primary-2));
  isolation:isolate;cursor:default;
  transform:translateY(24px) scale(.985);opacity:0;
  transition:transform .9s cubic-bezier(.2,.7,.2,1), opacity .9s cubic-bezier(.2,.7,.2,1), box-shadow .45s ease;
  box-shadow:0 16px 36px -24px color-mix(in oklab,var(--primary) 55%,transparent);
}
.lead-card.in{opacity:1;transform:none}
.lead-card.in:hover{
  transform:translateY(-6px);
  box-shadow:0 32px 64px -22px color-mix(in oklab,var(--primary) 65%,transparent);
}

.lead-photo{position:absolute;inset:0;z-index:0}
.lead-photo img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 18%;
  transition:transform 1s cubic-bezier(.2,.7,.2,1), filter .5s ease;
  will-change:transform;filter:saturate(.96);
}
.lead-card:hover .lead-photo img{transform:scale(1.06);filter:saturate(1.06)}
.lead-photo-fallback{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font-family:var(--serif);font-weight:500;font-size:6rem;letter-spacing:-0.04em;
  color:rgba(255,255,255,.85);
  background:
    radial-gradient(closest-side,rgba(255,255,255,.18),transparent 65%),
    linear-gradient(160deg,var(--primary),var(--primary-2));
}
.lead-photo-grain{
  position:absolute;inset:0;
  background-image:radial-gradient(rgba(255,255,255,.18) 1px,transparent 1.2px);
  background-size:14px 14px;mix-blend-mode:overlay;pointer-events:none;
}
.lead-photo::after{
  content:'';position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(180deg, transparent 38%, rgba(7,18,25,.55) 72%, rgba(7,18,25,.92) 100%);
  transition:background .4s ease;
}
.lead-card:hover .lead-photo::after{
  background:linear-gradient(180deg, transparent 22%, rgba(7,18,25,.6) 60%, rgba(7,18,25,.96) 100%);
}

.lead-pill{
  position:absolute;top:16px;left:16px;z-index:3;
  display:inline-flex;align-items:center;gap:8px;
  background:rgba(255,255,255,.92);color:var(--ink);
  padding:6px 12px;border-radius:999px;
  font-size:.68rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 6px 14px -8px rgba(11,31,41,.35);
  transition:transform .35s ease;
}
.lead-card:hover .lead-pill{transform:translateY(-2px)}
.lead-pill-dot{
  width:6px;height:6px;border-radius:50%;background:var(--primary);
  box-shadow:0 0 0 3px color-mix(in oklab,var(--primary) 22%,transparent);
}

.lead-shine{
  position:absolute;inset:-1px;z-index:2;pointer-events:none;border-radius:inherit;
  background:linear-gradient(120deg, transparent 35%, rgba(255,255,255,.18) 50%, transparent 65%);
  transform:translateX(-110%);
  transition:transform .9s cubic-bezier(.2,.7,.2,1);
}
.lead-card:hover .lead-shine{transform:translateX(110%)}

.lead-body{
  position:absolute;left:0;right:0;bottom:0;z-index:3;
  padding:22px 22px 24px;color:#fff;
}
.lead-name{
  font-family:var(--serif);font-size:1.4rem;font-weight:500;
  letter-spacing:-0.012em;line-height:1.2;
  text-shadow:0 2px 16px rgba(0,0,0,.25);
}
.lead-title{
  margin-top:6px;
  font-size:.7rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.78);
}
.lead-bio{
  margin-top:14px;
  font-size:.88rem;line-height:1.55;
  color:rgba(255,255,255,.86);
}
.lead-link{
  display:inline-flex;align-items:center;gap:8px;margin-top:16px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.24);
  color:#fff;text-decoration:none;
  font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.01em;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  transition:background .25s ease, border-color .25s ease, transform .25s ease;
}
.lead-link:hover{background:rgba(255,255,255,.24);border-color:rgba(255,255,255,.4);transform:translateY(-1px)}
.lead-link-arr{display:inline-block;transition:transform .25s ease}
.lead-link:hover .lead-link-arr{transform:translate(2px,-2px)}

/* Hover-to-reveal: only on real pointer devices, otherwise show body fully */
@media (hover:hover) and (pointer:fine){
  .lead-body{
    transform:translateY(calc(100% - 96px));
    transition:transform .55s cubic-bezier(.2,.7,.2,1);
  }
  .lead-bio,.lead-link{
    opacity:0;transform:translateY(10px);
    transition:opacity .35s ease, transform .55s cubic-bezier(.2,.7,.2,1);
  }
  .lead-bio{transition-delay:.05s}
  .lead-link{transition-delay:.12s}
  .lead-card:hover .lead-body,
  .lead-card:focus-within .lead-body{transform:translateY(0)}
  .lead-card:hover .lead-bio,
  .lead-card:focus-within .lead-bio,
  .lead-card:hover .lead-link,
  .lead-card:focus-within .lead-link{opacity:1;transform:translateY(0)}
}

.lead-foot{
  display:flex;justify-content:space-between;align-items:center;
  margin-top:40px;padding-top:24px;
  border-top:1px solid color-mix(in oklab,var(--line) 80%,transparent);
  color:var(--muted);font-size:.9rem;flex-wrap:wrap;gap:12px;
}
.lead-foot a{
  color:var(--primary);font-weight:500;text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  transition:gap .25s ease, color .2s ease;
}
.lead-foot a:hover{color:var(--primary-2);gap:14px}

@media (prefers-reduced-motion:reduce){
  .lead-card,.lead-card .lead-photo img,.lead-shine,.lead-body,.lead-bio,.lead-link{transition:none !important}
  .lead-shine{display:none}
}

/* Image lightbox */
.js-zoomable{cursor:zoom-in;transition:transform .25s ease, box-shadow .25s ease}
.js-zoomable:hover{transform:translateY(-2px);box-shadow:0 12px 32px rgba(0,0,0,.12)}
.leader-photo .js-zoomable:hover,.partner-tile .js-zoomable:hover,.gal-tile .js-zoomable:hover{transform:none;box-shadow:none}
.lightbox{position:fixed;inset:0;background:rgba(8,12,20,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);display:flex;align-items:center;justify-content:center;z-index:9999;opacity:0;pointer-events:none;transition:opacity .2s ease;padding:32px}
.lightbox.is-open{opacity:1;pointer-events:auto}
.lightbox-img{max-width:min(1280px,95vw);max-height:90vh;width:auto;height:auto;border-radius:14px;box-shadow:0 24px 80px rgba(0,0,0,.5);background:#fff;cursor:zoom-out;transform:scale(.96);transition:transform .25s ease}
.lightbox.is-open .lightbox-img{transform:scale(1)}
.lightbox-close{position:absolute;top:22px;right:22px;width:44px;height:44px;border-radius:50%;border:0;background:rgba(255,255,255,.12);color:#fff;font-size:22px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s ease}
.lightbox-close:hover{background:rgba(255,255,255,.22)}
.lightbox-caption{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.85);font-size:.92rem;letter-spacing:.01em;text-align:center;max-width:90vw}
@media (max-width:640px){
  .lightbox{padding:16px}
  .lightbox-close{top:12px;right:12px;width:38px;height:38px}
}
