/* National Home Buyers USA — Design System
   Dark, authoritative, premium fintech meets aggressive REI.
   Tokens locked in CLAUDE.md §4.
*/

/* ---------- RESET & BASE ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  font-size:16px;line-height:1.6;color:#E5E7EB;background:#0A0E1A;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img,video{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:inherit}

/* ---------- DESIGN TOKENS ---------- */
:root{
  --bg:#0A0E1A;
  --bg-card:#111827;
  --bg-card-2:#1F2937;
  --border:#1F2937;
  --border-2:#374151;
  --text:#E5E7EB;
  --text-muted:#9CA3AF;
  --text-bright:#FFFFFF;
  --accent:#C9A84C;
  --accent-hover:#A8893D;
  --accent-glow:rgba(201,168,76,0.18);
  --urgent:#EF4444;
  --warn:#F59E0B;
  --gold:#FBBF24;
  --max-w:1200px;
  --radius:10px;
  --radius-lg:16px;
  --shadow:0 4px 24px rgba(0,0,0,0.35);
  --shadow-lg:0 20px 60px rgba(0,0,0,0.5);
  --shadow-accent:0 8px 30px rgba(201,168,76,0.35);
}

/* ---------- TYPOGRAPHY ---------- */
h1,h2,h3,h4{
  font-family:'Oswald',sans-serif;
  font-weight:700;color:var(--text-bright);
  line-height:1.1;letter-spacing:-0.01em;
}
h1{font-size:clamp(2.4rem,6vw,4.5rem);text-transform:uppercase;letter-spacing:-0.02em}
h2{font-size:clamp(2rem,4.5vw,3.25rem);text-transform:uppercase}
h3{font-size:clamp(1.4rem,2.5vw,2rem)}
h4{font-size:1.2rem;font-weight:600}
p{margin-bottom:1rem}
.eyebrow{
  display:inline-block;font-family:'Oswald',sans-serif;
  font-size:0.85rem;font-weight:600;letter-spacing:0.18em;
  text-transform:uppercase;color:var(--accent);margin-bottom:1rem;
}
.text-accent{color:var(--accent)}
.text-urgent{color:var(--urgent)}
.text-muted{color:var(--text-muted)}

/* ---------- LAYOUT ---------- */
.container{max-width:var(--max-w);margin:0 auto;padding:0 1.5rem}
section{padding:5rem 0;position:relative}
section.tight{padding:3rem 0}
@media(max-width:768px){section{padding:3.5rem 0}}

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:0.6rem;
  padding:1rem 1.75rem;font-family:'Oswald',sans-serif;font-weight:700;
  font-size:1.05rem;letter-spacing:0.04em;text-transform:uppercase;
  border-radius:var(--radius);transition:all .2s ease;
  white-space:nowrap;cursor:pointer;border:2px solid transparent;
  text-align:center;line-height:1.2;
}
.btn-primary{background:var(--accent);color:#0A0E1A;box-shadow:var(--shadow-accent)}
.btn-primary:hover{background:var(--accent-hover);transform:translateY(-2px);box-shadow:0 12px 36px rgba(201,168,76,0.5)}
.btn-secondary{background:transparent;color:var(--text-bright);border-color:var(--border-2)}
.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}
.btn-ghost{background:transparent;color:var(--accent);padding:0.5rem 0}
.btn-ghost:hover{color:var(--accent-hover)}
.btn-block{width:100%}
.btn-lg{padding:1.2rem 2.25rem;font-size:1.15rem}
.btn-sm{padding:0.7rem 1.2rem;font-size:0.9rem}

/* ---------- HEADER / NAV ---------- */
.site-header{
  position:sticky;top:0;z-index:90;
  background:rgba(10,14,26,0.85);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
}
.site-header .container{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:1.25rem;padding-bottom:1.25rem;
}
.logo{display:flex;align-items:center;gap:0.6rem;font-family:'Oswald',sans-serif;font-weight:700;font-size:1.15rem;color:var(--text-bright);letter-spacing:0.02em}
.logo img{width:180px;height:auto;display:block}
.site-header .logo img{display:block;border-radius:4px}
.site-footer .logo img{width:120px;height:auto}
@media(max-width:480px){.logo img{width:150px}}
/* legacy text-logo fallback (unused once SVG loads) */
.logo-mark{width:36px;height:36px;border-radius:8px;background:linear-gradient(135deg,var(--accent),#E8C97A);display:grid;place-items:center;color:#0A0E1A;font-weight:700;font-size:1.1rem}
.logo-text{line-height:1;text-transform:uppercase}
.logo-text small{display:block;font-size:0.65rem;color:var(--text-muted);font-weight:400;letter-spacing:0.16em;margin-top:3px}
.nav-links{display:flex;gap:2rem;align-items:center}
.nav-links a{font-size:0.95rem;font-weight:500;color:var(--text-muted);transition:color .15s}
.nav-links a:hover{color:var(--text-bright)}
.nav-cta{display:flex;align-items:center;gap:1rem}
.phone-link{display:flex;align-items:center;gap:0.4rem;color:var(--text-bright);font-weight:600}
.phone-link svg{width:16px;height:16px;color:var(--accent)}
.menu-toggle{display:none;width:40px;height:40px;border-radius:8px;background:var(--bg-card);align-items:center;justify-content:center}
.menu-toggle span,.menu-toggle span::before,.menu-toggle span::after{display:block;width:18px;height:2px;background:var(--text-bright);position:relative;transition:transform .2s}
.menu-toggle span::before{content:"";position:absolute;top:-6px;left:0}
.menu-toggle span::after{content:"";position:absolute;top:6px;left:0}
@media(max-width:900px){
  .nav-links{display:none}
  .menu-toggle{display:flex}
  .nav-links.open{
    display:flex;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;background:var(--bg-card);padding:1.5rem;border-bottom:1px solid var(--border);gap:1rem;
  }
  .phone-link span{display:none}
}

/* ---------- HERO ---------- */
.hero{
  position:relative;padding:5rem 0 6rem;overflow:hidden;
  background:
    radial-gradient(ellipse 1000px 600px at 80% -10%,rgba(201,168,76,0.18),transparent 50%),
    radial-gradient(ellipse 800px 500px at 0% 110%,rgba(201,168,76,0.10),transparent 60%),
    var(--bg);
}
.hero::before{
  content:"";position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 60% 60% at 50% 40%,black 30%,transparent 80%);
  pointer-events:none;
}
.hero-grid{display:grid;grid-template-columns:1.1fr 1fr;gap:3rem;align-items:center;position:relative;z-index:1}
@media(max-width:980px){.hero-grid{grid-template-columns:1fr;gap:2.5rem}}
@media(max-width:768px){.hero{padding:3rem 0 4rem}}
.hero h1{margin-bottom:1.25rem}
.hero h1 .accent-block{color:var(--accent)}
.hero-sub{font-size:1.2rem;color:var(--text-muted);margin-bottom:2rem;max-width:560px}
.hero-trust{display:flex;flex-wrap:wrap;gap:2rem;align-items:center;margin:2rem 0}
.stars{display:flex;gap:0.25rem;color:var(--gold);font-size:1.1rem}
.stars-meta{display:flex;flex-direction:column;gap:0.15rem}
.stars-meta strong{color:var(--text-bright);font-weight:700}
.stars-meta span{font-size:0.85rem;color:var(--text-muted)}
.trust-badges{display:flex;gap:1.25rem;flex-wrap:wrap;font-size:0.9rem;color:var(--text-muted)}
.trust-badges div{display:flex;align-items:center;gap:0.4rem}
.trust-badges svg{width:14px;height:14px;color:var(--accent)}

/* ---------- LEAD FORM CARD ---------- */
.form-card{
  background:var(--bg-card);border:1px solid var(--border-2);
  border-radius:var(--radius-lg);padding:2rem;box-shadow:var(--shadow-lg);
  position:relative;overflow:hidden;
}
.form-card::before{
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:linear-gradient(90deg,var(--accent),#E8C97A);
}
.form-card-header{margin-bottom:1.5rem;text-align:center}
.form-card-header h2{font-size:1.7rem;margin-bottom:0.5rem}
.form-card-header p{color:var(--text-muted);font-size:0.95rem;margin:0}
.progress-bar{height:6px;background:var(--bg-card-2);border-radius:99px;margin-bottom:1.5rem;overflow:hidden}
.progress-bar-fill{height:100%;background:var(--accent);border-radius:99px;transition:width .35s ease;width:50%}
.form-step{display:none}
.form-step.active{display:block;animation:fadeIn .3s ease}
.form-step h3{font-family:'Inter',sans-serif;font-size:0.95rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:1rem;text-align:center}
.field{margin-bottom:1rem}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:0.75rem}
.field-row-3{display:grid;grid-template-columns:2fr 1fr 1fr;gap:0.75rem}
@media(max-width:480px){.field-row,.field-row-3{grid-template-columns:1fr}}
.field label{display:block;font-size:0.85rem;color:var(--text-muted);margin-bottom:0.4rem;font-weight:500}
.field input,.field select,.field textarea{
  width:100%;padding:0.95rem 1rem;background:var(--bg);
  border:1.5px solid var(--border-2);border-radius:8px;color:var(--text-bright);
  transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-glow);
}
.field textarea{min-height:90px;resize:vertical}
.field-error{display:none;color:var(--urgent);font-size:0.85rem;margin-top:0.4rem}
.field.has-error input,.field.has-error select{border-color:var(--urgent)}
.field.has-error .field-error{display:block}
.form-cta{margin-top:1.5rem}
.form-actions{display:flex;gap:0.75rem}
.form-actions .btn-secondary{flex:0 0 auto}
.form-actions .btn-primary{flex:1}
@media(max-width:520px){
  .form-actions{flex-direction:column-reverse;gap:0.6rem}
  .form-actions .btn-secondary,.form-actions .btn-primary{width:100%;flex:none}
}
.form-disclaimer{font-size:0.78rem;color:var(--text-muted);text-align:center;margin-top:1rem;line-height:1.5}
.form-disclaimer a{color:var(--text-muted);text-decoration:underline}
.consent-block{margin-bottom:0.5rem;display:flex;flex-direction:column;gap:0.4rem}
.consent-label{display:flex;align-items:flex-start;gap:0.5rem;font-size:11px;color:var(--text-muted);line-height:1.5;cursor:pointer}
.consent-label input[type="checkbox"]{margin-top:0.15rem;flex-shrink:0;accent-color:var(--accent);width:14px;height:14px;cursor:pointer}
.consent-label a{color:#C9A84C;text-decoration:underline}
.consent-private{font-size:11px;color:var(--text-muted);text-align:center;margin-top:0.25rem;margin-bottom:0}

/* ---------- STAT STRIP ---------- */
.stat-strip{
  background:var(--bg-card);border-top:1px solid var(--border);border-bottom:1px solid var(--border);
  padding:2.5rem 0;
}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem;text-align:center}
@media(max-width:768px){.stat-grid{grid-template-columns:repeat(2,1fr);gap:1.5rem}}
.stat-num{font-family:'Oswald',sans-serif;font-weight:700;font-size:clamp(1.8rem,4vw,2.75rem);color:var(--accent);line-height:1}
.stat-label{font-size:0.9rem;color:var(--text-muted);margin-top:0.5rem;text-transform:uppercase;letter-spacing:0.06em}

/* ---------- SECTION HEADERS ---------- */
.section-header{text-align:center;max-width:780px;margin:0 auto 3rem}
.section-header h2{margin-bottom:1rem}
.section-header p{font-size:1.15rem;color:var(--text-muted)}

/* ---------- HOW IT WORKS ---------- */
.steps-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:880px){.steps-grid{grid-template-columns:1fr}}
.step-card{
  background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius-lg);
  padding:2rem;position:relative;transition:transform .2s,border-color .2s;
}
.step-card:hover{transform:translateY(-4px);border-color:var(--accent)}
.step-num{
  position:absolute;top:-1rem;left:2rem;
  width:48px;height:48px;border-radius:12px;
  background:var(--accent);color:#0A0E1A;font-family:'Oswald',sans-serif;
  font-weight:700;font-size:1.5rem;display:grid;place-items:center;
  box-shadow:var(--shadow-accent);
}
.step-card h3{margin-top:1.25rem;margin-bottom:0.6rem}
.step-card p{color:var(--text-muted);margin:0}

/* ---------- COMPARISON TABLE ---------- */
.compare{display:grid;grid-template-columns:1fr 1fr;gap:1rem;max-width:980px;margin:0 auto}
@media(max-width:760px){.compare{grid-template-columns:1fr}}
.compare-card{
  background:var(--bg-card);border:1px solid var(--border-2);
  border-radius:var(--radius-lg);padding:2rem;
}
.compare-card.us{border-color:var(--accent);background:linear-gradient(180deg,rgba(201,168,76,0.07),transparent 60%),var(--bg-card)}
.compare-card h3{margin-bottom:0.4rem}
.compare-card .compare-tag{font-family:'Oswald',sans-serif;font-size:0.8rem;letter-spacing:0.12em;color:var(--text-muted);text-transform:uppercase;margin-bottom:1.5rem;display:block}
.compare-card.us .compare-tag{color:var(--accent)}
.compare-list{list-style:none;padding:0;margin:0}
.compare-list li{display:flex;gap:0.75rem;padding:0.75rem 0;border-top:1px solid var(--border);align-items:flex-start}
.compare-list li:first-child{border-top:0}
.compare-list svg{width:18px;height:18px;flex-shrink:0;margin-top:2px}
.compare-list .ico-no{color:var(--urgent)}
.compare-list .ico-yes{color:var(--accent)}
.compare-list span{color:var(--text);font-size:0.95rem}

/* ---------- TESTIMONIALS ---------- */
.testimonial-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:980px){.testimonial-grid{grid-template-columns:1fr}}
.testimonial{
  background:var(--bg-card);border:1px solid var(--border-2);
  border-radius:var(--radius-lg);padding:2rem;display:flex;flex-direction:column;gap:1rem;
}
.testimonial .stars{font-size:1rem}
.testimonial blockquote{font-size:1rem;color:var(--text);line-height:1.6;margin:0}
.testimonial-meta{display:flex;align-items:center;gap:0.75rem;margin-top:auto;padding-top:1rem;border-top:1px solid var(--border)}
.avatar{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--accent),#E8C97A);display:grid;place-items:center;color:#0A0E1A;font-weight:700;font-family:'Oswald',sans-serif}
.testimonial-meta strong{display:block;color:var(--text-bright);font-size:0.95rem}
.testimonial-meta span{font-size:0.85rem;color:var(--text-muted)}

/* ---------- SITUATIONS GRID ---------- */
.situation-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
@media(max-width:980px){.situation-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.situation-grid{grid-template-columns:1fr}}
.situation{
  background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius);
  padding:1.5rem;text-align:left;transition:all .2s;
}
.situation:hover{border-color:var(--accent);transform:translateY(-2px)}
.situation-icon{
  width:42px;height:42px;border-radius:10px;background:rgba(201,168,76,0.12);
  display:grid;place-items:center;margin-bottom:1rem;
}
.situation-icon svg{width:22px;height:22px;color:var(--accent)}
.situation h4{font-family:'Inter',sans-serif;font-size:1rem;font-weight:600;color:var(--text-bright);margin-bottom:0.4rem}
.situation p{font-size:0.85rem;color:var(--text-muted);margin:0}

/* ---------- FAQ ---------- */
.faq-list{max-width:840px;margin:0 auto}
.faq-item{
  background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius);
  margin-bottom:0.75rem;overflow:hidden;
}
.faq-q{
  width:100%;text-align:left;padding:1.25rem 1.5rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  font-family:'Oswald',sans-serif;font-size:1.1rem;font-weight:600;color:var(--text-bright);
}
.faq-q::after{content:"+";font-size:1.6rem;color:var(--accent);transition:transform .2s;line-height:1}
.faq-item.open .faq-q::after{transform:rotate(45deg)}
.faq-a{
  max-height:0;overflow:hidden;transition:max-height .3s ease;
  padding:0 1.5rem;color:var(--text-muted);
}
.faq-item.open .faq-a{max-height:500px;padding-bottom:1.25rem}

/* ---------- CTA STRIPE ---------- */
.cta-stripe{
  background:linear-gradient(135deg,#0A0E1A 0%,#C9A84C 100%);
  padding:4rem 0;text-align:center;position:relative;overflow:hidden;
}
.cta-stripe h2{color:#0A0E1A;font-size:clamp(1.8rem,4vw,2.75rem)}
.cta-stripe p{color:#0A0E1A;opacity:0.85;font-size:1.1rem;max-width:640px;margin:1rem auto 2rem}
.cta-stripe .btn{background:#0A0E1A;color:var(--accent);border-color:#0A0E1A}
.cta-stripe .btn:hover{background:#000;color:var(--accent)}

/* ---------- FOOTER ---------- */
.site-footer{background:#05080F;padding:3.5rem 0 2rem;border-top:1px solid var(--border)}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:2.5rem;margin-bottom:2.5rem}
@media(max-width:880px){.footer-grid{grid-template-columns:1fr 1fr;gap:2rem}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand p{color:var(--text-muted);font-size:0.92rem;margin-top:1rem;line-height:1.6}
.footer-col h4{font-family:'Oswald',sans-serif;font-size:0.85rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-bright);margin-bottom:1rem}
.footer-col ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:0.5rem}
.footer-col a{color:var(--text-muted);font-size:0.9rem;transition:color .15s}
.footer-col a:hover{color:var(--accent)}
.footer-legal{padding-top:2rem;border-top:1px solid var(--border);display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;color:var(--text-muted);font-size:0.85rem}
.footer-legal a{color:var(--text-muted)}
.footer-legal a:hover{color:var(--accent)}

/* ---------- STICKY MOBILE CTA ---------- */
.mobile-cta{
  position:fixed;bottom:0;left:0;right:0;z-index:80;
  background:var(--bg-card);border-top:1px solid var(--border-2);
  padding:0.75rem 1rem;display:none;gap:0.6rem;
  box-shadow:0 -8px 24px rgba(0,0,0,0.4);
}
.mobile-cta .btn{flex:1;padding:0.85rem 0.5rem;font-size:0.95rem}
.mobile-cta .btn-primary{flex:1.4}
@media(max-width:768px){.mobile-cta{display:flex}body{padding-bottom:80px}}

/* ---------- EXIT INTENT MODAL ---------- */
.modal-overlay{
  position:fixed;inset:0;background:rgba(2,4,9,0.85);backdrop-filter:blur(6px);
  z-index:100;display:none;align-items:center;justify-content:center;padding:1.5rem;
}
.modal-overlay.open{display:flex;animation:fadeIn .25s ease}
.modal{
  background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius-lg);
  max-width:480px;width:100%;padding:2.5rem 2rem;text-align:center;position:relative;
  box-shadow:var(--shadow-lg);animation:popIn .35s cubic-bezier(0.34,1.56,0.64,1);
}
.modal-close{
  position:absolute;top:1rem;right:1rem;width:32px;height:32px;border-radius:50%;
  background:var(--bg-card-2);color:var(--text-muted);font-size:1.2rem;line-height:1;
}
.modal h3{font-size:1.6rem;margin-bottom:0.6rem}
.modal p{color:var(--text-muted);margin-bottom:1.5rem}
.modal .btn{width:100%;margin-bottom:0.75rem}

/* ---------- BLOG CARDS ---------- */
.article-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:980px){.article-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.article-grid{grid-template-columns:1fr}}
.article-card{
  background:var(--bg-card);border:1px solid var(--border-2);border-radius:var(--radius-lg);
  padding:1.75rem;transition:all .2s;display:flex;flex-direction:column;gap:0.75rem;
}
.article-card:hover{border-color:var(--accent);transform:translateY(-3px)}
.article-card .tag{font-family:'Oswald',sans-serif;font-size:0.75rem;letter-spacing:0.12em;color:var(--accent);text-transform:uppercase}
.article-card h3{font-size:1.25rem;margin-bottom:0.4rem}
.article-card p{color:var(--text-muted);font-size:0.92rem;flex:1}
.article-card .meta{font-size:0.82rem;color:var(--text-muted)}

/* ---------- ARTICLE / LONG-FORM ---------- */
.article-body{max-width:760px;margin:0 auto}
.article-body h2{font-size:1.9rem;margin-top:2.5rem;margin-bottom:1rem}
.article-body h3{font-size:1.4rem;margin-top:2rem;margin-bottom:0.75rem}
@media(max-width:600px){.article-body h2{font-size:1.5rem}.article-body h3{font-size:1.2rem}}
.article-body p{font-size:1.05rem;color:var(--text);line-height:1.75;margin-bottom:1.25rem}
.article-body ul,.article-body ol{margin:1rem 0 1.5rem 1.5rem;color:var(--text)}
.article-body li{margin-bottom:0.5rem;line-height:1.7}
.article-body a{color:var(--accent);border-bottom:1px solid rgba(201,168,76,0.4)}
.article-body a:hover{border-bottom-color:var(--accent)}
.quick-answer{
  background:linear-gradient(135deg,rgba(201,168,76,0.08),transparent 80%);
  border-left:4px solid var(--accent);border-radius:0 var(--radius) var(--radius) 0;
  padding:1.5rem 1.75rem;margin:1.5rem 0 2rem;
}
.quick-answer .label{font-family:'Oswald',sans-serif;font-size:0.8rem;letter-spacing:0.14em;color:var(--accent);text-transform:uppercase;margin-bottom:0.5rem;display:block}
.quick-answer p{margin:0;font-size:1.05rem;color:var(--text-bright)}
.share-bar{display:flex;gap:0.75rem;margin:2.5rem 0;padding:1.25rem 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);align-items:center}
.share-bar span{color:var(--text-muted);font-size:0.85rem;text-transform:uppercase;letter-spacing:0.08em;font-family:'Oswald',sans-serif}
.share-bar a{
  width:36px;height:36px;border-radius:8px;background:var(--bg-card);
  display:grid;place-items:center;color:var(--text-muted);transition:all .15s;
}
.share-bar a:hover{background:var(--accent);color:#0A0E1A}
.share-bar svg{width:16px;height:16px}

/* ---------- BREADCRUMBS ---------- */
.breadcrumbs{font-size:0.85rem;color:var(--text-muted);margin-bottom:1rem}
.breadcrumbs a{color:var(--text-muted)}
.breadcrumbs a:hover{color:var(--accent)}
.breadcrumbs span{margin:0 0.5rem;opacity:0.5}

/* ---------- ANIMATIONS ---------- */
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
@keyframes popIn{from{opacity:0;transform:scale(0.9)}to{opacity:1;transform:scale(1)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.5}}
.fade-up{opacity:0;transform:translateY(20px);transition:opacity .6s ease,transform .6s ease}
.fade-up.in{opacity:1;transform:translateY(0)}
.pulse-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:var(--accent);animation:pulse 1.5s infinite}

/* ---------- UTILITY ---------- */
.text-center{text-align:center}
.mt-0{margin-top:0}
.mt-1{margin-top:1rem}
.mt-2{margin-top:2rem}
.mt-3{margin-top:3rem}
.mb-0{margin-bottom:0}
.mb-1{margin-bottom:1rem}
.mb-2{margin-bottom:2rem}
.flex{display:flex}
.flex-center{display:flex;align-items:center;justify-content:center}
.gap-1{gap:1rem}
.gap-2{gap:2rem}
.hidden{display:none!important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

/* ---------- THANK YOU PAGE ---------- */
.thank-hero{
  text-align:center;padding:5rem 0 3rem;
  background:radial-gradient(ellipse 800px 400px at 50% 0%,rgba(201,168,76,0.18),transparent 60%),var(--bg);
}
@media(max-width:768px){.thank-hero{padding:2.5rem 0 2rem}}
.check-circle{
  width:88px;height:88px;border-radius:50%;background:var(--accent);
  display:grid;place-items:center;margin:0 auto 1.5rem;box-shadow:var(--shadow-accent);
}
.check-circle svg{width:42px;height:42px;color:#0A0E1A;stroke-width:3}
@media(max-width:600px){.thank-cta-call{width:100%;display:block;text-align:center}}

/* ---------- MARKETS WE SERVE ---------- */
.markets-we-serve{background:#05080F;padding:3rem 0 3.5rem;border-top:1px solid var(--border)}
.markets-we-serve .section-title{font-size:1.4rem;margin-bottom:2rem}
.markets-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2rem}
@media(max-width:880px){.markets-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.markets-grid{grid-template-columns:1fr 1fr}}
.markets-col h4{font-family:'Oswald',sans-serif;font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.875rem}
.markets-col ul{list-style:none;padding:0;display:flex;flex-direction:column;gap:.4rem}
.markets-col a{color:var(--text-muted);font-size:.88rem;transition:color .15s}
.markets-col a:hover{color:var(--accent)}

/* ---------- 404 ---------- */
.error-hero{text-align:center;padding:6rem 0 4rem}
.error-code{font-family:'Oswald',sans-serif;font-size:clamp(6rem,18vw,12rem);font-weight:700;line-height:1;color:var(--accent);letter-spacing:-0.04em}
