/* ============================================================
   AGING WITH STYLE  ·  Brand-aligned, liquid-glass presentation
   Brand palette
     Trust Blue Dark   #1b487e
     Trust Blue        #265fa1
     Trust Blue Light  #daebf9
     Radiant Gold      #fcd740
     Charcoal          #333333
   Typography
     Headlines: Montserrat (700 / 800)
     Body:      Source Sans Pro (400 / 600)
============================================================ */

:root{
  --blue-dark:#1b487e;
  --blue:#265fa1;
  --blue-light:#daebf9;
  --gold:#fcd740;
  --gold-soft:#ffe98a;
  --lavender:#ebe5ff;
  --lavender-strong:#c9b7ff;
  --lavender-wash:rgba(235,229,255,0.58);
  --charcoal:#333333;
  --ink:#1a2740;
  --paper:#f6f9fd;
  --white:#ffffff;

  --glass-bg: rgba(255,255,255,0.55);
  --glass-bg-strong: rgba(255,255,255,0.72);
  --glass-bg-dark: rgba(27,72,126,0.35);
  --glass-border: rgba(255,255,255,0.55);
  --glass-border-soft: rgba(255,255,255,0.35);
  --glass-shadow: 0 20px 60px rgba(27,72,126,0.18), 0 4px 16px rgba(27,72,126,0.10);
  --glass-shadow-lg: 0 30px 90px rgba(27,72,126,0.28), 0 8px 24px rgba(27,72,126,0.14);

  --radius-sm:14px;
  --radius:22px;
  --radius-lg:32px;

  --container: 1200px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;font-size:100%}
html[data-text-size="compact"]{font-size:94%;--text-scale:.94}
html[data-text-size="large"]{font-size:112.5%;--text-scale:1.12}
body{
  font-family:'Source Sans Pro', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size:calc(17px * var(--text-scale, 1));
  line-height:1.65;
  color:var(--charcoal);
  background:var(--paper);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
img{max-width:100%;display:block}
a{color:var(--blue);text-decoration:none;transition:color .2s ease}
a:hover{color:var(--blue-dark)}

h1,h2,h3,h4,h5{
  font-family:'Montserrat', -apple-system, BlinkMacSystemFont, sans-serif;
  font-weight:800;
  color:var(--ink);
  letter-spacing:-0.01em;
  line-height:1.15;
}
h2{font-size:clamp(1.85rem, 3.4vw, 2.85rem)}
h3{font-size:clamp(1.25rem, 1.8vw, 1.55rem);font-weight:700}
h4{font-size:1.1rem;font-weight:700}
p{font-size:1.05rem;color:#3d4a5e}
strong{color:var(--ink);font-weight:700}

.container{max-width:var(--container);margin:0 auto;padding:0 28px}
section{position:relative;padding:110px 0;overflow:hidden}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue);
  padding:8px 16px;border-radius:999px;
  background:linear-gradient(135deg, rgba(218,235,249,0.72), var(--lavender-wash));
  border:1px solid rgba(38,95,161,0.18);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.eyebrow.dark{color:#fff;background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.25)}
.eyebrow .dot{width:6px;height:6px;border-radius:50%;background:var(--gold)}
.section-head{max-width:880px;margin-bottom:60px}
.section-head h2{margin:18px 0 14px}
.section-head p{font-size:1.18rem;color:#52617a;max-width:720px}

/* ============================================================
   AMBIENT GRADIENT WASH (page-wide soft background)
============================================================ */
body::before{
  content:"";
  position:fixed;inset:0;
  background:
    radial-gradient(1100px 700px at 12% 8%, rgba(218,235,249,0.85), transparent 60%),
    radial-gradient(900px 600px at 92% 20%, rgba(252,215,64,0.16), transparent 65%),
    radial-gradient(820px 560px at 72% 44%, var(--lavender-wash), transparent 64%),
    radial-gradient(1000px 800px at 50% 110%, rgba(38,95,161,0.18), transparent 60%),
    linear-gradient(180deg,#eef5fc 0%, #f8fbff 50%, #eaf2fb 100%);
  z-index:-2;
  pointer-events:none;
}
body::after{
  content:"";
  position:fixed;inset:0;
  background-image:
    radial-gradient(circle at 20% 80%, rgba(255,255,255,0.4) 1px, transparent 1px),
    radial-gradient(circle at 80% 20%, rgba(255,255,255,0.3) 1px, transparent 1px);
  background-size:60px 60px;
  opacity:.4;
  z-index:-1;
  pointer-events:none;
}

/* ============================================================
   GLASS CARD PRIMITIVE
============================================================ */
.glass{
  position:relative;
  background:var(--glass-bg);
  backdrop-filter:blur(22px) saturate(160%);
  -webkit-backdrop-filter:blur(22px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius);
  box-shadow:var(--glass-shadow);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease, border-color .4s ease;
  overflow:hidden;
}
.glass::before{
  content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;
  background:linear-gradient(135deg, rgba(255,255,255,0.6) 0%, rgba(255,255,255,0) 35%, rgba(255,255,255,0) 65%, rgba(255,255,255,0.25) 100%);
  mix-blend-mode:overlay;
}
.glass::after{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.9), transparent);
  pointer-events:none;
}
.glass.lift:hover{
  transform:translateY(-6px);
  box-shadow:var(--glass-shadow-lg);
  border-color:rgba(255,255,255,0.85);
}

/* Lighter card variant, used in dense content areas (challenge cards, What We Do).
   Cleaner white surface, subtle shadow, no heavy blur. Keeps the
   stronger liquid-glass treatment for hero, C-Easy™, trust, and CTA sections. */
.glass.challenge,
.glass.wwd-card{
  background:rgba(255,255,255,0.86);
  backdrop-filter:blur(8px) saturate(120%);
  -webkit-backdrop-filter:blur(8px) saturate(120%);
  border:1px solid rgba(38,95,161,0.10);
  box-shadow:0 4px 18px rgba(27,72,126,0.06), 0 1px 2px rgba(27,72,126,0.04);
}
.glass.challenge::before,
.glass.wwd-card::before,
.glass.challenge::after,
.glass.wwd-card::after{display:none}
.glass.challenge.lift:hover,
.glass.wwd-card.lift:hover{
  background:rgba(255,255,255,0.96);
  border-color:rgba(38,95,161,0.20);
  box-shadow:0 14px 34px rgba(27,72,126,0.10), 0 2px 6px rgba(27,72,126,0.06);
}
/* Featured wide WWD card keeps its gold-warm tint */
.glass.wwd-card.wide{
  background:linear-gradient(135deg, rgba(255,255,255,0.90) 0%, rgba(252,215,64,0.10) 120%);
  border:1px solid rgba(252,215,64,0.40);
}

/* ============================================================
   NAVIGATION
============================================================ */
.nav{
  position:fixed;top:18px;left:50%;transform:translateX(-50%);
  width:min(1180px, calc(100% - 28px));
  z-index:100;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 22px;
  border-radius:999px;
  background:linear-gradient(135deg, rgba(255,255,255,0.76), rgba(235,229,255,0.62));
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,0.7);
  box-shadow:0 8px 32px rgba(27,72,126,0.12), 0 0 0 1px rgba(201,183,255,0.12);
  transition:background .3s ease, box-shadow .3s ease;
}
.nav.scrolled{
  background:linear-gradient(135deg, rgba(255,255,255,0.9), rgba(245,242,255,0.86));
  box-shadow:0 12px 40px rgba(27,72,126,0.18);
}
.nav-brand{display:flex;align-items:center;gap:14px;font-family:'Montserrat',sans-serif;font-weight:800;color:var(--blue-dark);letter-spacing:.01em}
.nav-brand .nav-logo{
  height:38px;width:auto;display:block;
  filter:drop-shadow(0 2px 4px rgba(27,72,126,0.18));
}
.nav-brand-divider{
  width:1px;height:28px;background:rgba(38,95,161,0.22);align-self:center;
}
.nav-brand-text{display:flex;flex-direction:column;line-height:1.05}
.nav-brand-text span{font-family:'Montserrat',sans-serif;font-weight:800;font-size:.95rem;color:var(--blue-dark);letter-spacing:-0.005em}
.nav-brand-text small{font-family:'Source Sans Pro',sans-serif;font-weight:600;font-size:.62rem;color:#5d6c84;letter-spacing:.14em;text-transform:uppercase;margin-top:1px}
.nav-links{display:flex;gap:6px;align-items:center}
.nav-links a{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.86rem;
  color:#33465f;padding:8px 14px;border-radius:999px;transition:all .2s ease;
}
.nav-links a:hover{background:rgba(38,95,161,0.08);color:var(--blue-dark)}
.nav-mobile-cta{display:none}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.92rem;
  padding:13px 24px;border-radius:999px;
  width:280px;max-width:100%;min-height:50px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  color:var(--ink);
  border:1px solid rgba(255,255,255,0.6);
  box-shadow:0 6px 20px rgba(252,215,64,0.45), inset 0 1px 0 rgba(255,255,255,0.8);
  cursor:pointer;
  transition:transform .25s ease, box-shadow .25s ease;
  white-space:nowrap;
  text-align:center;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 12px 28px rgba(252,215,64,0.55), inset 0 1px 0 rgba(255,255,255,0.9);color:var(--ink)}
.btn .arrow{transition:transform .25s ease}
.btn:hover .arrow{transform:translateX(4px)}
.btn.ghost{
  background:rgba(255,255,255,0.6);
  border:1px solid rgba(255,255,255,0.8);
  color:var(--blue-dark);
  box-shadow:0 6px 20px rgba(27,72,126,0.12);
}
.btn.ghost:hover{background:rgba(255,255,255,0.85);color:var(--blue-dark)}
/* C-Easy™ scheduling CTA — always Radiant Gold, never blue */
.btn--ceasy{background:linear-gradient(135deg,#ffe56a 0%,#fdd841 100%);color:var(--ink)}
.btn--ceasy:hover{background:linear-gradient(135deg,#ffe56a 0%,#fdd841 100%);color:var(--ink);box-shadow:0 12px 28px rgba(252,215,64,0.55), inset 0 1px 0 rgba(255,255,255,0.9)}
.btn--compact{padding:10px 18px;font-size:.85rem;width:auto;min-height:0}
.nav-cta{padding:10px 18px;font-size:.85rem;width:auto;min-height:0}
.nav-actions{display:flex;align-items:center;gap:10px}

.text-size-control{
  display:inline-flex;align-items:center;gap:4px;
  padding:4px;border-radius:999px;
  background:rgba(255,255,255,0.78);
  border:1px solid rgba(38,95,161,0.16);
  box-shadow:0 12px 32px rgba(27,72,126,0.16), inset 0 1px 0 rgba(255,255,255,0.72);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
}
.text-size-floating{
  position:fixed;right:22px;bottom:22px;z-index:120;
}
.text-size-label{
  font-family:'Montserrat',sans-serif;font-size:.68rem;font-weight:700;
  color:#55657d;letter-spacing:.10em;text-transform:uppercase;
  padding:0 6px 0 8px;white-space:nowrap;
}
.text-size-btn{
  width:34px;height:34px;border-radius:50%;border:0;
  display:grid;place-items:center;
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;
  color:var(--blue-dark);background:transparent;cursor:pointer;
  transition:background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease;
}
.text-size-btn:hover{background:rgba(38,95,161,0.10);transform:translateY(-1px)}
.text-size-btn.active{
  background:linear-gradient(135deg, var(--lavender), #fff 75%);
  color:var(--blue-dark);
  box-shadow:0 4px 12px rgba(27,72,126,0.12), inset 0 1px 0 rgba(255,255,255,0.85);
}
.text-size-btn:focus-visible,
a:focus-visible,
button:focus-visible{
  outline:3px solid rgba(201,183,255,0.9);
  outline-offset:3px;
}

.nav-toggle{
  display:none;background:rgba(255,255,255,0.7);border:1px solid rgba(255,255,255,0.85);
  cursor:pointer;padding:0;width:42px;height:42px;border-radius:50%;
  align-items:center;justify-content:center;flex-direction:column;gap:5px;
  box-shadow:0 4px 12px rgba(27,72,126,0.12);
  transition:background .2s ease;
}
.nav-toggle:hover{background:rgba(255,255,255,0.95)}
.nav-toggle .bar{
  display:block;width:18px;height:2px;background:var(--blue-dark);border-radius:2px;
  transition:transform .3s ease, opacity .2s ease;
  transform-origin:center;
}
.nav-toggle[aria-expanded="true"] .bar:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] .bar:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] .bar:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ============================================================
   HERO
============================================================ */
.hero{
  min-height:100vh;
  padding:160px 0 120px;
  display:flex;align-items:center;
  position:relative;
  isolation:isolate;
  overflow:hidden;
}
/* IMAGE: cinematic hero photograph, images/presentation-009.png */
.hero-bg{
  position:absolute;inset:0;z-index:-2;
  background:url('images/presentation-009.png') center 30%/cover no-repeat;
  transform:scale(1.04);
  animation:heroDrift 24s ease-in-out infinite alternate;
}
@keyframes heroDrift{
  0%  {transform:scale(1.04) translate(0,0)}
  100%{transform:scale(1.08) translate(-1.2%,-0.8%)}
}
.hero-overlay{
  position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(760px 520px at 72% 22%, rgba(201,183,255,0.20), transparent 62%),
    linear-gradient(102deg,
      rgba(11,30,58,0.86) 0%,
      rgba(15,40,75,0.72) 28%,
      rgba(27,72,126,0.42) 58%,
      rgba(27,72,126,0.18) 78%,
      rgba(252,215,64,0.10) 100%),
    radial-gradient(900px 600px at 88% 78%, rgba(252,215,64,0.22), transparent 60%),
    linear-gradient(180deg, transparent 60%, rgba(11,30,58,0.55) 100%);
}
.hero-container{position:relative;width:100%}
.hero-content{
  max-width:680px;color:#fff;
  position:relative;z-index:1;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--gold);
  padding:8px 18px;border-radius:999px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(252,215,64,0.45);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  margin-bottom:26px;
}
.hero-eyebrow::before{
  content:"";width:6px;height:6px;border-radius:50%;
  background:var(--gold);margin-right:10px;
  box-shadow:0 0 0 4px rgba(252,215,64,0.18);
}
.hero h1{
  font-size:clamp(2.7rem, 6vw, 5rem);
  font-weight:800;color:#fff;
  line-height:1.02;letter-spacing:-0.025em;
  margin:0 0 24px;
  text-shadow:0 4px 30px rgba(0,0,0,0.35);
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-campaign{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:clamp(1.2rem, 2vw, 1.65rem);
  line-height:1.2;letter-spacing:.005em;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  margin:0 0 22px;
}
.hero-sub{
  font-size:clamp(1.1rem, 1.6vw, 1.32rem);
  color:rgba(255,255,255,0.94);max-width:580px;
  margin:0 0 18px;font-weight:500;line-height:1.5;
  text-shadow:0 1px 8px rgba(0,0,0,0.3);
}
.hero-support{
  font-size:1rem;color:rgba(255,255,255,0.82);max-width:580px;
  margin:0 0 38px;line-height:1.65;font-weight:400;
  text-shadow:0 1px 6px rgba(0,0,0,0.25);
}
.hero-support strong{color:var(--gold);font-weight:700}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap}
.hero-actions .btn.ghost{
  background:rgba(255,255,255,0.12);
  border:1px solid rgba(255,255,255,0.45);
  color:#fff;
  backdrop-filter:blur(10px) saturate(140%);
  -webkit-backdrop-filter:blur(10px) saturate(140%);
  box-shadow:0 6px 20px rgba(0,0,0,0.18);
}
.hero-actions .btn.ghost:hover{
  background:rgba(255,255,255,0.22);
  border-color:rgba(255,255,255,0.65);
  color:#fff;
}


/* ============================================================
   SECTION: AUDIENCE-FIT STRIP, slim trust band between hero & shift
============================================================ */
.audience-strip{
  padding:0;
  background:linear-gradient(90deg, rgba(218,235,249,0.55) 0%, rgba(235,229,255,0.46) 48%, rgba(255,250,232,0.6) 100%);
  border-top:1px solid rgba(38,95,161,0.10);
  border-bottom:1px solid rgba(38,95,161,0.10);
  overflow:hidden;
}
.audience-row{
  display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:18px 0;
}
.audience-label{
  flex-shrink:0;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue-dark);
  padding-right:18px;
  border-right:1px solid rgba(38,95,161,0.18);
}
.audience-list{
  list-style:none;display:flex;flex-wrap:wrap;align-items:center;
  gap:10px 22px;margin:0;padding:0;
}
.audience-list li{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.92rem;color:#33445e;font-weight:500;
}
.audience-list .dot{
  width:5px;height:5px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 0 3px rgba(252,215,64,0.18);
  flex-shrink:0;
}

/* ============================================================
   SECTION: THE SHIFT
============================================================ */
.shift{
  background:linear-gradient(180deg, transparent 0%, rgba(235,229,255,0.32) 48%, rgba(218,235,249,0.55) 100%);
}
.shift-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.shift-text h2 .pull{color:var(--blue)}
.shift-text .question{
  display:block;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.4rem;
  color:var(--blue-dark);
  margin:24px 0;padding:20px 24px;border-left:4px solid var(--gold);
  background:rgba(255,255,255,0.55);border-radius:0 14px 14px 0;
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.shift-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:24px}
.shift-tags span{
  padding:8px 16px;border-radius:999px;
  background:rgba(255,255,255,0.7);border:1px solid rgba(38,95,161,0.18);
  font-size:.9rem;font-weight:600;color:var(--blue-dark);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
/* IMAGE: shift section, images/presentation-003.png */
.shift-image{
  position:relative;aspect-ratio:1/1;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--glass-shadow-lg);
  border:1px solid rgba(255,255,255,0.6);
}
.shift-image::before{
  content:"";position:absolute;inset:0;
  background:url('images/presentation-003.png') center/cover no-repeat;
}
.shift-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(252,215,64,0.1) 0%, transparent 50%, rgba(38,95,161,0.2) 100%);
}

/* ============================================================
   SECTION: STATS
============================================================ */
.stats{
  background:
    linear-gradient(135deg, rgba(27,72,126,0.94) 0%, rgba(38,95,161,0.92) 100%);
  color:#fff;
  position:relative;isolation:isolate;
}
/* IMAGE: stats section subtle backdrop, images/presentation-004.png */
.stats::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:url('images/presentation-004.png') center/cover no-repeat;
  opacity:.18;mix-blend-mode:luminosity;
}
.stats::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(800px 500px at 90% 0%, rgba(252,215,64,0.18), transparent 60%);
}
.stats h2{color:#fff}
.stats .section-head p{color:rgba(255,255,255,0.85)}
.stat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.stat{
  padding:42px 32px;text-align:left;
  background:rgba(255,255,255,0.10);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.25);
  position:relative;overflow:hidden;
}
.stat::before{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.6), transparent);
}
.stat .stat-num{
  font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:clamp(3rem, 5.5vw, 4.6rem);
  color:var(--gold);line-height:1;letter-spacing:-0.02em;
  text-shadow:0 4px 24px rgba(252,215,64,0.3);
}
.stat .stat-num .suffix{font-size:.55em;color:#fff;font-weight:700;margin-left:4px}
.stat h3{color:#fff;font-size:1.25rem;margin:14px 0 10px}
.stat p{color:rgba(255,255,255,0.78);font-size:.98rem;margin:0}
.stat .pulse{
  position:absolute;top:24px;right:24px;width:10px;height:10px;border-radius:50%;
  background:var(--gold);box-shadow:0 0 0 0 rgba(252,215,64,0.5);
  animation:pulse 2s infinite;
}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(252,215,64,0.6)}
  70%{box-shadow:0 0 0 14px rgba(252,215,64,0)}
  100%{box-shadow:0 0 0 0 rgba(252,215,64,0)}
}
.stats-source{
  margin:36px 0 0;text-align:center;
  font-size:.78rem;letter-spacing:.04em;
  color:rgba(255,255,255,0.45);
  font-style:italic;
}

/* ============================================================
   SECTION: YESTERDAY'S FAMILY
============================================================ */
.yesterday-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.challenge{
  padding:32px 28px;
  display:flex;flex-direction:column;gap:12px;
  min-height:220px;
}
.challenge .icon{
  width:52px;height:52px;border-radius:14px;
  background:linear-gradient(135deg, rgba(38,95,161,0.18) 0%, rgba(218,235,249,0.6) 100%);
  border:1px solid rgba(38,95,161,0.22);
  display:grid;place-items:center;font-size:1.45rem;
  color:var(--blue-dark);
  margin-bottom:6px;
}
.challenge h3{color:var(--blue-dark);font-size:1.15rem}
.challenge p{font-size:.98rem;color:#4b5970;margin:0}
.yesterday-banner{
  margin-top:34px;padding:30px 36px;
  background:linear-gradient(135deg, rgba(252,215,64,0.12) 0%, rgba(252,215,64,0.04) 100%);
  border:1px solid rgba(252,215,64,0.45);
  border-radius:var(--radius);
  display:flex;gap:24px;align-items:center;flex-wrap:wrap;
}
.yesterday-banner .stripe{width:6px;align-self:stretch;background:var(--gold);border-radius:6px}
.yesterday-banner p{flex:1;min-width:280px;font-size:1.05rem;color:var(--ink);margin:0}

/* ============================================================
   SECTION: OUR ANSWER
============================================================ */
.answer{
  background:linear-gradient(180deg, rgba(218,235,249,0.4) 0%, transparent 100%);
}
.answer-grid{display:grid;grid-template-columns:1fr 1.05fr;gap:50px;align-items:center}
/* IMAGE: answer section, images/presentation-005.png */
.answer-image{
  position:relative;aspect-ratio:5/6;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--glass-shadow-lg);border:1px solid rgba(255,255,255,0.6);
}
.answer-image::before{
  content:"";position:absolute;inset:0;
  background:url('images/presentation-005.png') center/cover no-repeat;
  transition:transform 1.2s ease;
}
.answer-image:hover::before{transform:scale(1.03)}
.answer-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 60%, rgba(27,72,126,0.4) 100%);
}
.answer-text h2{margin-bottom:18px}
.answer-services{margin-top:28px;display:grid;grid-template-columns:1fr 1fr;gap:10px;padding:0}
.answer-services li{
  list-style:none;display:flex;align-items:center;gap:12px;
  padding:14px 16px;border-radius:14px;
  background:rgba(255,255,255,0.55);border:1px solid rgba(255,255,255,0.7);
  font-weight:600;color:var(--blue-dark);font-size:.98rem;
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:transform .25s ease, background .25s ease;
}
.answer-services li:hover{transform:translateX(4px);background:rgba(255,255,255,0.8)}
.answer-services .check{
  flex-shrink:0;width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  display:grid;place-items:center;color:var(--ink);font-weight:800;font-size:.78rem;
  box-shadow:0 4px 10px rgba(252,215,64,0.4);
}

/* Productized variant, numbered "one connected process" */
.answer-services.productized{
  grid-template-columns:1fr;
  gap:12px;
  counter-reset:step;
  position:relative;
}
.answer-services.productized::before{
  content:"";position:absolute;left:23px;top:24px;bottom:24px;width:2px;
  background:linear-gradient(180deg, rgba(38,95,161,0.45) 0%, rgba(252,215,64,0.65) 100%);
  border-radius:2px;opacity:.55;
  z-index:0;
}
.answer-services.productized li{
  position:relative;z-index:1;
  padding:16px 20px;
  background:rgba(255,255,255,0.7);
  border:1px solid rgba(255,255,255,0.85);
  font-size:1.02rem;
}
.answer-services.productized li:hover{
  transform:translateX(6px);
  background:rgba(255,255,255,0.92);
  box-shadow:0 8px 24px rgba(27,72,126,0.12);
}
.answer-services .step-num{
  flex-shrink:0;width:34px;height:34px;border-radius:10px;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:var(--gold);
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:.95rem;
  display:grid;place-items:center;
  box-shadow:0 6px 14px rgba(38,95,161,0.35), inset 0 1px 0 rgba(255,255,255,0.25);
}
.answer-services.productized li:last-child .step-num{
  background:linear-gradient(135deg, var(--gold) 0%, #f5b800 100%);
  color:var(--ink);
  box-shadow:0 6px 14px rgba(252,215,64,0.45), inset 0 1px 0 rgba(255,255,255,0.6);
}
.answer-services .step-label{font-weight:700;color:var(--ink);letter-spacing:-0.005em}

/* ============================================================
   SECTION: FIVE-STEP JOURNEY
============================================================ */
.journey-rail{
  position:relative;display:grid;grid-template-columns:repeat(5,1fr);gap:18px;
}
.journey-rail::before{
  content:"";position:absolute;left:6%;right:6%;top:46px;height:3px;
  background:linear-gradient(90deg, var(--blue-dark) 0%, var(--blue) 50%, var(--gold) 100%);
  border-radius:3px;opacity:.35;z-index:0;
}
.step{
  position:relative;z-index:1;
  padding:28px 22px;text-align:center;
}
.step .num{
  width:64px;height:64px;border-radius:50%;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:#fff;font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.4rem;
  display:grid;place-items:center;margin:0 auto 18px;
  box-shadow:0 10px 24px rgba(38,95,161,0.45), inset 0 1px 0 rgba(255,255,255,0.4);
  position:relative;
}
.step .num::after{
  content:"";position:absolute;inset:-4px;border-radius:50%;
  border:1px solid rgba(38,95,161,0.25);
}
.step:nth-child(5) .num{background:linear-gradient(135deg, var(--gold) 0%, #f5b800 100%);color:var(--ink)}
.step h3{font-size:1.1rem;margin-bottom:8px;color:var(--blue-dark)}
.step p{font-size:.95rem;color:#52617a;margin:0}

/* ============================================================
   SECTION: C-EASY EVALUATION
============================================================ */
.ceasy{
  background:linear-gradient(160deg, rgba(27,72,126,0.96) 0%, rgba(15,40,75,0.98) 76%, rgba(77,69,131,0.96) 100%);
  color:#fff;position:relative;isolation:isolate;
}
/* IMAGE: c-easy section subtle backdrop, images/presentation-008.png */
.ceasy::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:url('images/presentation-008.png') center/cover no-repeat;
  opacity:.16;mix-blend-mode:luminosity;
}
.ceasy h2{color:#fff}
.ceasy .section-head p{color:rgba(255,255,255,0.82)}
.ceasy-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:48px;align-items:start}
.ceasy-meter{
  padding:36px;text-align:center;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(24px) saturate(160%);
  -webkit-backdrop-filter:blur(24px) saturate(160%);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--radius-lg);
  box-shadow:0 30px 80px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.25);
  position:sticky;top:100px;
}
.ceasy-meter .ring{
  position:relative;width:240px;height:240px;margin:8px auto 18px;
}
.ceasy-meter .ring svg{transform:rotate(-90deg);width:100%;height:100%}
.ceasy-meter .ring .track{stroke:rgba(255,255,255,0.12);stroke-width:14;fill:none}
.ceasy-meter .ring .fill{
  stroke:url(#ceasyGrad);stroke-width:14;fill:none;stroke-linecap:round;
  stroke-dasharray:0 1000;
  transition:stroke-dasharray 1.6s cubic-bezier(.2,.7,.2,1);
}
.ceasy-meter .ring-center{
  position:absolute;inset:0;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  padding:38px 42px;
  text-align:center;
}
.ceasy-meter .ring-num{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:4rem;color:var(--gold);line-height:1;
  text-shadow:0 4px 24px rgba(252,215,64,0.4);
}
.ceasy-meter .ring-label{
  font-family:'Montserrat',sans-serif;font-weight:600;font-size:.74rem;
  letter-spacing:.18em;color:rgba(255,255,255,0.7);
  text-transform:uppercase;
  margin-top:10px;
  white-space:nowrap;
}
.ceasy-meter .ring-sub{font-size:1rem;color:rgba(255,255,255,0.85);margin-top:10px}
.ceasy-meter .ceasy-tag{
  display:inline-block;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  padding:6px 14px;border-radius:999px;background:rgba(252,215,64,0.18);color:var(--gold);
  border:1px solid rgba(252,215,64,0.4);
}
.ceasy-meter h3{color:#fff;margin:18px 0 6px;font-size:1.5rem}
.ceasy-meter p{color:rgba(255,255,255,0.78);font-size:.98rem;margin:0}

.ceasy-tabs{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.ceasy-tab{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.88rem;
  padding:11px 20px;border-radius:999px;cursor:pointer;
  background:rgba(255,255,255,0.08);color:rgba(255,255,255,0.78);
  border:1px solid rgba(255,255,255,0.18);
  transition:all .25s ease;
}
.ceasy-tab:hover{background:rgba(255,255,255,0.16);color:#fff}
.ceasy-tab.active{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  color:var(--ink);border-color:transparent;
  box-shadow:0 6px 18px rgba(252,215,64,0.4);
}
.ceasy-panels{position:relative;min-height:340px}
.ceasy-panel{
  display:none;
  padding:30px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:var(--radius);
  animation:fadeUp .5s ease both;
}
.ceasy-panel.active{display:block}
@keyframes fadeUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.ceasy-panel h3{color:#fff;margin-bottom:10px;display:flex;align-items:center;gap:12px}
.ceasy-panel h3 .pip{width:8px;height:8px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 4px rgba(252,215,64,0.2)}
.ceasy-panel-lead{
  color:rgba(255,255,255,0.78);font-size:.98rem;line-height:1.5;
  margin:0 0 18px;padding-bottom:14px;
  border-bottom:1px solid rgba(255,255,255,0.12);
}
.ceasy-panel ul{list-style:none;display:grid;gap:10px;margin-top:6px}
.ceasy-panel li{
  display:flex;gap:14px;align-items:flex-start;
  padding:14px 16px;border-radius:14px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.12);
  color:rgba(255,255,255,0.92);font-size:.98rem;
}
.ceasy-panel li .marker{
  flex-shrink:0;width:28px;height:28px;border-radius:8px;
  background:linear-gradient(135deg, rgba(252,215,64,0.25), rgba(252,215,64,0.08));
  border:1px solid rgba(252,215,64,0.45);
  color:var(--gold);font-family:'Montserrat',sans-serif;font-weight:800;font-size:.78rem;
  display:grid;place-items:center;
}

/* ============================================================
   SECTION: FAMILY SCENARIOS
============================================================ */
.scenarios-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.scenario{
  padding:30px 26px;
  display:flex;flex-direction:column;gap:12px;
  min-height:280px;position:relative;overflow:hidden;
}
.scenario::after{
  content:"";position:absolute;inset:auto -30% -30% auto;width:70%;height:70%;border-radius:50%;
  background:radial-gradient(circle, rgba(252,215,64,0.18), transparent 70%);
  pointer-events:none;
}
.scenario .icon{
  width:56px;height:56px;border-radius:16px;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:var(--gold);display:grid;place-items:center;
  font-size:1.6rem;
  box-shadow:0 8px 20px rgba(38,95,161,0.4), inset 0 1px 0 rgba(255,255,255,0.25);
  margin-bottom:6px;
}
.scenario h3{font-size:1.08rem;color:var(--blue-dark)}
.scenario p{font-size:.96rem;color:#52617a;margin:0}
.scenarios-tagline{
  margin-top:34px;text-align:center;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.25rem;color:var(--blue-dark);
}
.scenarios-tagline .gold{color:#c8a000;background:linear-gradient(135deg, #d9b300, #fcd740);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ============================================================
   SECTION: WHAT WE ACTUALLY DO
============================================================ */
.what-we-do{
  background:linear-gradient(180deg, transparent 0%, rgba(218,235,249,0.4) 100%);
}
.wwd-grid{
  display:grid;grid-template-columns:repeat(3,1fr);gap:22px;
}
.wwd-card{
  padding:32px 28px;
  display:flex;flex-direction:column;gap:14px;
  min-height:240px;
  position:relative;
}
.wwd-card .wwd-icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:var(--gold);
  display:grid;place-items:center;
  box-shadow:0 8px 20px rgba(38,95,161,0.35), inset 0 1px 0 rgba(255,255,255,0.25);
  margin-bottom:4px;
}
.wwd-card .wwd-icon.gold{
  background:linear-gradient(135deg, var(--gold) 0%, #f5b800 100%);
  color:var(--ink);
  box-shadow:0 8px 20px rgba(252,215,64,0.45), inset 0 1px 0 rgba(255,255,255,0.6);
}
.wwd-card h3{font-size:1.18rem;color:var(--blue-dark)}
.wwd-card p{font-size:.98rem;color:#52617a;margin:0}
.wwd-card.wide{
  grid-column:span 2;
  flex-direction:row;align-items:center;gap:24px;
  background:linear-gradient(135deg, rgba(255,255,255,0.75) 0%, rgba(252,215,64,0.10) 120%);
  border:1px solid rgba(252,215,64,0.45);
}
.wwd-card.wide .wwd-icon{flex-shrink:0}
.wwd-card.wide .wwd-wide-body{flex:1}
.wwd-card.wide h3{font-size:1.25rem}

/* ============================================================
   SECTION: CONVERSIONS
============================================================ */
.conversions{
  background:linear-gradient(180deg, transparent 0%, rgba(218,235,249,0.6) 100%);
}
.conv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.conv{
  border-radius:var(--radius-lg);overflow:hidden;
  background:rgba(255,255,255,0.6);
  border:1px solid rgba(255,255,255,0.7);
  box-shadow:var(--glass-shadow);
  transition:transform .4s cubic-bezier(.2,.7,.2,1), box-shadow .4s ease;
  display:flex;flex-direction:column;
}
.conv:hover{transform:translateY(-6px);box-shadow:var(--glass-shadow-lg)}
.conv .img{
  position:relative;aspect-ratio:5/3;overflow:hidden;
}
.conv .img img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 1s ease;
}
.conv:hover .img img{transform:scale(1.06)}
.conv .img::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg, transparent 50%, rgba(27,72,126,0.35) 100%);
}
.conv .badge{
  position:absolute;top:14px;left:14px;z-index:2;
  padding:6px 14px;border-radius:999px;
  background:rgba(255,255,255,0.85);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-dark);
  border:1px solid rgba(255,255,255,0.7);
}
.conv .body{
  padding:26px 28px 24px;
  display:flex;flex-direction:column;flex:1;
}
.conv h3{
  font-size:1.22rem;color:var(--blue-dark);margin-bottom:6px;
  letter-spacing:-0.005em;
}
.conv p{font-size:.96rem;color:#52617a;margin:0}
.conv .conv-lead{
  font-size:.98rem;color:#3d4a5e;line-height:1.5;
  margin-bottom:18px;
}

/* Spec sheet, "Best for" / "Typical scope" rows.
   Single grid on the <dl> so dt labels align in one column across all rows. */
.conv-specs{
  margin:0 0 20px;
  border-top:1px solid rgba(38,95,161,0.16);
  display:grid;
  grid-template-columns:auto 1fr;
  column-gap:14px;
  flex:1;align-content:start;
}
.conv-specs > div{display:contents}
.conv-specs dt,
.conv-specs dd{
  padding:13px 0;
  border-bottom:1px solid rgba(38,95,161,0.10);
  align-self:start;
}
.conv-specs > div:last-child dt,
.conv-specs > div:last-child dd{border-bottom:none}
.conv-specs dt{
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--blue);
  padding-top:15px;
  white-space:nowrap;
}
.conv-specs dt::before{
  content:"";display:inline-block;width:6px;height:6px;border-radius:50%;
  background:var(--gold);margin-right:8px;vertical-align:middle;
  box-shadow:0 0 0 3px rgba(252,215,64,0.18);
}
.conv-specs dd{
  margin:0;font-size:.92rem;color:#3d4a5e;line-height:1.5;
}

/* Card CTA, bottom-aligned arrow */
.conv .conv-cta{
  display:inline-flex;align-items:center;gap:8px;
  margin-top:auto;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.85rem;
  letter-spacing:.04em;
  color:var(--blue-dark);
  padding-top:14px;border-top:1px solid rgba(38,95,161,0.10);
  transition:color .25s ease, gap .25s ease;
}
.conv .conv-cta .arrow{
  display:inline-flex;align-items:center;justify-content:center;
  width:24px;height:24px;border-radius:50%;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  color:var(--ink);font-size:.85rem;
  box-shadow:0 4px 10px rgba(252,215,64,0.4);
  transition:transform .25s ease;
}
.conv:hover .conv-cta{color:var(--blue);gap:12px}
.conv:hover .conv-cta .arrow{transform:translateX(3px)}

/* Featured (full-width hero) conversion card, Bathroom */
.conv.conv-feature{
  grid-column:1 / -1;
  flex-direction:row;
  background:linear-gradient(135deg, rgba(255,255,255,0.78) 0%, rgba(218,235,249,0.55) 60%, rgba(252,215,64,0.10) 120%);
  border:1px solid rgba(252,215,64,0.4);
  box-shadow:0 24px 70px rgba(27,72,126,0.2), inset 0 1px 0 rgba(255,255,255,0.6);
}
.conv.conv-feature .img{
  flex:0 0 48%;
  aspect-ratio:auto;
  min-height:380px;
}
.conv.conv-feature .img img{
  width:100%;height:100%;object-fit:cover;
}
.conv.conv-feature .badge.featured{
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  color:var(--ink);
  border:1px solid rgba(255,255,255,0.7);
  box-shadow:0 6px 16px rgba(252,215,64,0.45);
  letter-spacing:.10em;
}
.conv.conv-feature .body{
  padding:38px 42px;
  flex:1;
  display:flex;flex-direction:column;justify-content:center;
}
.conv-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.74rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--blue);margin-bottom:8px;
}
.conv-eyebrow::before{
  content:"";width:24px;height:2px;background:var(--gold);border-radius:2px;
}
.conv.conv-feature h3{
  font-size:clamp(1.6rem, 2.4vw, 2.05rem);
  margin-bottom:10px;
}
.conv.conv-feature .conv-lead{
  font-size:1.08rem;line-height:1.55;color:#3d4a5e;margin-bottom:22px;max-width:560px;
}
.conv.conv-feature .conv-specs{margin-bottom:22px}
.conv.conv-feature .conv-specs > div{padding:14px 0}
.conv.conv-feature .conv-specs dd{font-size:.96rem}
.conv.conv-feature .conv-cta{
  align-self:flex-start;
  padding:12px 22px;border:1px solid rgba(38,95,161,0.25);border-top:1px solid rgba(38,95,161,0.25);
  border-radius:999px;
  background:rgba(255,255,255,0.6);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.conv.conv-feature:hover .conv-cta{
  background:rgba(255,255,255,0.85);
}

@media (max-width: 1024px){
  .conv.conv-feature{flex-direction:column;grid-column:1 / -1}
  .conv.conv-feature .img{flex:none;min-height:240px;aspect-ratio:5/3}
  .conv.conv-feature .body{padding:28px}
}
@media (max-width: 640px){
  /* Tighten the featured Bathroom card on small screens so it doesn't tower */
  .conv.conv-feature .img{min-height:200px;aspect-ratio:16/10}
  .conv.conv-feature .body{padding:22px}
  .conv.conv-feature h3{font-size:1.45rem}
  .conv.conv-feature .conv-lead{font-size:.98rem;margin-bottom:16px}
  .conv.conv-feature .conv-cta{padding:10px 18px}
}

/* ============================================================
   SECTION: TRUST / EXECUTION
============================================================ */
.trust{
  background:linear-gradient(135deg, rgba(27,72,126,0.96) 0%, rgba(38,95,161,0.92) 78%, rgba(77,69,131,0.90) 100%);
  color:#fff;position:relative;isolation:isolate;
}
/* IMAGE: trust section subtle backdrop, images/presentation-014.png */
.trust::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:url('images/presentation-014.png') center/cover no-repeat;
  opacity:.14;mix-blend-mode:luminosity;
}
.trust h2{color:#fff}
.trust .section-head p{color:rgba(255,255,255,0.85)}
.trust-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:42px}
.trust-card{
  padding:32px 28px;
  background:rgba(255,255,255,0.10);
  backdrop-filter:blur(20px) saturate(160%);
  -webkit-backdrop-filter:blur(20px) saturate(160%);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--radius-lg);
  box-shadow:0 20px 60px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.25);
}
.trust-card .icon{
  width:54px;height:54px;border-radius:14px;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  color:var(--ink);display:grid;place-items:center;font-size:1.4rem;font-weight:800;
  margin-bottom:14px;
  box-shadow:0 8px 20px rgba(252,215,64,0.4);
}
.trust-card h3{color:#fff;font-size:1.2rem;margin-bottom:8px}
.trust-card p{color:rgba(255,255,255,0.82);font-size:.98rem;margin:0}

.capabilities{
  padding:36px;
  background:rgba(255,255,255,0.08);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.2);
  border-radius:var(--radius-lg);
}
.capabilities h3{color:#fff;margin-bottom:18px;font-size:1.3rem}
.capabilities-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.capabilities-list li{
  list-style:none;padding:13px 16px;
  background:rgba(255,255,255,0.06);border:1px solid rgba(255,255,255,0.14);border-radius:12px;
  color:rgba(255,255,255,0.92);font-size:.94rem;font-weight:500;
  transition:all .25s ease;
}
.capabilities-list li:hover{background:rgba(255,255,255,0.14);transform:translateX(3px)}

/* ============================================================
   SECTION: Gift Of Love™  (shimmering gold highlight CTA)
============================================================ */
.gift-cta{
  position:relative;
  padding:90px 0;
  isolation:isolate;
  overflow:hidden;
  border-top:1px solid rgba(245,184,0,0.45);
  border-bottom:1px solid rgba(245,184,0,0.45);
}
/* Animated gold shimmer background */
.gift-shimmer{
  position:absolute;inset:0;z-index:-2;
  background:
    linear-gradient(120deg,
      #f5b800 0%,
      #fcd740 20%,
      #ffe98a 40%,
      #fcd740 60%,
      #f5b800 80%,
      #fcd740 100%);
  background-size:280% 100%;
  animation:goldShimmer 9s ease-in-out infinite alternate;
}
@keyframes goldShimmer{
  0%   {background-position:0% 50%}
  100% {background-position:100% 50%}
}
/* Diagonal light sweep across the section */
.gift-shine{
  position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:linear-gradient(115deg,
    transparent 30%,
    rgba(255,255,255,0.55) 48%,
    rgba(255,255,255,0.85) 50%,
    rgba(255,255,255,0.55) 52%,
    transparent 70%);
  background-size:220% 100%;
  background-position:-110% 0;
  animation:goldSweep 7s linear infinite;
  mix-blend-mode:overlay;
}
@keyframes goldSweep{
  0%   {background-position:-110% 0}
  100% {background-position:210% 0}
}
.gift-cta::after{
  content:"";position:absolute;inset:0;z-index:-1;pointer-events:none;
  background:
    radial-gradient(700px 400px at 15% 20%, rgba(255,255,255,0.45), transparent 60%),
    radial-gradient(600px 380px at 85% 80%, rgba(245,184,0,0.45), transparent 65%);
}

.gift-grid{
  display:grid;
  grid-template-columns:1fr 1.05fr;
  gap:60px;
  align-items:center;
}
.gift-image{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  box-shadow:
    0 30px 80px rgba(27,72,126,0.30),
    0 12px 28px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,255,255,0.45);
  border:1px solid rgba(255,255,255,0.65);
  transform:rotate(-2deg);
  transition:transform .55s cubic-bezier(.2,.7,.2,1);
}
.gift-image:hover{transform:rotate(0deg) scale(1.02)}
.gift-image img{display:block;width:100%;height:auto}

.gift-content{color:var(--ink)}
.gift-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Montserrat',sans-serif;font-weight:700;
  font-size:.78rem;letter-spacing:.20em;text-transform:uppercase;
  padding:8px 16px;border-radius:999px;
  color:var(--blue-dark);
  background:rgba(255,255,255,0.55);
  border:1px solid rgba(27,72,126,0.20);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  margin-bottom:20px;
}
.gift-eyebrow .gift-dot{
  width:8px;height:8px;border-radius:50%;background:var(--blue-dark);
  box-shadow:0 0 0 3px rgba(27,72,126,0.18);
}
.gift-content h2{
  font-size:clamp(2.05rem, 3.6vw, 2.9rem);
  color:var(--blue-dark);
  line-height:1.08;letter-spacing:-0.015em;
  margin:0 0 16px;
  text-shadow:0 1px 0 rgba(255,255,255,0.5);
}
.gift-content p{
  font-size:1.1rem;color:#2a3a55;
  max-width:540px;line-height:1.6;
  margin:0 0 30px;
  text-shadow:0 1px 0 rgba(255,255,255,0.35);
}
.gift-cta .btn.gift-btn{
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:var(--gold);
  border:1px solid rgba(255,255,255,0.35);
  box-shadow:0 10px 28px rgba(15,40,75,0.45), inset 0 1px 0 rgba(255,255,255,0.18);
}
.gift-cta .btn.gift-btn:hover{
  background:linear-gradient(135deg, var(--blue-dark) 0%, var(--ink) 100%);
  color:var(--gold);
}

@media (max-width: 1024px){
  .gift-grid{grid-template-columns:1fr;gap:40px}
  .gift-image{transform:rotate(0deg);max-width:520px;margin:0 auto}
}
@media (max-width: 640px){
  .gift-cta{padding:70px 0}
  .gift-content h2{font-size:1.85rem}
  .gift-content p{font-size:1rem}
}

/* Reduced motion: kill the shimmer + sweep animations */
@media (prefers-reduced-motion: reduce){
  .gift-shimmer,
  .gift-shine{animation:none}
}

/* ============================================================
   SECTION: LEGACY
============================================================ */
.legacy-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
/* IMAGE: legacy section, images/presentation-015.png */
.legacy-image{
  position:relative;aspect-ratio:4/5;border-radius:var(--radius-lg);overflow:hidden;
  box-shadow:var(--glass-shadow-lg);border:1px solid rgba(255,255,255,0.6);
}
.legacy-image::before{
  content:"";position:absolute;inset:0;
  background:url('images/presentation-015.png') center/cover no-repeat;
}
.legacy-image::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(135deg, rgba(252,215,64,0.12), transparent 50%, rgba(27,72,126,0.3) 100%);
}
.legacy-pillars{display:grid;gap:18px;margin-top:28px}
.pillar{
  display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;
  padding:22px 24px;
  background:rgba(255,255,255,0.55);
  border:1px solid rgba(255,255,255,0.7);border-radius:var(--radius);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.pillar .num{
  width:46px;height:46px;border-radius:14px;
  background:linear-gradient(135deg, var(--blue) 0%, var(--blue-dark) 100%);
  color:var(--gold);display:grid;place-items:center;
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:1.1rem;
}
.pillar h3{font-size:1.08rem;color:var(--blue-dark);margin-bottom:4px}
.pillar p{font-size:.96rem;color:#52617a;margin:0}

/* ============================================================
   SECTION: HOW FAMILIES START + CTA
============================================================ */
.start{
  background:linear-gradient(180deg, rgba(218,235,249,0.55) 0%, transparent 100%);
}
.start-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-bottom:48px}
.cta-trust{
  max-width:820px;margin:0 auto 28px;text-align:center;
  font-size:1rem;line-height:1.6;color:#52617a;
  padding:18px 28px;border-radius:18px;
  background:rgba(255,255,255,0.5);
  border:1px solid rgba(38,95,161,0.12);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
}
.start-step{
  padding:32px 28px;text-align:left;position:relative;
}
.start-step .num{
  font-family:'Montserrat',sans-serif;font-weight:800;font-size:3rem;
  background:linear-gradient(135deg, var(--blue-dark) 0%, var(--gold) 120%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  line-height:1;margin-bottom:12px;
}
.start-step h3{color:var(--blue-dark);font-size:1.18rem;margin-bottom:8px}
.start-step p{font-size:.98rem;color:#52617a;margin:0}

.cta-box{
  position:relative;
  padding:54px 50px;
  border-radius:var(--radius-lg);
  background:linear-gradient(135deg, var(--blue-dark) 0%, var(--blue) 100%);
  color:#fff;
  box-shadow:0 30px 80px rgba(27,72,126,0.32);
  overflow:hidden;
  isolation:isolate;
}
.cta-box::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(700px 400px at 100% 0%, rgba(252,215,64,0.22), transparent 60%),
             radial-gradient(560px 320px at 72% 100%, rgba(201,183,255,0.24), transparent 62%),
             radial-gradient(500px 300px at 0% 100%, rgba(218,235,249,0.18), transparent 60%);
}
.cta-box::after{
  content:"";position:absolute;left:0;right:0;top:0;height:1px;
  background:linear-gradient(90deg, transparent, rgba(255,255,255,0.5), transparent);
}
.cta-grid{display:grid;grid-template-columns:1.4fr 1fr;gap:40px;align-items:center}
.cta-box h2{color:#fff;font-size:clamp(1.7rem, 3vw, 2.4rem);margin-bottom:14px}
.cta-box p{color:rgba(255,255,255,0.9);font-size:1.1rem;max-width:540px}
.cta-box .cta-lead{margin-bottom:16px}
.cta-box .cta-reassure{
  display:inline-flex;align-items:center;gap:10px;
  font-size:.95rem;letter-spacing:.02em;color:rgba(255,255,255,0.9);
  padding:10px 16px;border-radius:999px;margin-bottom:6px;
  background:rgba(252,215,64,0.10);
  border:1px solid rgba(252,215,64,0.35);
  max-width:none;width:auto;
}
.cta-box .cta-reassure strong{color:var(--gold);font-weight:700}
.cta-tag{
  display:inline-block;padding:6px 14px;border-radius:999px;
  background:rgba(252,215,64,0.18);color:var(--gold);
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  border:1px solid rgba(252,215,64,0.4);margin-bottom:16px;
}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:24px}
.cta-actions .btn.ghost{background:rgba(255,255,255,0.12);border-color:rgba(255,255,255,0.3);color:#fff}
.cta-actions .btn.ghost:hover{background:rgba(255,255,255,0.22);color:#fff}
.cta-contact{
  padding:28px;
  background:rgba(255,255,255,0.10);
  border:1px solid rgba(255,255,255,0.22);
  border-radius:var(--radius);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
}
.cta-contact h4{color:#fff;font-family:'Montserrat',sans-serif;font-weight:700;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:14px}
.cta-contact-row{
  display:flex;align-items:center;gap:12px;
  padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.12);
}
.cta-contact-row:last-child{border-bottom:none}
.cta-contact-row .ico{
  width:36px;height:36px;border-radius:10px;
  background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.2);
  display:grid;place-items:center;color:var(--gold);
}
.cta-contact-row .label{font-size:.78rem;color:rgba(255,255,255,0.6);text-transform:uppercase;letter-spacing:.12em}
.cta-contact-row .val{
  color:#fff;font-weight:600;font-size:1rem;
  overflow-wrap:anywhere;word-break:break-word;min-width:0;
}
.cta-contact-row > div:not(.ico){min-width:0;flex:1}
.cta-contact-row a{color:#fff}
.cta-contact-row a:hover{color:var(--gold)}

/* ============================================================
   SECTION: CLOSING PROMISE
============================================================ */
.closing{
  background:
    linear-gradient(180deg, rgba(27,72,126,0.94) 0%, rgba(15,40,75,0.97) 100%);
  color:#fff;text-align:center;position:relative;isolation:isolate;
  padding:120px 0 100px;
}
/* IMAGE: closing section, images/presentation-020.png */
.closing::before{
  content:"";position:absolute;inset:0;z-index:-1;
  background:url('images/presentation-020.png') center/cover no-repeat;
  opacity:.22;mix-blend-mode:luminosity;
}
.closing::after{
  content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(800px 500px at 50% 100%, rgba(252,215,64,0.18), transparent 60%);
}
.closing h2{color:#fff;font-size:clamp(2rem, 4vw, 3rem);max-width:880px;margin:0 auto 22px}
.closing > .container > p{color:rgba(255,255,255,0.85);font-size:1.2rem;max-width:680px;margin:0 auto 38px}
.promise{
  display:inline-flex;align-items:center;gap:14px;flex-wrap:wrap;
  padding:24px 36px;border-radius:999px;
  background:rgba(255,255,255,0.10);
  backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(252,215,64,0.45);
  box-shadow:0 20px 60px rgba(0,0,0,0.25), inset 0 1px 0 rgba(255,255,255,0.2);
}
.promise span{
  font-family:'Montserrat',sans-serif;font-weight:700;font-size:1.05rem;color:var(--gold);
  letter-spacing:.04em;
}
.promise .sep{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.4)}
.closing-tagline{
  margin-top:48px;font-family:'Montserrat',sans-serif;font-weight:800;
  font-size:clamp(1.2rem,2.2vw,1.7rem);
  letter-spacing:.04em;
  background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}

/* ============================================================
   FOOTER
============================================================ */
.footer{
  padding:42px 0 50px;
  background:#0e2746;color:rgba(255,255,255,0.7);
}
.footer-row{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px}
.footer-brand{display:flex;align-items:center;gap:16px;color:#fff;font-family:'Montserrat',sans-serif;font-weight:700}
.footer-brand .footer-logo{
  height:46px;width:auto;display:block;
}
.footer-brand-divider{
  width:1px;height:36px;background:rgba(255,255,255,0.18);align-self:center;
}
.footer-meta{font-size:.9rem;color:rgba(255,255,255,0.55)}
/* ® always inherits the surrounding company-name color */
.reg{color:inherit;font-size:.7em;vertical-align:super;line-height:0;margin-left:1px}

/* ============================================================
   SCROLL REVEAL
============================================================ */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .8s ease, transform .8s ease}
.reveal.in{opacity:1;transform:translateY(0)}
.reveal.delay-1{transition-delay:.08s}
.reveal.delay-2{transition-delay:.16s}
.reveal.delay-3{transition-delay:.24s}
.reveal.delay-4{transition-delay:.32s}
.reveal.delay-5{transition-delay:.40s}
.reveal.delay-6{transition-delay:.48s}

/* ============================================================
   RESPONSIVE
============================================================ */
@media (max-width: 1024px){
  .shift-grid, .answer-grid, .ceasy-grid, .legacy-grid, .cta-grid{grid-template-columns:1fr;gap:36px}
  .ceasy-meter{position:static}
  .yesterday-grid, .conv-grid, .trust-cards, .start-steps, .scenarios-grid, .wwd-grid{grid-template-columns:repeat(2,1fr)}
  .wwd-card.wide{grid-column:span 2;flex-direction:column;align-items:flex-start}
  .stat-grid{grid-template-columns:1fr;gap:18px}
  .journey-rail{grid-template-columns:repeat(2,1fr)}
  .journey-rail::before{display:none}
  .capabilities-list, .answer-services{grid-template-columns:1fr}

  /* Mobile menu, collapses links into an animated dropdown */
  .nav-toggle{display:flex}
  .nav-cta{display:none}
  .nav-links{
    position:absolute;top:calc(100% + 12px);left:0;right:0;
    flex-direction:column;align-items:stretch;gap:4px;
    padding:14px;border-radius:22px;
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(22px) saturate(180%);
    -webkit-backdrop-filter:blur(22px) saturate(180%);
    border:1px solid rgba(255,255,255,0.7);
    box-shadow:0 20px 60px rgba(27,72,126,0.22);
    opacity:0;visibility:hidden;transform:translateY(-8px);
    transition:opacity .28s ease, transform .28s ease, visibility .28s;
    pointer-events:none;
  }
  .nav.open .nav-links{
    opacity:1;visibility:visible;transform:translateY(0);
    pointer-events:auto;
  }
  .nav-links a{
    padding:14px 18px;font-size:.98rem;border-radius:14px;
    color:var(--blue-dark);background:rgba(218,235,249,0.4);
    border:1px solid rgba(38,95,161,0.10);
  }
  .nav-links a:hover{background:rgba(218,235,249,0.8)}
  .nav-links .nav-mobile-cta{
    display:block;margin-top:6px;
    background:linear-gradient(135deg, var(--gold) 0%, var(--gold-soft) 100%);
    color:var(--ink);border:1px solid rgba(255,255,255,0.6);
    text-align:center;font-weight:700;
    box-shadow:0 6px 16px rgba(252,215,64,0.4);
  }
}
@media (max-width: 768px){
  .hero-actions,
  .cta-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn,
  .cta-actions .btn,
  .gift-actions .btn{width:100%;max-width:100%}
}
@media (max-width: 640px){
  section{padding:80px 0}
  .container{padding:0 20px}
  .hero{padding:130px 0 70px;min-height:auto}
  /* Shift the photo so the couple stays in frame on narrow viewports */
  .hero-bg{background-position:62% 30%}
  .hero-eyebrow{font-size:.7rem;padding:6px 14px;margin-bottom:18px}
  .hero-actions,
  .cta-actions{flex-direction:column;align-items:stretch}
  .hero-actions .btn,
  .cta-actions .btn,
  .gift-actions .btn{width:100%;max-width:100%}
  .yesterday-grid, .conv-grid, .trust-cards, .start-steps, .scenarios-grid, .journey-rail, .wwd-grid{grid-template-columns:1fr}
  .wwd-card.wide{grid-column:span 1}
  .nav{padding:10px 12px;width:calc(100% - 20px);top:12px}
  .text-size-floating{right:14px;bottom:14px}
  .text-size-control{padding:3px;gap:2px}
  .text-size-label{display:none}
  .text-size-btn{width:31px;height:31px;font-size:.72rem}
  .nav-brand-text{display:none}
  .cta-box{padding:32px 22px;border-radius:24px}
  .cta-box h2{font-size:1.55rem;line-height:1.15}
  .cta-tag{font-size:.7rem;letter-spacing:.14em}
  .cta-box .cta-reassure{
    display:flex;width:100%;max-width:100%;
    font-size:.88rem;padding:10px 14px;
    text-align:center;justify-content:center;
    flex-wrap:wrap;
  }
  .cta-contact{padding:20px;border-radius:18px}
  .cta-contact-row{gap:10px}
  .cta-contact-row .ico{width:32px;height:32px;flex-shrink:0}
  .cta-contact-row .val{font-size:.92rem}
  .ceasy-tab{font-size:.82rem;padding:9px 16px}
  /* Audience strip, label stacks above list, divider becomes bottom border */
  .audience-row{flex-direction:column;align-items:flex-start;gap:10px;padding:16px 0}
  .audience-label{
    padding:0 0 8px;border-right:none;
    border-bottom:1px solid rgba(38,95,161,0.18);
    align-self:stretch;
  }
  .audience-list{gap:8px 18px}
  .audience-list li{font-size:.88rem}
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
/* Externalized page assets and accessibility controls */
