/* LawyersFinder — אינדקס עורכי דין מומלצים */
:root{
  --ink:#10243A;
  --ink-2:#1E3A5F;
  --ink-soft:#3C5A7E;
  --burgundy:#8B2635;
  --burgundy-dark:#6E1D2A;
  --burgundy-soft:#B54256;
  --gold:#B89968;
  --gold-dark:#9A7F4E;
  --paper:#F7F4EE;
  --paper-2:#FBF9F4;
  --paper-card:#FFFFFF;
  --line:#E6DFD3;
  --line-strong:#C9BFA8;
  --muted:#6B5F4D;
  --text:#1A1A1A;
  --shadow-sm:0 1px 3px rgba(16,36,58,.06), 0 1px 2px rgba(16,36,58,.04);
  --shadow:0 6px 24px rgba(16,36,58,.08), 0 2px 6px rgba(16,36,58,.05);
  --shadow-lg:0 18px 48px rgba(16,36,58,.12), 0 6px 18px rgba(16,36,58,.06);
  --radius-sm:6px;
  --radius:10px;
  --radius-lg:14px;
  --max:1180px;
}

*{box-sizing:border-box}

/* 3-layer overflow guard (canonical) */
html,body{
  min-height:100%;
  width:100%;
  max-width:100vw;
  overflow-x:hidden;
  overscroll-behavior-x:none;
}
@supports (overflow-x:clip){
  html,body{overflow-x:clip}
}

html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  margin:0;
  font-family:'Heebo','Segoe UI',system-ui,-apple-system,sans-serif;
  color:var(--text);
  background:var(--paper);
  line-height:1.65;
  direction:rtl;
  font-size:16px;
  position:relative;
  transform:translateZ(0);
}

img{max-width:100%;height:auto;display:block}
a{color:var(--burgundy);text-decoration:none;transition:color .2s}
a:hover{color:var(--burgundy-dark)}
button{font-family:inherit;cursor:pointer;border:0;background:none}

h1,h2,h3,h4{
  font-family:'Frank Ruhl Libre','Heebo',serif;
  color:var(--ink);
  font-weight:700;
  letter-spacing:-.01em;
  line-height:1.25;
  overflow-wrap:anywhere;
  margin:0 0 .5em
}
h1{font-size:clamp(2rem,4.5vw,3.4rem);font-weight:800}
h2{font-size:clamp(1.5rem,3vw,2.2rem)}
h3{font-size:clamp(1.15rem,2vw,1.4rem)}
p{margin:0 0 1em;overflow-wrap:anywhere}

.wrap{max-width:var(--max);margin:0 auto;padding:0 22px}
.section{padding:64px 0;overflow-x:clip;max-width:100%}
.section-tight{padding:40px 0;overflow-x:clip;max-width:100%}

/* ===== TOPBAR ===== */
.topbar{
  background:var(--paper-2);
  border-bottom:1px solid var(--line);
  padding:14px 0;
  position:sticky;top:0;z-index:50;
  backdrop-filter:saturate(150%) blur(8px);
  -webkit-backdrop-filter:saturate(150%) blur(8px);
  background:rgba(251,249,244,.92);
  overflow-x:clip;max-width:100%;
}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{display:flex;align-items:center;gap:12px;color:var(--ink);font-weight:700}
.brand img{height:42px;width:auto}
.brand-text{display:flex;flex-direction:column;line-height:1.15}
.brand-text strong{font-family:'Frank Ruhl Libre',serif;font-size:1.15rem;color:var(--ink)}
.brand-text span{font-size:.78rem;color:var(--muted);letter-spacing:.01em}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  color:var(--ink-2);
  font-weight:500;
  font-size:.95rem;
  padding:8px 12px;
  border-radius:var(--radius-sm);
  transition:all .2s;
}
.nav a:hover{background:var(--paper);color:var(--burgundy)}
.nav-cta{
  background:var(--burgundy)!important;
  color:#fff!important;
  padding:10px 18px!important;
  border-radius:8px;
  font-weight:600;
}
.nav-cta:hover{background:var(--burgundy-dark)!important;color:#fff!important}
.nav-mobile-toggle{display:none;background:none;border:0;color:var(--ink);font-size:1.5rem;padding:6px}

@media (max-width:760px){
  .nav-mobile-toggle{display:block}
  .nav{display:none;position:absolute;top:64px;right:0;left:0;background:#fff;
    flex-direction:column;align-items:stretch;padding:12px;gap:0;border-bottom:1px solid var(--line);
    box-shadow:var(--shadow)}
  .nav.open{display:flex}
  .nav a{padding:14px;border-bottom:1px solid var(--line)}
  .nav a:last-child{border-bottom:0}
  .nav-cta{margin-top:8px;text-align:center}
}

/* ===== HERO ===== */
.hero{
  background:
    radial-gradient(ellipse at top right, rgba(184,153,104,.08), transparent 50%),
    linear-gradient(170deg, var(--paper-2) 0%, var(--paper) 100%);
  padding:72px 0 96px;
  position:relative;
  overflow-x:clip;max-width:100%;
  border-bottom:1px solid var(--line);
}
.hero::before{
  content:"";position:absolute;inset:auto -40px -40px auto;width:340px;height:340px;
  background:radial-gradient(circle, rgba(139,38,53,.06), transparent 70%);
  pointer-events:none;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:48px;
  align-items:center;
  position:relative;
  z-index:1;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--paper-card);
  border:1px solid var(--line-strong);
  color:var(--ink-2);
  padding:7px 14px;
  border-radius:99px;
  font-size:.82rem;
  font-weight:600;
  letter-spacing:.04em;
  margin-bottom:18px;
}
.hero-eyebrow::before{content:"";width:8px;height:8px;background:var(--burgundy);border-radius:50%}
.hero h1{margin-bottom:18px}
.hero h1 em{font-style:italic;color:var(--burgundy);font-weight:700}
.hero-sub{font-size:1.12rem;color:var(--ink-soft);margin-bottom:28px;max-width:60ch}
.hero-cta-row{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin-bottom:24px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:14px 28px;
  border-radius:8px;
  font-weight:600;
  font-size:1rem;
  cursor:pointer;
  transition:all .2s;
  text-decoration:none;
}
.btn-primary{background:var(--burgundy);color:#fff!important;box-shadow:var(--shadow-sm)}
.btn-primary:hover{background:var(--burgundy-dark);transform:translateY(-1px);box-shadow:var(--shadow);color:#fff!important}
.btn-secondary{background:transparent;color:var(--ink)!important;border:1px solid var(--line-strong)}
.btn-secondary:hover{background:var(--paper-card);border-color:var(--ink-soft);color:var(--ink)!important}
.btn-block{width:100%}
.btn-lg{padding:16px 32px;font-size:1.05rem}

.hero-trust{display:flex;flex-wrap:wrap;gap:20px;font-size:.92rem;color:var(--muted)}
.hero-trust span{display:inline-flex;align-items:center;gap:6px}
.hero-trust span::before{content:"✓";color:var(--burgundy);font-weight:700}

/* Hero form card (chat-bubble style) */
.lead-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:28px;
  box-shadow:var(--shadow-lg);
  position:relative;
}
.lead-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:5px;
  background:linear-gradient(90deg, var(--burgundy), var(--gold) 60%, var(--burgundy));
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.lead-card h2{font-size:1.3rem;margin-bottom:6px}
.lead-card .lead-sub{color:var(--muted);font-size:.92rem;margin-bottom:18px}

.chat-bubble{
  background:var(--paper-2);
  border:1px solid var(--line);
  border-radius:12px 12px 12px 4px;
  padding:14px 16px;
  margin-bottom:14px;
  font-size:.95rem;
  color:var(--ink);
  display:flex;align-items:start;gap:10px;
}
.chat-bubble .avatar{
  flex-shrink:0;width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-weight:700;font-size:.92rem;
  border:2px solid var(--gold);
}

.form-field{margin-bottom:14px}
.form-field label{display:block;font-weight:500;font-size:.88rem;margin-bottom:6px;color:var(--ink-2)}
.form-field input,.form-field select,.form-field textarea{
  width:100%;
  padding:13px 14px;
  border:1.5px solid var(--line-strong);
  border-radius:8px;
  font-family:inherit;
  font-size:1rem;
  background:#fff;
  color:var(--ink);
  transition:border-color .2s, box-shadow .2s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{
  outline:0;border-color:var(--burgundy);box-shadow:0 0 0 3px rgba(139,38,53,.12)
}
.form-error{color:var(--burgundy);font-size:.85rem;margin-top:4px;display:none}
.form-error.show{display:block}

.lead-footnote{font-size:.78rem;color:var(--muted);text-align:center;margin-top:12px}
.lead-footnote::before{content:"🔒 ";color:var(--gold-dark)}

/* Age slider */
.age-display{
  font-size:2.4rem;font-weight:800;color:var(--burgundy);
  text-align:center;margin:8px 0;font-family:'Frank Ruhl Libre',serif;
}
.age-slider{width:100%;-webkit-appearance:none;appearance:none;height:6px;border-radius:3px;
  background:linear-gradient(90deg,var(--burgundy) 0%,var(--burgundy) 50%,var(--line-strong) 50%,var(--line-strong) 100%);
  outline:0}
.age-slider::-webkit-slider-thumb{-webkit-appearance:none;width:24px;height:24px;border-radius:50%;
  background:var(--burgundy);cursor:pointer;border:3px solid #fff;box-shadow:var(--shadow-sm)}
.age-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:var(--burgundy);cursor:pointer;border:3px solid #fff}

@media (max-width:880px){
  .hero{padding:48px 0 64px}
  .hero-grid{grid-template-columns:1fr;gap:32px}
  .hero h1{font-size:2rem}
}

/* ===== TRUST BAR ===== */
.trust-band{
  background:var(--ink);color:#fff;
  padding:36px 0;
  overflow-x:clip;max-width:100%;
}
.trust-band .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;text-align:center}
.trust-stat strong{
  display:block;font-family:'Frank Ruhl Libre',serif;font-size:2.4rem;font-weight:800;color:var(--gold);
  line-height:1
}
.trust-stat span{display:block;font-size:.9rem;color:rgba(255,255,255,.78);margin-top:6px}
@media (max-width:680px){.trust-band .wrap{grid-template-columns:repeat(2,1fr)}}

/* ===== SECTION HEADER ===== */
.section-head{text-align:center;margin-bottom:48px;max-width:720px;margin-left:auto;margin-right:auto}
.section-eyebrow{
  display:inline-block;color:var(--burgundy);font-weight:600;font-size:.85rem;
  letter-spacing:.18em;text-transform:uppercase;margin-bottom:8px;
}
.section-head h2{margin-bottom:14px}
.section-head p{color:var(--ink-soft);font-size:1.05rem}

/* ===== CATEGORY GRID ===== */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.cat-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:24px 22px;
  display:flex;flex-direction:column;gap:8px;
  text-decoration:none;color:inherit;
  transition:all .2s;
  position:relative;
  overflow:hidden;
}
.cat-card::after{
  content:"";position:absolute;inset:auto 0 0 auto;width:60px;height:60px;
  background:radial-gradient(circle, var(--gold) 0%, transparent 70%);
  opacity:.15;border-radius:50%;
  transform:translate(20px,20px);transition:transform .3s;
}
.cat-card:hover{border-color:var(--burgundy);box-shadow:var(--shadow);transform:translateY(-2px)}
.cat-card:hover::after{transform:translate(0,0);opacity:.25}
.cat-icon{
  width:44px;height:44px;border-radius:8px;background:rgba(139,38,53,.08);
  display:flex;align-items:center;justify-content:center;color:var(--burgundy);font-size:1.5rem;margin-bottom:6px;
}
.cat-card h3{margin:0;font-size:1.2rem;color:var(--ink)}
.cat-card p{margin:0;color:var(--muted);font-size:.92rem;flex-grow:1}
.cat-card-cta{
  margin-top:12px;color:var(--burgundy);font-weight:600;font-size:.9rem;
  display:inline-flex;align-items:center;gap:4px;
}
.cat-card-cta::after{content:"←";transition:transform .2s}
.cat-card:hover .cat-card-cta::after{transform:translateX(-4px)}

/* ===== LAWYER CARDS ===== */
.lawyer-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.lawyer-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:all .2s;
  text-decoration:none;color:inherit;
}
.lawyer-card:hover{box-shadow:var(--shadow);transform:translateY(-3px);border-color:var(--gold)}
.lawyer-photo{
  aspect-ratio:1/1;width:100%;
  background:linear-gradient(135deg,var(--paper-2),var(--paper));
  object-fit:cover;
}
.lawyer-body{padding:20px 22px;flex-grow:1;display:flex;flex-direction:column}
.lawyer-body h3{margin:0 0 4px;font-size:1.25rem}
.lawyer-spec{color:var(--burgundy);font-weight:600;font-size:.88rem;margin-bottom:8px}
.lawyer-loc{color:var(--muted);font-size:.88rem;margin-bottom:12px}
.lawyer-loc::before{content:"📍 "}
.lawyer-rating{display:flex;align-items:center;gap:6px;margin-bottom:14px}
.stars{color:var(--gold);letter-spacing:1px;font-size:.95rem}
.rating-num{font-weight:600;color:var(--ink);font-size:.88rem}
.rating-count{color:var(--muted);font-size:.82rem}
.lawyer-card-cta{
  margin-top:auto;color:var(--burgundy);font-weight:600;font-size:.92rem;
  border-top:1px solid var(--line);padding-top:12px;display:inline-flex;align-items:center;gap:4px;
}
.lawyer-card-cta::after{content:"←";transition:transform .2s}
.lawyer-card:hover .lawyer-card-cta::after{transform:translateX(-4px)}

/* ===== HOW IT WORKS ===== */
.steps{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px;position:relative}
.step{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:28px 24px;
  text-align:center;
  position:relative;
}
.step-num{
  width:48px;height:48px;border-radius:50%;
  background:linear-gradient(135deg,var(--ink) 0%,var(--ink-2) 100%);
  color:var(--gold);font-family:'Frank Ruhl Libre',serif;font-weight:800;font-size:1.4rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 16px;border:2px solid var(--gold);
}
.step h3{font-size:1.1rem;margin-bottom:8px}
.step p{margin:0;color:var(--muted);font-size:.92rem}

/* ===== BLOG GRID ===== */
.blog-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px}
.blog-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;flex-direction:column;
  text-decoration:none;color:inherit;
  transition:all .2s;
}
.blog-card:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:var(--gold)}
.blog-thumb{aspect-ratio:16/9;width:100%;object-fit:cover;background:var(--paper-2)}
.blog-body{padding:22px}
.blog-cat{color:var(--burgundy);font-size:.78rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase}
.blog-card h3{margin:8px 0;font-size:1.15rem}
.blog-excerpt{color:var(--ink-soft);font-size:.95rem;margin:0}

/* ===== FAQ ===== */
.faq-wrap{max-width:820px;margin:0 auto;overflow-x:clip;max-width:100%}
.faq-item{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  margin-bottom:12px;
  overflow:hidden;
}
.faq-item summary{
  padding:18px 22px;
  cursor:pointer;
  font-weight:600;
  color:var(--ink);
  list-style:none;
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";font-size:1.6rem;color:var(--burgundy);font-weight:300;line-height:1;transition:transform .2s}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .faq-body{padding:0 22px 18px;color:var(--ink-soft);line-height:1.7}
.faq-item .faq-body p:last-child{margin-bottom:0}

/* ===== FINAL CTA ===== */
.final-cta{
  background:
    linear-gradient(180deg, var(--ink) 0%, var(--ink-2) 100%);
  color:#fff;
  padding:72px 0;
  text-align:center;
  position:relative;
  overflow-x:clip;max-width:100%;
}
.final-cta::before{
  content:"";position:absolute;inset:0 0 auto 0;height:3px;
  background:linear-gradient(90deg, transparent, var(--gold), transparent);
}
.final-cta h2{color:#fff;margin-bottom:14px}
.final-cta p{color:rgba(255,255,255,.82);font-size:1.08rem;max-width:620px;margin:0 auto 28px}
.final-cta .btn-primary{background:var(--gold);color:var(--ink)!important;font-weight:700}
.final-cta .btn-primary:hover{background:#cba87c;color:var(--ink)!important}

/* ===== BREADCRUMBS ===== */
.crumbs{
  font-size:.88rem;color:var(--muted);padding:18px 0;
  overflow-x:clip;max-width:100%;
}
.crumbs a{color:var(--ink-2)}
.crumbs a:hover{color:var(--burgundy)}
.crumbs .sep{margin:0 8px;color:var(--line-strong)}
.crumbs .active{color:var(--ink);font-weight:600}

/* ===== ARTICLE / LAWYER PROFILE ===== */
.profile{display:grid;grid-template-columns:300px 1fr;gap:48px;align-items:start}
.profile-side{position:sticky;top:96px}
.profile-photo{
  width:100%;aspect-ratio:1/1;
  border-radius:var(--radius);
  object-fit:cover;
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.profile-meta{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:20px;
  margin-top:18px;
  font-size:.93rem;
}
.profile-meta dt{font-weight:600;color:var(--ink);margin-top:10px;font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}
.profile-meta dt:first-child{margin-top:0}
.profile-meta dd{margin:4px 0 0;color:var(--ink-soft)}
.profile-content h1{margin-bottom:6px}
.profile-subhead{color:var(--burgundy);font-weight:600;font-size:1.08rem;margin-bottom:24px}
.profile-content h2{font-size:1.4rem;margin-top:32px;padding-bottom:8px;border-bottom:2px solid var(--gold);display:inline-block}
.profile-content p{font-size:1.02rem;line-height:1.75;color:var(--text)}
.profile-content ul{padding-right:20px;color:var(--text)}
.profile-content ul li{margin-bottom:8px;line-height:1.6}

.reviews{margin-top:36px;background:var(--paper-2);padding:28px;border-radius:var(--radius);border:1px solid var(--line)}
.reviews h2{margin-top:0;border-bottom:0;padding-bottom:0}
.review{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius-sm);
  padding:18px 20px;
  margin-bottom:12px;
}
.review-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.review-author{font-weight:600;color:var(--ink)}
.review-stars{color:var(--gold);letter-spacing:1.5px;font-size:.95rem}
.review-date{color:var(--muted);font-size:.82rem}
.review-text{margin:0;color:var(--ink-soft);font-style:italic;line-height:1.7}

@media (max-width:880px){
  .profile{grid-template-columns:1fr;gap:24px}
  .profile-side{position:static}
  .profile-photo{max-width:260px;margin:0 auto}
}

/* ===== FOOTER ===== */
.foot{
  background:var(--ink);
  color:rgba(255,255,255,.78);
  padding:56px 0 24px;
  overflow-x:clip;max-width:100%;
}
.foot a{color:rgba(255,255,255,.78)}
.foot a:hover{color:var(--gold)}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:32px;padding-bottom:36px;border-bottom:1px solid rgba(255,255,255,.1)}
.foot-brand img{height:48px;filter:brightness(0) invert(1);margin-bottom:14px}
.foot-brand p{margin:0 0 14px;font-size:.92rem;line-height:1.7;max-width:36ch}
.foot h4{color:#fff;font-family:'Frank Ruhl Libre',serif;font-size:1.05rem;margin-bottom:14px}
.foot ul{list-style:none;padding:0;margin:0}
.foot ul li{margin-bottom:8px;font-size:.92rem}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:20px;font-size:.85rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}
@media (max-width:760px){.foot-grid{grid-template-columns:1fr 1fr;gap:24px}.foot-brand{grid-column:1/-1}}

/* ===== ARTICLE BODY (blog post) ===== */
.article-body{max-width:760px;margin:0 auto}
.article-body h1{margin-bottom:8px}
.article-body .article-meta{color:var(--muted);font-size:.92rem;margin-bottom:28px}
.article-body img{border-radius:var(--radius);margin:20px 0}
.article-body p,.article-body li{font-size:1.04rem;line-height:1.85;color:var(--text)}
.article-body h2{font-size:1.6rem;margin-top:36px;padding-bottom:8px;border-bottom:2px solid var(--gold);display:inline-block}
.article-body h3{font-size:1.25rem;margin-top:24px}
.article-body blockquote{
  border-right:4px solid var(--burgundy);
  padding:8px 18px;margin:24px 0;
  background:var(--paper-2);
  font-style:italic;color:var(--ink-soft);
  border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}

/* ===== QUIZ / FUNNEL PAGES ===== */
.funnel-wrap{
  min-height:calc(100vh - 80px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:40px 22px;
  background:
    radial-gradient(ellipse at top, rgba(184,153,104,.06), transparent 60%),
    linear-gradient(170deg, var(--paper-2) 0%, var(--paper) 100%);
}
.funnel-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:32px 28px;
  max-width:520px;width:100%;
  box-shadow:var(--shadow-lg);
  position:relative;
}
.funnel-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:5px;
  background:linear-gradient(90deg, var(--burgundy), var(--gold) 60%, var(--burgundy));
  border-radius:var(--radius-lg) var(--radius-lg) 0 0;
}
.progress-bar{height:4px;background:var(--line);border-radius:2px;margin-bottom:20px;overflow:hidden}
.progress-fill{height:100%;background:linear-gradient(90deg,var(--burgundy),var(--gold));border-radius:2px;transition:width .4s ease}
.step-content{display:none}
.step-content.active{display:block;animation:fadeIn .3s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.step-q{font-family:'Frank Ruhl Libre',serif;font-size:1.4rem;font-weight:700;color:var(--ink);margin-bottom:16px;line-height:1.35}
.option-row{display:grid;gap:10px;margin-bottom:18px}
.option-btn{
  padding:14px 18px;
  background:var(--paper-2);
  border:1.5px solid var(--line-strong);
  border-radius:8px;
  font-weight:500;font-size:1rem;
  text-align:right;color:var(--ink);
  cursor:pointer;transition:all .15s;
}
.option-btn:hover{border-color:var(--burgundy);background:#fff;transform:translateY(-1px)}
.option-btn.selected{border-color:var(--burgundy);background:rgba(139,38,53,.06);color:var(--burgundy)}
.step-row{display:flex;gap:10px;margin-top:18px}
.step-row .btn{flex:1}
.step-back{background:transparent;color:var(--ink-soft)!important;border:1px solid var(--line-strong)}
.step-back:hover{background:var(--paper-2)}

/* ===== THANKS PAGE ===== */
.thanks-wrap{
  min-height:80vh;
  display:flex;align-items:center;justify-content:center;
  padding:40px 22px;
  text-align:center;
  background:linear-gradient(170deg, var(--paper-2) 0%, var(--paper) 100%);
}
.thanks-card{
  background:var(--paper-card);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  padding:48px 32px;
  max-width:560px;
  box-shadow:var(--shadow-lg);
}
.thanks-check{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg, #2c9a48 0%, #1f7a36 100%);
  color:#fff;font-size:2.4rem;
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 20px;font-weight:300;
}

/* utilities */
.text-center{text-align:center}
.mt-4{margin-top:32px}

/* Per-section overflow defense */
.topbar, .hero, .trust-band, .section, .section-tight, .faq-wrap, .final-cta, .foot, .funnel-wrap, .thanks-wrap{
  overflow-x:clip;max-width:100%;
}
h1,h2,h3,h4,p{overflow-wrap:anywhere}
