/* ============================================================
   Moneywise Financial Solutions — Stylesheet
   ============================================================ */

:root {
  --grey-field:  #A3A4AD;
  --ivory:       #FAF5F2;
  --paper:       #F7F5F5;
  --blue-deep:   #034291;
  --blue-mid:    #395DA0;
  --gold:        #B89968;
  --ink:         #0E1726;
  --ink-soft:    #2A3447;
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html {
  background: #000;
  color: var(--ink);
  -webkit-text-size-adjust: 100%;
  /* Suppress iOS Safari horizontal rubber-band that exposes black page edges
     when the user swipes left/right. Vertical bounce stays on. */
  overscroll-behavior-x: none;
}
/* Smooth scroll on desktop only. On iOS Safari, smooth-scroll amplifies any
   accidental scroll re-anchor (address bar collapse, fixed-element mutation)
   into a visible "snap to top" animation. Instant jump is the iOS native default. */
@media (min-width: 951px) {
  html { scroll-behavior: smooth; }
}

/* Sections get extra top margin when scrolled to via anchor, so the sticky nav
   doesn't crop the heading. Nav is ~64px so we use 80px for breathing room. */
section[id] {
  scroll-margin-top: 80px;
}

body {
  overflow-x: clip;
  overscroll-behavior-x: none;
  background: #000;
  color: var(--ink);
  font-family: 'Inter', system-ui, -apple-system, sans-serif;
  font-feature-settings: "ss01", "cv11";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, picture { display: block; max-width: 100%; }
picture { display: contents; }
a { color: inherit; text-decoration: none; }
a[aria-disabled="true"] {
  cursor: not-allowed;
  pointer-events: none;
  opacity: 0.6;
}

/* Skip iOS 300ms tap-delay on all interactive controls — eliminates the
   noticeable lag on first tap of buttons/links on iPhone. */
button,
a,
summary,
input,
select,
textarea,
[role="button"] {
  touch-action: manipulation;
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  width: 100%;
  min-height: 100svh;
  background: #000;
  overflow: hidden;
  isolation: isolate;
}

.hero-name {
  position: absolute;
  top: clamp(40px, 7vh, 100px);
  left: 50%;
  z-index: 4;
  pointer-events: none;
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  color: var(--blue-deep);
  line-height: 0.82;
  letter-spacing: -0.015em;
  white-space: nowrap;
  font-size: clamp(110px, 19vw, 280px);
  transform: translateX(-50%);
  opacity: 0;
  animation: nameIn 4s cubic-bezier(.22,1,.36,1) 0.6s forwards;
  text-shadow: 0 2px 30px rgba(3, 66, 145, 0.25);
}
.hero-name .dot {
  color: var(--gold);
  display: inline-block;
  transform: translateY(-0.04em);
}

.hero-lastname {
  position: absolute;
  top: calc(clamp(40px, 7vh, 100px) + clamp(160px, 22vw, 340px));
  left: 50%;
  z-index: 2;
  pointer-events: none;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-style: italic;
  color: var(--blue-deep);
  line-height: 0.82;
  letter-spacing: -0.02em;
  white-space: nowrap;
  font-size: clamp(48px, 8vw, 120px);
  opacity: 0;
  transform: translateX(-50%);
  animation: lastnameIn 3.2s cubic-bezier(.22,1,.36,1) 3.2s forwards;
  text-shadow: 0 2px 20px rgba(3, 66, 145, 0.2);
}
.hero-lastname .dot {
  color: var(--gold);
  display: inline-block;
  transform: translateY(-0.04em);
}
/* Desktop: drop Bonham 40px lower so it lines up with Termaya's shoulder
   instead of her ear/cheek. Placed AFTER the base .hero-lastname rule so it
   wins the cascade at equal specificity. Mobile has its own top override
   inside @media (max-width: 950px) that's unaffected. */
@media (min-width: 951px) {
  .hero-lastname {
    top: calc(clamp(40px, 7vh, 100px) + clamp(160px, 22vw, 340px) + 60px);
  }
}
/* Wide desktop (≥1650px) — Bonham drops another 20px (total +80px from base)
   to stay aligned with Termaya's shoulder at large viewports where the
   clamp() values cap out. Also swaps to lastnameInWide keyframe so the
   starting position shifts 25px right. */
@media (min-width: 1650px) {
  .hero-lastname {
    top: calc(clamp(40px, 7vh, 100px) + clamp(160px, 22vw, 340px) + 80px);
    animation-name: lastnameInWide;
  }
}
/* Ultra-wide desktop (≥1800px) — drop another 20px (total +100px from base). */
@media (min-width: 1800px) {
  .hero-lastname {
    top: calc(clamp(40px, 7vh, 100px) + clamp(160px, 22vw, 340px) + 100px);
  }
}

.hero-portrait {
  position: absolute;
  inset: 0;
  z-index: 1;
  background-image: url('hero-pic-1920.webp');
  background-size: cover;
  background-position: center top;
  background-repeat: no-repeat;
}
@media (max-width: 750px) {
  .hero-portrait {
    background-image: url('hero-pic-640.webp');
  }
}
@media (min-width: 751px) and (max-width: 1400px) {
  .hero-portrait {
    background-image: url('hero-pic-1200.webp');
  }
}
.hero-portrait img { display: none; }

.hero-cutout {
  position: absolute;
  inset: 0;
  z-index: 5;
  opacity: 1;
  pointer-events: none;
}
.hero-cutout img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

.hero-tag {
  position: absolute;
  left: clamp(22px, 4vw, 64px);
  bottom: clamp(110px, 14vh, 160px);
  z-index: 5;
  max-width: clamp(280px, 34vw, 460px);
  opacity: 0;
  animation: fadeUp 1s ease-out 1.1s forwards;
}
.hero-tag .eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--ivory);
  font-weight: 500;
  margin-bottom: 18px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.hero-tag .eyebrow::before {
  content: "";
  width: 28px;
  height: 1px;
  background: var(--gold);
  display: inline-block;
}
.hero-tag h2 {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(28px, 3.2vw, 44px);
  line-height: 1.1;
  color: var(--ivory);
  letter-spacing: -0.01em;
}
.hero-tag h2 em {
  font-style: italic;
  font-weight: 400;
  color: #E8B860;
}

.hero-cta-wrap {
  position: absolute;
  right: clamp(22px, 4vw, 64px);
  bottom: clamp(110px, 14vh, 160px);
  z-index: 5;
  opacity: 0;
  animation: fadeUp 1s ease-out 1.3s forwards;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 14px;
}
/* ============================================================
   SHARED BUTTON PATTERN — skew-wipe hover
   Applied to .hero-cta, .meet-cta, .tool-cta, .book-submit
   ============================================================ */
.hero-cta,
.meet-cta,
.tool-cta,
.book-submit {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding: 16px 32px;
  background: var(--blue-deep);
  color: var(--ivory);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  border-radius: 999px;
  border: none;
  cursor: pointer;
  overflow: hidden;
  outline: none;
  transition: color 0.4s ease;
  will-change: transform;
}
.hero-cta::before,
.meet-cta::before,
.tool-cta::before,
.book-submit::before {
  content: "";
  position: absolute;
  top: 0;
  left: -10%;
  width: 120%;
  height: 100%;
  background: var(--ink);
  transform: translate3d(-110%, 0, 0) skew(-20deg);
  transition: transform 0.5s cubic-bezier(.3, 1, .8, 1);
  z-index: 0;
}
@media (hover: hover) and (pointer: fine) {
  .hero-cta:hover::before,
  .meet-cta:hover::before,
  .tool-cta:hover::before,
  .book-submit:hover::before {
    transform: translate3d(0, 0, 0) skew(-20deg);
  }
}
/* Touch users don't get :hover, so :active provides the press-state feedback
   (mirrors the hover skew-wipe). Fires on tap-and-hold for ~150ms which is
   enough to perceive. */
.hero-cta:active::before,
.meet-cta:active::before,
.tool-cta:active::before,
.book-submit:active::before {
  transform: translate3d(0, 0, 0) skew(-20deg);
}
.hero-cta > *,
.meet-cta > *,
.tool-cta > *,
.book-submit > * {
  position: relative;
  z-index: 1;
}
.hero-cta:disabled,
.meet-cta:disabled,
.tool-cta:disabled,
.book-submit:disabled {
  opacity: 0.6;
  cursor: wait;
}

/* Hero CTA size override (it's larger than the others) */
.hero-cta {
  font-size: 13px;
  letter-spacing: 0.22em;
  font-weight: 500;
  padding: 16px 32px;
}
.hero-cta .arrow {
  width: 18px;
  height: 1px;
  background: var(--ivory);
  position: relative;
}
.hero-cta .arrow::after {
  content: "";
  position: absolute;
  right: -1px; top: -4px;
  width: 9px; height: 9px;
  border-top: 1px solid var(--ivory);
  border-right: 1px solid var(--ivory);
  transform: rotate(45deg);
}
.hero-cta-sub {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--ivory);
  opacity: 0.7;
  font-weight: 500;
}


/* ============================================================
   STICKY NAV
   ============================================================ */
.site-nav {
  position: sticky;
  top: 0;
  margin-top: -64px;
  z-index: 50;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0 clamp(22px, 4vw, 56px);
  min-height: 64px;
  font-family: 'Inter', sans-serif;
  background: var(--blue-deep);
  color: var(--ivory);
  width: 100%;
  box-sizing: border-box;
  transform: translateY(100%);
  animation: navUp 0.9s cubic-bezier(.16,.84,.3,1) 1.5s forwards;
  will-change: transform;
}
body.scrolled-past-hero .site-nav {
  transform: translateY(0);
  animation: none;
}
.site-nav .mono {
  font-family: 'Fraunces', serif;
  font-weight: 600;
  font-size: clamp(18px, 1.6vw, 22px);
  letter-spacing: 0.04em;
  font-variation-settings: "opsz" 144;
  text-transform: uppercase;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  color: var(--ivory);
  transition: opacity 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .site-nav .mono:hover { opacity: 0.85; }
}
.site-nav .nav-dot { color: var(--gold); }
.site-nav .nav-logo {
  height: 44px;
  width: auto;
  display: block;
  background: var(--ivory);
  border-radius: 50%;
  padding: 4px;
}
.site-nav .meta {
  display: flex;
  gap: clamp(18px, 2.4vw, 36px);
  text-transform: uppercase;
  font-size: 11px;
  letter-spacing: 0.28em;
  font-weight: 500;
  align-items: center;
}
.site-nav .meta a {
  opacity: 0.78;
  transition: opacity 0.3s ease, background 0.3s ease, color 0.3s ease;
  cursor: pointer;
  position: relative;
}
@media (hover: hover) and (pointer: fine) {
  .site-nav .meta a:hover { opacity: 1; }
}

/* "Book" pill — distinguishes it as the conversion link */
.site-nav .meta a.meta-cta {
  opacity: 1;
  padding: 8px 18px;
  border: 1px solid rgba(250, 245, 242, 0.4);
  border-radius: 999px;
  letter-spacing: 0.24em;
}
@media (hover: hover) and (pointer: fine) {
  .site-nav .meta a.meta-cta:hover {
    background: var(--ivory);
    color: var(--blue-deep);
    border-color: var(--ivory);
  }
}

/* ============================================================
   MOBILE NAV — Serrina pattern (hamburger left, brand centered,
   full-screen overlay on open)
   Hidden by default; activated only inside the mobile media query.
   ============================================================ */
.nav-toggle {
  display: none;
  position: relative;
  width: 44px;
  height: 44px;
  padding: 0;
  background: transparent;
  border: none;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  z-index: 101;
}
/* The 3 bars: position each absolutely centered so they can rotate around the same origin */
.nav-toggle-bar {
  display: block;
  position: absolute;
  width: 22px;
  height: 1.5px;
  background: var(--ivory);
  border-radius: 2px;
  left: 50%;
  top: 50%;
  margin-left: -11px;
  margin-top: -0.75px;
  transition: transform 0.45s cubic-bezier(.6,.05,.3,1.05),
              opacity 0.25s ease,
              background 0.35s ease;
  /* will-change removed (P2 #17): only animates on transient menu toggle,
     not worth a permanent GPU layer. */
}
.nav-toggle-bar:nth-child(1) { transform: translateY(-7px); }
.nav-toggle-bar:nth-child(3) { transform: translateY(7px); }

/* Hamburger → X when overlay open. Bars also flip to ink color since the overlay is ivory. */
body.nav-open .nav-toggle-bar { background: var(--ink); }
body.nav-open .nav-toggle-bar:nth-child(1) { transform: translateY(0) rotate(45deg); }
body.nav-open .nav-toggle-bar:nth-child(2) { opacity: 0; transform: scaleX(0); }
body.nav-open .nav-toggle-bar:nth-child(3) { transform: translateY(0) rotate(-45deg); }

/* Full-screen overlay — soft fade, content elements stagger-fade-up inside */
.nav-overlay {
  position: fixed;
  inset: 0;
  z-index: 100;
  background: var(--ivory);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: clamp(80px, 12vh, 140px) clamp(24px, 6vw, 60px) clamp(80px, 10vh, 120px);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.55s cubic-bezier(.22,1,.36,1),
              visibility 0.55s linear;
  pointer-events: none;
}
body.nav-open .nav-overlay {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}

/* Overlay's own brand element hidden — the site-nav brand stays visible on top
   (turns ink color when overlay opens) and serves as the title in the cream surface. */
.nav-overlay-brand {
  display: none;
}

.nav-overlay-menu {
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2.6vh, 28px);
  text-align: center;
}
.nav-overlay-menu a {
  display: block;
  overflow: hidden;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(34px, 7vw, 48px);
  line-height: 1;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: uppercase;
  transition: color 0.3s ease;
}
.nav-overlay-menu a span {
  display: inline-block;
  opacity: 0;
  transform: translateY(120%);
  transition: opacity 0.5s ease, transform 0.7s cubic-bezier(.22,1,.36,1);
}
body.nav-open .nav-overlay-menu a span {
  opacity: 1;
  transform: translateY(0);
}
/* Staggered delays for each link */
body.nav-open .nav-overlay-menu a:nth-child(1) span { transition-delay: 0.18s; }
body.nav-open .nav-overlay-menu a:nth-child(2) span { transition-delay: 0.24s; }
body.nav-open .nav-overlay-menu a:nth-child(3) span { transition-delay: 0.30s; }
body.nav-open .nav-overlay-menu a:nth-child(4) span { transition-delay: 0.36s; }
body.nav-open .nav-overlay-menu a:nth-child(5) span { transition-delay: 0.42s; }

.nav-overlay-menu a:active { color: var(--blue-deep); }

.nav-overlay-social {
  position: absolute;
  bottom: clamp(40px, 6vh, 64px);
  left: 50%;
  transform: translate(-50%, 12px);
  display: flex;
  gap: 22px;
  opacity: 0;
  transition: opacity 0.5s ease 0.5s, transform 0.6s cubic-bezier(.22,1,.36,1) 0.5s;
}
body.nav-open .nav-overlay-social {
  opacity: 1;
  transform: translate(-50%, 0);
}
.nav-overlay-social a {
  width: 44px;
  height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
  border-radius: 50%;
  border: 1px solid rgba(14, 23, 38, 0.2);
}

/* ============================================================
   REVEAL SECTION (pinned tagline + scroll-in photos)
   ============================================================ */
.reveal-section {
  position: relative;
  background: var(--ivory);
  min-height: 100svh;
}

.reveal-pin {
  position: relative;
  height: 100svh;
  width: 100%;
}

.reveal-tagline {
  position: absolute;
  top: 150px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  max-width: 1200px;
  width: 100%;
  padding: 0 clamp(24px, 6vw, 80px);
  text-align: center;
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(28px, 4.4vw, 68px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--ink);
  text-transform: uppercase;
  will-change: filter; /* P2 #17 verdict: KEPT — filter scrubs on both desktop AND mobile branches in scripts.js (lines 178-183 & 223-228) */
}
.reveal-tagline em {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: var(--blue-deep);
}

.reveal-photos {
  position: absolute;
  inset: 0;
  z-index: 10;
  pointer-events: none;
  isolation: isolate;
}

.reveal-photo {
  position: absolute;
  opacity: 0;
  will-change: transform, opacity;
  box-shadow: 0 30px 80px -20px rgba(14, 23, 38, 0.25);
}
.reveal-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.reveal-photo.center {
  top: 50%;
  left: 50%;
  width: clamp(280px, 30vw, 480px);
  height: clamp(380px, 42vw, 660px);
  margin-left: calc(clamp(280px, 30vw, 480px) / -2);
  margin-top: calc(clamp(380px, 42vw, 660px) / -2);
}

.reveal-photo.left {
  top: 40%;
  left: 28%;
  width: clamp(180px, 18vw, 280px);
  height: clamp(240px, 24vw, 380px);
}

.reveal-photo.right {
  top: 48%;
  right: 28%;
  width: clamp(160px, 18vw, 280px);
  height: clamp(160px, 18vw, 280px);
  box-shadow: none;
  filter: drop-shadow(0 20px 40px rgba(184, 153, 104, 0.35));
}

/* ============================================================
   3-STEP PROCESS
   ============================================================ */
.process-section {
  position: relative;
  background: var(--ivory);
  padding: clamp(80px, 12vh, 160px) clamp(24px, 6vw, 80px) clamp(100px, 14vh, 200px);
}
.process-intro {
  max-width: 1100px;
  margin: 0 auto clamp(60px, 9vh, 100px);
  text-align: center;
  padding: 0 clamp(20px, 3vw, 56px);
}
.process-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 24px;
}
.process-eyebrow::before,
.process-eyebrow::after {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--gold);
}
.process-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(34px, 4.4vw, 60px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.process-heading em {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: var(--blue-deep);
}
.process-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 640px;
  margin: 0 auto;
}
.process-grid {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
}
.process-step {
  padding: 0 clamp(20px, 3vw, 56px);
  border-right: 1px solid rgba(3, 66, 145, 0.18);
}
.process-step:last-child { border-right: none; }
.process-step .num {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(72px, 9vw, 140px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--blue-deep);
  margin-bottom: clamp(20px, 3vh, 40px);
}
.process-step .num .dot { color: var(--gold); }
.process-step h3 {
  font-family: 'Fraunces', serif;
  font-variation-settings: "opsz" 144;
  font-size: clamp(16px, 1.3vw, 20px);
  font-weight: 500;
  letter-spacing: -0.005em;
  color: var(--ink);
  margin-bottom: 22px;
}
.process-step p {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.6;
  color: var(--ink-soft);
}

/* ============================================================
   MARQUEE STRIP
   ============================================================ */
.marquee {
  position: relative;
  width: 100%;
  padding: 22px 0;
  background: var(--ivory);
  color: var(--blue-deep);
  border-top: 1px solid rgba(3, 66, 145, 0.12);
  border-bottom: 1px solid rgba(3, 66, 145, 0.12);
  font-family: 'Inter', sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  font-weight: 500;
  overflow: hidden;
}
.marquee .strip-track {
  display: flex;
  gap: 56px;
  animation: stripScroll 42s linear infinite;
  white-space: nowrap;
  width: max-content;
}
.marquee .strip-track span {
  display: inline-flex;
  align-items: center;
  gap: 56px;
}
.marquee .strip-track span::after {
  content: "✦";
  color: var(--gold);
  font-size: 11px;
}

/* ============================================================
   COACHING SECTION (dark, Polaroid frames + 3-tier copy)
   ============================================================ */
.coaching-section {
  position: relative;
  min-height: 100svh;
  padding: clamp(80px, 12vh, 140px) 0;
  background-image: linear-gradient(180deg, rgba(14,23,38,0.5) 0%, rgba(14,23,38,0.65) 100%), url('section-bg.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  color: var(--ivory);
  overflow: hidden;
}
.coaching-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 80px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 120px);
  align-items: center;
}

.coaching-photos {
  position: relative;
  width: min(560px, 100%);
  height: clamp(520px, 70vh, 760px);
  margin: 0 auto;
}
.polaroid {
  position: absolute;
  background: #fff;
  padding: 14px 14px 56px;
  box-shadow: 0 30px 70px -20px rgba(0,0,0,0.5);
  border-radius: 2px;
}
.polaroid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.polaroid-back {
  top: 0;
  left: 4%;
  width: 50%;
  height: 65%;
  transform: rotate(-6deg);
  z-index: 1;
}
.polaroid-front {
  top: 22%;
  right: 4%;
  width: 60%;
  height: 75%;
  transform: rotate(3deg);
  z-index: 2;
}

.coaching-accent {
  position: absolute;
  bottom: -40px;
  left: 20px;
  width: clamp(140px, 18vw, 220px);
  height: auto;
  z-index: 3;
  pointer-events: none;
  filter: drop-shadow(0 30px 50px rgba(0, 0, 0, 0.45));
  transform: rotate(-8deg);
}
.coaching-accent img {
  width: 100%;
  height: auto;
  display: block;
}

.coaching-copy {
  display: flex;
  flex-direction: column;
}
.coaching-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--gold);
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.coaching-eyebrow::before {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--gold);
}
.coaching-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(32px, 4vw, 56px);
  line-height: 1.08;
  letter-spacing: -0.015em;
  color: var(--ivory);
  text-transform: uppercase;
  margin-bottom: clamp(40px, 6vh, 72px);
}
.coaching-heading em {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: #E8B860;
}

.coaching-tier {
  padding: clamp(28px, 4vh, 40px) 0;
  border-top: 1px solid rgba(250, 245, 242, 0.18);
}
.coaching-tier:last-child {
  border-bottom: 1px solid rgba(250, 245, 242, 0.18);
}
.coaching-tier h3 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(22px, 2.4vw, 34px);
  line-height: 1.1;
  letter-spacing: -0.01em;
  color: var(--ivory);
  text-transform: uppercase;
  margin-bottom: 14px;
  display: inline-block;
  transform-origin: left center;
  transition: transform 0.4s cubic-bezier(.22,1,.36,1), color 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .coaching-tier h3:hover {
    transform: scale(1.06);
    color: #E8B860;
  }
}
.coaching-tier p {
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.15vw, 17px);
  line-height: 1.55;
  color: rgba(250, 245, 242, 0.78);
  font-weight: 400;
  max-width: 520px;
}

/* ============================================================
   MEET YOUR COACH (split section)
   ============================================================ */
.meet-section {
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 90svh;
  background: var(--ivory);
}
.meet-copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(80px, 12vh, 140px) clamp(40px, 7vw, 120px);
  max-width: 700px;
  margin-left: auto;
}
.meet-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  margin-bottom: clamp(24px, 4vh, 40px);
  font-weight: 600;
}
.meet-name {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(40px, 5.4vw, 84px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: clamp(28px, 4vh, 44px);
}
.meet-body {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.15vw, 19px);
  line-height: 1.6;
  color: var(--ink-soft);
  font-weight: 400;
  margin-bottom: 18px;
  max-width: 540px;
}
.meet-body em {
  font-style: italic;
  color: var(--blue-deep);
  font-weight: 500;
}
.meet-cta {
  margin-top: clamp(28px, 4vh, 44px);
  align-self: flex-start;
}
.meet-cta .arrow {
  width: 16px;
  height: 1px;
  background: var(--ivory);
  position: relative;
}
.meet-cta .arrow::after {
  content: "";
  position: absolute;
  right: -1px; top: -4px;
  width: 9px; height: 9px;
  border-top: 1px solid var(--ivory);
  border-right: 1px solid var(--ivory);
  transform: rotate(45deg);
}

.meet-photo {
  position: relative;
  width: 100%;
  min-height: 90svh;
  background-image: url('meet-bg.webp');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  overflow: hidden;
}
.meet-photo .polaroid-overlay {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-3deg);
  width: clamp(280px, 32vw, 420px);
  height: clamp(420px, 50vw, 640px);
  background: #fff;
  padding: 14px 14px 56px;
  box-shadow: 0 30px 60px -15px rgba(0,0,0,0.4);
  border-radius: 2px;
  transition: transform 0.6s cubic-bezier(.16,.84,.3,1), box-shadow 0.6s ease;
  cursor: pointer;
  /* will-change removed (P2 #17): only animates on :hover, mobile users
     never see it — no GPU layer needed. */
}
@media (hover: hover) and (pointer: fine) {
  .meet-photo .polaroid-overlay:hover {
    transform: translate(-50%, -52%) rotate(0deg) scale(1.04);
    box-shadow: 0 50px 80px -15px rgba(0,0,0,0.55);
  }
}
.meet-photo .polaroid-overlay:active {
  transform: translate(-50%, -52%) rotate(0deg) scale(1.02);
}
.meet-photo .polaroid-overlay img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
  background: #fff;
}

/* ============================================================
   DIFFERENTIATORS
   ============================================================ */
.differ-section {
  position: relative;
  background: linear-gradient(135deg, #E6EBF5 0%, #DDE6F0 50%, #CCD9E8 100%);
  padding: clamp(80px, 12vh, 140px) 0;
  overflow: hidden;
}
.differ-inner {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 80px);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: center;
}
.differ-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(40px, 5vw, 76px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--blue-deep);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.differ-heading em {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: var(--blue-deep);
}
.differ-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 540px;
  margin-bottom: clamp(40px, 6vh, 64px);
}
.differ-list {
  display: flex;
  flex-direction: column;
}
.differ-item {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: clamp(20px, 2.5vw, 36px);
  align-items: center;
  padding: clamp(20px, 3vh, 28px) 0;
  border-top: 1px solid rgba(3, 66, 145, 0.18);
  transition: padding-left 0.4s cubic-bezier(.16,.84,.3,1);
}
@media (hover: hover) and (pointer: fine) {
  .differ-item:hover { padding-left: 12px; }
}
.differ-item:last-child { border-bottom: 1px solid rgba(3, 66, 145, 0.18); }
.differ-num {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(22px, 2.4vw, 30px);
  color: var(--blue-deep);
  letter-spacing: -0.01em;
}
.differ-num em {
  font-style: italic;
  color: var(--gold);
  font-weight: 400;
}
.differ-body h3 {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(20px, 2vw, 28px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.differ-body p {
  font-family: 'Fraunces', serif;
  font-size: clamp(14px, 1.05vw, 16px);
  line-height: 1.5;
  color: var(--ink-soft);
  max-width: 460px;
}
.differ-arrow {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 1px solid rgba(3, 66, 145, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.4s ease, border-color 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .differ-item:hover .differ-arrow {
    background: var(--blue-deep);
    border-color: var(--blue-deep);
  }
}
.differ-arrow::after {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 1.5px solid var(--blue-deep);
  border-right: 1.5px solid var(--blue-deep);
  transform: rotate(45deg);
  transition: border-color 0.4s ease;
}
@media (hover: hover) and (pointer: fine) {
  .differ-item:hover .differ-arrow::after {
    border-color: var(--ivory);
  }
}
.differ-item:active { padding-left: 12px; }
.differ-item:active .differ-arrow { background: var(--blue-deep); border-color: var(--blue-deep); }
.differ-item:active .differ-arrow::after { border-color: var(--ivory); }

.differ-phone {
  position: relative;
  width: clamp(260px, 30vw, 380px);
  aspect-ratio: 3 / 4;
  margin: 0 auto;
  background: #fff;
  padding: 14px 14px 56px;
  box-shadow: 0 30px 70px -20px rgba(3, 66, 145, 0.3);
  border-radius: 2px;
  will-change: transform;
}
.differ-phone img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}

/* ============================================================
   TOOLS WE RECOMMEND (two stacked offer panels)
   ============================================================ */
.tools-section {
  position: relative;
  background: var(--blue-deep);
  padding: clamp(80px, 12vh, 140px) clamp(20px, 4vw, 60px);
}
.tools-intro {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 clamp(24px, 5vw, 80px) clamp(48px, 8vh, 88px);
  text-align: center;
}
.tools-intro .tools-eyebrow { color: var(--ivory); }
.tools-intro .tools-heading { color: var(--ivory); }
.tools-intro .tools-sub { color: rgba(250, 245, 242, 0.78); }
.tools-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  font-weight: 600;
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.tools-eyebrow::before,
.tools-eyebrow::after {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--gold);
}
.tools-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(34px, 4.4vw, 60px);
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--blue-deep);
  text-transform: uppercase;
  margin-bottom: 20px;
}
.tools-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 680px;
  margin: 0 auto;
}

/* ----- Each offer card ----- */
.tool-card {
  position: relative;
  max-width: 1400px;
  margin: 0 auto clamp(32px, 5vh, 56px);
  padding: clamp(48px, 7vh, 90px) clamp(40px, 5vw, 80px);
  border-radius: 4px;
  box-shadow: 0 30px 70px -25px rgba(0, 0, 0, 0.35);
}
.tool-card:last-of-type {
  margin-bottom: 0;
}
.tool-card--blue {
  background: linear-gradient(135deg, #E6EBF5 0%, #DDE6F0 50%, #CCD9E8 100%);
}
.tool-card--ivory {
  background: var(--ivory);
}
.tool-card-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(48px, 6vw, 90px);
  align-items: start;
}
.tool-card--reversed .tool-card-inner {
  /* same source order; image lives on the right naturally because it's the
     second child in the reversed card. Grid does the rest. */
}

/* ----- Image side (lifestyle scene with logo badge) ----- */
.tool-image {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: clamp(40px, 6vh, 80px);
}
.tool-scene {
  position: relative;
  width: 100%;
  max-width: 580px;
  aspect-ratio: 4 / 3;
  border-radius: 8px;
  overflow: hidden;
  box-shadow: 0 30px 70px -20px rgba(3, 66, 145, 0.3);
  margin: 0;
}
.tool-scene > img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.tool-scene-badge {
  position: absolute;
  bottom: 22px;
  left: 22px;
  padding: 12px 20px;
  background: #fff;
  border-radius: 6px;
  box-shadow: 0 12px 30px -10px rgba(14, 23, 38, 0.35);
  display: flex;
  align-items: center;
  justify-content: center;
}
.tool-scene-badge img {
  height: clamp(24px, 2.4vw, 30px);
  width: auto;
  display: block;
  image-rendering: -webkit-optimize-contrast;
}

/* ----- Copy side ----- */
.tool-copy {
  display: flex;
  flex-direction: column;
}
.tool-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  font-weight: 600;
  margin-bottom: 24px;
}
.tool-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(28px, 3.4vw, 44px);
  line-height: 1.1;
  letter-spacing: -0.015em;
  color: var(--ink);
  text-transform: uppercase;
  margin-bottom: 22px;
}
.tool-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-soft);
  margin-bottom: clamp(32px, 5vh, 48px);
}

/* ----- Accordion ----- */
.tool-accordion {
  border-top: 1px solid rgba(14, 23, 38, 0.15);
  margin-bottom: clamp(32px, 5vh, 48px);
}
.tool-row {
  border-bottom: 1px solid rgba(14, 23, 38, 0.15);
}
.tool-row summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: clamp(18px, 2.6vh, 26px) 0;
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(16px, 1.3vw, 20px);
  letter-spacing: 0.01em;
  color: var(--ink);
  text-transform: uppercase;
  cursor: pointer;
  user-select: none;
  transition: color 0.3s ease;
}
.tool-row summary::-webkit-details-marker { display: none; }
@media (hover: hover) and (pointer: fine) {
  .tool-row summary:hover { color: var(--blue-deep); }
}
.tool-plus {
  font-family: 'Inter', sans-serif;
  font-size: 20px;
  font-weight: 300;
  color: var(--blue-deep);
  transition: transform 0.4s cubic-bezier(.16,.84,.3,1);
  line-height: 1;
}
.tool-row[open] .tool-plus {
  transform: rotate(45deg);
}
.tool-row-body {
  padding: 0 0 clamp(22px, 3.2vh, 30px);
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 580px;
}

/* ----- Tool CTA arrow (extends shared button pattern) ----- */
.tool-cta {
  align-self: flex-start;
}
.tool-cta .arrow {
  width: 16px;
  height: 1px;
  background: var(--ivory);
  position: relative;
}
.tool-cta .arrow::after {
  content: "";
  position: absolute;
  right: -1px; top: -4px;
  width: 9px; height: 9px;
  border-top: 1px solid var(--ivory);
  border-right: 1px solid var(--ivory);
  transform: rotate(45deg);
}

/* ============================================================
   FAQ
   ============================================================ */
.faq-section {
  position: relative;
  background: var(--ivory);
  padding: clamp(80px, 12vh, 140px) clamp(24px, 5vw, 80px) clamp(80px, 12vh, 140px);
}
.faq-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(48px, 7vw, 96px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ink);
  text-align: center;
  text-transform: uppercase;
  margin-bottom: clamp(60px, 9vh, 100px);
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 0;
}
.faq-heading .faq-q {
  letter-spacing: -0.02em;
}
.faq-heading .faq-a {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: var(--blue-deep);
  letter-spacing: -0.005em;
  padding-left: 0.05em;
}

.faq-grid {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(40px, 6vw, 90px);
}
.faq-column {
  display: flex;
  flex-direction: column;
}

.faq-row {
  border-top: 1px solid rgba(14, 23, 38, 0.18);
}
.faq-column .faq-row:last-child {
  border-bottom: 1px solid rgba(14, 23, 38, 0.18);
}
.faq-row summary {
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding: clamp(22px, 3vh, 30px) 8px;
  font-family: 'Inter', sans-serif;
  font-weight: 500;
  font-size: clamp(13px, 1vw, 15px);
  letter-spacing: 0.22em;
  color: var(--ink);
  text-transform: uppercase;
  cursor: pointer;
  user-select: none;
  transition: color 0.3s ease;
}
.faq-row summary::-webkit-details-marker { display: none; }
@media (hover: hover) and (pointer: fine) {
  .faq-row summary:hover { color: var(--blue-deep); }
}
.faq-chev {
  width: 12px;
  height: 12px;
  border-right: 1.5px solid var(--ink);
  border-bottom: 1.5px solid var(--ink);
  transform: rotate(45deg);
  flex-shrink: 0;
  transition: transform 0.4s cubic-bezier(.16,.84,.3,1), border-color 0.3s ease;
  margin-bottom: 6px;
}
.faq-row[open] .faq-chev {
  transform: rotate(-135deg);
  margin-bottom: 0;
  margin-top: 6px;
  border-color: var(--blue-deep);
}
.faq-row-body {
  padding: 0 8px clamp(22px, 3vh, 30px);
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 540px;
}

/* ----- Dark marquee variant that sits below the FAQ ----- */
.marquee-dark {
  background: var(--ink);
  color: var(--ivory);
  border-top: none;
  border-bottom: none;
  font-size: 13px;
  letter-spacing: 0.3em;
  padding: 26px 0;
}
.marquee-dark .strip-track span {
  gap: 64px;
}
.marquee-dark .strip-track span::after {
  content: "\\";
  color: var(--gold);
  font-size: 14px;
  font-weight: 300;
}

/* ============================================================
   BOOKING SECTION
   ============================================================ */
.marquee-link {
  display: block;
  text-decoration: none;
  cursor: pointer;
}
.marquee-link.marquee-dark,
.marquee-link.marquee-dark span {
  color: var(--ivory);
}
@media (hover: hover) and (pointer: fine) {
  .marquee-link:hover .strip-track { animation-play-state: paused; }
}
.marquee-link:active .strip-track {
  animation-play-state: paused;
}

.book-section {
  position: relative;
  background: var(--ivory);
  padding: clamp(80px, 13vh, 160px) clamp(24px, 5vw, 80px);
}
.book-inner {
  max-width: 1300px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(48px, 7vw, 110px);
  align-items: start;
}

/* ----- Left side ----- */
.book-copy { display: flex; flex-direction: column; }
.book-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  font-weight: 600;
  margin-bottom: 24px;
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.book-eyebrow::before {
  content: "";
  width: 32px;
  height: 1px;
  background: var(--gold);
}
.book-heading {
  font-family: 'Fraunces', serif;
  font-weight: 400;
  font-variation-settings: "opsz" 144;
  font-size: clamp(40px, 5.4vw, 80px);
  line-height: 1.02;
  letter-spacing: -0.02em;
  color: var(--blue-deep);
  text-transform: uppercase;
  margin-bottom: 22px;
}
.book-heading em {
  font-style: italic;
  font-weight: 400;
  text-transform: lowercase;
  color: var(--gold);
}
.book-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.2vw, 19px);
  line-height: 1.55;
  color: var(--ink-soft);
  max-width: 520px;
  margin-bottom: clamp(32px, 5vh, 48px);
}
.book-points {
  list-style: none;
  padding: 0;
  margin: 0 0 clamp(40px, 6vh, 60px);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.book-points li {
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.5;
  color: var(--ink);
  padding-left: 36px;
  position: relative;
}
.book-points li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 22px;
  height: 1px;
  background: var(--gold);
}

.book-direct {
  border-top: 1px solid rgba(3, 66, 145, 0.18);
  padding-top: clamp(24px, 4vh, 36px);
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.book-direct-label {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.28em;
  color: var(--ink-soft);
  font-weight: 600;
  margin-bottom: 6px;
}
.book-direct-link {
  font-family: 'Fraunces', serif;
  font-size: clamp(17px, 1.4vw, 22px);
  font-weight: 500;
  color: var(--ink);
  transition: color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .book-direct-link:hover {
    color: var(--blue-deep);
  }
}

/* ----- Right side: form ----- */
.book-form {
  background: #fff;
  padding: clamp(36px, 5vw, 56px);
  border-radius: 4px;
  box-shadow: 0 30px 70px -25px rgba(3, 66, 145, 0.18);
  display: flex;
  flex-direction: column;
  gap: clamp(18px, 2.4vh, 22px);
}

.book-form-head {
  margin-bottom: clamp(8px, 1.5vh, 16px);
  padding-bottom: clamp(20px, 3vh, 28px);
  border-bottom: 1px solid rgba(3, 66, 145, 0.12);
}
.book-form-eyebrow {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: var(--blue-deep);
  font-weight: 600;
  display: inline-block;
  margin-bottom: 14px;
}
.book-form-title {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(22px, 2vw, 30px);
  line-height: 1.15;
  letter-spacing: -0.01em;
  color: var(--ink);
  margin-bottom: 10px;
}
.book-form-title em {
  font-style: italic;
  font-weight: 400;
  color: var(--blue-deep);
}
.book-form-sub {
  font-family: 'Fraunces', serif;
  font-size: clamp(14px, 1.05vw, 16px);
  line-height: 1.5;
  color: var(--ink-soft);
  font-style: italic;
}

/* Dropdown / select */
.book-select-wrap {
  position: relative;
}
.book-select-wrap::after {
  content: "";
  position: absolute;
  right: 18px;
  top: 50%;
  width: 8px;
  height: 8px;
  border-right: 1.5px solid var(--blue-deep);
  border-bottom: 1.5px solid var(--blue-deep);
  transform: translateY(-70%) rotate(45deg);
  pointer-events: none;
}
.book-field select {
  width: 100%;
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.1vw, 17px);
  padding: 14px 44px 14px 16px;
  border: 1px solid rgba(14, 23, 38, 0.18);
  border-radius: 4px;
  background: var(--paper);
  color: var(--ink);
  appearance: none;
  -webkit-appearance: none;
  cursor: pointer;
  transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
  font-weight: 400;
}
.book-field select:focus {
  outline: none;
  border-color: var(--blue-deep);
  box-shadow: 0 0 0 3px rgba(3, 66, 145, 0.15);
  background: #fff;
}

/* Label italic emphasis */
.book-field label em {
  font-style: italic;
  color: var(--blue-deep);
}

/* Checkbox group */
.book-checkgroup {
  border: none;
  padding: 0;
  margin: clamp(8px, 1.5vh, 14px) 0 0;
}
.book-checkgroup legend {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ink-soft);
  font-weight: 600;
  margin-bottom: 16px;
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.book-optional {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  text-transform: none;
  letter-spacing: 0;
  font-size: 13px;
  color: var(--grey-field);
}
.book-checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 24px;
}
.book-check {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  font-family: 'Fraunces', serif;
  font-size: clamp(14px, 1.05vw, 16px);
  color: var(--ink);
  cursor: pointer;
  user-select: none;
  line-height: 1.3;
}
.book-check input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border: 1.5px solid rgba(3, 66, 145, 0.4);
  border-radius: 3px;
  background: #fff;
  cursor: pointer;
  position: relative;
  transition: background 0.2s ease, border-color 0.2s ease;
  flex-shrink: 0;
}
.book-check input[type="checkbox"]:checked {
  background: var(--blue-deep);
  border-color: var(--blue-deep);
}
.book-check input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 1px;
  width: 5px;
  height: 10px;
  border-right: 1.5px solid var(--ivory);
  border-bottom: 1.5px solid var(--ivory);
  transform: rotate(45deg);
}
@media (hover: hover) and (pointer: fine) {
  .book-check:hover input[type="checkbox"] {
    border-color: var(--blue-deep);
  }
}
.book-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(14px, 2vw, 20px);
}
.book-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.book-field label {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.22em;
  color: var(--ink-soft);
  font-weight: 600;
}
.book-field input,
.book-field textarea {
  font-family: 'Fraunces', serif;
  font-size: clamp(16px, 1.1vw, 17px);
  padding: 14px 16px;
  border: 1px solid rgba(14, 23, 38, 0.18);
  border-radius: 4px;
  background: var(--paper);
  color: var(--ink);
  transition: border-color 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
  outline: none;
  width: 100%;
  font-weight: 400;
}
.book-field textarea {
  resize: vertical;
  min-height: 120px;
  font-family: 'Fraunces', serif;
  line-height: 1.5;
}
.book-field input:focus,
.book-field textarea:focus {
  border-color: var(--blue-deep);
  box-shadow: 0 0 0 3px rgba(3, 66, 145, 0.15);
  background: #fff;
}
/* Invalid state — applied by JS validation when format fails. Red border +
   soft red focus ring so the user sees exactly which field needs attention. */
.book-field input.is-invalid,
.book-field textarea.is-invalid {
  border-color: #B83A2E;
  background: #fff;
}
.book-field input.is-invalid:focus,
.book-field textarea.is-invalid:focus {
  border-color: #B83A2E;
  box-shadow: 0 0 0 3px rgba(184, 58, 46, 0.18);
}
.book-field input::placeholder,
.book-field textarea::placeholder {
  color: var(--grey-field);
  font-style: italic;
}

.book-honey {
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
}

.book-submit {
  align-self: flex-start;
  margin-top: 8px;
  padding: 18px 36px;
}
.book-submit .arrow {
  width: 16px;
  height: 1px;
  background: var(--ivory);
  position: relative;
}
.book-submit .arrow::after {
  content: "";
  position: absolute;
  right: -1px; top: -4px;
  width: 9px; height: 9px;
  border-top: 1px solid var(--ivory);
  border-right: 1px solid var(--ivory);
  transform: rotate(45deg);
}

.book-fineprint {
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: 0.04em;
  line-height: 1.5;
  color: var(--ink-soft);
  margin-top: 4px;
}
.book-status {
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.4;
  color: var(--blue-deep);
  margin-top: 8px;
  min-height: 1.4em;
}
.book-status.is-error { color: #B83A2E; }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer {
  position: relative;
}

.footer-gallery {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 0;
  width: 100%;
}
.footer-tile {
  position: relative;
  aspect-ratio: 3 / 4;
  overflow: hidden;
  /* Tiny negative margin-right covers sub-pixel rounding gaps between grid cells.
     Last child resets so the strip doesn't bleed past the right viewport edge. */
  margin-right: -1px;
}
.footer-tile:last-child {
  margin-right: 0;
}
.footer-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.8s cubic-bezier(.22,1,.36,1);
  /* will-change removed (P2 #17): only animates on :hover, mobile users
     never see it — no GPU layer needed. */
  transform: translateZ(0);
  image-rendering: -webkit-optimize-contrast;
}
/* First tile (Termaya portrait) — anchor to top so her forehead isn't cropped */
.footer-tile:first-child img {
  object-position: center top;
}
@media (hover: hover) and (pointer: fine) {
  .footer-tile:hover img {
    transform: scale(1.04);
  }
}

.footer-panel {
  background: linear-gradient(135deg, #E6EBF5 0%, #DDE6F0 50%, #CCD9E8 100%);
  color: var(--ink);
  padding: clamp(64px, 9vh, 110px) clamp(24px, 5vw, 80px) clamp(40px, 6vh, 60px);
}

.footer-cols {
  max-width: 1400px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1.6fr 1fr;
  gap: clamp(40px, 6vw, 100px);
  padding-bottom: clamp(60px, 10vh, 110px);
}
.footer-col {
  display: flex;
  flex-direction: column;
}
.footer-h {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(20px, 1.8vw, 26px);
  letter-spacing: -0.01em;
  color: var(--blue-deep);
  text-transform: uppercase;
  margin-bottom: 24px;
}
.footer-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.footer-list li,
.footer-list a {
  font-family: 'Fraunces', serif;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.5;
  color: var(--ink-soft);
  transition: color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .footer-list a:hover {
    color: var(--blue-deep);
  }
}

.footer-social {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: flex;
  gap: 14px;
}
.footer-social a {
  width: 42px;
  height: 42px;
  border: 1px solid rgba(3, 66, 145, 0.3);
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--blue-deep);
  transition: background 0.3s ease, color 0.3s ease, border-color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .footer-social a:hover {
    background: var(--blue-deep);
    color: var(--ivory);
    border-color: var(--blue-deep);
  }
}
.footer-social a:active {
  background: var(--blue-deep);
  color: var(--ivory);
  border-color: var(--blue-deep);
}
.footer-tagline {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-size: clamp(15px, 1.1vw, 17px);
  color: var(--ink-soft);
  margin-top: 4px;
}

.footer-brand {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(-20px, -1.5vh, -10px);
  padding: clamp(20px, 4vh, 50px) 0 clamp(40px, 6vh, 70px);
  border-top: 1px solid rgba(3, 66, 145, 0.18);
}
.footer-brand-line {
  font-family: 'Fraunces', serif;
  font-weight: 500;
  font-variation-settings: "opsz" 144;
  font-size: clamp(56px, 13vw, 220px);
  line-height: 0.9;
  letter-spacing: -0.025em;
  color: var(--blue-deep);
  text-transform: uppercase;
}
.footer-brand-italic {
  font-style: italic;
  font-weight: 400;
  text-transform: none;
  color: var(--blue-deep);
  margin-top: -0.1em;
}
.footer-dot {
  color: var(--gold);
}

.footer-legal {
  max-width: 1400px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 24px;
  padding-top: 24px;
  border-top: 1px solid rgba(3, 66, 145, 0.12);
  font-family: 'Inter', sans-serif;
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--ink-soft);
  font-weight: 500;
}
.footer-legal-by {
  opacity: 0.7;
}

/* ============================================================
   KEYFRAMES
   ============================================================ */
@keyframes nameIn {
  from { opacity: 1; transform: translateX(-150%); letter-spacing: -0.015em; }
  to   { opacity: 1; transform: translateX(-50%);  letter-spacing: -0.015em; }
}
@keyframes lastnameIn {
  from { opacity: 1; transform: translateX(calc(-50% + 10px)); }
  to   { opacity: 1; transform: translateX(calc(40% + 70px)); }
}
/* Wide desktop (≥1650px) — Bonham starts 25px right of center to keep it
   clear of Termaya's face at large viewports. */
@keyframes lastnameInWide {
  from { opacity: 1; transform: translateX(calc(-50% + 25px)); }
  to   { opacity: 1; transform: translateX(calc(40% + 70px)); }
}
@keyframes fadeUp {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes navUp {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
@keyframes stripScroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }
}
/* ============================================================
   RESPONSIVE (mobile)
   ============================================================ */
@media (max-width: 950px) {
  /* On mobile the reveal section is no longer pinned, but it KEEPS the same
     overlapping editorial composition as desktop (center photo with flatlay
     overlapping left and keys overlapping right). The blur-as-photos-rise
     effect still fires (see scripts.js revealSection mobile branch) — just
     scroll-tied instead of pinned, so the page flows naturally. */
  .reveal-section {
    min-height: 100svh;
  }
  .reveal-pin {
    height: 100svh;
    position: relative;
  }
  .reveal-tagline {
    font-size: clamp(28px, 7vw, 48px);
    top: clamp(90px, 14vh, 130px);
  }
  /* Smaller mobile photo sizes for the same overlap composition */
  .reveal-photo.center {
    width: 58vw; height: 75vw;
    margin-left: -29vw; margin-top: -37.5vw;
  }
  .reveal-photo.left {
    width: 34vw; height: 44vw;
    top: 38%; left: 4%;
  }
  .reveal-photo.right {
    width: 32vw; height: 32vw;
    top: calc(56% + 30px); right: 4%;
  }
  .faq-heading { font-size: clamp(32px, 9vw, 56px); }
  .process-grid { grid-template-columns: 1fr; gap: 60px; }
  .process-step { border-right: none; border-bottom: 1px solid rgba(3, 66, 145, 0.18); padding-bottom: 60px; }
  .process-step:last-child { border-bottom: none; padding-bottom: 0; }
  /* Land anchors exactly under 64px mobile fixed nav (desktop uses 80px). */
  section[id] { scroll-margin-top: 64px; }
  /* FAQ summaries: drop uppercase + heavy tracking on mobile so long
     questions are easier to scan; keep Inter + weight 500. */
  .faq-row summary {
    text-transform: none;
    letter-spacing: 0.005em;
    font-size: clamp(15px, 4vw, 17px);
  }
  /* Mobile nav: anchored to top of viewport via position:fixed so it appears
     above the hero (the nav sits AFTER the hero in DOM order — sticky only
     activates when scrolled to, so it would otherwise sit below the hero on load). */
  .nav-toggle { display: flex; }
  /* Mobile nav anchored to viewport top via position:fixed.
     overscroll-behavior-x: none on html/body handles the iOS bounce issue,
     so the nav doesn't need to change positioning to participate in scroll. */
  .site-nav {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    justify-content: flex-start;
    padding: 0 12px;
    margin-top: 0;
    transform: translateY(0);
    animation: none;
  }
  .site-nav .mono {
    /* The .mono link spans the full width so the absolutely-positioned brand text
       can center via its own transform, and the absolutely-positioned logo can
       anchor to the right edge without crowding the brand. */
    position: static;
    flex: 1;
    display: block;
    height: 64px;
  }
  /* Brand text centered in the nav (independent of logo position) */
  .site-nav .nav-brand {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    font-size: 0; /* hide full text; show only "Moneywise." via ::before */
    white-space: nowrap;
  }
  .site-nav .nav-brand::before {
    content: "Moneywise";
    font-size: 14px;
    letter-spacing: 0.06em;
  }
  /* Logo anchored to the right edge of the nav, separated from the brand text */
  .site-nav .nav-logo {
    display: block;
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    height: 36px;
    padding: 2px;
  }
  .site-nav .nav-brand .nav-dot {
    font-size: 14px;
  }
  .site-nav .meta { display: none; }

  body.nav-open {
    overflow: hidden;
  }
  /* When overlay is open, the nav bar itself becomes ivory so the whole screen
     reads as one continuous cream surface. Hamburger bars and brand flip to ink. */
  body.nav-open .site-nav {
    z-index: 102;
    background: var(--ivory);
    transition: background 0.4s cubic-bezier(.22,1,.36,1);
  }
  body.nav-open .site-nav .mono,
  body.nav-open .site-nav .nav-brand::before,
  body.nav-open .site-nav .nav-brand .nav-dot {
    color: var(--ink);
    transition: color 0.4s ease;
  }
  body.nav-open .site-nav .nav-brand .nav-dot {
    color: var(--gold);
  }
  /* Smooth the nav bg change going BACK to blue when closed too */
  .site-nav { transition: background 0.4s cubic-bezier(.22,1,.36,1); }
  .site-nav .mono, .site-nav .nav-brand::before, .site-nav .nav-brand .nav-dot {
    transition: color 0.4s ease;
  }
  .coaching-inner { grid-template-columns: 1fr; gap: 48px; }
  /* Coaching section on mobile — restructure from overlapping absolute
     positioning to a clean stacked flex layout. The desktop editorial
     overlap doesn't work in narrow viewports and was clipping the marquee
     above + the section heading below. Polaroids now stack center-aligned
     with the back rotated slightly left, front rotated slightly right,
     and the house accent floats below as a small editorial flourish. */
  /* Coaching section — exact same overlapping editorial composition as desktop
     (back polaroid top-left, front polaroid overlapping right-and-lower, house
     icon bottom-left). Just sized smaller and constrained to a centered max-
     width container so the cluster stays visually unified at any mobile/tablet
     width instead of getting pushed to viewport edges. */
  .coaching-photos {
    position: relative;
    width: min(440px, 100%);
    height: clamp(440px, 100vw, 580px);
    margin: 0 auto;
  }
  .polaroid-back {
    position: absolute;
    top: 0;
    left: 4%;
    width: 50%;
    height: 65%;
    max-width: none;
    max-height: none;
    transform: rotate(-6deg);
    z-index: 1;
  }
  .polaroid-front {
    position: absolute;
    top: 22%;
    right: 4%;
    bottom: auto;
    left: auto;
    width: 60%;
    height: 75%;
    max-width: none;
    max-height: none;
    transform: rotate(3deg);
    z-index: 2;
  }
  .coaching-accent {
    position: absolute;
    bottom: 0;
    left: 25%;
    width: 24%;
    max-width: 110px;
    margin: 0;
    transform: rotate(-8deg);
  }
  .meet-section { grid-template-columns: 1fr; min-height: auto; }
  .meet-copy { max-width: none; padding: 60px 24px; margin: 0; }
  .meet-photo { min-height: 70vh; }
  .meet-photo .polaroid-overlay { width: 72vw; height: 90vw; }
  .differ-inner { grid-template-columns: 1fr; gap: 60px; }
  .differ-phone { max-width: 320px; margin: 0 auto; }

  .tool-card-inner { grid-template-columns: 1fr; gap: 48px; }
  .tool-card--reversed .tool-card-inner { grid-template-areas: "img" "copy"; }
  .tool-card--reversed .tool-image { grid-area: img; }
  .tool-card--reversed .tool-copy { grid-area: copy; }
  .tool-scene { max-width: none; aspect-ratio: 5 / 3; }

  .faq-grid { grid-template-columns: 1fr; gap: 0; }
  .faq-column + .faq-column .faq-row:first-child { border-top: none; }

  /* Mobile: 6 tiles in one row (drop tile 7 since 7-across is too small) */
  .footer-gallery { grid-template-columns: repeat(6, 1fr); }
  .footer-tile:nth-child(n+7) { display: none; }
  /* Mobile footer: Explore + Contact side-by-side (Serrina pattern),
     Say Hello drops below as a full-width row with the header on the LEFT
     and social icons on the RIGHT */
  .footer-cols {
    grid-template-columns: 1fr 1fr;
    gap: 32px;
    padding-bottom: 60px;
  }
  .footer-col:nth-child(3) {
    grid-column: 1 / -1;
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
  }
  .footer-col:nth-child(3) .footer-h {
    margin-bottom: 0;
  }
  .footer-col:nth-child(3) .footer-social {
    margin: 0;
  }
  .footer-col:nth-child(3) .footer-tagline {
    display: none;
  }
  .footer-legal { flex-direction: column; align-items: flex-start; gap: 8px; font-size: 10px; letter-spacing: 0.16em; }

  .book-inner { grid-template-columns: 1fr; gap: 48px; }
  .book-row { grid-template-columns: 1fr; }
  .book-checks { grid-template-columns: 1fr; }

  .hero-name {
    top: clamp(50px, 8vh, 90px);
    font-size: clamp(76px, 20vw, 170px);
  }
  .hero-lastname {
    /* Position below hero-name: name font-size × line-height (0.82) + breathing room.
       Slides in from the LEFT edge and stops just before Termaya's face (~30% from
       left of viewport) so it reads as floating into the negative space beside her. */
    top: calc(clamp(50px, 8vh, 90px) + clamp(66px, 18vw, 140px));
    font-size: clamp(22px, 7vw, 50px);
    left: 0;
    transform: translateX(-110%);
    animation: lastnameInMobile 2.4s cubic-bezier(.22,1,.36,1) 2.4s forwards;
  }
  @keyframes lastnameInMobile {
    from { opacity: 1; transform: translateX(-110%); }
    to   { opacity: 1; transform: translateX(calc(28% + 5px)); }
  }
  /* Center Termaya horizontally in the viewport on mobile. The source image
     (6048×4024) has her slightly left of center — shift the crop anchor right
     so the cropped frame puts her face in the middle of the viewport. */
  .hero-portrait { background-position: 35% top; }
  .hero-cutout img { object-position: 35% top; }
  .hero-tag {
    /* Centered horizontally on mobile, dropped 50px lower (was 30, +20 more) */
    bottom: calc(clamp(150px, 22vh, 220px) - 50px);
    left: 22px;
    right: 22px;
    max-width: none;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .hero-tag .eyebrow {
    justify-content: center;
  }
  /* Hide the gold dash before the eyebrow on mobile — centered layout reads
     cleaner without the asymmetric left-only accent line. */
  .hero-tag .eyebrow::before {
    display: none;
  }
  .hero-tag h2 {
    font-size: clamp(22px, 6vw, 32px);
    text-align: center;
  }
  .hero-cta-wrap {
    /* Centered horizontally on mobile, dropped 50px lower (was 30, +20 more) */
    left: 22px;
    right: 22px;
    bottom: calc(clamp(40px, 8vh, 80px) - 50px);
    align-items: center;
  }

  /* Phase 6 — Tap target hygiene (WCAG 2.5.5: 44x44 min) */
  .differ-arrow { width: 44px; height: 44px; }
  .tool-row summary { min-height: 44px; }
  .faq-row summary { min-height: 44px; }
  .book-check { min-height: 44px; padding: 4px 0; }
  .footer-social a { width: 44px; height: 44px; }
}

/* Mobile (≤750px) — footer gallery drops to 4 tiles in one row, matching
   the Serrina reference. Each tile is larger and more legible than packing
   6 into a narrow viewport. */
@media (max-width: 750px) {
  .footer-gallery { grid-template-columns: repeat(4, 1fr); }
  .footer-tile:nth-child(n+5) { display: none; }
}

/* Small mobile (≤400px) — give the hero name + lastname extra top breathing room
   so they sit clear of the fixed nav and don't bunch against the top */
@media (max-width: 400px) {
  .hero-name {
    top: calc(clamp(50px, 8vh, 90px) + 30px);
  }
  .hero-lastname {
    top: calc(clamp(50px, 8vh, 90px) + clamp(66px, 18vw, 140px) + 30px);
  }
}

/* Ultra-narrow phones (≤340px — iPhone SE 1st-gen at 320×568) — tighten hero
   name sizes so "TERMAYA" doesn't overlap "Bonham" or push off-screen. */
@media (max-width: 340px) {
  .hero-name { font-size: clamp(56px, 18vw, 100px); }
  .hero-lastname { font-size: clamp(22px, 8vw, 50px); }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
