/*
 Theme Name: Elite Creator Child
 Template: twentytwentyfive
 Version: 1.0.0
*/

/* ===============================
   BRAND TOKENS / BASE
=================================*/
:root{
  --brown:#F57200;
  --black:#02010A;
  --white:#F1F1F1;

  --text:#0f1115;
  --muted:#4b5563;

  --container:1120px;
  --radius:16px;
}

html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--white);
}

/* Container utility */
.ec-container{max-width:var(--container);margin:0 auto;padding:0 20px}

/* Buttons */
.btn-primary{
  display:inline-block;background:var(--brown);color:#fff;
  padding:14px 28px;border-radius:12px;font-weight:700;text-decoration:none
}
.btn-primary:hover{opacity:.9}

/* ===============================
   THEME WRAPPER FIXES
=================================*/
.home header.wp-block-template-part{display:none !important}
.wp-site-blocks > * + *{margin-block-start:0 !important}
.wp-block-post-content,.entry-content{max-width:none !important;padding:0 !important}
.wp-block-post-content > *{
  background:transparent !important; box-shadow:none !important; padding:0 !important;
  margin-block-start:0 !important; margin-block-end:0 !important;
}

/* Full-bleed support */
.wp-site-blocks .alignfull{
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
}
.alignfull .ec-container{
  max-width: var(--container);
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 20px;
  padding-right: 20px;
}

/* ===============================
   HERO
=================================*/
.hero{background:var(--white);padding:56px 0 40px;text-align:center}
.eyebrow{font-size:14px;text-transform:uppercase;color:var(--black);letter-spacing:.04em;font-weight:800;margin:0 0 8px}
.hero-title{font-size:clamp(34px,4.2vw,58px);color:var(--brown);font-weight:800;margin:4px 0 10px}
.subhead{font-size:clamp(18px,1.6vw,22px);font-weight:700;margin:6px 0 8px;color:#0f1115}
.text{font-size:16px;color:var(--muted);max-width:760px;margin:0 auto 20px}
.hero-video{
  display:block;width:100%;max-width:980px;margin:14px auto 18px;
  border-radius:16px;box-shadow:0 10px 30px rgba(2,1,10,.12)
}
.hero-cta{margin-top:6px}

/* ===============================
   FOUNDERS (dark cards with avatars)
=================================*/
.founders-dark{background:#fff;padding:46px 20px 70px}
.founders-grid-dark{
  display:grid !important; gap:28px !important;
  max-width:var(--container); margin:0 auto;
}
@media (min-width:781px){ .founders-grid-dark{ grid-template-columns:1fr 1fr !important; } }
@media (max-width:780px){ .founders-grid-dark{ grid-template-columns:1fr !important; } }

.founder-card-dark{
  background:#0b0c12;color:#e9edf5;border-radius:36px;
  padding:48px 28px 30px;
  text-align:center;position:relative;
  box-shadow:0 18px 50px rgba(2,1,10,.25)
}
.founder-avatar{
  width:74px;height:74px;border-radius:50%;object-fit:cover;
  display:block;margin:0 auto 12px;
  border:4px solid #0b0c12;
  box-shadow:0 6px 18px rgba(0,0,0,.35)
}
.founder-card-dark h3{font-size:18px;font-weight:800;margin:4px 0 10px;color:#fff}
.founder-card-dark p{font-size:15px;line-height:1.65;color:#cdd3de;margin:0}

/* ===============================
   GROWTH SECTION
=================================*/
.growth-section{
  background:#f5f4f3;
  padding:90px 20px;
  text-align:center;
}
.growth-title{
  font-size:clamp(32px,3.5vw,52px);
  color:var(--brown);
  font-weight:800;
  margin-bottom:16px;
}
.growth-subtext{
  font-size:16px;color:#333;max-width:720px;margin:0 auto 48px;line-height:1.6;
}
.growth-roadmap{
  color:var(--brown);font-size:22px;font-weight:800;margin-bottom:36px;
}
.growth-grid{
  display:grid;grid-template-columns:repeat(2,1fr);
  gap:28px;max-width:1100px;margin:0 auto 26px;
}
.growth-card{
  background:#fff;border-radius:28px;padding:32px 28px;
  box-shadow:0 8px 30px rgba(0,0,0,.06);
  display:flex;flex-direction:column;justify-content:center;
  min-height:190px;
}
.growth-card h4{font-size:20px;font-weight:800;margin:0 0 10px;color:#0f1115}
.growth-card p{font-size:15px;line-height:1.6;color:#333;margin:0}
@media (max-width: 800px){ .growth-grid{ grid-template-columns:1fr; } }

/* ---- CTA BAR (COMPACT – matches bottom CTA) ---- */
.growth-cta-bar{
  background:#ffffff;
  border-radius:28px;
  box-shadow:0 8px 28px rgba(0,0,0,.12);
  padding:16px 22px;               /* compact */
  max-width:480px;                 /* compact pill width */
  margin:26px auto 0;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.growth-cta-bar .cta-left{ line-height:1.25; text-align:center; flex:1 1 auto; }
.growth-cta-bar .cta-title{ font-weight:800; font-size:20px; letter-spacing:.02em; color:#0f1115 }
.growth-cta-bar .cta-desc{ margin-top:6px; font-size:14px; color:#6b7280 }

/* Button in Growth CTA (compact) */
.growth-cta-bar .cta-btn-dark{
  display:inline-flex; align-items:center; justify-content:center;
  background:#0b0c12; color:#fff;
  padding:12px 20px; border-radius:22px;
  font-weight:800; font-size:14px; text-decoration:underline; white-space:nowrap;
  box-shadow:0 10px 24px rgba(0,0,0,.16);
  width:auto;
}
.growth-cta-bar .cta-btn-dark:hover{ filter:brightness(1.08) }

@media (max-width: 640px){
  .growth-cta-bar{ flex-direction:column; align-items:stretch; gap:14px; padding:16px 18px; max-width:min(92vw,540px); }
  .growth-cta-bar .cta-left{ text-align:center }
  .growth-cta-bar .cta-btn-dark{ width:100%; justify-content:center }
}

/* ===============================
   WHAT'S INSIDE (dark band + rounded video)
=================================*/
.inside-section{
  background:#0b0c12;
  color:#e9edf5;
  text-align:center;
  padding:80px 20px 64px;
}
.inside-title{
  font-size:clamp(28px,3.4vw,46px);
  font-weight:800;
  color:#fff;
  margin:0 0 10px;
}
.inside-sub{
  max-width:980px;
  margin:0 auto 28px;
  font-size:15.5px;
  line-height:1.6;
  color:#cfd6e2;
}
.inside-video-wrap{
  max-width:1100px;
  margin:0 auto;
  border-radius:28px;
  overflow:hidden;
  box-shadow:0 24px 70px rgba(0,0,0,.45);
}
.inside-video{ display:block; width:100%; height:auto; }
@media (max-width:720px){
  .inside-section{ padding:64px 16px 48px; }
  .inside-title{ font-size:32px; }
  .inside-sub{ font-size:14.5px; }
  .inside-video-wrap{ border-radius:22px; }
}

/* Force dark background */
.inside-section,
.bundles-section{ background:#0b0c12 !important; }

/* Refinements */
.inside-section { padding-top: 120px; }
.inside-video-wrap {
  max-width: 880px;
  margin: 50px auto 0;
  border-radius: 24px;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}
.inside-video { object-fit: cover; }
@media (max-width: 768px) {
  .inside-section { padding-top: 60px; }
  .inside-video-wrap { max-width: 92%; margin-top: 40px; border-radius: 18px; }
}
.inside-section { padding-top: 120px !important; padding-bottom: 80px; }
.inside-video-wrap{ box-shadow:0 20px 56px rgba(0,0,0,.34) !important; }

/* ===== PRO INTRO (title + subhead only) ===== */
.pro-intro{
  background:#0b0c12 !important;
  color:#e9edf5;
  text-align:center;
  padding:72px 20px 42px;
  width:100vw;
  margin-left:calc(50% - 50vw);
  margin-right:calc(50% - 50vw);
  position:relative;
  z-index:1;
}
.pro-intro::before,
.pro-intro::after{
  content:"";
  position:absolute; left:0; right:0; height:1px; background:#0b0c12;
}
.pro-intro::before{ top:-1px; }
.pro-intro::after{  bottom:-1px; }
.pro-intro .ec-container{ max-width:1120px; margin:0 auto; padding:0 20px; }
.pro-intro__title{
  margin:0 0 14px; font-weight:900; color:#fff; line-height:1.05; letter-spacing:.01em;
  font-size:clamp(34px,5.2vw,64px);
}
.pro-intro__sub{
  margin:0 auto; max-width:1100px; line-height:1.6; font-weight:600; color:#cfd6e2;
  font-size:clamp(16px,1.6vw,20px);
}
@media (max-width: 600px){
  .pro-intro{ padding:56px 16px 34px; }
  .pro-intro__title{ font-size:clamp(30px,8vw,40px); }
}

/* Seam fixes (for pro-intro only) */
#pro-intro,.pro-intro{ background:#0b0c12 !important; position:relative; z-index:2; margin:0 !important; border:0 !important; }
#pro-intro::before,.pro-intro::before{ content:""; position:absolute; top:-20px; left:0; right:0; height:20px; background:#0b0c12; pointer-events:none; z-index:5; }
#inside.inside-section .inside-video-wrap,.inside-section .inside-video-wrap{ box-shadow:none !important; border-bottom:none !important; margin-bottom:-2px !important; }
#inside + .wp-block-spacer,#inside + .wp-block-separator,.pro-intro + .wp-block-spacer,.pro-intro + .wp-block-separator{ display:none !important; height:0 !important; margin:0 !important; border:0 !important; background:transparent !important; }

/* ===== Become a Pro (images left, text right) ===== */
.pro2-section{ background:#0b0c12; color:#e9edf5; padding:56px 20px 80px; }
.pro2-section .ec-container{ max-width:1200px; margin:0 auto; }
.pro2-title{ text-align:center; font-weight:900; color:#fff; font-size:clamp(28px,3.6vw,44px); margin:0 0 8px; letter-spacing:.01em; }
.pro2-sub{ text-align:center; max-width:980px; margin:0 auto 36px; color:#cfd6e2; font-size:15.5px; line-height:1.6; }
.pro2-grid{ display:grid; grid-template-columns:1fr; gap:28px; align-items:start; }
@media (min-width: 980px){ .pro2-grid{ grid-template-columns:minmax(340px,460px) 1fr; column-gap:32px; } }
.pro2-photos{ display:grid; gap:22px; }
.photo-card{ border-radius:20px; overflow:hidden; box-shadow:0 16px 42px rgba(0,0,0,.35); }
.photo-card img{ display:block; width:100%; height:auto; object-fit:cover; }
.pro2-bundles{ display:grid; gap:22px; }
.pro2-bundle{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); border-radius:16px; padding:20px 22px; }
.pro2-bundle h3{ margin:0 0 10px; color:#fff; font-weight:900; font-size:18px; letter-spacing:.005em; }
.pro2-bundle ul{ margin:0; padding-left:18px; display:grid; gap:8px; }
.pro2-bundle li{ color:#d8e0ee; font-size:15px; line-height:1.55; }

/* CTA pill in Become-a-Pro (kept) */
.pro2-cta{
  background:#ffffff;
  border-radius:28px;
  box-shadow:0 10px 28px rgba(0,0,0,.16);
  padding:16px 22px;
  max-width:820px;
  margin:28px auto 0;
  display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.pro2-cta .cta-left{ text-align:left; line-height:1.25; }
.pro2-cta .cta-title{ font-weight:900; color:#0f1115; font-size:20px; letter-spacing:.01em; }
.pro2-cta .cta-desc{ color:#6b7280; font-size:14px; margin-top:6px; }
.cta-btn-dark{
  display:inline-flex; align-items:center; justify-content:center;
  background:#0b0c12; color:#fff; padding:12px 20px;
  border-radius:22px; font-weight:800; text-decoration:underline;
}
.cta-btn-dark:hover{ filter:brightness(1.08); }
@media (max-width:640px){
  .pro2-cta{ flex-direction:column; align-items:stretch; text-align:center; }
  .cta-btn-dark{ align-self:center; width:100%; }
}

/* Hard overrides for the band */
#become-a-pro.pro2-section{ background:#0b0c12 !important; color:#e9edf5; position:relative; padding:56px 20px 80px; isolation:isolate; }
#become-a-pro.pro2-section.alignfull{ width:100vw !important; margin-left:calc(50% - 50vw) !important; margin-right:calc(50% - 50vw) !important; }
#become-a-pro :where(.wp-block-group,.wp-block-columns,.wp-block-column,.wp-block-spacer,.wp-block-separator){ background:transparent !important; border:0 !important; box-shadow:none !important; margin:0 !important; padding:0 !important; }
#become-a-pro .ec-container{ max-width:1200px !important; margin:0 auto; }
#become-a-pro .pro2-title{ text-align:center; color:#fff; font-weight:900; font-size:clamp(28px,3.6vw,44px); margin:0 0 10px; }
#become-a-pro .pro2-sub{ text-align:center; max-width:980px; margin:0 auto 36px; color:#cfd6e2; font-size:15.5px; line-height:1.6; }
#become-a-pro .pro2-inner{ display:grid !important; grid-template-columns:1fr; gap:28px; align-items:start; }
@media (min-width:980px){ #become-a-pro .pro2-inner{ grid-template-columns:minmax(340px,460px) 1fr !important; column-gap:32px; } }
#become-a-pro .pro2-photos{ display:grid; gap:22px; }
#become-a-pro .photo-card{ border-radius:20px; overflow:hidden; box-shadow:0 16px 42px rgba(0,0,0,.35); }
#become-a-pro .photo-card img{ display:block; width:100%; height:auto; object-fit:cover; }
#become-a-pro .pro2-bundles{ display:grid; gap:22px; }
#become-a-pro .pro2-bundle{ background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07); border-radius:16px; padding:20px 22px; }
#become-a-pro .pro2-bundle h3{ margin:0 0 10px; color:#fff; font-weight:900; font-size:18px; }
#become-a-pro .pro2-bundle ul{ margin:0; padding-left:18px; display:grid; gap:8px; }
#become-a-pro .pro2-bundle li{ color:#d8e0ee; font-size:15px; line-height:1.55; }

/* ===== Rebuilt “Become a Pro” band (alt layout used in HTML) ===== */
.pro-rebuild{ background:#0b0c12; color:#e9edf5; padding:60px 0 48px; position:relative; }
.pro-rebuild.alignfull{ width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.pro-rebuild .ec-container{ max-width:1200px; margin:0 auto; padding:0 20px; }
.pro-rebuild .pro-head h2{ margin:0 0 10px; text-align:center; color:#fff; font-weight:800; font-size:clamp(28px,3.6vw,44px); }
.pro-rebuild .pro-head p{ margin:0; text-align:center; color:#cfd6e2; line-height:1.55; }
.pro-rebuild .pro-grid{ display:grid; grid-template-columns:1fr; gap:28px; align-items:start; margin-top:28px; }
@media (min-width:1024px){ .pro-rebuild .pro-grid{ grid-template-columns:360px 1fr; column-gap:48px; } }
.pro-rebuild .pro-left{ display:grid; gap:24px; justify-items:start; }
.pro-rebuild .card{ width:100%; max-width:360px; border-radius:20px; overflow:hidden; box-shadow:0 18px 48px rgba(0,0,0,.40); background:#111; }
.pro-rebuild .card img{ display:block; width:100%; height:auto; aspect-ratio:3/4; object-fit:cover; }
.pro-rebuild .bundle{ margin-bottom:24px; }
.pro-rebuild .bundle h3{ margin:0 0 10px; color:#fff; font-weight:800; letter-spacing:.2px; font-size:clamp(18px,1.8vw,24px); }
.pro-rebuild .bundle ul{ margin:0; padding-left:1.2em; display:grid; gap:10px; }
.pro-rebuild .bundle li{ color:#d8e0ee; line-height:1.55; }
.pro-rebuild :where(.wp-block-separator,.wp-block-spacer){ display:none !important; height:0 !important; margin:0 !important; }

/* Make the whole band truly black */
.pro-rebuild,
.pro-rebuild *:where(.wp-block-group,.wp-block-columns,.wp-block-column){
  background:#0b0c12 !important;
  border:0 !important;
  box-shadow:none !important;
}
.wp-site-blocks > .pro-rebuild,
.wp-site-blocks > section.pro-rebuild{
  background:#0b0c12 !important;
}

/* ===== MEMBERSHIP PLANS ===== */
.plans-section{ background:#efefef; padding:70px 20px 90px; }
.plans-head{ text-align:center; max-width:980px; margin:0 auto 32px; }
.plans-title{ margin:0 0 10px; font-weight:900; color:var(--brown); font-size:clamp(28px,3.2vw,44px); letter-spacing:.01em; }
.plans-sub{ margin:0 auto; line-height:1.6; color:#4b4b4b; font-size:15.5px; }
.plans-grid{ display:grid; grid-template-columns: repeat(3, 1fr); gap:28px; max-width:1120px; margin:26px auto 0; }
.plan-card{ background:#fff; border-radius:28px; padding:28px; box-shadow:0 10px 30px rgba(0,0,0,.08); display:flex; flex-direction:column; justify-content:space-between; overflow: hidden; }
.plan-pro{ box-shadow:0 14px 42px rgba(0,0,0,.12); }
.plan-name{ text-align:center; margin:0 0 8px; font-size:clamp(20px,2.2vw,30px); font-weight:800; color:#0f1115; }
.plan-price{ text-align:center; margin:0 0 14px; line-height:1; }
.price-num{ font-weight:900; color:var(--brown); font-size:clamp(40px,3.6vw,56px); }
.price-per{ font-weight:900; color:var(--brown); font-size:clamp(22px,1.8vw,34px); margin-left:6px; }
.plan-list{ margin:12px 0 18px; padding-left:18px; color:#222; display:grid; gap:8px; }
.plan-note{ margin:0 0 18px; color:#555; font-size:15px; }

/* Plan buttons */
.plan-btn{ display:flex; align-items:center; justify-content:center; border-radius:16px; padding:16px 22px; font-weight:900; text-transform:uppercase; letter-spacing:.02em; text-decoration:none; width:100%; max-width:100%; box-sizing:border-box; margin-top:auto; transition:all .2s ease; }
.btn-outline{ background:#fff; border:3px solid #0f1115; color:#0f1115; }
.btn-outline:hover{ background:#0f1115; color:#fff; transition:all .25s ease; }
.btn-fill{ background:var(--brown); color:#fff; border:none; box-shadow:0 8px 22px rgba(98,41,0,.25); }
.btn-fill:hover{ filter:brightness(1.08); transform:translateY(-1px); transition:all .25s ease; }

/* ===== Social Proof: Ready to Join? ===== */
.reviews-section{ background:#0b0c12; color:#e9edf5; padding:80px 0 40px; position:relative; z-index:1; }
.reviews-section.alignfull{ width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
.reviews-title{ color:#fff; font-weight:800; text-align:center; margin:0 0 6px; font-size:clamp(34px,4vw,56px); }
.reviews-sub{ text-align:center; margin:0 0 34px; color:#cfd6e2; font-weight:700; font-size:clamp(18px,2vw,24px); }
.reviews-figure{ max-width:1100px; margin:0 auto 28px; border-radius:22px; overflow:hidden; box-shadow:0 18px 60px rgba(0,0,0,.45); }
.reviews-figure img{ display:block; width:100%; height:auto; }

/* Default bottom CTA pill */
.join-cta-bar{
  background:#ffffff;
  border-radius:28px;
  box-shadow:0 8px 28px rgba(0,0,0,.12);
  padding:16px 22px;
  max-width:820px;
  margin:26px auto 0;
  display:flex; align-items:center; justify-content:space-between; gap:22px;
}
.join-cta-bar .cta-left{ line-height:1.2; text-align:left; }
.join-cta-bar .cta-title{ font-weight:800; font-size:20px; letter-spacing:.02em; color:#0f1115; }
.join-cta-bar .cta-desc{ margin-top:6px; font-size:14px; color:#6b7280; }
.join-cta-bar .cta-btn-dark{
  display:inline-flex; align-items:center; justify-content:center;
  background:#0b0c12; color:#fff; padding:14px 22px; border-radius:22px;
  font-weight:800; text-decoration:underline; white-space:nowrap; box-shadow:0 10px 24px rgba(0,0,0,.16);
}
.join-cta-bar .cta-btn-dark:hover{ filter:brightness(1.08); }
@media (max-width:640px){
  .join-cta-bar{ flex-direction:column; align-items:stretch; gap:14px; padding:16px 18px; }
  .join-cta-bar .cta-left{ text-align:center; }
  .join-cta-bar .cta-btn-dark{ width:100%; justify-content:center; }
}

/* Remove any faint seams */
.reviews-section + .wp-block-spacer,
.reviews-section + .wp-block-separator{
  display:none !important; height:0 !important; margin:0 !important; border:0 !important;
}

/* === READY TO JOIN — compact variant === */
#social-proof.reviews-section{ background:#0b0c12 !important; color:#e9edf5; padding:80px 0 48px; position:relative; z-index:1; }
#social-proof.reviews-section.alignfull{ width:100vw; margin-left:calc(50% - 50vw); margin-right:calc(50% - 50vw); }
#social-proof .ec-container{ max-width:1200px; margin:0 auto; padding:0 20px; text-align:center; }
#social-proof .reviews-title{ color:#fff; font-weight:800; margin:0 0 8px; font-size:clamp(34px,4vw,56px); }
#social-proof .reviews-sub{ color:#cfd6e2; margin:0 0 28px; font-weight:700; font-size:clamp(18px,2vw,24px); }
#social-proof .reviews-figure{ max-width:1100px; margin:0 auto 24px; border-radius:22px; overflow:hidden; box-shadow:0 18px 60px rgba(0,0,0,.45); }
#social-proof .reviews-figure img{ display:block; width:100%; height:auto; }
/* Compact pill + button */
#social-proof .join-cta-bar{ max-width:480px !important; margin:26px auto 0 !important; padding:16px 22px !important; gap:18px !important; justify-content:space-between !important; }
#social-proof .join-cta-bar .cta-left{ flex:1 1 auto !important; text-align:center !important; line-height:1.25 !important; }
#social-proof .join-cta-bar .cta-title{ font-size:20px !important; font-weight:800 !important; letter-spacing:.02em !important; color:#0f1115 !important; }
#social-proof .join-cta-bar .cta-desc{ margin-top:6px !important; font-size:14px !important; color:#6b7280 !important; }
#social-proof .join-cta-bar .cta-btn-dark{ display:inline-flex !important; align-items:center !important; justify-content:center !important; padding:12px 20px !important; border-radius:22px !important; font-weight:800 !important; font-size:14px !important; white-space:nowrap !important; background:#0b0c12 !important; color:#fff !important; text-decoration:underline !important; box-shadow:0 10px 24px rgba(0,0,0,.16) !important; width:auto !important; min-width:unset !important; }
#social-proof .join-cta-bar .cta-btn-dark:hover{ filter:brightness(1.08) !important; }
@media (max-width:640px){
  #social-proof .join-cta-bar{ flex-direction:column; align-items:stretch; gap:14px; padding:16px 18px; }
  #social-proof .join-cta-bar .cta-left{ text-align:center !important; }
  #social-proof .join-cta-bar .cta-btn-dark{ width:100% !important; justify-content:center !important; }
}

/* =========================================
   Tidy spacing above “What’s inside”
========================================= */
.inside-section { 
  padding-top: 56px !important;   /* desktop/tablet */
  padding-bottom: 64px;
}
@media (max-width: 768px){
  .inside-section { padding-top: 40px !important; }
}

/* =========================================
   REAL FIX: kill white line between #inside
   and the next (custom HTML) section
========================================= */

/* Paint the Gutenberg wrapper after #inside black and overlap 1px */
#inside {
  background: #0b0c12 !important;
  padding-bottom: 0 !important;
  margin-bottom: -1px !important;
}

#inside .inside-video-wrap {
  box-shadow: none !important;
  margin-bottom: 0 !important;
  line-height: 0 !important;
  background: #0b0c12 !important;
}

#inside::after {
  content: "";
  display: block;
  position: relative;
  width: 100%;
  height: 2px;
  background: #0b0c12;
  margin-top: -2px; /* overlaps any rendering gap */
  z-index: 5;
}

/* Make sure the next section continues in black */
#pro-intro,
#become-a-pro,
.pro-intro,
.pro2-section,
.pro-rebuild {
  background: #0b0c12 !important;
  position: relative;
  z-index: 4;
  margin-top: 0 !important;
  border: 0 !important;
}

/* Kill any hidden block WordPress injects between sections */
#inside + .wp-block-group,
#inside + .wp-block-html,
#inside + .wp-block-cover,
#inside + .wp-block-columns,
#inside + .wp-block-template-part {
  background: #0b0c12 !important;
  margin-top: -2px !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  position: relative;
  z-index: 3;
}

/* Prevent any default white background on site wrappers */
.wp-site-blocks > * + * {
  background: transparent !important;
  margin-block-start: 0 !important;
}

/* Remove any tiny media gap at the end of the Inside section */
#inside { padding-bottom:0 !important; }
#inside .inside-video-wrap{ box-shadow:none !important; margin-bottom:0 !important; line-height:0; }
#inside .inside-video-wrap img,
#inside .inside-video-wrap video{ display:block; width:100%; height:auto; margin:0; border:0; background:#0b0c12; }

/* =========================================
   FINAL, BULLETPROOF SEAM FIX
   Kills the white line above “Become a Pro”
   and keeps the next band pure black.
========================================= */

/* 0) Ensure Inside ends flush (no media gap) */
#inside { padding-bottom: 0 !important; margin-bottom: -1px !important; }
#inside .inside-video-wrap { 
  box-shadow: none !important; 
  margin-bottom: 0 !important; 
  line-height: 0 !important;
}
#inside .inside-video-wrap img,
#inside .inside-video-wrap video {
  display: block; width: 100%; height: auto; margin: 0; border: 0;
  background: #0b0c12;   /* same as the band below */
}

/* 1) Whatever comes right after #inside: no borders, no hairlines */
#inside + * {
  background: #0b0c12 !important;
  margin-top: -1px !important;     /* overlaps by 1px to hide any seam */
  border: 0 !important;
  box-shadow: none !important;
  outline: none !important;
  position: relative;
}

/* 2) Nuke any pseudo-element “rules” some blocks draw */
#inside + *::before,
#inside + *::after {
  content: none !important;
  display: none !important;
}

/* 3) If that wrapper is specifically HTML/Group/Columns/Cover, reinforce it */
#inside + .wp-block-html,
#inside + .wp-block-group,
#inside + .wp-block-columns,
#inside + .wp-block-cover {
  background: #0b0c12 !important;
  margin-top: -1px !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}

/* 4) Make sure their first child section starts flush (no extra top margin) */
#inside + .wp-block-html > section,
#inside + .wp-block-group > section,
#inside + .wp-block-columns > section,
#inside + .wp-block-cover > section {
  margin-top: 0 !important;
}

/* 5) Kill any spacers/separators immediately after Inside */
#inside + * > .wp-block-separator,
#inside + * > .wp-block-spacer {
  display: none !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* 6) Ensure the dark band itself remains solid black and not offset */
.pro-rebuild,
#become-a-pro.pro2-section {
  background: #0b0c12 !important;
  margin-top: 0 !important;        /* we already overlapped via the wrapper */
  position: relative;
  z-index: 2;
}

/* 7) In case the theme adds a top border to alignfull sections globally */
.wp-site-blocks > .alignfull {
  border-top: 0 !important;
  box-shadow: none !important;
  outline: none !important;
}
/* ====== FAQ (matches screenshot) ====== */
.faq-section{ 
  background: var(--white);
  padding: 40px 0 80px;
}
.faq-title{
  text-align:center;
  margin: 0 0 18px;
  font-weight: 900;
  color: var(--brown);                 /* brown heading like screenshot */
  letter-spacing:.01em;
  font-size: clamp(28px, 4.4vw, 44px); /* big but responsive */
}

/* Card wrapper */
.faq-card{
  max-width: 980px;
  margin: 0 auto;
  background:#fff;
  border-radius: 18px;
  /* soft outer shadow + faint inner border to mimic the card */
  box-shadow:
    0 14px 44px rgba(0,0,0,.10),
    inset 0 0 0 1px rgba(0,0,0,.06);
  overflow:hidden;                     /* clip dividers to the radius */
}

/* Each item */
.faq-item{
  background:#fff;
}

/* Make the summary row look like a list line */
.faq-item > summary{
  list-style: none;
  display:flex;
  align-items:center;
  gap:18px;
  padding: 22px 28px;
  cursor:pointer;
  user-select:none;
  font-weight:800;
  color:#111;
  font-size: clamp(16px, 1.4vw, 20px);
  line-height:1.35;
  position:relative;
}
.faq-item > summary::-webkit-details-marker{ display:none; }

/* Thin divider exactly like the screenshot */
.faq-item:not(:last-of-type) > summary{
  border-bottom: 1px solid rgba(0,0,0,.10);
}

/* The + / – icon */
.faq-icon{
  width:26px; height:26px;
  display:grid; place-items:center;
  font-weight:900;
  flex: 0 0 26px;
  color: var(--brown);
  transform: translateY(-1px); /* nudge to match screenshot baseline */
}
.faq-icon::before{
  content:"+";
  font-size: 24px;
  line-height: 1;
}
.faq-item[open] > summary .faq-icon::before{
  content:"–";                         /* changes to minus when open */
  font-size: 28px;
}

/* Answer body */
.faq-a{
  padding: 10px 28px 22px 72px;        /* indent so text aligns after icon */
  font-size:16px;
  color: var(--muted);
  line-height:1.7;
  background:#fff;
}
.faq-a p{ margin: 0 0 12px; }
.faq-a p:last-child{ margin-bottom:0; }

/* List styling inside answers */
.faq-a ul{
  margin: 8px 0 0 0;
  padding-left: 18px;
  display:grid;
  gap: 6px;
}
.faq-a li{ color: var(--muted); }

/* Small radius at the very end looks tighter */
.faq-item:last-of-type > summary{
  border-bottom: 0;
}
/* ===== FOOTER (FULL-BLEED BLACK) ===== */
.site-footer {
  background: #02010A !important;
  color: #fff;
  text-align: center;
  padding: 70px 20px 40px;
  width: 100vw;
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  position: relative;
  isolation: isolate;
  z-index: 10;
}

/* Ensure WP blocks don't override it */
.site-footer:where(.wp-block-group, .wp-block-columns, .wp-block-cover),
.site-footer *:where(.wp-block-group, .wp-block-columns, .wp-block-cover),
.wp-site-blocks > .site-footer {
  background: #02010A !important;
  border: 0 !important;
  box-shadow: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.footer-inner {
  max-width: 980px;
  margin: 0 auto;
}

.footer-title {
  font-size: clamp(26px, 4vw, 42px);
  font-weight: 900;
  letter-spacing: 0.03em;
  margin: 0 0 26px;
  color: #fff;
}

.footer-nav {
  display: flex;
  justify-content: center;
  gap: 38px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}

.footer-nav a {
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  transition: opacity 0.2s ease, text-decoration-color 0.2s ease;
}

.footer-nav a:hover {
  text-decoration: underline;
  text-decoration-thickness: 1.5px;
  text-underline-offset: 3px;
  opacity: 0.9;
}

.footer-copy {
  color: #9ca3af;
  font-size: 14px;
  font-weight: 500;
  margin: 0;
}
/* ===== FULL-BLEED FOOTER (edge-to-edge) ===== */

/* prevent any horizontal scrollbar from full-bleed */
html, body { overflow-x: hidden; }

/* 1) Make the footer content centered as before */
.site-footer {
  position: relative;
  z-index: 10;
  color: #fff;
  text-align: center;
  padding: 70px 20px 40px;
}

/* 2) Paint a full-viewport black stripe behind the footer
      that ignores parent widths/margins completely */
.site-footer::before {
  content: "";
  position: absolute;
  top: 0; bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;                 /* FULL viewport width */
  background: #02010A;          /* footer black */
  z-index: -1;                  /* sits behind footer content */
}

/* 3) Nuke any Gutenberg wrapper backgrounds/padding around the footer */
.wp-site-blocks > .site-footer,
.site-footer:where(.wp-block-group, .wp-block-columns, .wp-block-cover),
.site-footer *:where(.wp-block-group, .wp-block-columns, .wp-block-cover) {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Optional: your existing inner layout styles */
.footer-inner { max-width: 980px; margin: 0 auto; }
.footer-title {
  font-size: clamp(26px, 4vw, 42px);
  font-weight: 900; letter-spacing: .03em;
  margin: 0 0 26px; color: #fff;
}
.footer-nav {
  display: flex; justify-content: center; gap: 38px; flex-wrap: wrap;
  margin-bottom: 28px;
}
.footer-nav a {
  color: #fff; text-decoration: none; font-weight: 700; font-size: 14px;
  letter-spacing: .02em; text-transform: uppercase; transition: opacity .2s;
}
.footer-nav a:hover { opacity: .9; text-decoration: underline; text-underline-offset: 3px; }
.footer-copy { color: #9ca3af; font-size: 14px; font-weight: 500; margin: 0; }



/* ===== Add spacing between FAQ and footer ===== */
.faq-section {
  margin-bottom: 2cm !important; /* adds vertical space before footer */
}

/* ===== REMOVE DEFAULT WORDPRESS FOOTER ===== */
footer.wp-block-template-part,
.wp-block-group.has-global-padding > footer,
footer.site-footer + div.wp-block-template-part {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* ===== Kill the empty space after the footer (TT5) ===== */

/* TT5 adds bottom padding via this CSS var — set it to 0 */
:root{
  --wp--style--root--padding-bottom: 0 !important;
}

/* Also zero any padding the root wrapper may add */
.wp-site-blocks{
  padding-bottom: 0 !important;
  min-height: 100vh;                 /* so the page can stretch */
  display: flex;
  flex-direction: column;            /* and we can pin the footer to the end */
}

/* Make your custom footer the natural end of the page */
#ece-footer,
.ece-footer{
  margin-top: auto !important;       /* pushes the footer to the bottom */
}

/* Be extra safe: no gap from the last element */
.wp-site-blocks > *:last-child{
  margin-bottom: 0 !important;
}

/* If the theme sneaks in a default template-part footer, hide it */
footer.wp-block-template-part{
  display: none !important;
}

/* Remove any potential page scroll bar caused by fractional widths */
html, body{ height: 100%; margin: 0; overflow-x: hidden; }

/* --- Sticky footer: make the page fill the viewport and pin the footer to the end --- */
.wp-site-blocks{
  display:flex !important;
  flex-direction:column !important;
  min-height:100dvh !important;           /* covers mobile address-bar changes too */
  padding-bottom:0 !important;             /* TT5 root padding override */
}

/* your custom footer is the last flex item */
.site-footer{
  margin-top:auto !important;              /* pushes footer to the bottom on tall screens */
}

/* make absolutely sure there’s no element after the footer contributing height */
.wp-site-blocks > *:last-child{
  margin-bottom:0 !important;
  padding-bottom:0 !important;
}

/* nuke any theme footer template-part / credits if present */
footer.wp-block-template-part,
footer.wp-block-template-part *{
  display:none !important;
  height:0 !important;
  margin:0 !important;
  padding:0 !important;
}

/* keep the full-bleed black stripe behind your footer */
.site-footer{ position:relative; z-index:10; }
.site-footer::before{
  content:""; position:absolute; inset:0; left:50%; transform:translateX(-50%);
  width:100vw; background:#02010A; z-index:-1;
}

/* (you already had this, but keep it with the sticky set) */
html,body{height:100%;margin:0;overflow-x:hidden;}

/* Pricing grid – responsive columns */
@media (max-width: 1024px){
  .plans-grid{
    grid-template-columns: 1fr 1fr;   /* 2-up on tablets */
    gap: 22px;
  }
}

@media (max-width: 680px){
  .plans-grid{
    grid-template-columns: 1fr;       /* 1-up on phones */
    gap: 18px;
  }
  .plan-card{
    padding: 22px;
    border-radius: 20px;
    overflow: visible;                 /* let content grow naturally */
  }
  .plan-name{
    font-size: clamp(18px, 5.2vw, 22px);
  }
  .price-num{                          /* slightly smaller prices on small screens */
    font-size: clamp(34px, 8vw, 44px);
  }
  .price-per{
    font-size: clamp(18px, 4.8vw, 24px);
  }
  .plan-btn{
    padding: 14px 16px;
    font-size: 13px;
  }
}
/* ===== PLANS — 2 cards only ===== */
.plans-grid{
  grid-template-columns: repeat(2, 1fr);   /* 2-up by default */
}

/* If a third plan still exists in the markup, hide it */
.plans-grid .plan-card:nth-child(n+3){
  display: none !important;
}

/* ===== Make the 2nd plan CTA match the 1st (outline style) ===== */
/* Your first plan uses .btn-outline; convert .btn-fill to the same look */
.plan-card .btn-fill{
  background: #fff !important;
  color: #0f1115 !important;
  border: 3px solid #0f1115 !important;
  box-shadow: none !important;
  transform: none !important;
  filter: none !important;
}
.plan-card .btn-fill:hover{
  background: #0f1115 !important;
  color: #fff !important;
  border-color: #0f1115 !important;
  box-shadow: none !important;
  transform: none !important;
}

/* ===== Keep mobile responsive behavior ===== */
@media (max-width: 1024px){
  .plans-grid{ grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px){
  .plans-grid{ grid-template-columns: 1fr; }
}


video::-webkit-media-controls {
  display: none !important;
}

video::-webkit-media-controls-enclosure {
  display: none !important;
}


