/*
  The Profitable Chair Challenge  -  https://profitablechairchallenge.com
  Crafted with care by Wave Agency waveagency.com
  Version: 2.0.5  |  2026-06-26
*/
/* =========================================================
   The Profitable Chair Challenge - brand system (SalonTech)
   Real brand tokens. Hot pink + black + cyan, gold foil = VIP.
   ========================================================= */

:root{
  /* Brand */
  --pink:      #F20AA5;   /* primary action / brand */
  --pink-deep: #C5078A;   /* hover */
  --pink-wash: #FDE7F5;   /* light pink panel wash */
  --black:     #000000;
  --ink:       #1A1A1A;   /* dark UI + text on light */
  --paper:     #FFFFFF;
  --panel:     #F5F5F5;
  --panel-2:   #ECECEC;
  --line:      #E5E5E5;
  --line-2:    #D4D4D4;
  --line-dark: #2E2E2E;
  --muted:     #5F5F5F;
  --muted-2:   #8A8A8A;
  --cyan:      #51CDE0;
  --cyan-deep: #2FB6CC;
  --gold-solid:#9A7B14;
  --gold-foil: linear-gradient(135deg,#BF953F 0%,#FCF6BA 22%,#B38728 48%,#FBF5B7 74%,#AA771C 100%);

  --display: "Playfair Display", Georgia, "Times New Roman", serif;
  --body: "Poppins", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;

  --maxw: 1180px;
  --gut: clamp(20px, 5vw, 56px);
  --radius: 16px;
  --radius-sm: 10px;

  /* legacy aliases (map old names to new brand) */
  --porcelain: var(--paper);
  --porcelain-2: var(--panel);
  --espresso: var(--black);
  --espresso-2: #0c0c0c;
  --brass: var(--pink);
  --brass-deep: var(--pink-deep);
  --rose: var(--pink);
  --white: #ffffff;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  margin:0; background:var(--paper); color:var(--ink);
  font-family:var(--body); font-size:17px; line-height:1.65;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{ max-width:100%; height:auto; display:block; }
a{ color:var(--pink-deep); text-decoration:none; }
a:hover{ text-decoration:underline; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:700; line-height:1.06; color:var(--ink); margin:0; letter-spacing:-0.005em; }
h1{ font-size:clamp(2.5rem, 6vw, 4.3rem); font-weight:800; }
h2{ font-size:clamp(2rem, 4.4vw, 3.1rem); }
h3{ font-size:clamp(1.3rem, 2.6vw, 1.7rem); font-weight:700; }
p{ margin:0 0 1em; }
.accent-script{ font-family:var(--display); font-style:italic; font-weight:500; }

/* Layout */
.wrap{ max-width:var(--maxw); margin-inline:auto; padding-inline:var(--gut); }
.section{ padding-block:clamp(58px, 9vw, 116px); }
.section--tight{ padding-block:clamp(42px, 6vw, 76px); }
.center{ text-align:center; }
.lede{ font-size:clamp(1.06rem, 2.2vw, 1.32rem); color:var(--muted); max-width:62ch; }
.center .lede{ margin-inline:auto; }

.eyebrow{
  font-family:var(--body); font-weight:700; font-size:.74rem;
  letter-spacing:.2em; text-transform:uppercase; color:var(--pink);
  display:inline-flex; align-items:center; gap:.6em; margin:0 0 1.1rem;
}
.eyebrow::before{ content:""; width:28px; height:2px; background:var(--pink); display:inline-block; }
.center .eyebrow{ justify-content:center; }
.center .eyebrow::after{ content:""; width:28px; height:2px; background:var(--pink); display:inline-block; }

.gold{ background:var(--gold-foil); -webkit-background-clip:text; background-clip:text; color:transparent; }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--body); font-weight:600; font-size:1rem;
  padding:.95em 1.7em; border-radius:999px; border:2px solid transparent; cursor:pointer;
  transition:transform .15s ease, background .2s ease, color .2s ease, box-shadow .2s ease, border-color .2s ease;
  text-decoration:none !important;
}
.btn:hover{ transform:translateY(-2px); }
.btn--primary{ background:var(--pink); color:#fff; box-shadow:0 12px 30px -10px rgba(242,10,165,.6); }
.btn--primary:hover{ background:var(--pink-deep); }
.btn--ghost{ background:transparent; color:var(--ink); border-color:var(--ink); }
.btn--ghost:hover{ background:var(--ink); color:#fff; }
.btn--on-dark{ background:var(--pink); color:#fff; box-shadow:0 12px 30px -12px rgba(242,10,165,.7); }
.btn--on-dark:hover{ background:var(--pink-deep); }
.btn--ghost-light{ background:transparent; color:#fff; border-color:rgba(255,255,255,.55); }
.btn--ghost-light:hover{ background:#fff; color:var(--ink); }
.btn--gold{ background:var(--gold-foil); color:#2a2208; border:none; font-weight:700; }
.btn .arr{ transition:transform .2s ease; }
.btn:hover .arr{ transform:translateX(3px); }

/* Header */
.site-header{
  position:sticky; top:0; z-index:50; background:rgba(255,255,255,.9);
  backdrop-filter:saturate(150%) blur(10px); border-bottom:1px solid var(--line);
}
.nav{ display:flex; align-items:center; justify-content:space-between; gap:1rem; padding-block:.8rem; }
.brand{ display:flex; align-items:center; gap:.6rem; text-decoration:none; }
.brand:hover{ text-decoration:none; }
.brand .logo-img{ height:40px; width:auto; display:block; }
.brand .wordmark{ display:flex; flex-direction:column; line-height:1; }
.brand .wordmark b{ font-family:var(--display); font-weight:800; font-size:1.12rem; color:var(--ink); letter-spacing:.005em; }
.brand .wordmark span{ font-size:.62rem; letter-spacing:.28em; text-transform:uppercase; color:var(--pink); font-weight:700; margin-top:2px; }
.nav-links{ display:flex; align-items:center; gap:1.9rem; }
.nav-links a{ color:var(--ink); font-weight:500; font-size:.96rem; }
.nav-links a:hover{ color:var(--pink); text-decoration:none; }
.nav-toggle{ display:none; }

/* Announcement strip */
.strip{
  background:var(--black); color:#fff; font-size:.78rem; letter-spacing:.12em;
  text-transform:uppercase; font-weight:600; text-align:center; padding:.6rem 1rem;
}
.strip b{ color:var(--pink); font-weight:700; }

/* Hero (dark, dramatic) */
.hero{
  position:relative; overflow:hidden; color:#fff;
  background:radial-gradient(120% 120% at 80% -10%, #2a0a20 0%, #0c0c0c 46%, #000 100%);
  padding-block:clamp(70px, 11vw, 130px);
}
.hero .wrap{ position:relative; z-index:2; max-width:900px; }
.hero h1{ color:#fff; margin-bottom:.4rem; }
.hero h1 .accent-script{ color:var(--pink); }
.hero .eyebrow{ color:var(--pink); }
.hero .lede{ color:#d9d4d2; margin-top:1.1rem; font-size:clamp(1.1rem,2.4vw,1.42rem); }
.hero-cta{ display:flex; flex-wrap:wrap; gap:.8rem; margin-top:2rem; }
.hero-chair{ position:absolute; right:-2%; bottom:-8%; width:min(42vw,440px); color:var(--pink); opacity:.16; z-index:1; pointer-events:none; }
.proof-row{ display:flex; flex-wrap:wrap; gap:1.8rem 2.6rem; margin-top:2.4rem; }
.proof b{ font-family:var(--display); font-weight:700; font-size:2rem; color:#fff; line-height:1; display:block; }
.proof span{ font-size:.82rem; color:#b9b4b2; margin-top:.3rem; display:block; }

/* Hero next-up ribbon */
.nextup{
  display:inline-flex; align-items:center; gap:.9rem; flex-wrap:wrap;
  margin-top:1.8rem; padding:.55rem .55rem .55rem 1.15rem;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.16); border-radius:999px;
}
.nextup .pulse{ width:9px; height:9px; border-radius:50%; background:var(--pink); position:relative; flex:0 0 auto; }
.nextup .pulse::after{ content:""; position:absolute; inset:-6px; border-radius:50%; border:2px solid var(--pink); opacity:.6; animation:pp 2s ease-out infinite; }
@keyframes pp{ 0%{transform:scale(.6);opacity:.6} 100%{transform:scale(1.6);opacity:0} }
.nextup span{ color:#eee; }
.nextup b{ color:#fff; }

/* ===== High-impact CLASS cards (schedule) ===== */
.schedule-up{ background:var(--panel); border-bottom:1px solid var(--line); }
.sec-head{ display:flex; align-items:flex-end; justify-content:space-between; gap:1.6rem; flex-wrap:wrap; margin-bottom:2.4rem; }
.sec-head .lede{ margin:0; }

.classes{ display:grid; gap:1.6rem; grid-template-columns:repeat(3,1fr); }
.classcard{
  position:relative; display:flex; flex-direction:column; overflow:hidden;
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:0 1px 0 rgba(0,0,0,.02);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.classcard:hover{ transform:translateY(-6px); box-shadow:0 30px 60px -34px rgba(0,0,0,.5); }
.classcard__head{
  background:var(--black); color:#fff; padding:1.5rem 1.6rem 1.3rem; position:relative;
}
.classcard__head .m{ font-family:var(--body); font-weight:700; font-size:.74rem; letter-spacing:.22em; text-transform:uppercase; color:var(--pink); }
.classcard__head .d{ font-family:var(--display); font-weight:800; font-size:2.7rem; line-height:1; margin-top:.25rem; color:#fff; }
.classcard__head .wk{ font-size:.82rem; color:#b9b4b2; margin-top:.45rem; }
.classcard__body{ padding:1.5rem 1.6rem 1.7rem; display:flex; flex-direction:column; flex:1; }

/* session timeline inside a class card */
.timeline{ list-style:none; margin:0 0 1.5rem; padding:0; position:relative; display:grid; gap:1rem; }
.timeline::before{ content:""; position:absolute; left:8px; top:6px; bottom:34px; width:2px; background:var(--line); }
.tl{ display:flex; gap:.85rem; align-items:flex-start; position:relative; }
.tl .dot{ width:18px; height:18px; border-radius:50%; background:#fff; border:3px solid var(--pink); flex:0 0 auto; margin-top:1px; z-index:1; }
.tl--vip .dot{ border:none; background:var(--gold-foil); }
.tl b{ display:block; font-size:.94rem; color:var(--ink); font-weight:600; }
.tl span{ font-size:.82rem; color:var(--muted); }
.tl--vip b{ color:var(--gold-solid); font-weight:700; }
.classcard .btn{ margin-top:auto; justify-content:center; }

/* featured (soonest) */
.classcard--featured{ border-color:var(--pink); box-shadow:0 26px 56px -30px rgba(242,10,165,.55); }
.classcard--featured .classcard__head{ background:linear-gradient(135deg,#F20AA5,#C5078A); }
.classcard--featured .classcard__head .m{ color:#ffe3f5; }
.tag-soon{
  position:absolute; top:1.15rem; right:1.15rem; z-index:2;
  background:var(--gold-foil); color:#2a2208; font-size:.64rem; font-weight:800;
  letter-spacing:.12em; text-transform:uppercase; padding:.34em .75em; border-radius:999px;
}

/* Sequence (the three nights, full-width section) */
.seq{ display:grid; gap:1.4rem; }
.seq .step{
  display:grid; grid-template-columns:auto 1fr; gap:1.5rem;
  background:var(--paper); border:1px solid var(--line); border-radius:var(--radius);
  padding:clamp(1.4rem,2.6vw,2.1rem); transition:border-color .2s, box-shadow .2s;
}
.seq .step:hover{ border-color:var(--pink); box-shadow:0 20px 44px -32px rgba(242,10,165,.4); }
.seq .num{ font-family:var(--display); font-weight:800; font-size:2.6rem; color:var(--pink); line-height:1; width:1.8ch; }
.seq .step--vip{ background:#0c0c0c; border-color:#000; color:#fff; }
.seq .step--vip h3{ color:#fff; } .seq .step--vip p{ color:#cfcaC8; }
.seq .step--vip .num{ background:var(--gold-foil); -webkit-background-clip:text; background-clip:text; color:transparent; }
.seq .tag{ display:inline-block; font-size:.68rem; letter-spacing:.16em; text-transform:uppercase; font-weight:700; color:var(--pink); margin-bottom:.5rem; }
.seq .step--vip .tag{ background:var(--gold-foil); -webkit-background-clip:text; background-clip:text; color:transparent; }
.seq .step h3{ margin-bottom:.4rem; }
.seq .step p{ color:var(--muted); margin:0; }

/* Dark band */
.band-dark{ background:#0c0c0c; color:#e9e6e4; }
.band-dark h2, .band-dark h3{ color:#fff; }
.band-dark .lede{ color:#bdb8b6; }
.band-dark .eyebrow{ color:var(--pink); }
.band-dark .eyebrow::before, .band-dark .eyebrow::after{ background:var(--pink); }

/* Who list */
.who{ list-style:none; padding:0; margin:0; display:grid; gap:.9rem; }
.who li{ display:flex; gap:.85rem; align-items:flex-start; padding-bottom:.9rem; border-bottom:1px solid var(--line-dark); }
.who li:last-child{ border-bottom:0; }
.who .tick{ color:var(--pink); flex:0 0 auto; margin-top:.2rem; }

/* Cards grid */
.grid{ display:grid; gap:1.4rem; }
.grid-2{ grid-template-columns:repeat(2,1fr); }
.grid-3{ grid-template-columns:repeat(3,1fr); }
.card{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,2.4vw,2rem); transition:border-color .2s, box-shadow .2s, transform .2s; }
.card:hover{ border-color:var(--pink); transform:translateY(-3px); box-shadow:0 22px 46px -34px rgba(242,10,165,.4); }
.card h3{ margin-bottom:.5rem; }
.card p{ color:var(--muted); margin-bottom:0; }

/* About strip */
.about-strip{ display:grid; grid-template-columns:.85fr 1.15fr; gap:clamp(1.5rem,5vw,3.5rem); align-items:center; }
.about-strip img{ border-radius:var(--radius); border:1px solid var(--line); }
.about-stats{ display:flex; gap:2rem; flex-wrap:wrap; margin-top:1.4rem; }
.about-stats .s b{ font-family:var(--display); font-weight:800; font-size:1.8rem; color:var(--pink); display:block; line-height:1; }
.about-stats .s span{ font-size:.8rem; color:var(--muted); }

/* Testimonials */
.quotes{ display:grid; gap:1.4rem; grid-template-columns:repeat(2,1fr); }
.quote{ background:var(--paper); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.4rem,2.4vw,1.9rem); }
.quote .stars{ color:var(--pink); letter-spacing:.16em; font-size:.9rem; margin-bottom:.7rem; }
.quote h3{ font-size:1.16rem; margin-bottom:.5rem; }
.quote p{ color:var(--muted); margin-bottom:1rem; }
.quote .who-line{ display:flex; align-items:center; gap:.7rem; }
.quote .who-line .av{ width:40px; height:40px; border-radius:50%; background:var(--pink-wash); color:var(--pink-deep); font-weight:700; font-size:.8rem; display:flex; align-items:center; justify-content:center; flex:0 0 auto; }
.quote .who-line b{ font-size:.92rem; color:var(--ink); display:block; line-height:1.2; }
.quote .who-line span{ font-size:.78rem; color:var(--muted); }

/* FAQ */
.faq{ max-width:780px; margin-inline:auto; }
.faq details{ border-bottom:1px solid var(--line); padding:1.15rem 0; }
.faq summary{ font-family:var(--display); font-weight:700; font-size:1.2rem; color:var(--ink); cursor:pointer; list-style:none; display:flex; justify-content:space-between; gap:1rem; align-items:center; }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; color:var(--pink); font-size:1.6rem; line-height:1; transition:transform .2s ease; }
.faq details[open] summary::after{ transform:rotate(45deg); }
.faq details p{ color:var(--muted); margin:.8rem 0 0; }

/* Register block */
.register{ background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); padding:clamp(1.5rem,3vw,2.6rem); }
.register .embed-slot{ background:var(--paper); border:2px dashed var(--pink); border-radius:var(--radius-sm); min-height:360px; display:flex; align-items:center; justify-content:center; text-align:center; color:var(--muted); padding:2rem; font-size:.92rem; }
.register .consent{ font-size:.78rem; color:var(--muted); margin-top:1rem; }

/* Final */
.final h2{ max-width:18ch; margin-inline:auto; }

/* Footer */
.site-footer{ background:var(--black); color:#9a9a9a; padding-block:clamp(40px,6vw,64px); font-size:.9rem; }
.site-footer .wrap{ display:flex; flex-wrap:wrap; justify-content:space-between; gap:1.5rem; align-items:center; }
.site-footer a{ color:#d4d4d4; }
.site-footer .foot-brand b{ font-family:var(--display); font-weight:800; color:#fff; font-size:1.15rem; display:block; }
.site-footer .foot-brand span{ font-size:.64rem; letter-spacing:.26em; text-transform:uppercase; color:var(--pink); font-weight:700; }
.site-footer nav{ display:flex; gap:1.4rem; flex-wrap:wrap; }

/* Sticky mobile CTA */
.mobile-cta{ position:fixed; left:0; right:0; bottom:0; z-index:60; display:none; padding:.7rem var(--gut) calc(.7rem + env(safe-area-inset-bottom)); background:rgba(0,0,0,.96); backdrop-filter:blur(6px); border-top:1px solid var(--line-dark); }
.mobile-cta .btn{ width:100%; justify-content:center; }

/* Reveals */
.js .reveal{ opacity:0; transform:translateY(22px); transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1); }
.js .reveal.in{ opacity:1; transform:none; }
.js .reveal.d1{ transition-delay:.08s; } .js .reveal.d2{ transition-delay:.16s; } .js .reveal.d3{ transition-delay:.24s; }

/* Responsive */
@media (max-width:980px){
  .classes{ grid-template-columns:1fr; }
  .grid-3{ grid-template-columns:1fr; }
  .grid-2{ grid-template-columns:1fr; }
  .quotes{ grid-template-columns:1fr; }
  .about-strip{ grid-template-columns:1fr; }
  .about-strip .about-media{ max-width:380px; }
  .nav-links{ display:none; }
  .nav .btn.nav-cta{ display:none; }
  .mobile-cta{ display:block; }
  body{ padding-bottom:78px; }
  .hero-chair{ opacity:.1; }
}
@media (max-width:560px){
  .seq .step{ grid-template-columns:1fr; gap:.6rem; }
  .seq .num{ font-size:2rem; }
  .proof-row{ gap:1.4rem 2rem; }
}

/* A11y */
a:focus-visible, button:focus-visible, summary:focus-visible, .btn:focus-visible{ outline:3px solid var(--pink); outline-offset:3px; border-radius:4px; }
.skip{ position:absolute; left:-9999px; top:0; background:var(--black); color:#fff; padding:.7rem 1rem; z-index:100; }
.skip:focus{ left:8px; top:8px; }
@media (prefers-reduced-motion:reduce){ *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; } }

/* =========================================================
   v3: video embed, animated value charts, placeholder forms
   ========================================================= */

/* Cloudflare Stream video frame (16:9) */
.video-wrap{ max-width:840px; margin-inline:auto; }
.video-frame{
  position:relative; padding-top:56.25%; border-radius:var(--radius); overflow:hidden;
  border:1px solid var(--line); background:#000; box-shadow:0 34px 70px -38px rgba(0,0,0,.55);
}
.video-frame iframe{ position:absolute; inset:0; width:100%; height:100%; border:0; }

/* ---- Animated value charts ---- */
.viz-grid{ display:grid; grid-template-columns:1.12fr .88fr; gap:1.5rem; margin-top:2.6rem; }
.viz-card{ background:rgba(255,255,255,.045); border:1px solid var(--line-dark); border-radius:var(--radius); padding:clamp(1.3rem,2.4vw,1.8rem); }
.viz-card h3{ font-size:1.2rem; color:#fff; margin-bottom:.25rem; }
.viz-card > p{ color:#bdb8b6; font-size:.92rem; margin:0 0 1.1rem; }
.viz-card svg{ width:100%; height:auto; display:block; }
.chart-grid{ stroke:rgba(255,255,255,.10); stroke-width:1; }
.chart-axis{ stroke:rgba(255,255,255,.22); stroke-width:1.5; }
.chart-txt{ fill:#a9a4a2; font-family:var(--body); font-size:13px; }
.chart-mark{ stroke:rgba(255,255,255,.3); stroke-width:1.5; stroke-dasharray:4 5; }

.legend{ display:flex; gap:1.4rem; flex-wrap:wrap; margin-top:1rem; }
.lg{ font-size:.82rem; color:#cfcaC8; display:inline-flex; align-items:center; gap:.5em; }
.lg::before{ content:""; width:12px; height:12px; border-radius:3px; display:inline-block; }
.lg--keep::before{ background:var(--pink); }
.lg--drift::before{ background:#7a7a7a; }

/* line draw animation */
.draw{ fill:none; }
.draw--drift{ stroke:#7a7a7a; stroke-width:3; stroke-linecap:round; stroke-linejoin:round; }
.draw--keep{ stroke:var(--pink); stroke-width:4; stroke-linecap:round; stroke-linejoin:round; filter:drop-shadow(0 4px 10px rgba(242,10,165,.4)); }
.js .viz .draw{ stroke-dasharray:1; stroke-dashoffset:1; }
.js .viz.in .draw{ stroke-dashoffset:0; transition-property:stroke-dashoffset; transition-duration:1.7s; transition-timing-function:ease; transition-delay:var(--d,0s); }
.dot-end{ transform-box:fill-box; transform-origin:center; }
.js .viz .dot-end{ opacity:0; transform:scale(0); }
.js .viz.in .dot-end{ opacity:1; transform:scale(1); transition:opacity .4s ease 1.5s, transform .5s cubic-bezier(.2,1.4,.4,1) 1.5s; }

/* bar grow animation */
.bar{ transform-box:fill-box; transform-origin:bottom; }
.js .viz .bar{ transform:scaleY(0); }
.js .viz.in .bar{ transform:scaleY(1); transition-property:transform; transition-duration:.9s; transition-timing-function:cubic-bezier(.2,.85,.25,1); transition-delay:var(--d,0s); }

/* ---- Placeholder form (disabled until GHL embed) ---- */
.pform{ display:grid; gap:1rem; }
.pf-row{ display:grid; gap:.35rem; }
.pf-row label{ font-size:.82rem; font-weight:600; color:var(--ink); }
.pf-row input, .pf-row select{
  padding:.85rem .95rem; border:1px solid var(--line-2); border-radius:10px;
  font-family:var(--body); font-size:1rem; background:#fff; color:var(--ink);
}
.pf-row input:disabled, .pf-row select:disabled{ background:#fafafa; color:#9a9a9a; cursor:not-allowed; }
.pf-check{ display:flex; gap:.55rem; font-size:.82rem; color:var(--muted); align-items:flex-start; }
.pf-check input{ margin-top:.2rem; }
.pf-submit{ width:100%; justify-content:center; margin-top:.3rem; }
.pf-note{ font-size:.76rem; color:var(--muted-2); text-align:center; margin:.5rem 0 0; }
.btn[disabled]{ opacity:.5; cursor:not-allowed; box-shadow:none; transform:none !important; }
.btn[disabled]:hover{ background:var(--pink); }

@media (max-width:980px){ .viz-grid{ grid-template-columns:1fr; } }

/* two-up class cards (other upcoming classes on event pages) */
.classes--2{ grid-template-columns:repeat(2,1fr); max-width:780px; margin-inline:auto; }
@media (max-width:980px){ .classes--2{ grid-template-columns:1fr; } }

/* =========================================================
   v4: "it's free" reassurance band + free chip on cards
   ========================================================= */
.free-band{ background:var(--pink-wash); }
.free-grid{ display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(1.6rem,5vw,3.5rem); align-items:center; }
.free-band .eyebrow{ color:var(--pink-deep); }
.free-band h2 .big{ display:block; }
.free-list{
  list-style:none; margin:0; padding:clamp(1.4rem,2.6vw,2.1rem); display:grid; gap:1rem;
  background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  box-shadow:0 26px 56px -38px rgba(242,10,165,.4);
}
.free-list li{ display:flex; gap:.85rem; align-items:flex-start; font-weight:500; color:var(--ink); font-size:1.02rem; }
.free-list .ck{ width:28px; height:28px; border-radius:50%; background:var(--pink); color:#fff; display:flex; align-items:center; justify-content:center; flex:0 0 auto; margin-top:1px; }
.free-list .ck svg{ width:15px; height:15px; }

/* "Free" chip inside class card heads */
.free-chip{
  display:inline-block; background:#fff; color:var(--pink); font-family:var(--body);
  font-weight:700; font-size:.62rem; letter-spacing:.08em; text-transform:uppercase;
  padding:.22em .62em; border-radius:999px; margin-right:.45em; vertical-align:middle;
}

@media (max-width:860px){ .free-grid{ grid-template-columns:1fr; } }

/* =========================================================
   v5: equal-size charts + richer "turn around" animation
   ========================================================= */
.viz-grid{ grid-template-columns:1fr 1fr; align-items:stretch; }
.viz-card{ display:flex; flex-direction:column; }
.viz-card svg{ margin-top:.5rem; }

.js .viz .gl{ opacity:0; }
.js .viz.in .gl{ opacity:1; transition:opacity .6s ease var(--d,0s); }

.js .viz .marker{ opacity:0; transform:translateY(-14px); }
.js .viz.in .marker{ opacity:1; transform:none; transition:opacity .6s ease .7s, transform .6s cubic-bezier(.2,.9,.3,1) .7s; }

.js .viz .area{ opacity:0; }
.js .viz.in .area{ opacity:1; transition:opacity .9s ease 1.5s; }

.trend{ fill:none; stroke:var(--pink); stroke-width:3.5; stroke-linecap:round; stroke-linejoin:round; }
.js .viz .trend{ stroke-dasharray:1; stroke-dashoffset:1; }
.js .viz.in .trend{ stroke-dashoffset:0; transition:stroke-dashoffset .8s ease 1s; }

.bar--hot{ filter:drop-shadow(0 6px 14px rgba(242,10,165,.45)); }
.js .viz.in .bar{ transition-timing-function:cubic-bezier(.2,1.25,.35,1); }

.pulse-ring{ transform-box:fill-box; transform-origin:center; }
.js .viz .pulse-ring{ opacity:0; }
@keyframes ringpulse{ 0%{ transform:scale(.5); opacity:.7 } 70%{ opacity:.15 } 100%{ transform:scale(2.6); opacity:0 } }
.js .viz.in .pulse-ring{ opacity:1; animation:ringpulse 2.1s ease-out 1.7s infinite; }

/* =========================================================
   v6: mobile hamburger (no box) + full-screen menu
   ========================================================= */
.nav-toggle{ display:none; background:none; border:0; padding:6px; margin:-6px; cursor:pointer; color:var(--ink); line-height:0; }
.nav-toggle .bars{ display:inline-block; width:27px; height:18px; position:relative; }
.nav-toggle .bars span{ position:absolute; left:0; right:0; height:2.5px; background:currentColor; border-radius:2px; }
.nav-toggle .bars span:nth-child(1){ top:0; }
.nav-toggle .bars span:nth-child(2){ top:50%; transform:translateY(-50%); }
.nav-toggle .bars span:nth-child(3){ bottom:0; }
.nav-close{ color:var(--ink); }
.nav-close .x{ display:inline-block; width:24px; height:24px; position:relative; }
.nav-close .x::before, .nav-close .x::after{ content:""; position:absolute; top:50%; left:0; right:0; height:2.5px; background:currentColor; border-radius:2px; }
.nav-close .x::before{ transform:rotate(45deg); }
.nav-close .x::after{ transform:rotate(-45deg); }

.mobile-menu{ display:none; position:fixed; inset:0; z-index:100; background:var(--paper); flex-direction:column; }
.mobile-menu.open{ display:flex; animation:menuIn .26s ease; }
@keyframes menuIn{ from{ opacity:0; transform:translateY(-8px) } to{ opacity:1; transform:none } }
.mm-top{ display:flex; align-items:center; justify-content:space-between; padding-block:.8rem; }
.mm-links{ display:flex; flex-direction:column; gap:.2rem; padding:1.6rem var(--gut) 0; }
.mm-links a{ font-family:var(--display); font-weight:700; font-size:2rem; color:var(--ink); padding:.55rem 0; border-bottom:1px solid var(--line); }
.mm-links a:hover{ color:var(--pink); text-decoration:none; }
.mm-cta{ margin-top:auto; padding:1.6rem var(--gut) calc(2rem + env(safe-area-inset-bottom)); }
.mm-cta .btn{ width:100%; justify-content:center; }
body.menu-open{ overflow:hidden; }

@media (max-width:980px){ .nav-toggle{ display:inline-flex; } }
@media (min-width:981px){ .mobile-menu{ display:none !important; } }

/* v6 fixes: kill mobile horizontal overflow */
@media (max-width:980px){
  .about-strip .about-media{ max-width:100%; min-width:0; }
}
.pform{ width:100%; }
.pf-row{ min-width:0; }
.pf-row input, .pf-row select{ width:100%; }

/* v6 fix: keep mobile-menu top bar full width so logo aligns to header (x = gutter) */
.mobile-menu .mm-top{ width:100%; max-width:none; margin-inline:0; }
