/* ===== Dyme Capital x Skool — funnel styles ===== */
:root{
  --bg:#ffffff;
  --band:#f7f7f8;
  --text:#1a1a1a;
  --muted:#6b6b72;
  --border:#e8e8ea;
  --yellow:#F9CA24;
  --yellow-2:#FFC93C;
  --radius:15px;
  --shadow:0 4px 18px rgba(0,0,0,.06);
  --shadow-lg:0 10px 40px rgba(0,0,0,.10);
  --maxw:1080px;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  padding-bottom:env(safe-area-inset-bottom);
}
img{max-width:100%;display:block}

.container{max-width:var(--maxw);margin:0 auto;padding:0 20px}

/* ---- Header ---- */
.site-header{padding:18px 20px;border-bottom:1px solid var(--border);background:#fff}
.cobrand{display:flex;align-items:center;justify-content:center;gap:14px;flex-wrap:wrap}
.cobrand-logo.dyme{height:30px;width:auto}
.cobrand-logo.skool{height:26px;width:auto;border-radius:6px}
.cobrand-sep{font-size:.78rem;color:var(--muted);font-weight:500}

/* ---- Hero ---- */
.hero{max-width:840px;margin:0 auto;padding:54px 20px 40px;text-align:center}
.headline{
  font-size:clamp(1.9rem,5.2vw,3.4rem);
  font-weight:800;
  line-height:1.08;
  letter-spacing:-.02em;
  margin-bottom:16px;
}
/* Yellow accent underline on the lead phrase — text stays dark, only the line is yellow */
.hl-underline{
  text-decoration-line:underline;
  text-decoration-color:var(--yellow);
  text-decoration-thickness:3px;
  text-underline-offset:3px;
  text-decoration-skip-ink:none;
}
.subline{font-size:clamp(.95rem,2.4vw,1.1rem);color:var(--muted);font-weight:500;margin-bottom:22px}
.pills{display:flex;flex-wrap:wrap;justify-content:center;gap:9px;margin-bottom:36px}
.pill{
  font-size:.82rem;font-weight:600;color:var(--text);
  border:1px solid var(--border);border-radius:100px;
  padding:7px 16px;background:#fff;
}

/* ---- VSL ---- */
.vsl{
  position:relative;max-width:760px;margin:0 auto 28px;
  aspect-ratio:16/9;border-radius:var(--radius);overflow:hidden;
  box-shadow:var(--shadow-lg);background:#0d0d0d;
}
.vsl-poster{
  position:absolute;inset:0;cursor:pointer;
  background:url('vsl-thumb.jpg') center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
}
.vsl-poster::before{content:'';position:absolute;inset:0;backdrop-filter:blur(8px);
  background:rgba(0,0,0,.32);filter:blur(0)}
.vsl-poster img{filter:blur(8px)}
.play-btn{
  position:relative;z-index:2;width:84px;height:84px;border-radius:50%;
  border:none;cursor:pointer;background:var(--yellow);
  display:flex;align-items:center;justify-content:center;
  padding-left:5px;box-shadow:0 0 0 0 rgba(249,202,36,.6);
  animation:playpulse 2s infinite ease-out;transition:transform .15s ease;
}
.play-btn:hover{transform:scale(1.06)}
@keyframes playpulse{
  0%{box-shadow:0 0 0 0 rgba(249,202,36,.55)}
  70%{box-shadow:0 0 0 22px rgba(249,202,36,0)}
  100%{box-shadow:0 0 0 0 rgba(249,202,36,0)}
}

/* ---- CTA button ---- */
.cta-join{
  font-family:inherit;font-size:1.15rem;font-weight:800;letter-spacing:-.01em;
  color:#1a1a1a;background:var(--yellow);
  border:none;border-radius:14px;padding:18px 44px;cursor:pointer;
  box-shadow:0 6px 20px rgba(249,202,36,.4);transition:transform .15s ease;
}
.cta-join:hover{transform:translateY(-1px)}
.pulse{animation:ctapulse 2.2s infinite ease-in-out}
@keyframes ctapulse{
  0%,100%{transform:scale(1);box-shadow:0 6px 20px rgba(249,202,36,.35)}
  50%{transform:scale(1.035);box-shadow:0 10px 30px rgba(249,202,36,.55)}
}

/* ---- Section bands & titles ---- */
.band{background:var(--band);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.section-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;letter-spacing:-.02em;text-align:center;line-height:1.12}
.section-lead{text-align:center;color:var(--muted);font-weight:500;margin-top:10px}

/* ---- Included ---- */
.included{padding:64px 0}
.feature-grid{
  display:grid;grid-template-columns:1fr;gap:16px;margin-top:38px;
}
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow);
}
.feature-card .emoji{font-size:1.9rem;display:block;margin-bottom:10px}
.feature-card h3{font-size:1.05rem;font-weight:700;margin-bottom:4px}
.feature-card p{font-size:.92rem;color:var(--muted)}
/* Closing flourish under the grid — not a card */
.more-line{text-align:center;color:var(--muted);font-size:.95rem;font-weight:600;margin-top:26px}

/* ---- Testimonials ---- */
.testimonials{padding:64px 20px}
.testimonial-grid{display:grid;grid-template-columns:1fr;gap:16px;margin-top:38px}
.testimonial-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:24px 22px;box-shadow:var(--shadow);display:flex;flex-direction:column;gap:14px;
}
.stars{color:#F5B100;font-size:1rem;letter-spacing:2px}
.quote{font-size:.98rem;line-height:1.5;color:#2a2a2e;flex:1}
.person{display:flex;align-items:center;gap:12px}
.avatar{
  width:42px;height:42px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:700;font-size:1.05rem;
}
.name{font-weight:700;font-size:.95rem}
.meta{font-size:.82rem;color:var(--muted)}

/* ---- FAQ ---- */
.faq-band{padding:64px 0}
.faq{max-width:760px}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);margin-top:14px;overflow:hidden}
.faq-item:first-of-type{margin-top:38px}
.faq-q{
  width:100%;text-align:left;background:none;border:none;cursor:pointer;
  font-family:inherit;font-size:1.02rem;font-weight:700;color:var(--text);
  padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;
}
.faq-icon{font-size:1.5rem;font-weight:400;color:var(--muted);transition:transform .2s ease;flex:none}
.faq-q[aria-expanded="true"] .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .25s ease}
.faq-a p{padding:0 22px 20px;color:var(--muted);font-size:.95rem}

/* ---- Closing CTA ---- */
.closing-cta{text-align:center;padding:60px 20px}

/* ---- Footer ---- */
.site-footer{border-top:1px solid var(--border);padding:34px 20px 80px;text-align:center}
.footer-logo{height:28px;width:auto;margin:0 auto 12px;opacity:.85}
.copyright{font-size:.8rem;color:var(--muted)}

/* ---- Sticky mobile CTA ---- */
.sticky-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:50;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(to top,rgba(255,255,255,.98) 70%,rgba(255,255,255,0));
  display:none;
}
.sticky-cta .cta-join{width:100%;display:block}

/* ---- Modal ---- */
.modal-backdrop{
  position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.6);
  display:none;align-items:center;justify-content:center;padding:18px;
  -webkit-overflow-scrolling:touch;
}
.modal-backdrop.open{display:flex}
.modal{
  position:relative;background:#fff;border-radius:16px;overflow:hidden;
  width:100%;max-width:480px;box-shadow:var(--shadow-lg);
  display:flex;flex-direction:column;
}
.modal-close{
  position:absolute;top:8px;right:10px;z-index:2;
  background:rgba(255,255,255,.9);border:1px solid var(--border);border-radius:50%;
  width:34px;height:34px;font-size:1.5rem;line-height:1;cursor:pointer;color:#1a1a1a;
}
.modal-body{
  width:100%;height:560px;max-height:85vh;
  overflow:auto;-webkit-overflow-scrolling:touch;
}
.modal-body iframe{display:block;width:100%;height:100%}

/* ===== Responsive ===== */
@media(max-width:600px){
  .cobrand{gap:10px}
  .cobrand-sep{flex-basis:100%;text-align:center;order:2;font-size:.72rem}
  .cobrand-logo.dyme{order:1;height:26px}
  .cobrand-logo.skool{order:3;height:24px}
  .sticky-cta{display:block}
  /* hide the inline hero CTA on mobile to avoid duplicate with sticky? keep it visible */
  /* Modal goes near full-screen on mobile */
  .modal-backdrop{padding:0}
  .modal{max-width:none;width:100%;height:100%;border-radius:0}
  .modal-body{height:100%;max-height:none}
}

@media(min-width:640px){
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .testimonial-grid{grid-template-columns:repeat(2,1fr)}
}
@media(min-width:980px){
  .feature-grid{grid-template-columns:repeat(3,1fr)}
  .testimonial-grid{grid-template-columns:repeat(3,1fr)}
}
