/* ============================================================
   HOLY HUSTLE FITNESS — Brand-aligned homepage
   Ported from html-files/home.html. Drives all holyhustle/* blocks.
   Colors:   #050505 / #18181B / #27272A / #D4A017 / #EAB308
   Fonts:    Anton (display) · Oswald (labels) · Inter (body)
   Ratio:    70% black/charcoal · 20% white/gray · 10% gold
   ============================================================ */
:root{
  --ink:#050505;
  --ink-card:#18181B;
  --ink-deep:#27272A;
  --gold:#D4A017;            /* metallic — headlines, borders */
  --gold-cta:#EAB308;        /* bright — CTAs, interactive */
  --gold-bright:#facc15;     /* hover */
  --paper:#FFFFFF;
  --muted:#A1A1AA;
}
html{scroll-behavior:smooth;}
body.holyhustle-home{
  background:var(--ink); color:#fff; min-height:100vh;
  font-family:'Inter',system-ui,sans-serif; overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
.holyhustle-home a{text-decoration:none;color:inherit;}
.holyhustle-home button{font-family:inherit;}

.holyhustle-home h1,.holyhustle-home h2,.holyhustle-home h3,.holyhustle-home h4,.price,.contact-h2,.stat-num,.form-title,.card-title,.pkg-title,.reel-title,.proc-num,.feat-h2{
  font-family:'Anton',sans-serif; font-weight:400; text-transform:uppercase; letter-spacing:.005em;
}
.eyebrow,.badge,.nav,.btn,.tag,.footer-brand,.price-detail,.pkg-tag,.pill,.reel-tag{
  font-family:'Oswald',sans-serif; font-weight:600;
}

/* progress + ambient */
.progress{position:fixed;top:0;left:0;height:3px;width:100%;background:linear-gradient(90deg,var(--gold),var(--gold-cta));transform-origin:0 50%;transform:scaleX(0);z-index:100;}
.ambient{position:fixed;top:-15%;right:-10%;width:50vw;height:50vw;max-width:680px;max-height:680px;background:radial-gradient(circle,rgba(212,160,23,.14),transparent 62%);pointer-events:none;z-index:0;filter:blur(20px);}

/* HEADER */
.header{position:fixed;top:0;left:0;right:0;z-index:90;transition:background .35s, border-color .35s;border-bottom:1px solid transparent;}
/* blur lives on a pseudo, NOT the header — backdrop-filter on .header would make
   the nav overlay's position:fixed resolve to the header box, not the viewport */
.header.solid{background:rgba(5,5,5,.82);border-color:rgba(212,160,23,.2);}
.header.solid::before{content:"";position:absolute;inset:0;z-index:-1;backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);pointer-events:none;}
.header-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;padding:16px 22px;transition:padding .35s;}
.header.solid .header-inner{padding:11px 22px;}
/* keep brand above the open overlay so the logo stays visible */
.header .brand{position:relative;z-index:2;}
.nav{display:flex !important;align-items:center;gap:32px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:#d4d4d8;}
.nav a{transition:color .2s;}
.nav a:hover,.nav a:focus{color:var(--gold-cta);}
.nav a:focus{outline:none;}
.nav a:focus-visible{outline:2px solid var(--gold-cta);outline-offset:4px;border-radius:6px;}
/* hamburger + close — icons drawn in CSS (core SVG can render empty) */
.nav .wp-block-navigation__responsive-container-open,
.nav .wp-block-navigation__responsive-container-close{position:relative;z-index:2;color:var(--gold-cta);background:transparent;border:0;cursor:pointer;width:44px;height:44px;display:flex;align-items:center;justify-content:center;padding:0;}
.nav .wp-block-navigation__responsive-container-open svg,
.nav .wp-block-navigation__responsive-container-close svg{display:none;}
.nav .wp-block-navigation__responsive-container-open::before{content:"";width:24px;height:2px;background:currentColor;box-shadow:0 -7px 0 currentColor,0 7px 0 currentColor;}
.nav .wp-block-navigation__responsive-container-close::before{content:"\00d7";font-size:34px;line-height:1;}
/* when open: solid header bar, hide hamburger, pin close top-right */
.header:has(.is-menu-open){background:rgba(5,5,5,.98);}
.header:has(.is-menu-open)::before{backdrop-filter:none;-webkit-backdrop-filter:none;}
.nav:has(.is-menu-open) .wp-block-navigation__responsive-container-open{display:none !important;}
.nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-close{position:fixed;top:16px;right:14px;}
/* Open overlay — full viewport, sits just under the brand (z:1 < brand z:2) so
   the logo stays visible; links stacked below the header bar */
.nav .wp-block-navigation__responsive-container.is-menu-open{position:fixed !important;inset:0 !important;z-index:1;display:flex !important;flex-direction:column;justify-content:flex-start;align-items:stretch;background-color:rgba(5,5,5,.98) !important;color:#fff !important;padding:88px 28px 40px;}
.nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content{display:flex;flex-direction:column;gap:0;width:100%;}
.nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container{flex-direction:column;gap:0;width:100%;}
.nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item{border-bottom:1px solid rgba(255,255,255,.09);}
.nav .wp-block-navigation__responsive-container.is-menu-open a,
.nav .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__label{color:#fff !important;font-family:'Oswald';font-weight:600;font-size:24px;letter-spacing:.14em;text-transform:uppercase;padding:18px 0;display:block;}
.nav .wp-block-navigation__responsive-container.is-menu-open a:hover,
.nav .wp-block-navigation__responsive-container.is-menu-open a.is-active,
.nav .wp-block-navigation__responsive-container.is-menu-open [aria-current="page"]{color:var(--gold-cta) !important;}
/* Deterministic responsive toggle: hamburger < 960px, inline links >= 960px. */
@media(max-width:959.98px){
  .nav .wp-block-navigation__responsive-container-open{display:flex !important;}
  .nav .wp-block-navigation__responsive-container:not(.is-menu-open){display:none !important;}
}
@media(min-width:960px){
  .nav .wp-block-navigation__responsive-container-open,
  .nav .wp-block-navigation__responsive-container-close{display:none !important;}
  .nav .wp-block-navigation__responsive-container{display:flex !important;position:static !important;background:transparent !important;}
}

/* BUTTONS */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:9px;border-radius:999px;font-weight:700;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;border:none;transition:transform .25s cubic-bezier(.2,.8,.2,1), background .25s, color .25s, box-shadow .25s;font-size:14px;font-family:'Oswald';}
.btn-sm{padding:10px 22px;font-size:13px;}
.btn-lg{padding:18px 30px;font-size:15px;}
.btn-block{width:100%;padding:15px;}
.btn-gold{background:var(--gold-cta);color:#000;box-shadow:0 8px 30px -8px rgba(234,179,8,.55);}
.btn-gold:hover{background:var(--gold-bright);transform:translateY(-3px);box-shadow:0 14px 38px -8px rgba(234,179,8,.7);}
.btn-ghost{background:transparent;color:#fff;border:1px solid rgba(212,160,23,.55);}
.btn-ghost:hover{background:rgba(212,160,23,.12);color:var(--gold-cta);transform:translateY(-3px);}
.btn-dark{background:#000;color:#fff;}
.btn-dark:hover{background:var(--ink-card);transform:translateY(-3px);}
.btn-outline-dark{background:transparent;color:#000;border:2px solid #000;}
.btn-outline-dark:hover{background:#000;color:#fff;transform:translateY(-3px);}
.btn svg{width:1em;height:1em;}

/* MOBILE STICKY CTA */
.mobile-sticky{position:fixed;bottom:18px;left:18px;right:18px;z-index:80;display:none;}
.mobile-sticky .btn{width:100%;padding:16px;box-shadow:0 12px 36px -8px rgba(0,0,0,.7), 0 0 0 1px rgba(212,160,23,.4);}
@media(max-width:680px){.mobile-sticky{display:block;}body.holyhustle-home{padding-bottom:80px;}
/* floating sticky CTA covers the booking action on mobile — hide the header button */
.header-inner > .wp-block-buttons{display:none;}}

/* HERO */
.hero{position:relative;padding-top:120px;overflow:hidden;}
.hero-grid{position:absolute;inset:-10% 0;background-image:linear-gradient(rgba(255,255,255,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.04) 1px,transparent 1px);background-size:46px 46px;-webkit-mask-image:radial-gradient(circle at 30% 20%,#000,transparent 75%);mask-image:radial-gradient(circle at 30% 20%,#000,transparent 75%);z-index:0;}
.hero-glow{position:absolute;border-radius:50%;filter:blur(60px);z-index:0;}
.hero-glow-1{top:-6%;left:-8%;width:520px;height:520px;background:radial-gradient(circle,rgba(212,160,23,.22),transparent 60%);}
.hero-glow-2{bottom:6%;right:-6%;width:420px;height:420px;background:radial-gradient(circle,rgba(212,160,23,.13),transparent 60%);}
.hero-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:30px 22px 90px;display:grid;gap:48px;align-items:center;}
@media(min-width:1000px){.hero-inner{grid-template-columns:1.05fr .95fr;padding:40px 22px 120px;}}
.badge{display:inline-flex;align-items:center;gap:8px;border-radius:999px;border:1px solid rgba(212,160,23,.45);background:rgba(212,160,23,.1);padding:9px 16px;font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-cta);margin-bottom:24px;}
.h1{font-size:clamp(74px,17vw,128px);line-height:.95;color:#fff;}
.line{display:block;}
.gold{color:var(--gold-cta);}
.hero-sub{margin-top:24px;max-width:520px;font-size:18px;line-height:1.6;color:#d4d4d8;}
.hero-sub strong{color:#fff;font-weight:600;}
.hero-cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px;}
.pillars{margin-top:40px;display:grid;grid-template-columns:repeat(3,1fr);gap:12px;max-width:560px;}
.pillar{border:1px solid rgba(255,255,255,.1);background:rgba(255,255,255,.03);border-radius:16px;padding:16px;transition:border-color .3s, transform .3s;}
.pillar:hover{border-color:rgba(212,160,23,.55);transform:translateY(-4px);}
.pillar-title{font-family:'Oswald';font-size:14px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-cta);}
.pillar-text{margin-top:8px;font-size:12px;line-height:1.5;color:var(--muted);}

/* VERTICAL VIDEO COMPONENT */
.vreel{position:relative;border-radius:28px;overflow:hidden;border:1px solid rgba(212,160,23,.3);background:var(--ink-card);box-shadow:0 40px 80px -30px #000;aspect-ratio:9/16;}
.vreel-video{width:100%;height:100%;object-fit:cover;display:block;background:#000;}
.vreel-placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;background:linear-gradient(135deg,rgba(212,160,23,.18),rgba(24,24,27,.95)),radial-gradient(circle at 30% 20%,rgba(212,160,23,.25),transparent 50%);color:#fff;text-align:center;padding:24px;pointer-events:none;}
.vreel-placeholder.hidden{display:none;}
.vreel-play{width:80px;height:80px;border-radius:50%;background:rgba(212,160,23,.18);border:1px solid rgba(212,160,23,.5);display:flex;align-items:center;justify-content:center;color:var(--gold-cta);animation:pulse 2.4s ease-in-out infinite;}
.vreel-play svg{width:30px;height:30px;margin-left:4px;}
@keyframes pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(212,160,23,.4);}50%{transform:scale(1.05);box-shadow:0 0 0 20px rgba(212,160,23,0);}}
.vreel-placeholder-text{font-family:'Anton';font-size:22px;text-transform:uppercase;letter-spacing:.04em;}
.vreel-placeholder-sub{font-family:'Oswald';font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:rgba(255,255,255,.6);}
.vreel-label{position:absolute;bottom:0;left:0;right:0;padding:20px;background:linear-gradient(to top,#000,rgba(0,0,0,.7),transparent);}
.vreel-tag{display:inline-block;font-family:'Oswald';font-weight:600;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--gold-cta);background:rgba(212,160,23,.15);border:1px solid rgba(212,160,23,.4);padding:4px 10px;border-radius:999px;margin-bottom:10px;}
.vreel-title{font-family:'Anton';font-size:24px;text-transform:uppercase;line-height:1;color:#fff;}
.vreel-glow{position:absolute;inset:-16px;border-radius:36px;background:rgba(212,160,23,.18);filter:blur(50px);z-index:-1;}
/* unmute toggle — top-right of the reel; video still autoplays muted */
.vreel-mute{position:absolute;top:12px;right:12px;z-index:4;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:rgba(0,0,0,.5);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);transition:background .2s,color .2s,transform .2s;}
.vreel-mute:hover{background:var(--gold-cta);color:#000;transform:scale(1.06);}
.vreel-mute svg{width:18px;height:18px;display:block;}
.vreel-mute .icon-unmuted{display:none;}
.vreel-mute.is-unmuted .icon-muted{display:none;}
.vreel-mute.is-unmuted .icon-unmuted{display:block;}

.hero-video{position:relative;}
.hero-video .vreel{aspect-ratio:4/5;}
.float-tag{position:absolute;display:inline-flex;align-items:center;gap:6px;background:var(--gold-cta);color:#000;font-family:'Oswald';font-weight:700;text-transform:uppercase;letter-spacing:.12em;font-size:12px;padding:8px 14px;border-radius:999px;box-shadow:0 10px 30px -8px rgba(0,0,0,.6);z-index:3;}
.float-tag-1{top:22px;left:22px;animation:bob 3.5s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translateY(0);}50%{transform:translateY(-9px);}}

.scroll-hint{position:relative;z-index:2;display:flex;align-items:center;justify-content:center;gap:10px;padding-bottom:20px;font-family:'Oswald';text-transform:uppercase;letter-spacing:.3em;font-size:11px;color:var(--muted);}
.scroll-hint span{width:1px;height:34px;background:linear-gradient(var(--gold),transparent);animation:drop 1.8s ease-in-out infinite;}
@keyframes drop{0%{opacity:.2;transform:scaleY(.3);transform-origin:top;}50%{opacity:1;transform:scaleY(1);}100%{opacity:.2;transform:scaleY(.3);transform-origin:bottom;}}

/* MARQUEE — two identical groups, each ≥ viewport, translateX(-50%) loops seamlessly */
.marquee{border-top:1px solid rgba(212,160,23,.22);border-bottom:1px solid rgba(212,160,23,.22);background:#000;padding:18px 0;overflow:hidden;position:relative;z-index:2;}
.marquee-track{display:flex;width:max-content;will-change:transform;animation:hh-marquee-scroll 28s linear infinite;}
.marquee-group{display:flex;flex-shrink:0;align-items:center;}
.marquee-track span,.marquee-group span{display:inline-flex;align-items:center;gap:22px;padding-right:22px;font-family:'Anton';font-size:30px;text-transform:uppercase;color:#fff;white-space:nowrap;}
.marquee-track svg,.marquee-group svg{color:var(--gold-cta);width:18px;height:18px;flex-shrink:0;}
@keyframes hh-marquee-scroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
@media(prefers-reduced-motion:reduce){.marquee-track{animation:none;}}

/* MISSION BAND */
.mission{background:#000;padding:60px 0;border-bottom:1px solid rgba(212,160,23,.12);}
.mission-inner{max-width:1200px;margin:0 auto;padding:0 22px;text-align:center;}
.mission-h{font-family:'Anton';font-size:clamp(34px,5vw,60px);text-transform:uppercase;line-height:1;}
.mission-h .gold{color:var(--gold-cta);}
.mission-sub{margin-top:14px;color:var(--muted);font-size:16px;}

/* STATS */
.stats{position:relative;z-index:2;background:var(--ink);padding:60px 0;}
.stats-inner{max-width:1200px;margin:0 auto;padding:0 22px;display:grid;grid-template-columns:repeat(2,1fr);gap:30px;}
@media(min-width:760px){.stats-inner{grid-template-columns:repeat(4,1fr);}}
.stat{text-align:center;}
.stat-num{font-size:clamp(48px,7vw,80px);line-height:1;color:var(--gold-cta);}
.stat-label{margin-top:8px;font-family:'Oswald';text-transform:uppercase;letter-spacing:.18em;font-size:13px;font-weight:600;color:var(--muted);}

/* SECTION */
.section{position:relative;z-index:2;padding:96px 0;}
.section-inner{max-width:1200px;margin:0 auto;padding:0 22px;}
.section-head{max-width:780px;margin-bottom:54px;}
.section-head.center{margin-left:auto;margin-right:auto;text-align:center;}
.eyebrow{font-family:'Oswald';font-size:13px;font-weight:600;letter-spacing:.3em;text-transform:uppercase;color:var(--gold-cta);}
.eyebrow-dark{color:rgba(0,0,0,.7);}
.h2{font-size:clamp(38px,6vw,72px);line-height:.95;margin-top:12px;color:#fff;}

/* REEL GRID */
.reels{background:#000;padding:96px 0;position:relative;overflow:hidden;}
.reels::before{content:'';position:absolute;top:20%;left:-10%;width:500px;height:500px;background:radial-gradient(circle,rgba(212,160,23,.14),transparent 60%);filter:blur(40px);}
/* reels are a horizontal carousel at every size — max 4 frames visible on desktop */
.reel-grid{display:flex;gap:18px;position:relative;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 0 14px;touch-action:pan-x;}
.reel-grid::-webkit-scrollbar{display:none;}
.reel-grid > *{flex:0 0 78%;scroll-snap-align:start;}
@media(min-width:680px){.reel-grid > *{flex-basis:calc((100% - 18px) / 2);}}
@media(min-width:1000px){.reel-grid > *{flex-basis:calc((100% - 54px) / 4);}}
.reel-grid .vreel{aspect-ratio:9/16;}

/* PACKAGES */
.packages{padding:96px 0;}
.pkg-grid{display:grid;gap:24px;}
@media(min-width:760px){.pkg-grid{grid-template-columns:repeat(2,1fr);}}
@media(min-width:1100px){.pkg-grid{grid-template-columns:repeat(3,1fr);}}
/* mobile: packages become a swipeable scroll-snap slider.
   overflow-x:auto forces overflow-y to clip, so the hover lift gets cut off —
   drop the translate on touch and pad the track for the glow/shadow. */
@media(max-width:759.98px){
  .pkg-grid{display:flex;grid-template-columns:none;gap:16px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin:0 -22px;padding:18px 22px 28px;touch-action:pan-x;}
  .pkg-grid::-webkit-scrollbar{display:none;}
  .pkg-grid > .pkg{flex:0 0 86%;scroll-snap-align:center;}
  .pkg-grid > .pkg:hover{transform:none;}
}
/* prev/next buttons for the reel + package carousels (JS-injected) */
.hh-carousel-nav{display:flex;justify-content:center;gap:14px;margin-top:26px;}
.hh-carousel-btn{width:46px;height:46px;border-radius:50%;border:1px solid rgba(212,160,23,.5);background:transparent;color:var(--gold-cta);font-family:'Oswald';font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .2s,opacity .2s;}
.hh-carousel-btn:hover{background:var(--gold-cta);color:#000;transform:translateY(-2px);}
.hh-carousel-btn:focus{outline:none;}
.hh-carousel-btn:focus-visible{outline:2px solid var(--gold-cta);outline-offset:3px;}
.hh-carousel-btn:disabled{opacity:.3;pointer-events:none;}
.pkg{position:relative;border:1px solid rgba(212,160,23,.25);background:linear-gradient(180deg,rgba(24,24,27,.85),rgba(24,24,27,.6));border-radius:24px;padding:32px;transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,box-shadow .35s;display:flex;flex-direction:column;}
.pkg:hover{transform:translateY(-8px);border-color:rgba(212,160,23,.75);box-shadow:0 30px 60px -30px rgba(212,160,23,.45);}
.pkg-tag{position:absolute;top:18px;right:18px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-cta);background:rgba(212,160,23,.12);border:1px solid rgba(212,160,23,.4);padding:5px 11px;border-radius:999px;}
.pkg-icon{display:flex;height:56px;width:56px;align-items:center;justify-content:center;border-radius:18px;background:rgba(212,160,23,.1);box-shadow:inset 0 0 0 1px rgba(212,160,23,.35);color:var(--gold);margin-bottom:24px;transition:transform .35s;}
.pkg:hover .pkg-icon{transform:rotate(-8deg) scale(1.08);}
.pkg-icon svg{width:26px;height:26px;}
.pkg-title{font-size:28px;}
.pkg-price-row{display:flex;align-items:flex-end;gap:8px;margin-top:18px;padding-bottom:20px;border-bottom:1px solid rgba(255,255,255,.07);}
.pkg-price{font-family:'Anton';font-size:60px;line-height:.9;color:#fff;}
.pkg-price-detail{padding-bottom:8px;font-family:'Oswald';font-weight:600;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold-cta);}
.pkg-features{margin-top:22px;display:grid;gap:12px;flex:1;}
.pkg-feature{display:flex;gap:12px;align-items:flex-start;color:#e4e4e7;font-size:15px;line-height:1.5;}
.pkg-feature svg{color:var(--gold-cta);flex-shrink:0;width:18px;height:18px;margin-top:2px;}
.pkg-cta{margin-top:24px;}

/* PROVERBS & PROTEIN FEATURE */
.feat{position:relative;padding:96px 0;background:linear-gradient(180deg,#050505,#0a0a0a);overflow:hidden;}
.feat::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,160,23,.4),transparent);}
.feat::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(212,160,23,.4),transparent);}
.feat-glow{position:absolute;top:30%;right:-10%;width:520px;height:520px;background:radial-gradient(circle,rgba(212,160,23,.18),transparent 60%);filter:blur(50px);}
.feat-inner{position:relative;z-index:2;max-width:1200px;margin:0 auto;padding:0 22px;display:grid;gap:54px;align-items:center;}
@media(min-width:1000px){.feat-inner{grid-template-columns:1fr 1fr;}}
.feat-free{display:inline-flex;align-items:center;gap:8px;background:var(--gold-cta);color:#000;font-family:'Oswald';font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:12px;padding:8px 14px;border-radius:999px;margin-bottom:20px;box-shadow:0 8px 24px -6px rgba(234,179,8,.5);}
.feat-h2{font-size:clamp(54px,8vw,104px);line-height:.95;color:#fff;}
.feat-h2 .gold{color:var(--gold-cta);}
.feat-tagline{margin-top:18px;font-family:'Anton';font-size:clamp(22px,3vw,32px);text-transform:uppercase;color:var(--gold);letter-spacing:.04em;}
.feat-desc{margin-top:22px;max-width:520px;font-size:17px;line-height:1.7;color:#d4d4d8;}
.feat-features{margin-top:26px;display:grid;gap:12px;}
.feat-feature{display:flex;gap:12px;align-items:center;color:#e4e4e7;font-size:15px;}
.feat-feature svg{color:var(--gold-cta);width:18px;height:18px;flex-shrink:0;}
.feat-cta{margin-top:30px;display:flex;flex-wrap:wrap;gap:12px;}
.feat-video{position:relative;}
.feat-video .vreel{aspect-ratio:9/16;max-width:380px;margin:0 auto;}

/* RAISE THE STANDARD */
.standard{background:#000;padding:96px 0;position:relative;overflow:hidden;}
.standard-glow{position:absolute;top:10%;left:8%;width:460px;height:460px;background:radial-gradient(circle,rgba(212,160,23,.16),transparent 60%);filter:blur(40px);}
.standard-inner{position:relative;z-index:1;max-width:1200px;margin:0 auto;padding:0 22px;display:grid;gap:44px;align-items:center;}
@media(min-width:980px){.standard-inner{grid-template-columns:1fr 1fr;}}
.standard-card{overflow:hidden;border-radius:28px;border:1px solid rgba(255,255,255,.1);background:var(--ink-card);}
.standard-img{position:relative;aspect-ratio:5/4;overflow:hidden;background:#000;color:#fff;}
/* HH Raise The Standard — GRITTY B&W FILM REEL. Constant grain, scratches +
   vignette. JS steps frame-to-frame: eases to a photo, dwells, then speeds to
   the next. No sprocket side borders. */
.standard-film{filter:contrast(1.04);}
/* GPU-smooth B&W: a grayscale backdrop overlay we crossfade via OPACITY
   (opacity is composited on the GPU — no filter-transition chop) */
.film-bw{position:absolute;inset:0;z-index:1;pointer-events:none;opacity:0;backdrop-filter:grayscale(1);-webkit-backdrop-filter:grayscale(1);transition:opacity 1s ease;will-change:opacity;}
.standard-film.film-moving .film-bw{opacity:1;}
/* during the slide: distortion is jitter + static only — no filter change */
.standard-film.film-glitch{animation:filmShake .6s both;}
.standard-film.film-glitch::before{opacity:.5;animation:filmGrain .08s steps(2) infinite;}
@keyframes filmShake{
  0%{transform:translateY(0);}
  12%{transform:translateY(-7px);}
  24%{transform:translateY(6px);}
  36%{transform:translateY(-5px);}
  50%{transform:translateY(8px);}
  64%{transform:translateY(-4px);}
  78%{transform:translateY(4px);}
  90%{transform:translateY(-2px);}
  100%{transform:translateY(0);}
}
/* first time in view: power on from B&W to color (original reveal) */
.standard-film.film-reveal{animation:filmReveal 1.9s ease;}
@keyframes filmReveal{
  0%{filter:grayscale(1) brightness(1.7) contrast(1.4);}
  10%{filter:grayscale(1) brightness(.8) contrast(1.3);}
  20%{filter:grayscale(1) brightness(1.3) contrast(1.2);}
  35%{filter:grayscale(1) brightness(1) contrast(1.2);}
  55%{filter:grayscale(1) contrast(1.15);}        /* hold B&W */
  68%{filter:grayscale(.6) brightness(1.15);}     /* color creeping in */
  74%{filter:grayscale(1) brightness(.85);}       /* flicker back */
  82%{filter:grayscale(.3);}
  100%{filter:contrast(1.04);}                    /* settle to color */
}
.film-track{display:flex;flex-direction:column;will-change:transform;}
.film-track--static{transform:none !important;}
.film-frame{flex:0 0 auto;width:100%;aspect-ratio:4/5;background-size:cover;background-position:center;border-bottom:2px solid #000;}
/* film grain */
.standard-film::before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;opacity:.22;mix-blend-mode:overlay;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");background-size:150px 150px;animation:filmGrain .22s steps(2) infinite;}
/* vertical scratches + vignette + projector flicker */
.standard-film::after{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;background:
  repeating-linear-gradient(90deg,transparent 0 7px,rgba(255,255,255,.05) 7px 8px,transparent 8px 27px,rgba(0,0,0,.06) 27px 28px,transparent 28px 54px),
  radial-gradient(130% 120% at 50% 50%,transparent 58%,rgba(0,0,0,.55) 100%);
  animation:filmFlicker .42s steps(3) infinite, scratchShift 3.2s steps(5) infinite;}
.film-scrim{position:absolute;inset:0;z-index:3;pointer-events:none;background:linear-gradient(135deg,rgba(0,0,0,.62),transparent 46%);}
.standard-film .standard-img-copy{position:absolute;top:0;left:0;max-width:340px;padding:36px;z-index:5;}
.standard-film .eyebrow{color:#fff;}
@keyframes filmGrain{0%{background-position:0 0;}50%{background-position:-40px 30px;}100%{background-position:35px -45px;}}
@keyframes filmFlicker{0%,100%{opacity:.88;}50%{opacity:1;}}
@keyframes scratchShift{0%{background-position:0 0,0 0;}100%{background-position:16px 0,0 0;}}
@media(prefers-reduced-motion:reduce){
  .standard-film.film-reveal,.standard-film.film-glitch,.standard-film::before,.standard-film::after{animation:none !important;}
}
.standard-big{margin-top:24px;font-family:'Anton';font-size:clamp(44px,6vw,68px);line-height:.9;text-transform:uppercase;}
.standard-rule{margin-top:22px;height:6px;width:160px;background:var(--gold-cta);}
.standard-text{margin-top:24px;max-width:520px;font-size:18px;line-height:1.7;color:#d4d4d8;}
.benefits{margin-top:30px;display:grid;gap:12px;}
@media(min-width:560px){.benefits{grid-template-columns:1fr 1fr;}}
.benefit{display:flex;align-items:center;gap:12px;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.03);border-radius:14px;padding:14px 16px;transition:border-color .3s,transform .3s;}
.benefit:hover{border-color:rgba(212,160,23,.5);transform:translateX(4px);}
.benefit svg{color:var(--gold-cta);flex-shrink:0;width:18px;height:18px;}
.benefit span{font-weight:500;color:#e4e4e7;font-size:14px;}
.standard-quote{margin:34px 0 0;padding:20px 26px;border-left:4px solid var(--gold-cta);background:rgba(212,160,23,.06);border-radius:0 14px 14px 0;font-family:'Oswald';font-size:clamp(18px,2.4vw,24px);font-style:italic;line-height:1.5;color:#fff;}
.standard-quote cite{display:block;margin-top:12px;font-style:normal;font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold-cta);}

/* TESTIMONIALS SLIDER */
.testimonials{background:#000;padding:96px 0;position:relative;overflow:hidden;}
.testimonials::before{content:'';position:absolute;bottom:0;right:-8%;width:480px;height:480px;background:radial-gradient(circle,rgba(212,160,23,.14),transparent 60%);filter:blur(40px);}
.testi-track{position:relative;display:flex;gap:24px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:48px;touch-action:pan-x;}
.testi-track::-webkit-scrollbar{display:none;}
.testi-card{flex:0 0 100%;scroll-snap-align:center;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px;background:var(--ink-card);border:1px solid rgba(212,160,23,.25);border-radius:24px;padding:48px 32px;}
.testi-quote{max-width:760px;margin:0;font-family:'Oswald';font-weight:500;font-style:italic;font-size:clamp(20px,2.6vw,30px);line-height:1.5;color:#fff;}
.testi-quote::before{content:'\201C';font-family:Georgia,serif;font-size:54px;color:var(--gold-cta);line-height:0;vertical-align:-14px;margin-right:6px;}
.testi-cite{display:flex;flex-direction:column;gap:4px;}
.testi-name{margin:0;font-family:'Anton';text-transform:uppercase;letter-spacing:.04em;color:var(--gold-cta);font-size:20px;}
.testi-role{margin:0;font-family:'Oswald';font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);}
.testi-nav{display:flex;align-items:center;justify-content:center;gap:18px;margin-top:32px;}
.testi-arrow{width:46px;height:46px;border-radius:50%;border:1px solid rgba(212,160,23,.5);background:transparent;color:var(--gold-cta);font-family:'Oswald';font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s,color .2s,transform .2s;}
.testi-arrow:hover{background:var(--gold-cta);color:#000;transform:translateY(-2px);}
.testi-dots{display:flex;gap:10px;align-items:center;}
.testi-dot{width:10px;height:10px;border-radius:50%;border:none;background:rgba(255,255,255,.25);cursor:pointer;padding:0;transition:background .2s,transform .2s;}
.testi-dot.active{background:var(--gold-cta);transform:scale(1.3);}

/* CONTACT */
.contact{position:relative;z-index:2;background:linear-gradient(135deg,var(--gold-bright),var(--gold-cta));color:#000;padding:90px 0;}
.contact-inner{max-width:1200px;margin:0 auto;padding:0 22px;display:grid;gap:48px;align-items:center;}
@media(min-width:980px){.contact-inner{grid-template-columns:1fr 1fr;}}
.contact-h2{font-size:clamp(54px,9vw,104px);line-height:.95;margin-top:14px;color:#000;}
.contact-sub{margin-top:22px;max-width:460px;font-size:18px;font-weight:500;line-height:1.6;color:rgba(0,0,0,.78);}
.contact-actions{margin-top:30px;display:flex;flex-wrap:wrap;gap:14px;}
.contact-formwrap{background:var(--ink);border-radius:24px;padding:32px;box-shadow:0 40px 80px -30px rgba(0,0,0,.5);}
.contact-form-head{margin-bottom:22px;}
.form-title{font-size:30px;color:#fff;margin-top:8px;}
.form{display:flex;flex-direction:column;gap:18px;}
.field-row{display:grid;gap:18px;}
@media(min-width:480px){.field-row{grid-template-columns:1fr 1fr;}}
.field{display:flex;flex-direction:column;gap:8px;}
.field>span{font-family:'Oswald';font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:12px;color:var(--gold-cta);}
.field input{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:13px 15px;color:#fff;font-family:'Inter';font-size:15px;transition:border-color .25s,background .25s;}
.field input::placeholder{color:#71717a;}
.field input:focus{outline:none;border-color:var(--gold-cta);background:rgba(212,160,23,.06);}
.pills{display:flex;flex-wrap:wrap;gap:8px;}
.pill{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:999px;padding:9px 14px;color:#d4d4d8;font-size:12px;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;transition:all .2s;}
.pill:hover{border-color:rgba(212,160,23,.55);}
.pill.active{background:var(--gold-cta);color:#000;border-color:var(--gold-cta);}
.submit{margin-top:6px;display:flex;align-items:center;justify-content:center;gap:10px;background:var(--gold-cta);color:#000;border:none;border-radius:999px;padding:17px;font-family:'Oswald';font-weight:700;font-size:16px;text-transform:uppercase;letter-spacing:.12em;cursor:pointer;transition:background .25s,transform .25s,box-shadow .25s;}
.submit:hover{background:var(--gold-bright);transform:translateY(-2px);box-shadow:0 14px 34px -10px rgba(234,179,8,.7);}
.submit svg{width:20px;height:20px;}
.submit-arrow{transition:transform .25s;}
.submit:hover .submit-arrow{transform:translateX(5px);}
/* mobile form polish — even pill grid + smaller submit text + tidy spacing */
@media(max-width:980px){
  .pills{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
  .pill{display:flex;align-items:center;justify-content:center;text-align:center;min-height:44px;padding:10px 12px;line-height:1.2;}
  .submit{font-size:clamp(13px,3.2vw,16px);letter-spacing:.06em;padding:16px 14px;}
  .submit svg{width:18px;height:18px;}
}
@media(max-width:560px){
  .contact-formwrap{padding:24px 18px;}
  .contact-actions{gap:10px;}
  .contact-actions .btn{flex:1 1 140px;justify-content:center;}
}
.form-note{font-size:12px;color:#71717a;text-align:center;}

/* FOOTER */
.footer{background:#000;padding:40px 0;}
.footer-inner{max-width:1200px;margin:0 auto;padding:32px 22px 0;border-top:1px solid rgba(255,255,255,.08);display:flex;flex-direction:column;gap:12px;}
@media(min-width:760px){.footer-inner{flex-direction:row;align-items:center;justify-content:space-between;}}
.footer-brand{font-family:'Anton';text-transform:uppercase;letter-spacing:.2em;font-size:18px;color:#fff;}
.footer-tag{font-family:'Oswald';font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:#52525b;}

/* REVEAL */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .9s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform;}
.reveal.in{opacity:1;transform:translateY(0);}
.pop{opacity:0;animation:pop .9s cubic-bezier(.2,.7,.2,1) forwards;}
@keyframes pop{from{opacity:0;transform:translateY(26px);}to{opacity:1;transform:translateY(0);}}
@media(prefers-reduced-motion:reduce){
  .pop,.marquee-track,.float-tag-1,.scroll-hint span,.vreel-play{animation:none !important;}
  .pop,.reveal{opacity:1 !important;transform:none !important;}
}

/* ============================================================
   COMPOSITION BRIDGE — core blocks inside holyhustle/* containers.
   Container templates give core blocks the design classNames (.h1,
   .hero-sub, .h2, .pkg-features …) so existing rules above style them.
   These add the few things composition needs.
   ============================================================ */
.hh-vreel{position:relative;display:block;}
.wp-block-heading.h1,.wp-block-heading.h2,.wp-block-heading.mission-h,.wp-block-heading.feat-h2,.wp-block-heading.contact-h2{margin:0;}
/* core button groups standing in for the mockup CTA rows (spacing only — the
   button look itself comes from theme.json default + registered block styles) */
.hero .wp-block-buttons{margin-top:34px;gap:14px;}
.feat .wp-block-buttons{margin-top:30px;gap:12px;}
.contact .wp-block-buttons{margin-top:30px;gap:14px;}
.standard .wp-block-buttons{margin-top:28px;}
.pkg .wp-block-buttons.pkg-cta{margin-top:24px;}
.pkg .wp-block-buttons.pkg-cta .wp-block-button{width:100%;}
/* group wrappers used purely for layout shouldn't add flow margins */
.hero-copy,.section-head,.pillars,.pkg-features,.feat-features,.reel-grid,.pkg-grid,.feat-copy,.standard-right,.contact-left{margin:0;}
/* proverbs reel keeps the mockup's centered, narrower column */
.feat-inner > .hh-vreel{max-width:380px;margin:0 auto;width:100%;}


/* gold list markers */
.holyhustle-home li::marker,
.editor-styles-wrapper li::marker{color:var(--gold-cta);}

/* Charcoal Card — the .pkg look for core Group/Columns/Column */
.is-style-hh-card{
	background:linear-gradient(180deg,rgba(24,24,27,.85),rgba(24,24,27,.6));
	border:1px solid rgba(212,160,23,.25);
	border-radius:24px;
	padding:32px;
	transition:transform .35s cubic-bezier(.2,.8,.2,1),border-color .35s,box-shadow .35s;
}
.is-style-hh-card:hover{border-color:rgba(212,160,23,.6);box-shadow:0 30px 60px -30px rgba(212,160,23,.45);}

/* Gold Outline — transparent panel with a gold rule */
.is-style-hh-outline{
	background:transparent;
	border:1px solid rgba(212,160,23,.55);
	border-radius:20px;
	padding:28px;
}

/* Ghost button — transparent, gold border (brand secondary CTA) */
.wp-block-button.is-style-hh-ghost .wp-block-button__link{
	background:transparent;
	color:#fff;
	border:1px solid rgba(212,160,23,.55);
	border-radius:999px;
}
.wp-block-button.is-style-hh-ghost .wp-block-button__link:hover{
	background:rgba(212,160,23,.12);
	color:var(--gold-cta);
}
/* Dark button — black pill (use on the gold contact band) */
.wp-block-button.is-style-hh-dark .wp-block-button__link{
	background:#000;color:#fff;border-radius:999px;
}
.wp-block-button.is-style-hh-dark .wp-block-button__link:hover{background:var(--ink-card);}
/* Outline Dark button — transparent, black border */
.wp-block-button.is-style-hh-outline-dark .wp-block-button__link{
	background:transparent;color:#000;border:2px solid #000;border-radius:999px;
}
.wp-block-button.is-style-hh-outline-dark .wp-block-button__link:hover{background:#000;color:#fff;}

/* Gold Frame image */
.is-style-hh-frame img,
.is-style-hh-frame.wp-block-image img{
	border:2px solid var(--gold-cta);
	border-radius:18px;
	box-shadow:0 24px 60px -30px rgba(212,160,23,.5);
}

/* Gold Glow separator — gradient rule like the mockup section dividers */
.wp-block-separator.is-style-hh-glow{
	border:none;height:2px;max-width:240px;opacity:1;
	background:linear-gradient(90deg,transparent,var(--gold-cta),transparent);
}
.wp-block-separator.is-style-hh-glow.alignfull,
.wp-block-separator.is-style-hh-glow.alignwide{max-width:none;}

/* Gold text accent for heading/paragraph */
.is-style-hh-gold{color:var(--gold-cta) !important;}

/* Editor canvas: match the dark brand so inline editing is WYSIWYG */
.editor-styles-wrapper{background:var(--ink);color:#fff;font-family:'Inter',system-ui,sans-serif;}
.editor-styles-wrapper .hh-item-tools .components-button{color:#fff;}

/* Let holyhustle/* sections span full width in the editor — core constrains
   root children to contentSize (1200px); these sections are full-bleed by design. */
.block-editor-block-list__layout.is-root-container > [data-type^="holyhustle/"],
.editor-styles-wrapper .is-root-container > [data-type^="holyhustle/"]{
	max-width:none !important;
	margin-left:0 !important;
	margin-right:0 !important;
}

/* WordPress integration — strip default block chrome so the ported layout owns spacing */
.holyhustle-home .wp-site-blocks > main:not(.site-main):not(.error-404),
.holyhustle-home main.wp-block-group:not(.site-main):not(.error-404){padding:0 !important;}
.holyhustle-home .holyhustle-section{max-width:none;}

/* core/navigation styled like the original flat .nav */
.nav .wp-block-navigation__container{gap:32px;font-size:13px;letter-spacing:.18em;text-transform:uppercase;}
.nav .wp-block-navigation-item a{color:#d4d4d8;transition:color .2s;}
.nav .wp-block-navigation-item a:hover{color:var(--gold-cta);text-decoration:none;}

/* ACTIVE STATE — gold for current page (WP current-menu-item) + in-view anchor (scrollspy .is-active) */
.nav .current-menu-item > a,
.nav .current-menu-item .wp-block-navigation-item__content,
.nav .current_page_item > a,
.nav .current_page_item .wp-block-navigation-item__content,
.nav .wp-block-navigation-item.is-active > a,
.nav a.is-active,
.nav [aria-current="page"],
.nav .wp-block-navigation-item__content.is-active{color:var(--gold-cta) !important;}
