/* ═══════════════════ ACCESSIBILITY ═══════════════════ */
.skip-link{position:absolute;top:-100%;left:16px;padding:8px 16px;background:#122F51;color:#fff;z-index:9999;font-size:14px;border-radius:0 0 8px 8px;transition:top .2s;}
.skip-link:focus{top:0;}

.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;
}

/* ═══════════════════ TOKENS ═══════════════════ */
:root {
  --navy:       #122F51;
  --navy-dark:  #0c2040;
  --navy-mid:   #1e4370;
  --navy-light: #2a5a94;
  --navy-pale:  #d6e4f0;
  --white:      #ffffff;
  --off-white:  #faf9f8;
  --text-body:  #3a4a5c;
  --text-muted: #6b7f94;
  --grad-pink:  #f5d6e8;
  --grad-blue:  #c8d8f0;
  --grad-lav:   #ddd0f0;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:'DM Sans',sans-serif;background:var(--off-white);color:var(--navy);overflow-x:hidden;}
::-webkit-scrollbar{width:3px;}
::-webkit-scrollbar-thumb{background:var(--navy-light);}
img{display:block;max-width:100%;}
a{text-decoration:none;color:inherit;}

/* ═══════════════════ GRADIENT BG ═══════════════════ */
.grad-bg {
  background: linear-gradient(135deg, 
    #fde8f0 0%, #e8d8f5 20%, #d0dff8 40%, 
    #e8f0fd 60%, #f5e0f0 80%, #fde8f0 100%);
  background-size: 400% 400%;
  animation: gradShift 12s ease infinite;
}
@keyframes gradShift {
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}

.grad-bg-2 {
  background: linear-gradient(135deg,
    #e8f0fd 0%, #f0e8fb 30%, #fde8f2 60%, #e8f4fd 100%);
  background-size:300% 300%;
  animation: gradShift 15s ease infinite;
}

/* ═══════════════════ SCROLL REVEAL ═══════════════════ */
.sr{opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease;}
.sr.d1{transition-delay:.1s}.sr.d2{transition-delay:.2s}.sr.d3{transition-delay:.3s}
.sr.d4{transition-delay:.4s}.sr.d5{transition-delay:.5s}.sr.d6{transition-delay:.6s}
.sr.vis{opacity:1;transform:translateY(0);}

/* ═══════════════════ NAV ═══════════════════ */
nav {
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  z-index:520;width:calc(100% - 48px);max-width:1200px;
  height:68px;display:flex;align-items:center;justify-content:space-between;
  padding:0 28px;
  background:rgba(255,255,255,0.72);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-radius:100px;
  border:1px solid rgba(255,255,255,0.9);
  box-shadow:0 4px 24px rgba(18,47,81,0.08),inset 0 1px 0 rgba(255,255,255,0.8);
  transition:box-shadow .3s,background .3s;
}
nav.scrolled{
  background:rgba(255,255,255,0.88);
  box-shadow:0 8px 32px rgba(18,47,81,0.12),inset 0 1px 0 rgba(255,255,255,0.9);
}

.nav-logo {
  font-family:'Playfair Display',serif;
  font-size:20px;font-weight:700;
  color:var(--navy);letter-spacing:.02em;
  flex-shrink:0;
}
.nav-logo sup {
  font-family:'Questrial',sans-serif;
  font-size:10px;font-weight:400;
  letter-spacing:.15em;vertical-align:super;
  color:var(--navy-light);
}

.nav-links{display:flex;align-items:center;gap:36px;list-style:none;}
.nav-links a {
  font-family:'Questrial',sans-serif;
  font-size:11.5px;letter-spacing:.05em;text-transform:uppercase;
  color:var(--text-body);transition:color .2s;white-space:nowrap;
}
.nav-links a:hover{color:var(--navy);}

.nav-cta {
  font-family:'Questrial',sans-serif;
  font-size:12px;letter-spacing:.08em;text-transform:uppercase;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
  background:var(--navy);color:var(--white)!important;
  padding:10px 22px;border-radius:100px;
  text-decoration:none;
  transition:background .25s,transform .2s;white-space:nowrap;
}
.nav-cta:hover{background:var(--navy-light);transform:translateY(-1px);}

/* ── Hamburger button ── */
.nav-burger{
  display:none;            /* hidden on desktop */
  flex-direction:column;justify-content:center;align-items:center;
  gap:5px;width:40px;height:40px;
  background:none;border:none;cursor:pointer;padding:0;
  position:relative;z-index:520;
}
.nav-burger span{
  display:block;width:22px;height:2px;
  background:var(--navy);border-radius:2px;
  transition:transform .3s,opacity .3s;
}
.nav-burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger.open span:nth-child(2){opacity:0;}
.nav-burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* ── Mobile / Tablet drawer ── */
.nav-drawer{
  display:none;            /* hidden on desktop */
  position:fixed;top:0;left:0;right:0;bottom:0;
  z-index:510;
  background:rgba(255,255,255,0.98);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  flex-direction:column;align-items:center;justify-content:center;
  gap:12px;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.nav-drawer.open{opacity:1;pointer-events:auto;}
.nav-drawer-links{
  list-style:none;padding:0;margin:0 0 28px;
  display:flex;flex-direction:column;align-items:center;gap:24px;
}
.nav-drawer-links a{
  font-family:'Questrial',sans-serif;
  font-size:16px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--navy);text-decoration:none;
  transition:color .2s;
  display:inline-flex;align-items:center;min-height:44px;
}
.nav-drawer-links a:hover{color:var(--navy-light);}
.drawer-cta{padding:16px 48px;font-size:14px;min-width:200px;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.2;}
.desktop-only{display:inline-flex;}

/* ── Responsive: Tablet (≤1024) ── */
@media(max-width:1024px){
  .nav-links{display:none;}
  .desktop-only{display:none;}
  .nav-burger{display:flex;}
  .nav-drawer{display:flex;}
}

/* ═══════════════════ LOGO MARQUEE ═══════════════════ */
#logo-marquee{
  padding:40px 0 0;
  width:100%;
  align-self:stretch;
  position:relative;
  z-index:1;
}
.logo-marquee-label{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--navy-light);
  text-align:center;margin:0 0 24px;
}
.logo-marquee-track{
  width:100%;overflow:hidden;
  -webkit-mask-image:linear-gradient(to right, transparent, black 8%, black 92%, transparent);
  mask-image:linear-gradient(to right, transparent, black 8%, black 92%, transparent);
}
.logo-marquee-inner{
  display:flex;align-items:center;gap:64px;
  width:max-content;
  animation:marquee-scroll 30s linear infinite;
}
.logo-marquee-item{
  font-family:'Playfair Display',serif;
  font-size:1.4rem;font-weight:600;
  color:var(--navy);
  opacity:0.9;
  white-space:nowrap;
  letter-spacing:.02em;
  flex-shrink:0;
}
@keyframes marquee-scroll{
  0%{transform:translateX(0);}
  100%{transform:translateX(-50%);}
}
@media(max-width:680px){
  #logo-marquee{padding:28px 0;}
  .logo-marquee-inner{gap:40px;}
  .logo-marquee-item{font-size:1.1rem;}
}

/* ═══════════════════ SECTION SHARED ═══════════════════ */
section{padding:100px 80px;}
.section-inner{max-width:1200px;margin:0 auto;}

.eyebrow {
  font-family:'Questrial',sans-serif;
  font-size:11.5px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--navy-light);margin-bottom:16px;display:block;
}
h1.section-title,
h2.section-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(32px,4vw,52px);font-weight:600;
  line-height:1.15;color:var(--navy);margin-bottom:20px;
}
h1.section-title em,
h2.section-title em{font-style:italic;color:var(--navy-light);}
.section-lead {
  font-size:16px;line-height:1.7;color:var(--text-body);
  max-width:600px;margin-bottom:48px;
}

/* ═══════════════════ 1. HERO ═══════════════════ */
#hero {
  min-height:100vh;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  padding:148px 48px 80px;text-align:center;
  position:relative;overflow:hidden;
}
#hero::before {
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 80% at 20% 40%, rgba(253,216,240,0.7) 0%, transparent 60%),
             radial-gradient(ellipse 60% 60% at 80% 20%, rgba(200,216,240,0.7) 0%, transparent 55%),
             radial-gradient(ellipse 70% 70% at 60% 80%, rgba(221,208,240,0.6) 0%, transparent 55%),
             radial-gradient(ellipse 50% 50% at 10% 80%, rgba(200,230,245,0.5) 0%, transparent 50%);
  background-color:#faf5fc;
  animation:gradShift 14s ease infinite;
  background-size:200% 200%;
}

.hero-content{position:relative;z-index:2;}

.hero-eyebrow {
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.25em;text-transform:uppercase;
  color:var(--navy-light);margin-bottom:20px;
  opacity:0;animation:fadeUp .8s .2s forwards;
}
.hero-title {
  font-family:'Playfair Display',serif;
  font-size:clamp(38px,5.5vw,72px);font-weight:700;
  line-height:1.1;color:var(--navy);margin-bottom:18px;
  opacity:0;animation:fadeUp .8s .4s forwards;
}
.hero-title em{font-style:italic;color:var(--navy-light);}
.hero-sub {
  font-size:clamp(15px,1.5vw,18px);line-height:1.7;
  color:var(--text-body);max-width:620px;margin:0 auto 32px;
  opacity:0;animation:fadeUp .8s .6s forwards;
}
.hero-sub strong{color:var(--navy);font-weight:500;}

.hero-ctas{
  display:flex;gap:16px;justify-content:center;flex-wrap:wrap;
  opacity:0;animation:fadeUp .8s .8s forwards;
  margin-bottom:36px;
}
.hero-ctas .liquid-glow-btn,
.hero-ctas .btn-secondary{min-width:220px;text-align:center;justify-content:center;}

/* Floating glassmorphism stats pill */
.hero-stats-pill{
  display:flex;align-items:center;justify-content:space-evenly;
  background:rgba(255,255,255,0.28);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,0.45);
  box-shadow:0 8px 32px rgba(0,0,0,0.06), inset 0 1px 0 rgba(255,255,255,0.6);
  border-radius:28px;
  padding:24px 40px;
  max-width:680px;
  margin:0 auto;
  opacity:0;animation:fadeUp .8s 1s forwards;
}
.hero-stat-item{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  flex:1;
}
.hero-stat-num{
  font-family:'Playfair Display',serif;
  font-size:clamp(26px,3vw,36px);font-weight:700;
  color:var(--navy);line-height:1;
  display:flex;align-items:baseline;gap:2px;
}
.hero-stat-num span{color:var(--navy);font-size:.75em;}
.hero-stat-label{
  font-family:'DM Sans',sans-serif;
  font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(18,47,81,0.55);font-weight:400;text-align:center;
  line-height:1.3;
}
.hero-stat-divider{
  width:1px;height:40px;
  background:rgba(18,47,81,0.1);
  flex-shrink:0;
}
.label-short{display:none;}
@media(max-width:480px){
  .label-full{display:none;}
  .label-short{display:inline;}
  .hero-stats-pill{padding:20px 16px;border-radius:20px;}
  .hero-stat-num{font-size:22px;}
  .hero-stat-divider{height:30px;}
}
.btn-primary {
  font-family:'Questrial',sans-serif;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;align-items:center;justify-content:center;line-height:1;
  background:var(--navy);color:var(--white);
  padding:14px 32px;border-radius:100px;
  text-decoration:none;cursor:pointer;
  transition:background .25s,transform .2s,box-shadow .25s;
  box-shadow:0 4px 20px rgba(18,47,81,0.2);
}
.btn-primary:hover{background:var(--navy-light);transform:translateY(-2px);box-shadow:0 8px 28px rgba(18,47,81,0.25);}

.btn-secondary {
  font-family:'Questrial',sans-serif;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;justify-content:center;line-height:1;
  background:transparent;
  color:var(--navy);
  padding:14px 32px;border-radius:100px;
  border:1px solid rgba(18,47,81,0.2);
  text-decoration:none;cursor:pointer;
  transition:background .25s,border-color .25s,box-shadow .25s,transform .25s;
}
.btn-secondary:hover{border-color:var(--navy);background:rgba(18,47,81,0.05);transform:translateY(-2px);}
.btn-sec-arrow {
  display:inline-block;
  transition:transform .25s ease;
}
.btn-secondary:hover .btn-sec-arrow {
  transform:translateX(4px);
}


/* Stats Bar moved into Hero as floating pill */

/* ═══════════════════ 3. WHO WE ARE ═══════════════════ */
#who {
  padding: 120px 48px;
  background: linear-gradient(135deg,
    rgba(238,242,255,0.9) 0%,
    rgba(245,243,255,0.7) 25%,
    rgba(255,255,255,0.95) 50%,
    rgba(253,242,248,0.7) 75%,
    rgba(240,245,255,0.9) 100%
  );
  overflow: visible;
}
.who-wrap {
  max-width: 1160px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 80px;
  align-items: center;
}

/* ── Left visual ── */
.who-visual {
  position: relative;
}
.who-img {
  width: 100%;
  aspect-ratio: 4/5;
  object-fit: cover;
  border-radius: 28px;
  display: block;
  box-shadow: 0 24px 64px rgba(18,47,81,0.12);
}
.who-quote-card {
  position: absolute;
  bottom: -28px;
  right: -28px;
  max-width: 300px;
  background: rgba(255,255,255,0.82);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  border: 1px solid rgba(255,255,255,0.4);
  box-shadow: 0 16px 48px rgba(18,47,81,0.08), inset 0 1px 0 rgba(255,255,255,0.6);
  border-radius: 20px;
  padding: 24px 26px;
  z-index: 10;
}
.who-quote-text {
  font-family: 'DM Sans', sans-serif;
  font-style: normal;
  font-weight: 500;
  font-size: 13.5px;
  line-height: 1.75;
  color: var(--navy);
  margin-bottom: 0;
}
.who-quote-tag {
  font-family: 'Questrial', sans-serif;
  font-size: 9.5px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: rgba(18,47,81,0.4);
}

/* ── Right content ── */
.who-content { padding-right: 8px; }
.who-intro {
  font-family: 'DM Sans', sans-serif;
  font-size: 16px;
  line-height: 1.85;
  color: #5a6a7e;
  margin-bottom: 44px;
}

/* Pillars list */
.who-pillars {
  display: flex;
  flex-direction: column;
  gap: 28px;
}
.who-pillar {
  display: flex;
  align-items: flex-start;
  gap: 20px;
  transition: transform .25s;
  cursor: default;
}
.who-pillar:hover { transform: translateY(-2px); }
.who-pillar:hover .who-pillar-icon { color: var(--navy); background: rgba(18,47,81,0.1); }
.who-pillar-icon {
  flex-shrink: 0;
  width: 44px; height: 44px;
  border-radius: 12px;
  background: rgba(18,47,81,0.06);
  display: flex; align-items: center; justify-content: center;
  color: rgba(18,47,81,0.5);
  transition: background .25s, color .25s;
}
.who-pillar-icon svg { width: 20px; height: 20px; }
.who-pillar-body {}
.who-pillar-title {
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 600;
  color: var(--navy);
  margin-bottom: 5px;
  line-height: 1.3;
}
.who-pillar-desc {
  font-family: 'DM Sans', sans-serif;
  font-size: 13.5px;
  line-height: 1.7;
  color: var(--text-body);
}

/* Mobile */
@media (max-width: 900px) {
  .who-wrap { grid-template-columns: 1fr; gap: 32px; }
  .who-content { order: -1; }
  .who-img { aspect-ratio:auto; max-height:220px; object-fit:cover; border-radius:20px; }
  .who-quote-card { right: 16px; bottom: -24px; max-width: 260px; }
  #who { padding: 80px 20px; }
}

/* ═══════════════════ 4. SERVICES ═══════════════════ */
#services {
  background: radial-gradient(ellipse at 30% 20%, #f0f7ff 0%, #f8fafc 50%, #fafbfd 100%);
}
.services-header { text-align:center; margin-bottom:56px; }
.services-header .section-lead { margin:0 auto; }

/* ── Tabs ── */
.svc-tabs {
  display: flex;
  justify-content: center;
  gap: 10px;
  margin-bottom: 64px;
  flex-wrap: wrap;
}
.svc-tab {
  font-family: 'Questrial', sans-serif;
  font-size: 12px;
  letter-spacing: .1em;
  text-transform: uppercase;
  padding: 12px 28px;
  min-height: 44px;
  border-radius: 100px;
  border: 1px solid rgba(255,255,255,0.55);
  background: rgba(255,255,255,0.42);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  color: var(--text-body);
  cursor: pointer;
  transition: all .25s;
  white-space: nowrap;
  box-shadow: 0 2px 12px rgba(18,47,81,0.04);
}
.svc-tab:hover {
  border-color: rgba(18,47,81,0.25);
  color: var(--navy);
  background: rgba(255,255,255,0.62);
}
.svc-tab.active {
  background: var(--navy);
  color: var(--white);
  border-color: var(--navy);
  box-shadow: 0 4px 20px rgba(18,47,81,0.22);
  backdrop-filter: none;
}
.svc-link-short { display: none; }
.svc-sticky-num {
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-weight: 600;
  margin-right: 4px;
  font-size: 12px;
  opacity: 0.5;
  vertical-align: middle;
  line-height: 1;
}
.svc-tab.active .svc-sticky-num { opacity: 1; }

/* ── Panels ── */
.svc-panel { display: none; }
.svc-panel.active { display: block; animation: panelFadeIn .4s forwards; }
@keyframes panelFadeIn {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── Liquid-Flow Timeline ── */
.lf-timeline{
  position:relative;
  max-width:920px;
  margin:0 auto;
  padding:0 0 24px;
}

/* Track (background line) */
.lf-track{
  position:absolute;
  left:50%; top:28px; bottom:28px;
  width:2px;
  transform:translateX(-50%);
  background:rgba(18,47,81,0.08);
  border-radius:2px;
  z-index:0;
}
/* Liquid fill (scroll-driven) */
.lf-fill{
  width:100%;
  height:0%;
  background:var(--navy);
  border-radius:2px;
  transition:height 60ms linear;
}

/* ── Item row (grid: card | node | spacer) ── */
.lf-item{
  display:grid;
  grid-template-columns:1fr 56px 1fr;
  align-items:start;
  gap:0 32px;
  margin-bottom:48px;
  position:relative;
}

/* Left / Right placement */
.lf-item.left  .lf-card  { grid-column:1; }
.lf-item.left  .lf-node  { grid-column:2; }
.lf-item.left  .lf-spacer{ grid-column:3; }
.lf-item.right .lf-spacer{ grid-column:1; }
.lf-item.right .lf-node  { grid-column:2; }
.lf-item.right .lf-card  { grid-column:3; }

/* Card entrance */
.lf-item .lf-card{
  opacity:0;
  transition:opacity .6s ease, transform .6s ease, box-shadow .3s;
}
.lf-item.left .lf-card { transform:translateX(-40px); }
.lf-item.right .lf-card{ transform:translateX(40px); }
.lf-item.vis .lf-card   { opacity:1; transform:translateX(0); }

/* ── Node ── */
.lf-node{
  width:56px; height:56px;
  border-radius:50%;
  background:#fff;
  border:2px solid #e2e8f0;
  display:flex; align-items:center; justify-content:center;
  color:#94a3b8;
  position:relative;
  z-index:10;
  margin:0 auto;
  flex-shrink:0;
  transition:background .5s, border-color .5s, color .5s, box-shadow .5s;
}
.lf-node svg{ width:20px; height:20px; }

/* Activated node */
.lf-item.node-active .lf-node{
  background:var(--navy);
  border-color:var(--navy);
  color:#fff;
  box-shadow:0 0 0 6px rgba(18,47,81,0.12), 0 4px 16px rgba(18,47,81,0.18);
}
/* Pulse ring on activation */
.lf-item.node-active .lf-node::after{
  content:'';
  position:absolute; inset:-4px;
  border-radius:50%;
  border:2px solid var(--navy);
  animation:lf-pulse 1.5s ease-out infinite;
}
@keyframes lf-pulse{
  0%  { transform:scale(1); opacity:0.5; }
  100%{ transform:scale(1.6); opacity:0; }
}

/* ── Card ── */
.lf-card{
  background:#fff;
  border:1px solid rgba(18,47,81,0.06);
  border-radius:20px;
  padding:32px;
  box-shadow:0 4px 24px rgba(18,47,81,0.05);
  cursor:default;
  text-align:left;
}
.lf-card:hover{
  transform:translateY(-5px) !important;
  box-shadow:0 12px 40px rgba(18,47,81,0.10);
}
.lf-num{
  display:block;
  font-family:'Playfair Display',serif;
  font-style:italic; font-weight:700;
  font-size:2.2rem; line-height:1;
  color:rgba(18,47,81,0.08);
  margin-bottom:6px;
}
.lf-title{
  font-family:'Playfair Display',serif;
  font-size:1.15rem; font-weight:600;
  color:var(--navy);
  letter-spacing:-0.01em;
  line-height:1.3;
  margin:0 0 10px;
}
.lf-desc{
  font-family:'DM Sans',sans-serif;
  font-size:13.5px; line-height:1.75;
  color:var(--text-body);
  margin:0 0 14px;
}
.lf-tags{
  display:flex; flex-wrap:wrap; gap:6px;
}
.lf-tags span{
  font-family:'Questrial',sans-serif;
  font-size:10px; letter-spacing:.08em; text-transform:uppercase;
  padding:4px 12px; border-radius:100px;
  background:rgba(18,47,81,0.04);
  color:var(--navy-light);
  border:1px solid rgba(18,47,81,0.08);
}

/* ── Mobile ── */
@media(max-width:768px){
  .lf-track{ left:28px; transform:none; }
  .lf-item.left,
  .lf-item.right{
    display:flex !important;
    flex-direction:row !important;
    align-items:flex-start;
    gap:20px;
    margin-bottom:28px;
  }
  .lf-node{ order:1 !important; flex-shrink:0; width:48px; height:48px; }
  .lf-item.left .lf-card,
  .lf-item.right .lf-card{ order:2 !important; flex:1; }
  .lf-item .lf-card{ transform:translateX(0) !important; }
  .lf-item.left .lf-card{ transform:translateY(20px) !important; }
  .lf-item.right .lf-card{ transform:translateY(20px) !important; }
  .lf-item.vis .lf-card{ transform:translateY(0) !important; }
  .lf-spacer{ display:none !important; }
  .lf-timeline{ padding-left:6px; }
  .lf-card{ padding:24px 20px; }
  /* Tab bar: sticky pill style (matches nav) */
  .svc-tabs{
    position:sticky;top:90px;z-index:500;
    flex-wrap:nowrap;justify-content:center;gap:0;
    overflow-x:auto;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    background:rgba(255,255,255,0.82);
    backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
    border:1px solid rgba(255,255,255,0.9);
    box-shadow:0 4px 24px rgba(18,47,81,0.08);
    border-radius:100px;
    margin:0 4px 40px;
    padding:4px;
  }
  .svc-tabs::-webkit-scrollbar{display:none;}
  .svc-tab{
    flex:1;text-align:center;
    padding:10px 16px;font-size:10px;letter-spacing:.12em;
    min-height:40px;
    border-radius:100px;border:none;
    background:transparent;backdrop-filter:none;-webkit-backdrop-filter:none;
    box-shadow:none;
    color:var(--text-muted);
  }
  .svc-tab.active{
    background:var(--navy-light);color:var(--white);
    border:none;box-shadow:none;
  }
  .svc-tab:hover{background:rgba(18,47,81,0.05);border:none;border-radius:100px;}
  .svc-tab.active:hover{background:var(--navy-light);}
  .svc-link-full{display:none;}
  .svc-link-short{display:inline;}
}

/* ═══════════════════ 5. PRODUCT CATEGORIES ═══════════════════ */
#products {
  padding: 100px 48px 100px;
  background: linear-gradient(160deg, #f0e8fb 0%, #e8f0fd 50%, #fde8f2 100%);
  overflow: hidden;
}
.products-header { text-align:center; margin-bottom:64px; }
.products-grid {
  max-width: 1100px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: 24px;
}

/* — Product Cards (replaces Tailwind CDN) — */
.pcard{display:block;position:relative;height:500px;width:100%;border-radius:24px;overflow:hidden;box-shadow:0 20px 25px -5px rgba(0,0,0,.1),0 8px 10px -6px rgba(0,0,0,.1);}
.pcard img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1s ease-out;z-index:0;}
.pcard:hover img{transform:scale(1.1);}
.pcard-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),rgba(0,0,0,.1),transparent);z-index:10;pointer-events:none;}
.pcard-body{position:absolute;bottom:0;left:0;right:0;padding:32px;z-index:20;background:rgba(255,255,255,.2);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.2);height:260px;display:flex;flex-direction:column;}
.pcard-body h3{font-size:1.875rem;font-family:'Playfair Display',serif;color:#fff;margin:0 0 12px;}
.pcard-body p{color:rgba(255,255,255,.8);font-size:.875rem;line-height:1.625;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;min-height:4.5rem;}
.pcard-cta{margin-top:auto;display:inline-flex;align-items:center;color:#fff;font-size:.875rem;font-weight:600;letter-spacing:.05em;transition:transform .3s;cursor:pointer;}
.pcard:hover .pcard-cta{transform:translateX(8px);}
.pcard-cta span{margin-left:8px;}

/* Product cards — products page smaller variant */
.pcard-sm{height:260px;}
.pcard-sm .pcard-body{height:160px;padding:20px;}
.pcard-sm .pcard-body h3{font-size:1.25rem;margin-bottom:4px;}
@media(min-width:769px){
  .pcard-sm{height:280px;}
  .pcard-sm .pcard-body{height:170px;padding:24px;}
  .pcard-sm .pcard-body h3{font-size:1.5rem;}
  .pcard-sm-tall{height:340px;}
  .pcard-sm-tall .pcard-body{height:200px;}
  .pcard-sm-tall .pcard-body h3{margin-bottom:8px;}
}

@media(max-width:768px){
  #products { padding:72px 20px; }
  .products-grid { grid-template-columns:1fr; gap:16px; }
  .products-grid .pcard, .products-grid .pcard-sm, .products-grid .pcard-sm-tall { height:200px !important; }
  .products-grid .pcard-body { height:auto !important; padding:12px 16px !important; }
  .products-grid .pcard-body h3 { font-size:16px !important; margin-bottom:2px !important; }
  .products-grid .pcard-body p { font-size:11.5px !important; line-height:1.4 !important; min-height:0 !important; margin-bottom:0 !important; display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden; }
  .products-grid .pcard-cta { margin-top:auto !important; margin-left:auto !important; font-size:11px !important; }
  .products-grid .pcard-featured, .products-grid .pcard-sm-tall { order:-1; }
}

/* ═══════════════════ 6. METHODOLOGY ═══════════════════ */
#methodology {
  background: #080f1e;
  position: relative;
  overflow: hidden;
  padding: 120px 0;
}
/* Background glow blobs */
#methodology::before {
  content: '';
  position: absolute;
  top: -120px; left: -120px;
  width: 600px; height: 600px;
  background: radial-gradient(circle, rgba(59,130,246,0.07) 0%, transparent 70%);
  pointer-events: none;
}
#methodology::after {
  content: '';
  position: absolute;
  bottom: -80px; right: -80px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(139,92,246,0.06) 0%, transparent 70%);
  pointer-events: none;
}

.meth-inner {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 5fr 7fr;
  gap: 80px;
  align-items: start;
}

/* Left sticky column */
.meth-sticky {
  position: sticky;
  top: 120px;
}
.meth-sticky .eyebrow {
  color: rgba(148,163,184,0.8);
  border-color: rgba(148,163,184,0.15);
}
.meth-sticky .section-title {
  color: #f8fafc;
  font-size: clamp(32px, 3.5vw, 44px);
  margin-bottom: 20px;
}
.meth-sticky .section-title em { color: #93c5fd; }
.meth-lead {
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  line-height: 1.8;
  color: #94a3b8;
  margin-top: 20px;
}

/* Steps column */
.meth-steps {
  display: flex;
  flex-direction: column;
  gap: 20px;
  position: relative;
  z-index: 1;
}

/* Card */
.meth-card {
  position: relative;
  overflow: hidden;
  border-radius: 24px;
  padding: 40px 44px;
  background: rgba(255,255,255,0.04);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  border: 1px solid rgba(255,255,255,0.08);
  transition: background .4s, border-color .4s, transform .4s;
  cursor: default;
}
.meth-card:hover {
  background: rgba(255,255,255,0.08);
  border-color: rgba(96,165,250,0.25);
  transform: translateX(6px);
}

/* Giant watermark number */
.meth-num {
  position: absolute;
  bottom: -28px; right: -8px;
  font-family: 'Playfair Display', serif;
  font-size: 11rem;
  font-weight: 700;
  line-height: 1;
  color: rgba(255,255,255,0.04);
  pointer-events: none;
  user-select: none;
  transition: transform .6s ease, color .4s;
}
.meth-card:hover .meth-num {
  transform: translateY(-16px) scale(1.08);
  color: rgba(255,255,255,0.08);
}

.meth-card-inner { position: relative; z-index: 2; }

.meth-step-label {
  font-family: 'Questrial', sans-serif;
  font-size: 10px;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: #60a5fa;
  margin-bottom: 12px;
}
.meth-card-title {
  font-family: 'Playfair Display', serif;
  font-size: 22px;
  font-weight: 700;
  color: #f8fafc;
  line-height: 1.3;
  margin-bottom: 14px;
}
.meth-card-desc {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  line-height: 1.8;
  color: #94a3b8;
}

/* Mobile */
@media (max-width: 1024px) {
  .meth-inner {
    grid-template-columns: 1fr;
    gap: 48px;
    padding: 0 24px;
  }
  .meth-sticky { position: static; }
  .meth-num { font-size: 8rem; }
  .meth-card { padding: 28px 28px; }
  #methodology { padding: 80px 0; }
}

/* ═══════════════════ 7. PATENTED INGREDIENTS ═══════════════════ */
#ingredients{
  padding:0;overflow:hidden;
  background:transparent;
}
.ing-header{text-align:center;padding:0 80px;margin-bottom:64px;}
.ingredients-marquee{
  display:flex;gap:20px;width:max-content;
  animation:marquee 30s linear infinite;
}
.ingredients-marquee:hover{animation-play-state:paused;}
.ing-card{
  background:rgba(255,255,255,0.45);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border-radius:20px;
  padding:32px 28px;width:260px;flex-shrink:0;
  border:1px solid rgba(255,255,255,0.6);
  cursor:default;
}
.ing-card:hover{
  /* no vertical shift */
}
.ing-num{
  font-family:'Questrial',sans-serif;
  font-size:10px;letter-spacing:.2em;color:var(--text-muted);
  margin-bottom:16px;display:flex;align-items:center;
}
.ing-name{
  font-family:'Playfair Display',serif;
  font-size:19px;font-weight:600;color:var(--navy);
  margin-bottom:8px;
}
.ing-cn{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.05em;color:var(--navy-light);
  margin-bottom:12px;
}
.ing-desc{font-size:12.5px;line-height:1.65;color:var(--text-muted);}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.ing-cta{text-align:center;margin-top:56px;padding:0 80px;}

/* ═══════════════════ 8. BRAND ELEVATION ═══════════════════ */
#elevation{
  padding:100px 80px;
  background:linear-gradient(135deg,#fde8f2 0%,#e8d8f8 40%,#d0e0f8 100%);
}
.elevation-header{text-align:center;margin-bottom:64px;}
.elevation-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
}
.elev-card{
  border-radius:20px;overflow:hidden;
  background:rgba(255,255,255,0.65);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.8);
  transition:transform .3s,box-shadow .3s;
}
.elev-card:hover{transform:translateY(-6px);box-shadow:0 20px 40px rgba(18,47,81,0.12);}
.elev-img{
  height:180px;overflow:hidden;
  background:linear-gradient(135deg,rgba(18,47,81,0.08),rgba(221,208,240,0.4));
}
.elev-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s;}
.elev-card:hover .elev-img img{transform:scale(1.05);}
.elev-body{padding:28px;}
.elev-body h3{
  font-family:'Playfair Display',serif;
  font-size:17px;font-weight:600;color:var(--navy);margin-bottom:8px;
}
.elev-body p{font-size:13px;line-height:1.65;color:var(--text-body);}

/* ═══════════════════ 9. WHY CHOOSE KEEPP ═══════════════════ */
#why{background:radial-gradient(ellipse at 30% 20%, #f0f7ff 0%, #f8fafc 50%, #fafbfd 100%);padding:100px 80px;}
.why-header{text-align:center;margin-bottom:64px;}
.why-grid{
  max-width:1200px;margin:0 auto;
  display:grid;grid-template-columns:repeat(3,1fr);gap:24px;
  margin-bottom:56px;
}
.why-card{
  background:var(--white);border-radius:20px;padding:36px 28px;
  border:1px solid rgba(18,47,81,0.07);
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.why-card:hover{
  transform:translateY(-6px);
  box-shadow:0 20px 40px rgba(18,47,81,0.1);
  border-color:rgba(18,47,81,0.15);
}
.why-card-num{
  font-family:'Playfair Display',serif;
  font-size:40px;font-weight:700;color:var(--navy-pale);
  line-height:1;margin-bottom:20px;display:flex;align-items:center;
}
.why-card h3{
  font-family:'Playfair Display',serif;
  font-size:18px;font-weight:600;color:var(--navy);margin-bottom:12px;
}
.why-card p{font-size:14px;line-height:1.7;color:var(--text-body);}
.why-cta{text-align:center;display:flex;justify-content:center;}

/* ── Why Accordion ── */
.why-accordion{
  max-width:1200px;margin:0 auto 56px;
  display:flex;gap:12px;
  height:480px;
}

.why-acc-item{
  position:relative;
  flex:0 0 64px;
  border-radius:20px;
  overflow:hidden;
  cursor:pointer;
  transition:flex .7s cubic-bezier(.4,0,.2,1);
}
.why-acc-item.is-active{
  flex:1 1 0%;
}

/* Background image */
.why-acc-img{
  position:absolute;inset:0;
  background-size:cover;
  background-position:center;
  transition:transform .7s cubic-bezier(.4,0,.2,1);
}
.why-acc-item.is-active .why-acc-img{
  transform:scale(1.05);
}

/* Dark overlay */
.why-acc-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(18,47,81,0.75) 0%, rgba(18,47,81,0.15) 50%, transparent 100%);
  transition:background .5s ease;
}
.why-acc-item:not(.is-active) .why-acc-overlay{
  background:rgba(18,47,81,0.55);
}

/* Content: number + title + description — shown on active */
.why-acc-content{
  position:absolute;
  bottom:0;left:0;right:0;
  padding:36px 32px;
  z-index:2;
  opacity:0;
  transform:translateY(16px);
  transition:opacity .5s .15s ease, transform .5s .15s ease;
}
.why-acc-item.is-active .why-acc-content{
  opacity:1;
  transform:translateY(0);
}

.why-acc-num{
  font-family:'Playfair Display',serif;
  font-style:italic;font-weight:700;
  font-size:2.4rem;line-height:1;
  color:rgba(255,255,255,0.35);
  display:block;margin-bottom:8px;
}

.why-acc-title{
  font-family:'Playfair Display',serif;
  font-size:1.35rem;font-weight:600;
  color:#fff;letter-spacing:-0.02em;
  line-height:1.25;margin:0 0 10px;
}

.why-acc-desc{
  font-family:'DM Sans',sans-serif;
  font-size:13.5px;line-height:1.75;
  color:rgba(255,255,255,0.85);
  max-width:420px;
  margin:0;
}

/* Label: vertical text shown on collapsed items */
.why-acc-label{
  position:absolute;
  top:50%;left:50%;
  transform:translate(-50%,-50%) rotate(-90deg);
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.85);
  white-space:nowrap;
  z-index:2;
  transition:opacity .35s ease;
}
.why-acc-item.is-active .why-acc-label{
  opacity:0;
  pointer-events:none;
}

/* ── Tablet ≤ 960px ── */
@media(max-width:960px){
  .why-accordion{height:400px;gap:8px;}
  .why-acc-item{flex:0 0 48px;border-radius:16px;}
  .why-acc-content{padding:28px 24px;}
  .why-acc-title{font-size:1.15rem;}
  .why-acc-desc{font-size:13px;}
}

/* ── Mobile ≤ 680px : vertical stack ── */
@media(max-width:680px){
  #why{padding:64px 20px;}
  .why-accordion{
    flex-direction:column;
    height:auto;
    gap:8px;
  }
  .why-acc-item{
    flex:0 0 56px;
    border-radius:16px;
  }
  .why-acc-item.is-active{
    flex:0 0 280px;
  }
  .why-acc-label{
    bottom:auto;top:50%;left:50%;
    transform:translate(-50%,-50%) rotate(0deg);
  }
  .why-acc-content{padding:24px 20px;}
  .why-acc-num{font-size:1.8rem;}
  .why-acc-title{font-size:1.1rem;}
  .why-acc-desc{font-size:12.5px;}
}

/* ═══════════════════ 10. CASE STUDY ═══════════════════ */
#case{
  padding:100px 80px;
  background:linear-gradient(160deg,#e8f0fd 0%,#f0e8fb 50%,#fde8f2 100%);
}
.case-header{text-align:center;margin-bottom:64px;}
.case-card{
  max-width:1000px;margin:0 auto;
  background:rgba(255,255,255,0.75);backdrop-filter:blur(16px);
  border-radius:28px;overflow:hidden;
  border:1px solid rgba(255,255,255,0.9);
  box-shadow:0 20px 60px rgba(18,47,81,0.1);
}
.case-top{
  background:var(--navy);padding:48px 56px;
  display:grid;grid-template-columns:1fr auto;gap:40px;align-items:center;
}
.case-brand{
  font-family:'Playfair Display',serif;
  font-size:40px;font-weight:700;color:var(--white);
  margin-bottom:8px;
}
.case-region{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:rgba(255,255,255,0.5);margin-bottom:16px;
}
.case-tags{display:flex;flex-wrap:wrap;gap:8px;}
.case-tag{
  font-family:'Questrial',sans-serif;
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  padding:5px 14px;border-radius:100px;
  border:1px solid rgba(18,47,81,0.18);
  color:var(--navy);
  background:rgba(200,218,243,0.28);
}
.case-stats{display:flex;gap:32px;}
.case-stat-item{text-align:right;}
.case-stat-num{
  font-family:'Playfair Display',serif;
  font-size:32px;font-weight:700;color:var(--white);
  line-height:1;
}
.case-stat-label{
  font-family:'Questrial',sans-serif;
  font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.45);margin-top:4px;
}
.case-body{padding:48px 56px;}
.case-body p{font-size:15px;line-height:1.8;color:var(--text-body);margin-bottom:32px;}
.case-link{
  margin-top:8px;
}

/* Case split layout (left text / right image) */
.case-split{
  max-width:1100px;margin:0 auto;
  display:grid;grid-template-columns:1fr 1fr;gap:72px;align-items:center;
}
.case-split-content{ padding-right:8px; }
.case-brand-name{
  font-family:'Playfair Display',serif;
  font-size:40px;font-weight:700;color:var(--navy);
  margin-bottom:8px;line-height:1.1;
}
.case-region-label{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.15em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:16px;
}
.case-split-desc{
  font-family:'DM Sans',sans-serif;
  font-size:15px;line-height:1.85;color:var(--text-body);
  margin-bottom:28px;
}
.case-split-stats{
  display:flex;gap:32px;margin-bottom:28px;
}
.case-split-stats .case-stat-item{ text-align:left; }
.case-split-visual{ position:relative; }
.case-split-img{
  width:100%;
  border-radius:28px;
  object-fit:cover;
  box-shadow:0 12px 40px rgba(18,47,81,0.08);
}
@media(max-width:768px){
  .case-split{grid-template-columns:1fr;gap:20px;}
  /* Image moves to top */
  .case-split-visual{order:-1;}
  .case-split-img{max-height:200px;width:100%;object-fit:cover;border-radius:16px;}
  /* Brand + region inline */
  .case-split-content{display:flex;flex-wrap:wrap;align-items:baseline;gap:0;}
  .case-brand-name{font-size:24px;margin-right:10px;margin-bottom:0;}
  .case-region-label{margin-bottom:12px;}
  .case-tags{width:100%;}
  /* Description compact */
  .case-split-desc{font-size:14px;line-height:1.7;margin-bottom:20px;}
  /* Stats inline row */
  .case-split-stats{
    flex-direction:row;gap:24px;margin-bottom:16px;
    padding:12px 0;border-top:1px solid rgba(18,47,81,0.08);
    width:100%;
  }
  .case-split-stats .case-stat-item{
    display:flex;align-items:baseline;gap:6px;text-align:left;
  }
  .case-split-stats .case-stat-num{font-size:20px;}
  .case-split-stats .case-stat-label{font-size:10px;margin-top:0;}
  .case-split-content .case-link{width:100%;}
}

/* ═══════════════════ 11. VISION + MISSION ═══════════════════ */
#vision{padding:100px 80px;background:var(--navy);}
.vision-inner{max-width:1200px;margin:0 auto;}
.vision-top{
  display:grid;grid-template-columns:1fr 1fr;gap:80px;
  align-items:center;margin-bottom:80px;
}
.vision-text .eyebrow{color:rgba(255,255,255,0.4);}
.vision-text h2{color:var(--white);margin-bottom:24px;}
.vision-text p{font-size:16px;line-height:1.8;color:rgba(255,255,255,0.6);}
.vision-pillars{display:flex;flex-direction:column;gap:24px;}
.pillar{
  background:rgba(255,255,255,0.05);border-radius:16px;padding:28px 32px;
  border:1px solid rgba(255,255,255,0.08);
  transition:background .3s;
}
.pillar:hover{background:rgba(255,255,255,0.08);}
.pillar-title{
  font-family:'Playfair Display',serif;
  font-size:22px;font-weight:600;color:var(--white);margin-bottom:8px;
}
.pillar-sub{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-bottom:12px;
}
.pillar p{font-size:14px;line-height:1.7;color:rgba(255,255,255,0.55);}

.mission-section{border-top:1px solid rgba(255,255,255,0.08);padding-top:64px;}
.mission-eyebrow{
  font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);text-align:center;margin-bottom:48px;
}
.mission-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.mission-card{
  background:rgba(255,255,255,0.04);border-radius:16px;padding:32px 28px;
  border:1px solid rgba(255,255,255,0.06);
  text-align:center;
}
.mission-card h3{
  font-family:'Playfair Display',serif;
  font-size:18px;font-weight:600;color:var(--white);margin-bottom:12px;
}
.mission-card p{font-size:14px;line-height:1.7;color:rgba(255,255,255,0.5);}

/* ═══════════════════ 12. CTA BAND ═══════════════════ */
#cta-band{
  padding:120px 80px;text-align:center;
  background:linear-gradient(135deg,#fde8f0 0%,#e8d8f5 40%,#d8e8f8 100%);
  background-size:200% 200%;
  animation:gradShift 10s ease infinite;
}
#cta-band .eyebrow{margin-bottom:20px;}
#cta-band h2{
  font-family:'Playfair Display',serif;
  font-size:clamp(36px,5vw,60px);font-weight:700;
  color:var(--navy);margin-bottom:20px;line-height:1.15;
}
#cta-band h2 em{font-style:italic;}
#cta-band p{
  font-size:17px;line-height:1.7;color:var(--text-body);
  max-width:520px;margin:0 auto 44px;
}
.cta-actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.cta-actions .btn-primary,
.cta-actions .btn-secondary{min-width:240px;text-align:center;}

/* ═══════════════════ FOOTER ═══════════════════ */
footer{background:var(--navy-dark);padding:64px 80px 40px;}
.footer-inner{max-width:1200px;margin:0 auto;}
.footer-top{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;
  gap:48px;margin-bottom:56px;
}
.footer-brand .nav-logo{display:block;margin-bottom:16px;}
.footer-brand p{font-size:13px;line-height:1.7;color:rgba(255,255,255,0.4);max-width:240px;}
.footer-col h4{
  font-family:'Questrial',sans-serif;
  font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,0.35);margin-bottom:20px;
}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:4px;}
.footer-col ul li a{
  font-size:13px;color:rgba(255,255,255,0.5);
  transition:color .2s;
  display:inline-flex;align-items:center;min-height:44px;
}
.footer-col ul li a:hover{color:var(--white);}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,0.07);padding-top:28px;
  display:flex;justify-content:space-between;align-items:center;
}
.footer-bottom p{font-size:12px;color:rgba(255,255,255,0.25);}

/* ═══════════════════ MODAL ═══════════════════ */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(12,32,64,0.7);backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;padding:24px;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-wrapper{
  position:relative;max-width:520px;width:100%;
  transform:scale(.95);transition:transform .3s;
}
.modal-overlay.open .modal-wrapper{transform:scale(1);}
.modal{
  background:var(--white);border-radius:24px;padding:48px;
  width:100%;
  height:75vh;display:flex;flex-direction:column;
  box-shadow:0 40px 80px rgba(18,47,81,0.2);
  overflow:hidden;
}
.modal-form-body{flex:1;overflow-y:auto;padding-right:4px;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;}
.modal .form-submit{flex-shrink:0;margin-top:16px;}
.modal-close-outer{
  position:absolute;top:-44px;right:0;
  width:36px;height:36px;
  border-radius:50%;border:none;
  background:rgba(255,255,255,0.9);
  cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1;
  font-size:18px;color:var(--navy);transition:background .2s,transform .2s;
  box-shadow:0 4px 16px rgba(0,0,0,0.15);
  z-index:1001;
}
.modal-close-outer:hover{background:var(--white);transform:scale(1.1);}
.modal h3{
  font-family:'Playfair Display',serif;
  font-size:28px;font-weight:600;color:var(--navy);margin-bottom:8px;
}
.modal p{font-size:14px;color:var(--text-body);margin-bottom:28px;line-height:1.6;}
.form-group{margin-bottom:16px;}
.form-group label{
  display:block;font-family:'Questrial',sans-serif;
  font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--text-muted);margin-bottom:6px;
}
.form-group input,.form-group textarea,.form-group select{
  width:100%;padding:12px 16px;border-radius:10px;
  border:1.5px solid rgba(18,47,81,0.12);
  font-family:'DM Sans',sans-serif;font-size:14px;color:var(--navy);
  background:var(--off-white);outline:none;
  transition:border-color .2s;
}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{
  border-color:var(--navy);
}
.form-group textarea{height:100px;resize:vertical;}
.form-submit{
  width:100%;padding:14px;border-radius:100px;border:none;
  display:flex;align-items:center;justify-content:center;line-height:1;
  background:var(--navy);color:var(--white);
  font-family:'Questrial',sans-serif;font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  cursor:pointer;transition:background .25s;margin-top:8px;
}
.form-submit:hover{background:var(--navy-light);}
.form-submit:disabled{opacity:.4;cursor:not-allowed;}
.form-alt-contact{font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--text-muted);line-height:1.7;margin-top:8px;margin-bottom:16px;text-align:left;}
.form-alt-contact a{color:var(--navy);font-weight:500;text-decoration:underline;text-underline-offset:2px;}
.form-alt-contact a:hover{color:var(--navy-light);}
.form-alt-contact-link{color:var(--navy);font-weight:500;text-decoration:underline;text-underline-offset:2px;}
.form-alt-contact-link:hover{color:var(--navy-light);}

/* Contact form extras */
.form-group .req{color:#d44;}
.cf-phone-row{display:grid;grid-template-columns:120px 1fr;gap:8px;}
.form-group input.error,.form-group textarea.error,.form-group select.error{border-color:#d44;}

/* Contact form success */
.cf-success{text-align:center;padding:40px 20px;flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;}
.cf-success-icon{
  width:56px;height:56px;border-radius:50%;
  background:rgba(18,47,81,0.06);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;
}
.cf-success-icon svg{width:28px;height:28px;stroke:var(--navy);fill:none;}
.cf-success h3{
  font-family:'Playfair Display',serif;
  font-size:24px;font-weight:600;color:var(--navy);margin-bottom:8px;
}
.cf-success p{
  font-family:'DM Sans',sans-serif;
  font-size:14px;color:var(--text-body);line-height:1.6;margin-bottom:24px;
}
.cf-success-close{
  font-family:'Questrial',sans-serif;
  font-size:13px;letter-spacing:.1em;text-transform:uppercase;
  background:var(--navy);color:var(--white);
  border:none;border-radius:100px;padding:12px 32px;
  cursor:pointer;transition:background .25s;
}
.cf-success-close:hover{background:var(--navy-light);}

/* ═══════════════════ RESPONSIVE ═══════════════════ */
@media(max-width:1024px){
  section{padding:80px 48px;}
  .services-grid{grid-template-columns:repeat(2,1fr);}
  .elevation-grid{grid-template-columns:repeat(2,1fr);}
  .why-grid{grid-template-columns:repeat(2,1fr);}
  .footer-top{grid-template-columns:1fr 1fr;gap:32px;}
}
@media(max-width:768px){
  nav{padding:0 24px;}
  section{padding:64px 20px;}
  #vision{padding:80px 20px;}
  #cta-band{padding:80px 20px;}
  #elevation{padding:64px 20px;}
  #case{padding:48px 20px;}
  footer{padding:48px 20px 32px;}
  .who-grid{grid-template-columns:1fr;}
  .products-grid{grid-template-columns:1fr;}
  .stats-inner{grid-template-columns:repeat(2,1fr);}
  .vision-top{grid-template-columns:1fr;}
  .mission-grid{grid-template-columns:1fr;}
  .case-top{grid-template-columns:1fr;padding:28px 20px;}
  .case-brand{font-size:28px;}
  .case-stats{justify-content:flex-start;gap:20px;}
  .case-stat-num{font-size:24px;}
  .case-body{padding:28px 20px;}
  .case-split-content{padding-right:0;}
  .case-brand-name{font-size:28px;}
  .case-split-stats{gap:20px;}
  .footer-top{grid-template-columns:1fr;}
  .modal{padding:32px 24px;height:70vh;}
  .modal-close-outer{top:-40px;right:0;width:32px;height:32px;font-size:14px;}
  .cf-phone-row{grid-template-columns:110px 1fr;}
  .hero-ctas{flex-direction:column;align-items:center;}
  .hero-ctas .liquid-glow-btn,
  .hero-ctas .btn-secondary{width:100%;max-width:300px;min-width:0;}
}

/* ═══════════════════ HERO AURORA BLOBS ═══════════════════ */
@keyframes fadeUp {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes blob1 {
  0%   { transform: translate(0px, 0px) scale(1); }
  25%  { transform: translate(180px, -120px) scale(1.25); }
  50%  { transform: translate(-120px, 160px) scale(0.85); }
  75%  { transform: translate(220px, 100px) scale(1.15); }
  100% { transform: translate(0px, 0px) scale(1); }
}
@keyframes blob2 {
  0%   { transform: translate(0px, 0px) scale(1); }
  20%  { transform: translate(-200px, 130px) scale(1.2); }
  45%  { transform: translate(160px, -180px) scale(0.8); }
  70%  { transform: translate(-100px, -120px) scale(1.3); }
  100% { transform: translate(0px, 0px) scale(1); }
}
@keyframes blob3 {
  0%   { transform: translate(0px, 0px) scale(1); }
  30%  { transform: translate(140px, 200px) scale(0.78); }
  60%  { transform: translate(-180px, -100px) scale(1.28); }
  80%  { transform: translate(100px, -160px) scale(0.9); }
  100% { transform: translate(0px, 0px) scale(1); }
}
@keyframes blob4 {
  0%   { transform: translate(0px, 0px) scale(1.1); }
  35%  { transform: translate(-160px, -180px) scale(0.8); }
  65%  { transform: translate(200px, 120px) scale(1.25); }
  100% { transform: translate(0px, 0px) scale(1.1); }
}

.hero-blob {
  position:absolute;
  border-radius:50%;
  filter:blur(70px);
  opacity:0.65;
  will-change:transform;
  pointer-events:none;
}
.hero-blob-1 {
  width:700px;height:700px;
  background:#F5EEFF;
  top:-150px;left:-100px;
  animation:blob1 10s ease-in-out infinite;
}
.hero-blob-2 {
  width:650px;height:650px;
  background:#FDE4F0;
  top:0px;right:-100px;
  animation:blob2 12s ease-in-out infinite;
}
.hero-blob-3 {
  width:580px;height:580px;
  background:#DAEEFF;
  bottom:-80px;left:25%;
  animation:blob3 9s ease-in-out infinite;
}
.hero-blob-4 {
  width:500px;height:500px;
  background:#FCE8F9;
  bottom:60px;right:15%;
  animation:blob4 11s ease-in-out infinite;
}

/* ── Methodology Rotary: Mobile RWD (Version 1 card style) ── */
@media (max-width: 1023px) {
  /* Cancel the 500vh runway — use normal scroll */
  #methodology-runway {
    height: auto !important;
  }
  /* Sticky frame → normal block, vertical layout */
  #methodology-runway > div[style*="position:sticky"] {
    position: relative !important;
    height: auto !important;
    flex-direction: column !important;
    padding: 72px 0 80px !important;
    overflow: visible !important;
  }
  /* Hide rotating dial on mobile */
  .meth-dial-panel {
    display: none !important;
  }
  /* Right panel: full width, vertical flex — Version 1 style */
  #meth-right-panel {
    position: relative !important;
    width: 100% !important;
    height: auto !important;
    display: flex !important;
    flex-direction: column !important;
    gap: 16px !important;
    padding: 0 20px !important;
    overflow: visible !important;
  }
  /* Step cards: Version 1 dark glassmorphism cards, stacked vertically */
  .meth-step-card {
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    height: auto !important;
    flex-shrink: 0 !important;
    opacity: 1 !important;
    transform: none !important;
    pointer-events: auto !important;
    /* Version 1 card style */
    padding: 32px 28px !important;
    background: rgba(255,255,255,0.04) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
    border-radius: 20px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: flex-start !important;
    transition: none !important;
    /* Subtle left accent */
    border-left: 3px solid rgba(96,165,250,0.35) !important;
  }
  /* Step label colour */
  .meth-step-card > div:first-child {
    color: #60a5fa;
    margin-bottom: 10px;
  }
  /* Hide right-edge progress bar */
  #dial-progress-bar { display: none; }
}


/* Hero Style 1 — shimmer on "Beauty & Wellness" */
.hero1-shimmer {
  background: linear-gradient(90deg, #122F51 0%, #6b92b8 40%, #122F51 100%);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: shimmer1 4s linear infinite;
}
@keyframes shimmer1 {
  0%   { background-position: 200% center; }
  100% { background-position: 0% center; }
}

/* ── Liquid Glow Button ─────────────────────────────── */
.liquid-glow-btn {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 16px 40px;
  border-radius: 100px;
  font-family: 'Questrial', sans-serif;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: .1em;
  text-transform: uppercase;
  text-decoration: none;
  color: #ffffff;
  overflow: hidden;
  cursor: pointer;
  isolation: isolate;
  border: none;
  outline: none;
  /* flowing gradient — pink → lavender → periwinkle → pink */
  background: linear-gradient(
    110deg,
    #e878a8,
    #c97dd4,
    #8b8fe8,
    #7baee8,
    #c97dd4,
    #e878a8
  );
  background-size: 300% 100%;
  background-position: 0% 50%;
  animation: lgb-flow 6s ease-in-out infinite;
  box-shadow: 0 8px 30px rgba(180, 100, 180, 0.35);
  transition: transform .25s ease, box-shadow .25s ease;
}
.liquid-glow-btn:hover {
  transform: scale(1.04);
  box-shadow: 0 10px 40px rgba(180, 100, 180, 0.55);
  animation-duration: 2s;
}
/* Shimmer overlay */
.liquid-glow-btn::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(
    105deg,
    transparent 25%,
    rgba(255,255,255,0.18) 50%,
    transparent 75%
  );
  background-size: 200% 100%;
  animation: lgb-shimmer 3s linear infinite;
  pointer-events: none;
}
.liquid-glow-btn:hover::after {
  animation-duration: 1.5s;
}
.liquid-glow-btn__text {
  position: relative;
  z-index: 2;
}
/* hide the blob canvas — no longer needed */
.liquid-glow-btn__canvas { display: none; }

@keyframes lgb-flow {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}
@keyframes lgb-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
/* ── end Liquid Glow Button ────────────────────────── */
