/* ============================================================
   DESIGN SYSTEM — Jeremy Dorn Performance Coaching
   Senior Product Designer Spec · March 2026

   LAYOUT:  max-width 1200px · 24px gutter · 8px base grid
   TYPE:    Montserrat (headings) · Inter (body)
   PALETTE: Navy #1A1A2E · Gold #C8A97E · Off-white #F8F6F3
   ============================================================ */

/* ------- Tokens ------- */
:root {
    /* Color */
    --navy:        #1A1A2E;
    --navy-deep:   #12121F;
    --navy-light:  #242442;
    --navy-card:   #1E1E36;
    --gold:        #C8A97E;
    --gold-hover:  #D9BC96;
    --gold-dark:   #B89968;
    --gold-muted:  rgba(200,169,126,.12);
    --gold-glow:   rgba(200,169,126,.08);
    --offwhite:    #F8F6F3;
    --slate:       #3D3D50;
    --slate-light: #6B6B80;
    --white:       #FFFFFF;
    --border:      rgba(200,169,126,.15);
    --border-light: #E8E5E0;

    /* Typography scale (fluid) */
    --fs-hero:   clamp(2.25rem, 4.5vw, 3.75rem);  /* 36–60px */
    --fs-h2:     clamp(1.75rem, 3vw, 2.75rem);     /* 28–44px */
    --fs-h3:     clamp(1.125rem, 1.5vw, 1.375rem); /* 18–22px */
    --fs-body:   1rem;          /* 16px */
    --fs-body-lg: 1.125rem;     /* 18px */
    --fs-small:  0.875rem;      /* 14px */
    --fs-micro:  0.8125rem;     /* 13px */
    --fs-label:  0.75rem;       /* 12px */

    /* Spacing (8px grid) */
    --sp-1: 4px;
    --sp-2: 8px;
    --sp-3: 12px;
    --sp-4: 16px;
    --sp-5: 20px;
    --sp-6: 24px;
    --sp-8: 32px;
    --sp-10: 40px;
    --sp-12: 48px;
    --sp-16: 64px;
    --sp-20: 80px;
    --sp-24: 96px;
    --sp-32: 128px;

    /* Layout */
    --container: 1200px;
    --container-narrow: 760px;
    --gutter: 24px;
    --nav-h: 72px;
    --section-py: clamp(80px, 10vw, 128px);
    --radius: 12px;
    --radius-sm: 8px;
    --radius-lg: 16px;

    /* Motion */
    --ease:      cubic-bezier(.25,.46,.45,.94);
    --ease-out:  cubic-bezier(.16,1,.3,1);
    --dur:       .3s;
    --dur-slow:  .6s;
    --dur-enter: .8s;
}

/* ------- Reset ------- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
body { font-family:'Inter',system-ui,sans-serif; font-size:var(--fs-body); line-height:1.65; color:var(--slate); background:var(--offwhite); overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { text-decoration:none; color:inherit; }
ul,ol { list-style:none; }
button { font:inherit; cursor:pointer; border:none; background:none; }

/* Accessibility */
.skip-link {
    position:absolute; left:-9999px; top:auto; width:1px; height:1px; overflow:hidden;
    background:var(--gold); color:var(--navy); padding:var(--sp-3) var(--sp-6);
    font-weight:600; z-index:9999; border-radius:0 0 var(--radius-sm) 0;
}
.skip-link:focus { left:0; width:auto; height:auto; overflow:visible; }

/* Focus ring */
:focus-visible {
    outline: 2px solid var(--gold);
    outline-offset: 3px;
}

/* ------- Layout ------- */
.container       { max-width:var(--container); margin:0 auto; padding:0 var(--gutter); }
.container--narrow { max-width:var(--container-narrow); }

/* ------- Utility ------- */
.gold { color:var(--gold); }

/* ------- Buttons ------- */
.btn {
    display:inline-flex; align-items:center; gap:var(--sp-2);
    font-family:'Montserrat',sans-serif; font-weight:700; font-size:var(--fs-small);
    letter-spacing:.8px; text-transform:uppercase;
    padding:16px 36px; border-radius:var(--radius-sm);
    transition: all var(--dur) var(--ease);
    position:relative; overflow:hidden;
}
.btn--gold {
    background:var(--gold); color:var(--navy);
    box-shadow: 0 2px 8px rgba(200,169,126,.2);
}
.btn--gold:hover {
    background:var(--gold-hover);
    transform:translateY(-2px);
    box-shadow: 0 8px 28px rgba(200,169,126,.35);
}
.btn--gold:active { transform:translateY(0); }
.btn--lg { padding:18px 44px; font-size:15px; }
.btn--xl { padding:22px 52px; font-size:16px; letter-spacing:1px; }

/* Periodic shimmer glint on gold buttons */
.btn--gold::after {
    content:''; position:absolute; top:0; left:-100%; width:100%; height:100%;
    background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);
}
@keyframes btn-shimmer {
    0%,100% { left:-100%; }
    50% { left:100%; }
}
.btn--gold:hover::after { animation:none; left:100%; transition:left .5s var(--ease); }
.hero__actions .btn--gold::after { animation:btn-shimmer 4s ease-in-out infinite; }


/* ============================================================
   NAVIGATION
   Height: 72px · Background: navy 95% opacity + blur
   Scrolled: 60px height + shadow
   ============================================================ */

.nav {
    position:fixed; top:0; left:0; right:0;
    height:var(--nav-h); z-index:100;
    background:rgba(26,26,46,.92);
    backdrop-filter:blur(16px); -webkit-backdrop-filter:blur(16px);
    border-bottom:1px solid transparent;
    transition: all var(--dur) var(--ease);
}
.nav--scrolled {
    height:60px;
    border-bottom-color:var(--border);
    box-shadow:0 4px 24px rgba(0,0,0,.25);
}
.nav__inner {
    max-width:var(--container); margin:0 auto; padding:0 var(--gutter);
    height:100%; display:flex; align-items:center; justify-content:space-between;
}
.nav__logo {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:18px; letter-spacing:3px; color:var(--white);
    transition:color var(--dur);
}
.nav__logo:hover { color:var(--gold); }

.nav__menu {
    display:flex; align-items:center; gap:var(--sp-8);
}
.nav__link {
    font-size:var(--fs-small); font-weight:500;
    color:rgba(255,255,255,.6); letter-spacing:.3px;
    padding:var(--sp-2) 0; position:relative;
    transition:color var(--dur);
}
.nav__link::after {
    content:''; position:absolute; bottom:0; left:0;
    width:0; height:1.5px; background:var(--gold);
    transition:width var(--dur) var(--ease-out);
}
.nav__link:hover { color:var(--white); }
.nav__link:hover::after { width:100%; }

.nav__cta {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-micro); letter-spacing:.8px; text-transform:uppercase;
    color:var(--navy); background:var(--gold);
    padding:10px 24px; border-radius:6px;
    transition:all var(--dur) var(--ease);
}
.nav__cta:hover { background:var(--gold-hover); transform:translateY(-1px); }

/* Hamburger (mobile) */
.nav__toggle {
    display:none; flex-direction:column; gap:5px;
    padding:4px; z-index:101;
}
.nav__toggle span {
    display:block; width:22px; height:2px;
    background:var(--white); border-radius:2px;
    transition:all var(--dur) var(--ease);
}
.nav__toggle[aria-expanded="true"] span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.nav__toggle[aria-expanded="true"] span:nth-child(2) { opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }


/* ============================================================
   HERO
   Full-viewport · Navy bg · 2-col grid (text 55% / image 45%)
   Padding-top: nav-h + 64px · Padding-bottom: 80px
   ============================================================ */

.hero {
    background:var(--navy); min-height:100vh; min-height:100dvh;
    padding-top:calc(var(--nav-h) + var(--sp-16));
    padding-bottom:var(--sp-20);
    display:flex; align-items:center;
    position:relative; overflow:hidden;
}
.hero__bg-glow {
    position:absolute; top:-30%; right:-15%;
    width:700px; height:700px;
    background:radial-gradient(circle,var(--gold-glow) 0%,transparent 65%);
    pointer-events:none;
}
.hero__grid {
    display:grid; grid-template-columns:1.15fr 1fr;
    gap:var(--sp-16); align-items:center;
}

/* Badge */
.hero__badge {
    display:inline-flex; align-items:center; gap:var(--sp-2);
    font-size:var(--fs-micro); font-weight:500;
    color:var(--gold); background:var(--gold-muted);
    padding:6px 14px; border-radius:20px;
    margin-bottom:var(--sp-6);
}
.hero__badge-dot {
    width:6px; height:6px; border-radius:50%;
    background:var(--gold);
    animation: pulse 2s infinite;
}
@keyframes pulse {
    0%,100% { opacity:1; } 50% { opacity:.4; }
}

.hero__title {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:var(--fs-hero); line-height:1.12;
    color:var(--white); margin-bottom:var(--sp-6);
    letter-spacing:-.5px;
}
.hero__sub {
    font-size:var(--fs-body-lg); line-height:1.75;
    color:rgba(255,255,255,.6); max-width:540px;
    margin-bottom:var(--sp-10);
}

/* Actions */
.hero__actions {
    display:flex; align-items:center; gap:var(--sp-6);
    flex-wrap:wrap; margin-bottom:var(--sp-12);
}
.hero__note {
    font-size:var(--fs-micro); color:rgba(255,255,255,.4);
    font-weight:500; letter-spacing:.3px;
}

/* Social proof cluster */
.hero__proof {
    display:flex; align-items:center; gap:var(--sp-3);
}
.hero__proof-avatars {
    display:flex;
}
.avatar {
    width:32px; height:32px; border-radius:50%;
    background:var(--navy-light); border:2px solid var(--navy);
    display:flex; align-items:center; justify-content:center;
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:12px; color:var(--gold);
}
.avatar + .avatar { margin-left:-8px; }
.hero__proof-text {
    font-size:var(--fs-micro); color:rgba(255,255,255,.45);
}
.hero__proof-text strong { color:rgba(255,255,255,.7); }

/* Hero image */
.hero__visual { position:relative; }
.hero__img-wrap {
    width:100%; max-width:520px; margin:0 auto;
    aspect-ratio:5/6; border-radius:var(--radius-lg);
    overflow:hidden; position:relative;
    background:linear-gradient(135deg,var(--navy-light),var(--slate));
}
.hero__img-wrap img { width:100%; height:100%; object-fit:cover; }
.hero__img-fallback::after {
    content:'Dein Foto hier'; position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-family:'Montserrat',sans-serif; font-size:16px;
    color:rgba(255,255,255,.15); letter-spacing:2px; text-transform:uppercase;
}

/* Floating stat cards */
.hero__float {
    position:absolute; background:rgba(26,26,46,.85);
    backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
    border:1px solid var(--border); border-radius:var(--radius-sm);
    padding:14px 20px; display:flex; flex-direction:column;
    animation: float 4s ease-in-out infinite;
}
.hero__float--top { top:12%; right:-32px; }
.hero__float--bottom { bottom:16%; left:-28px; animation-delay:2s; }
.hero__float-num {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:24px; color:var(--gold); line-height:1;
}
.hero__float-label { font-size:var(--fs-label); color:rgba(255,255,255,.5); margin-top:2px; }

@keyframes float {
    0%,100% { transform:translateY(0); }
    50% { transform:translateY(-8px); }
}


/* ============================================================
   SOCIAL PROOF BAR
   Navy-deep bg · 3-col grid · 80px py
   Animated counters on scroll
   ============================================================ */

.proof-bar {
    background:var(--navy); padding:var(--sp-8) 0;
    border-top:1px solid rgba(200,169,126,.08);
    border-bottom:1px solid rgba(200,169,126,.08);
}
.proof-bar__grid {
    display:grid; grid-template-columns:1fr auto 1fr auto 1fr;
    align-items:center; gap:var(--sp-8);
    text-align:center;
}
.proof-bar__item { display:flex; flex-direction:column; align-items:center; }
.proof-bar__metric { display:flex; align-items:baseline; gap:2px; white-space:nowrap; }
.proof-bar__num {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:clamp(28px,3vw,38px); color:var(--gold); line-height:1;
}
.proof-bar__suffix {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:clamp(28px,3vw,38px); color:var(--gold); line-height:1;
}
.proof-bar__label {
    font-size:var(--fs-micro); color:rgba(255,255,255,.4);
    margin-top:var(--sp-1); max-width:200px; letter-spacing:.3px;
}
.proof-bar__divider {
    width:1px; height:36px;
    background:rgba(200,169,126,.15);
}


/* ============================================================
   SECTIONS (shared)
   ============================================================ */

.section { padding:var(--section-py) 0; }
.section--light { background:var(--offwhite); }
.section--dark  { background:var(--navy); }

.section__head {
    text-align:center; max-width:800px;
    margin:0 auto var(--sp-16);
}
.section__label {
    display:inline-block;
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-label); letter-spacing:3px; text-transform:uppercase;
    color:var(--gold); margin-bottom:var(--sp-3);
}
.section__title {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:var(--fs-h2); line-height:1.15;
    color:var(--navy); letter-spacing:-.3px;
}
.section__title--light { color:var(--white); }

.section__sub {
    font-size:var(--fs-body-lg); line-height:1.7;
    color:var(--slate-light); margin-top:var(--sp-4);
}
.section__sub--light { color:rgba(255,255,255,.55); }


/* ============================================================
   VIDEO SECTION
   16:9 container · Rounded corners · Play button overlay
   Click-to-load YouTube (GDPR friendlier, better perf)
   ============================================================ */

.video__wrap {
    position:relative; width:100%;
    aspect-ratio:16/9; border-radius:var(--radius-lg);
    overflow:hidden; background:var(--navy);
    box-shadow: 0 24px 64px rgba(26,26,46,.2);
}
.video__placeholder {
    position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    cursor:pointer; background:var(--navy);
}
.video__placeholder img { width:100%; height:100%; object-fit:cover; opacity:.7; }
.video__play {
    position:absolute; top:50%; left:50%;
    transform:translate(-50%,-50%);
    transition:transform var(--dur) var(--ease), opacity var(--dur);
}
.video__placeholder:hover .video__play { transform:translate(-50%,-50%) scale(1.08); }
.video__iframe { position:absolute; inset:0; width:100%; height:100%; border:none; }


/* ============================================================
   PROBLEM SECTION
   3-col grid · card with left gold border accent
   ============================================================ */

.problems__grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:var(--sp-6);
}
.prob {
    background:var(--navy-card); border-radius:var(--radius);
    padding:var(--sp-10) var(--sp-8);
    border-left:3px solid var(--gold);
    transition:all var(--dur) var(--ease);
}
.prob:hover {
    transform:translateY(-4px);
    box-shadow:0 16px 48px rgba(0,0,0,.25);
}
.prob__icon { margin-bottom:var(--sp-5); opacity:.8; }
.prob__title {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-h3); color:var(--white);
    margin-bottom:var(--sp-3);
}
.prob__text {
    font-size:var(--fs-small); line-height:1.75;
    color:rgba(255,255,255,.55);
}

.problems__closer {
    text-align:center; margin-top:var(--sp-12);
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:clamp(18px,2vw,24px); color:var(--white);
}


/* ============================================================
   PILLARS SECTION
   3-col · card with top gold line
   ============================================================ */

.pillars__grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:var(--sp-6);
}
.pillar {
    background:var(--white); border-radius:var(--radius);
    padding:var(--sp-10) var(--sp-8);
    border-top:3px solid var(--gold);
    transition:all var(--dur) var(--ease);
    box-shadow:0 2px 12px rgba(26,26,46,.04);
}
.pillar:hover {
    transform:translateY(-4px);
    box-shadow:0 16px 48px rgba(26,26,46,.08);
}
.pillar__head { margin-bottom:var(--sp-5); }
.pillar__num {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:42px; color:var(--gold-muted); line-height:1;
    color:rgba(200,169,126,.2);
}
.pillar__title {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:22px; color:var(--navy);
    margin-top:var(--sp-2);
}
.pillar__desc {
    font-size:var(--fs-small); line-height:1.75;
    color:var(--slate-light); margin-bottom:0;
}
.pillar__list { display:flex; flex-direction:column; gap:var(--sp-3); }
.pillar__list li {
    font-size:var(--fs-small); color:var(--slate);
    padding-left:var(--sp-5); position:relative;
}
.pillar__list li::before {
    content:''; position:absolute; left:0; top:9px;
    width:10px; height:2px; background:var(--gold);
}


/* ============================================================
   TESTIMONIALS
   3-col · dark bg cards on dark section
   Metric hero number + quote + author + before/after
   ============================================================ */

.testi__grid {
    display:grid; grid-template-columns:repeat(3,1fr);
    gap:var(--sp-6);
}
.testi {
    background:var(--navy-card); border:1px solid var(--border);
    border-radius:var(--radius); overflow:hidden;
    display:flex; flex-direction:column;
    transition:all var(--dur) var(--ease);
}
.testi:hover {
    border-color:var(--gold);
    transform:translateY(-4px);
    box-shadow:0 16px 48px rgba(0,0,0,.2);
}

/* Testimonial video */
.testi__video {
    position:relative; aspect-ratio:16/9;
    cursor:pointer; overflow:hidden;
    background:var(--navy);
}
.testi__video img {
    width:100%; height:100%; object-fit:cover;
    opacity:.75; transition:opacity var(--dur);
}
.testi__video:hover img { opacity:.5; }
.testi__video-play {
    position:absolute; top:50%; left:50%;
    transform:translate(-50%,-50%);
    transition:transform var(--dur) var(--ease);
}
.testi__video:hover .testi__video-play { transform:translate(-50%,-50%) scale(1.1); }
.testi__video iframe {
    position:absolute; inset:0; width:100%; height:100%; border:none;
}

.testi__body { padding:var(--sp-6); display:flex; flex-direction:column; flex-grow:1; }

.testi__top {
    text-align:center; padding-bottom:var(--sp-4);
    margin-bottom:var(--sp-4);
    border-bottom:1px solid var(--border);
}
.testi__metric {
    display:block; font-family:'Montserrat',sans-serif;
    font-weight:800; font-size:clamp(36px,4vw,48px);
    color:var(--gold); line-height:1;
}
.testi__metric-sub {
    display:block; font-size:var(--fs-small);
    color:rgba(255,255,255,.5); margin-top:var(--sp-2);
}
.testi__quote {
    font-size:var(--fs-small); line-height:1.8;
    color:rgba(255,255,255,.65); font-style:italic;
    padding-left:var(--sp-5); border-left:2px solid var(--gold);
    margin-bottom:var(--sp-6); flex-grow:1;
}
.testi__author {
    display:flex; align-items:center; gap:var(--sp-3);
    margin-bottom:var(--sp-6);
}
.testi__avatar {
    width:40px; height:40px; border-radius:50%;
    background:var(--navy); color:var(--gold);
    display:flex; align-items:center; justify-content:center;
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:16px; flex-shrink:0;
    border:1px solid var(--border);
}
.testi__avatar-img {
    width:40px; height:40px; border-radius:50%;
    object-fit:cover; flex-shrink:0;
    border:2px solid var(--border);
}
.testi__author strong { display:block; font-size:var(--fs-small); color:var(--white); }
.testi__author span { font-size:var(--fs-micro); color:rgba(255,255,255,.45); }


.testi__cta { text-align:center; margin-top:var(--sp-12); }


/* ============================================================
   ABOUT
   2-col grid (image 45% / text 55%) · 80px gap
   ============================================================ */

.about__grid {
    display:grid; grid-template-columns:1fr 1.3fr;
    gap:var(--sp-20); align-items:center;
}
.about__img-inner {
    width:100%; aspect-ratio:4/5;
    border-radius:var(--radius-lg); overflow:hidden;
    background:linear-gradient(135deg,var(--navy-light),var(--slate));
    position:relative;
}
.about__img-inner img { width:100%; height:100%; object-fit:cover; }
.about__img-fallback::after {
    content:'Dein Foto hier'; position:absolute; inset:0;
    display:flex; align-items:center; justify-content:center;
    font-family:'Montserrat',sans-serif; font-size:14px;
    color:rgba(255,255,255,.15); letter-spacing:2px; text-transform:uppercase;
}

.about__content .section__label { text-align:left; }
.about__content .section__title { text-align:left; margin-bottom:var(--sp-6); }
.about__text {
    font-size:var(--fs-body); line-height:1.8;
    color:var(--slate-light); margin-bottom:var(--sp-4);
}
.about__text:last-of-type { margin-bottom:var(--sp-8); }

.about__stats {
    display:flex; gap:var(--sp-10);
    padding-top:var(--sp-8);
    border-top:1px solid var(--border-light);
}
.about__stat { display:flex; flex-direction:column; }
.about__stat-num {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:28px; color:var(--gold); line-height:1;
    margin-bottom:var(--sp-1);
}
.about__stat-text { font-size:var(--fs-micro); color:var(--slate-light); }

.about__trustpilot {
    display:flex; align-items:center; gap:var(--sp-3);
    padding:var(--sp-3) var(--sp-5);
    background:rgba(0,182,122,.06); border:1px solid rgba(0,182,122,.15);
    border-radius:var(--radius-sm);
    transition:all var(--dur) var(--ease);
}
.about__trustpilot:hover { background:rgba(0,182,122,.1); border-color:rgba(0,182,122,.3); }
.about__trustpilot-stars { display:flex; gap:2px; flex-shrink:0; }
.about__trustpilot-text {
    font-size:var(--fs-micro); font-weight:500;
    color:var(--slate);
}


/* ============================================================
   STEPS / HOW IT WORKS
   Centered 3-step vertical timeline · Navy bg
   ============================================================ */

.steps__grid {
    max-width:600px; margin:0 auto;
}
.step {
    display:flex; gap:var(--sp-6); align-items:flex-start;
}
.step__marker { flex-shrink:0; position:relative; }
.step__num {
    width:52px; height:52px; border-radius:50%;
    background:var(--gold-muted); border:2px solid var(--gold);
    display:flex; align-items:center; justify-content:center;
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:20px; color:var(--gold);
}
.step__title {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-h3); color:var(--white);
    margin-bottom:var(--sp-2);
}
.step__text {
    font-size:var(--fs-small); line-height:1.75;
    color:rgba(255,255,255,.55);
}
.step__body { padding-top:var(--sp-2); }

.step__line {
    width:2px; height:36px;
    background:linear-gradient(to bottom,var(--gold),rgba(200,169,126,.15));
    margin-left:25px; /* centers under step__num */
}

.steps__cta { text-align:center; margin-top:var(--sp-12); }


/* ============================================================
   FAQ
   Native <details> element · animated open
   ============================================================ */

.faq__item {
    border-bottom:1px solid var(--border-light);
}
.faq__item:first-child { border-top:1px solid var(--border-light); }

.faq__q {
    width:100%; display:flex; justify-content:space-between;
    align-items:center; padding:var(--sp-6) 0;
    font-family:'Montserrat',sans-serif; font-weight:600;
    font-size:var(--fs-body); color:var(--navy);
    cursor:pointer; gap:var(--sp-4);
    transition:color var(--dur);
    list-style:none; /* remove default marker */
}
.faq__q::-webkit-details-marker { display:none; }
.faq__q::marker { display:none; content:''; }
.faq__q:hover { color:var(--gold-dark); }

.faq__chevron {
    flex-shrink:0; width:24px; height:24px; position:relative;
    transition:transform var(--dur) var(--ease);
}
.faq__chevron::before, .faq__chevron::after {
    content:''; position:absolute; background:var(--gold);
    border-radius:1px;
}
.faq__chevron::before { width:12px; height:2px; top:11px; left:2px; transform:rotate(45deg); }
.faq__chevron::after  { width:12px; height:2px; top:11px; left:10px; transform:rotate(-45deg); }

details[open] .faq__chevron { transform:rotate(180deg); }

.faq__a {
    padding-bottom:var(--sp-6);
}
.faq__a p {
    font-size:var(--fs-small); line-height:1.85;
    color:var(--slate-light);
}


/* ============================================================
   FINAL CTA
   Navy bg · centered · glow effect
   ============================================================ */

.section--cta {
    background:var(--navy); padding:var(--section-py) 0;
    position:relative; overflow:hidden;
    text-align:center;
}
.cta__glow {
    position:absolute; top:50%; left:50%;
    transform:translate(-50%,-50%);
    width:500px; height:500px;
    background:radial-gradient(circle,rgba(200,169,126,.06) 0%,transparent 65%);
    pointer-events:none;
}
.cta__content { position:relative; z-index:1; }
.cta__title {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:var(--fs-h2); color:var(--white);
    line-height:1.15; margin-bottom:var(--sp-5);
}
.cta__text {
    font-size:var(--fs-body-lg); line-height:1.75;
    color:rgba(255,255,255,.55); margin-bottom:var(--sp-10);
    max-width:500px; margin-left:auto; margin-right:auto;
}
.cta__micro {
    font-size:var(--fs-micro); color:rgba(255,255,255,.3);
    margin-top:var(--sp-5);
}


/* ============================================================
   FOOTER
   ============================================================ */

.footer {
    background:var(--navy-deep); padding:var(--sp-12) 0 var(--sp-8);
    border-top:1px solid var(--border);
}
.footer__top {
    display:flex; justify-content:space-between; align-items:center;
    padding-bottom:var(--sp-8);
    border-bottom:1px solid rgba(255,255,255,.06);
}
.footer__logo {
    font-family:'Montserrat',sans-serif; font-weight:800;
    font-size:16px; letter-spacing:3px; color:var(--white);
}
.footer__tagline { font-size:var(--fs-micro); color:rgba(255,255,255,.3); margin-top:var(--sp-1); }

.footer__social { display:flex; gap:var(--sp-3); }
.footer__icon {
    width:40px; height:40px; border-radius:50%;
    background:rgba(255,255,255,.05);
    display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,.4); transition:all var(--dur) var(--ease);
}
.footer__icon:hover { background:var(--gold); color:var(--navy); }

.footer__bottom {
    display:flex; justify-content:space-between; align-items:center;
    padding-top:var(--sp-6); font-size:var(--fs-micro);
    color:rgba(255,255,255,.25);
}
.footer__links { display:flex; gap:var(--sp-6); }
.footer__links a { color:rgba(255,255,255,.25); transition:color var(--dur); }
.footer__links a:hover { color:var(--gold); }


/* ============================================================
   STICKY MOBILE CTA
   Fixed bottom bar · shows after scrolling past hero
   ============================================================ */

.mobile-cta {
    display:none; position:fixed; bottom:0; left:0; right:0;
    z-index:99; padding:var(--sp-3) var(--sp-4);
    background:rgba(26,26,46,.95);
    backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
    border-top:1px solid var(--border);
    transform:translateY(100%);
    transition:transform var(--dur) var(--ease);
}
.mobile-cta--visible { transform:translateY(0); }
.mobile-cta__btn {
    display:block; width:100%; text-align:center;
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-small); letter-spacing:.8px; text-transform:uppercase;
    color:var(--navy); background:var(--gold);
    padding:14px 0; border-radius:6px;
    transition:background var(--dur);
}
.mobile-cta__btn:hover { background:var(--gold-hover); }


/* ============================================================
   COACHING RESULTS BARS
   Horizontal bar chart · Before/After comparison
   ============================================================ */

.results__grid {
    max-width:700px; margin:0 auto;
    display:flex; flex-direction:column; gap:var(--sp-5);
    background:rgba(255,255,255,.03); border:1px solid var(--border);
    border-radius:var(--radius); padding:var(--sp-8) var(--sp-8);
    transition:max-width .5s var(--ease-out), padding .5s var(--ease-out);
}
.results__grid.expanded {
    max-width:900px;
    padding:var(--sp-10) var(--sp-10);
}

/* Compact single-row result */
.result-row {
    display:grid; grid-template-columns:110px 36px 1fr 36px;
    align-items:center; gap:var(--sp-3);
}
.result-row__label {
    font-family:'Montserrat',sans-serif; font-weight:600;
    font-size:var(--fs-small); color:var(--white);
}
.result-row__before {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-small); color:rgba(255,255,255,.4);
    text-align:right;
}
.result-row__after {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-small); color:var(--gold);
}
.result-row__track {
    display:flex; flex-direction:column; gap:3px;
    justify-content:center; height:28px;
}
.result-row__bar {
    height:10px; border-radius:4px;
    transition:width 1.2s var(--ease-out);
}
.result-row__bar--before {
    background:rgba(255,255,255,.1);
}
.result-row__bar--after {
    background:linear-gradient(90deg, var(--gold-dark), var(--gold));
}

.results__expand {
    display:flex; align-items:center; justify-content:center; gap:var(--sp-2);
    margin:var(--sp-4) auto 0;
    font-family:'Montserrat',sans-serif; font-weight:600;
    font-size:var(--fs-micro); letter-spacing:.5px;
    color:var(--gold); background:var(--gold-muted);
    border:1px solid rgba(200,169,126,.2);
    padding:10px 20px; border-radius:6px;
    cursor:pointer; transition:all var(--dur) var(--ease);
}
.results__expand:hover {
    background:rgba(200,169,126,.18); border-color:var(--gold);
}
.results__expand-icon { transition:transform var(--dur) var(--ease); }
.results__expand.active .results__expand-icon { transform:rotate(45deg); }

/* Hidden metrics area */
.results__more {
    display:flex; flex-direction:column; gap:var(--sp-5);
    max-height:0; overflow:hidden; opacity:0;
    transition:max-height .5s var(--ease-out), opacity .4s var(--ease), margin .4s var(--ease);
    margin-top:0;
}
.results__more.active {
    max-height:600px; opacity:1;
    margin-top:var(--sp-5);
}

/* Legend */
.results__legend {
    display:flex; justify-content:center; gap:var(--sp-8);
    margin-top:var(--sp-4);
}
.results__legend-item {
    display:flex; align-items:center; gap:var(--sp-2);
    font-size:var(--fs-micro); color:rgba(255,255,255,.45);
}
.results__legend-item::before {
    content:''; width:16px; height:8px; border-radius:3px;
}
.results__legend-item--before::before { background:rgba(255,255,255,.12); }
.results__legend-item--after::before { background:var(--gold); }

/* ============================================================
   BOOKING MODAL
   Centered overlay · dark backdrop · gold accents
   ============================================================ */

.modal {
    position:fixed; inset:0; z-index:200;
    display:flex; align-items:center; justify-content:center;
    padding:var(--sp-6);
    opacity:0; visibility:hidden;
    transition:opacity var(--dur) var(--ease), visibility var(--dur);
}
.modal.active {
    opacity:1; visibility:visible;
}
.modal__backdrop {
    position:absolute; inset:0;
    background:rgba(12,12,20,.8);
    backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px);
}
.modal__container {
    position:relative; z-index:1;
    width:100%; max-width:680px; max-height:90vh;
    background:var(--white); border-radius:var(--radius-lg);
    box-shadow:0 32px 80px rgba(0,0,0,.35);
    overflow:hidden;
    transform:translateY(20px) scale(.97);
    transition:transform var(--dur) var(--ease-out);
}
.modal.active .modal__container {
    transform:translateY(0) scale(1);
}
.modal__header {
    display:flex; align-items:center; justify-content:space-between;
    padding:var(--sp-6) var(--sp-8);
    border-bottom:1px solid var(--border-light);
}
.modal__title {
    font-family:'Montserrat',sans-serif; font-weight:700;
    font-size:var(--fs-h3); color:var(--navy);
}
.modal__close {
    width:40px; height:40px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    color:var(--slate-light); background:var(--offwhite);
    transition:all var(--dur);
}
.modal__close:hover { background:var(--navy); color:var(--white); }
.modal__body {
    padding:var(--sp-6) var(--sp-8) var(--sp-8);
    overflow-y:auto; max-height:calc(90vh - 72px);
}
.modal__intro {
    font-size:var(--fs-small); line-height:1.7;
    color:var(--slate-light); margin-bottom:var(--sp-6);
}
.modal__embed {
    border-radius:var(--radius);
    margin-bottom:var(--sp-6);
}
.modal__embed iframe {
    width:100%; min-height:800px; border:none;
    border-radius:var(--radius);
}
.modal__placeholder {
    text-align:center; padding:var(--sp-10);
}
.modal__placeholder svg { margin:0 auto var(--sp-4); }
.modal__placeholder-text {
    font-family:'Montserrat',sans-serif; font-weight:600;
    font-size:var(--fs-small); color:var(--navy); margin-bottom:var(--sp-2);
}
.modal__placeholder-hint {
    font-size:var(--fs-micro); color:var(--slate-light);
}
.modal__footer {
    padding-top:var(--sp-4);
    border-top:1px solid var(--border-light);
}
.modal__trust {
    display:flex; justify-content:center; gap:var(--sp-6);
}
.modal__trust span {
    font-size:var(--fs-micro); font-weight:500;
    color:var(--slate-light);
    display:flex; align-items:center; gap:var(--sp-1);
}
.modal__trust span::before {
    content:''; width:6px; height:6px; border-radius:50%;
    background:var(--gold);
}

/* Pillars closer text */
.pillars__closer {
    text-align:center; margin-top:var(--sp-12);
    font-size:var(--fs-body-lg); line-height:1.7;
    color:var(--slate-light); max-width:600px;
    margin-left:auto; margin-right:auto;
}


/* ============================================================
   SCROLL ANIMATIONS
   ============================================================ */

.fade-up {
    opacity:0; transform:translateY(28px);
    transition: opacity var(--dur-enter) var(--ease),
                transform var(--dur-enter) var(--ease-out);
}
.fade-up.visible {
    opacity:1; transform:translateY(0);
}


/* ============================================================
   RESPONSIVE · MOBILE-FIRST OVERRIDES
   Breakpoints: 1024px (tablet) · 768px (mobile) · 480px (small)
   ============================================================ */

@media (max-width:1024px) {
    .hero__grid { gap:var(--sp-10); }
    .problems__grid, .pillars__grid, .testi__grid {
        grid-template-columns:repeat(2,1fr);
    }
    .about__grid { gap:var(--sp-12); }
    .hero__float--top { right:-12px; }
    .hero__float--bottom { left:-12px; }
}

@media (max-width:768px) {
    /* Reduce section padding on mobile */
    .section { padding:clamp(56px, 8vw, 80px) 0; }
    .section__head { margin-bottom:var(--sp-10); }

    /* Nav */
    .nav__toggle { display:flex; }
    .nav__menu {
        position:fixed; top:0; right:-100%;
        width:85%; max-width:340px; height:100vh; height:100dvh;
        background:var(--navy); flex-direction:column;
        align-items:flex-start; padding:100px 32px 40px;
        gap:0; transition:right .4s var(--ease-out);
        box-shadow:-10px 0 40px rgba(0,0,0,.5);
    }
    .nav__menu.active { right:0; }
    .nav__link {
        font-size:17px; padding:16px 0; width:100%;
        border-bottom:1px solid rgba(255,255,255,.06);
    }
    .nav__link::after { display:none; }
    .nav__cta { margin-top:var(--sp-5); text-align:center; width:100%; display:block; }

    /* Hero */
    .hero { padding-bottom:var(--sp-12); }
    .hero__grid {
        grid-template-columns:1fr; text-align:center;
        padding-top:var(--sp-8); gap:var(--sp-8);
    }
    .hero__visual { order:-1; }
    .hero__img-wrap { max-width:240px; aspect-ratio:1; margin:0 auto; border-radius:50%; }
    .hero__sub { margin-left:auto; margin-right:auto; font-size:var(--fs-body); }
    .hero__actions { justify-content:center; }
    .hero__proof { justify-content:center; }
    .hero__float { display:none; }
    .hero__actions { margin-bottom:var(--sp-4); }

    /* Grids → single col */
    .problems__grid, .pillars__grid, .testi__grid {
        grid-template-columns:1fr;
    }

    /* Proof bar */
    .proof-bar { padding:var(--sp-6) 0; }
    .proof-bar__grid {
        grid-template-columns:1fr;
        gap:var(--sp-4);
    }
    .proof-bar__divider { width:48px; height:1px; margin:0 auto; }
    .proof-bar__num, .proof-bar__suffix { font-size:clamp(24px,5vw,32px); }

    /* Problem cards — reduce padding */
    .prob { padding:var(--sp-8) var(--sp-6); }
    .problems__closer { margin-top:var(--sp-8); font-size:clamp(16px,4vw,20px); }

    /* Pillar cards — reduce padding */
    .pillar { padding:var(--sp-8) var(--sp-6); }
    .pillars__closer { margin-top:var(--sp-8); font-size:var(--fs-body); }

    /* Results */
    .results__grid { padding:var(--sp-6); }
    .results__grid.expanded { padding:var(--sp-6); }

    /* Testimonials */
    .testi__body { padding:var(--sp-5); }
    .testi__quote { font-size:var(--fs-micro); }

    /* About */
    .about__grid {
        grid-template-columns:1fr; gap:var(--sp-8);
    }
    .about__img-inner { max-width:300px; margin:0 auto; }
    .about__content .section__label,
    .about__content .section__title { text-align:center; }
    .about__text { text-align:center; }
    .about__stats { justify-content:center; flex-wrap:wrap; gap:var(--sp-6); }
    .about__trustpilot { justify-content:center; width:100%; }

    /* Steps */
    .step { gap:var(--sp-5); }
    .step__num { width:44px; height:44px; font-size:17px; }
    .step__line { margin-left:21px; }

    /* FAQ — larger touch targets */
    .faq__q { padding:var(--sp-5) 0; min-height:48px; }

    /* CTA */
    .cta__title { font-size:clamp(1.5rem,5vw,2rem); }
    .cta__text { font-size:var(--fs-body); }

    /* Modal — near fullscreen */
    .modal { padding:var(--sp-3); }
    .modal__container { max-width:100%; max-height:95vh; border-radius:var(--radius); }
    .modal__header { padding:var(--sp-4) var(--sp-5); }
    .modal__body { padding:var(--sp-4) var(--sp-5) var(--sp-5); max-height:calc(95vh - 60px); }
    .modal__embed iframe { min-height:600px; }
    .modal__trust { gap:var(--sp-4); }

    /* Buttons full width */
    .btn { width:100%; max-width:380px; justify-content:center; }
    .btn--lg { padding:16px 32px; font-size:14px; }
    .btn--xl { padding:18px 36px; font-size:14px; }

    /* Footer — stack layout */
    .footer__top { flex-direction:column; text-align:center; gap:var(--sp-5); }
    .footer__bottom { flex-direction:column; text-align:center; gap:var(--sp-3); }
    .footer__links { justify-content:center; }

    /* Mobile CTA bar */
    .mobile-cta { display:block; }

    /* Extra bottom padding for mobile CTA bar */
    .footer { padding-bottom:80px; }
}

@media (max-width:480px) {
    .hero { padding-top:calc(var(--nav-h) + var(--sp-8)); padding-bottom:var(--sp-8); }
    .hero__title { font-size:26px; line-height:1.15; }
    .hero__badge { font-size:11px; padding:5px 10px; }
    .hero__img-wrap { max-width:200px; }
    .hero__sub { font-size:var(--fs-small); }
    .hero__note { font-size:11px; }

    /* Section titles */
    .section__title { font-size:clamp(1.35rem,5vw,1.75rem); }
    .section { padding:48px 0; }

    /* Proof bar */
    .proof-bar__num, .proof-bar__suffix { font-size:24px; }

    /* Cards — tighter padding */
    .prob { padding:var(--sp-6) var(--sp-5); }
    .prob__title { font-size:16px; }
    .pillar { padding:var(--sp-6) var(--sp-5); }
    .pillar__num { font-size:36px; }
    .pillar__title { font-size:18px; }

    /* Results */
    .result-row { grid-template-columns:80px 30px 1fr 30px; gap:var(--sp-2); }
    .result-row__label { font-size:var(--fs-micro); }
    .results__grid { padding:var(--sp-5) var(--sp-4); }

    /* Testimonials */
    .testi__metric { font-size:32px; }
    .testi__body { padding:var(--sp-4); }
    .testi__author { gap:var(--sp-2); }

    /* About */
    .about__stats { flex-direction:column; align-items:center; gap:var(--sp-5); }
    .about__stat-num { font-size:24px; }
    .about__img-inner { max-width:240px; }

    /* Steps */
    .step__num { width:40px; height:40px; font-size:15px; }
    .step__line { margin-left:19px; height:28px; }
    .step__title { font-size:16px; }
    .step__text { font-size:13px; }

    /* FAQ */
    .faq__q { font-size:var(--fs-small); }

    /* CTA */
    .cta__title { font-size:22px; }
    .cta__text { font-size:var(--fs-small); }
    .cta__micro { font-size:11px; }

    /* Modal — true fullscreen */
    .modal { padding:0; }
    .modal__container { max-height:100vh; border-radius:0; }
    .modal__embed iframe { min-height:500px; }

    /* Nav CTA */
    .nav__cta { padding:8px 16px; font-size:11px; }

    /* Footer */
    .footer__social { justify-content:center; }
}

/* ------- Cookie consent banner ------- */
#cookieBanner {
    position:fixed; bottom:0; left:0; right:0;
    z-index:10000;
    background:var(--navy-deep, #12121F);
    border-top:1px solid rgba(200,169,126,.2);
    padding:var(--sp-4) var(--gutter);
    animation:cbSlideUp .4s ease both;
}
#cookieBanner.cb--hidden { animation:cbSlideDown .35s ease both; }
@keyframes cbSlideUp { from { transform:translateY(100%); } to { transform:translateY(0); } }
@keyframes cbSlideDown { from { transform:translateY(0); } to { transform:translateY(100%); } }

.cb__inner {
    max-width:var(--container, 1200px); margin:0 auto;
    display:flex; align-items:center; justify-content:space-between;
    gap:var(--sp-4); flex-wrap:wrap;
}
.cb__text {
    font-size:var(--fs-small); color:rgba(255,255,255,.6);
    line-height:1.6; flex:1; min-width:200px;
}
.cb__text a { color:var(--gold); text-decoration:underline; }
.cb__actions { display:flex; gap:var(--sp-3); flex-shrink:0; }
.cb__btn {
    padding:var(--sp-2) var(--sp-5); border-radius:6px;
    font-size:var(--fs-small); font-weight:600;
    cursor:pointer; border:none; transition:all .25s;
}
.cb__btn--accept { background:var(--gold); color:var(--navy); }
.cb__btn--accept:hover { background:var(--gold-hover); }
.cb__btn--reject {
    background:transparent; color:rgba(255,255,255,.5);
    border:1px solid rgba(255,255,255,.15);
}
.cb__btn--reject:hover { border-color:rgba(255,255,255,.3); color:rgba(255,255,255,.7); }

@media (max-width:580px) {
    .cb__inner { flex-direction:column; text-align:center; }
    .cb__actions { width:100%; justify-content:center; }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce) {
    *, *::before, *::after {
        animation-duration:.01ms !important;
        transition-duration:.01ms !important;
    }
    .fade-up { opacity:1; transform:none; }
    html { scroll-behavior:auto; }
}
