/* ═══════════════════════════════════════
   SHARED STYLES — DFW CASH HOME BUYERS
   Used by all city, situation, and blog pages
═══════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,900;1,700&family=DM+Sans:wght@300;400;500;600;700&display=swap');

:root {
  --ink:#0d0c0a;--cream:#f6f1e9;--warm:#ede8de;--panel:#e4ddd2;
  --gold:#c8922a;--gold-lt:#e8b84b;--gold-pale:#f5e8cc;
  --rust:#a63d2f;--sage:#3d5c3a;--sage-lt:#5a7f56;
  --muted:#7a7068;--border:#d5cec4;--white:#fff;
  --sh-sm:0 2px 8px rgba(13,12,10,.08);
  --sh-md:0 8px 32px rgba(13,12,10,.12);
  --fh:'Playfair Display',Georgia,serif;
  --fb:'DM Sans',system-ui,sans-serif;
  --max:1200px;--r:8px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);background:var(--cream);color:var(--ink);line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px}

@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}
@keyframes pdot{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(.7);opacity:.5}}

/* NAV */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;background:rgba(246,241,233,.96);backdrop-filter:blur(12px);border-bottom:1px solid var(--border)}
.nav-in{display:flex;align-items:center;justify-content:space-between;height:66px}
.logo{font-family:var(--fh);font-size:1.3rem;font-weight:900;letter-spacing:-.02em}
.logo span{color:var(--gold)}
.nav-r{display:flex;align-items:center;gap:18px}
.nav-lk{font-size:.87rem;font-weight:500;color:var(--muted);transition:color .2s}
.nav-lk:hover{color:var(--ink)}
.nav-btn{display:inline-flex;align-items:center;gap:7px;background:var(--ink);color:var(--cream);padding:10px 22px;border-radius:var(--r);font-size:.88rem;font-weight:600;transition:all .2s;white-space:nowrap}
.nav-btn:hover{background:var(--gold);color:var(--ink)}

/* HERO — INNER PAGES */
.page-hero{padding:120px 0 80px;background:var(--ink);position:relative;overflow:hidden}
.page-hero::before{content:'';position:absolute;top:-100px;right:-100px;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(200,146,42,.12) 0%,transparent 65%);pointer-events:none}
.page-hero::after{content:'';position:absolute;bottom:-100px;left:-100px;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(200,146,42,.06) 0%,transparent 70%);pointer-events:none}
.page-hero-in{position:relative;z-index:1;display:grid;grid-template-columns:60% 40%;gap:60px;align-items:center}
.hero-badge{display:inline-flex;align-items:center;gap:8px;background:rgba(200,146,42,.15);border:1px solid rgba(200,146,42,.4);color:var(--gold-lt);padding:7px 16px;border-radius:100px;font-size:.74rem;font-weight:600;letter-spacing:.07em;text-transform:uppercase;width:fit-content;margin-bottom:24px;animation:fadeUp .5s ease both}
.badge-dot{width:7px;height:7px;border-radius:50%;background:var(--gold);animation:pdot 2s infinite;flex-shrink:0}
.page-h1{font-family:var(--fh);font-size:clamp(2.2rem,3.5vw,3.4rem);font-weight:900;color:var(--cream);line-height:1.1;letter-spacing:-.025em;margin-bottom:20px;animation:fadeUp .5s .08s ease both}
.page-h1 em{color:var(--gold);font-style:italic}
.page-desc{font-size:1rem;color:rgba(246,241,233,.6);max-width:520px;line-height:1.75;margin-bottom:32px;animation:fadeUp .5s .16s ease both}
.hero-acts{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .5s .24s ease both}

/* MINI FORM (hero right side) */
.mini-form-wrap{background:rgba(246,241,233,.06);border:1px solid rgba(246,241,233,.12);border-radius:12px;padding:28px;animation:fadeUp .5s .1s ease both}
.mf-title{font-family:var(--fh);font-size:1.2rem;font-weight:700;color:var(--cream);margin-bottom:6px}
.mf-sub{font-size:.8rem;color:rgba(246,241,233,.45);margin-bottom:20px}
.mfg{margin-bottom:11px}
.mfg input,.mfg select{width:100%;background:rgba(246,241,233,.07);border:1px solid rgba(246,241,233,.15);color:var(--cream);padding:11px 14px;border-radius:var(--r);font-family:var(--fb);font-size:.88rem;outline:none;transition:border-color .2s;-webkit-appearance:none}
.mfg input::placeholder{color:rgba(246,241,233,.3)}
.mfg input:focus,.mfg select:focus{border-color:var(--gold)}
.mfg select option{background:#1a1916}
.mf-btn{width:100%;background:var(--gold);color:var(--ink);border:none;border-radius:var(--r);padding:13px;font-family:var(--fb);font-size:.93rem;font-weight:700;cursor:pointer;transition:all .2s;margin-top:4px}
.mf-btn:hover{background:var(--gold-lt)}

/* BUTTONS */
.btn-g{display:inline-flex;align-items:center;gap:9px;background:var(--gold);color:var(--ink);padding:14px 28px;border-radius:var(--r);font-size:.95rem;font-weight:700;border:none;cursor:pointer;transition:all .2s;box-shadow:0 4px 20px rgba(200,146,42,.35)}
.btn-g:hover{background:var(--gold-lt);transform:translateY(-2px)}
.btn-dk{display:inline-flex;align-items:center;gap:8px;background:rgba(246,241,233,.1);color:var(--cream);padding:14px 24px;border-radius:var(--r);font-size:.9rem;font-weight:600;border:1px solid rgba(246,241,233,.15);cursor:pointer;transition:all .2s}
.btn-dk:hover{background:rgba(246,241,233,.15)}
.btn-ink{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:var(--cream);padding:14px 28px;border-radius:var(--r);font-size:.95rem;font-weight:700;border:none;cursor:pointer;transition:all .2s}
.btn-ink:hover{background:#2a2825;transform:translateY(-2px)}

/* TRUST BAR */
.tbar{background:var(--gold);padding:13px 0}
.tbar-in{display:flex;align-items:center;justify-content:center;gap:32px;flex-wrap:wrap}
.ti{display:flex;align-items:center;gap:7px;font-size:.79rem;font-weight:700;color:var(--ink);white-space:nowrap}
.ti svg{width:14px;height:14px;flex-shrink:0}

/* SECTIONS */
.sec{padding:88px 0}
.sec-alt{background:var(--warm)}
.sec-dk{background:var(--ink)}
.slbl{display:inline-block;font-size:.71rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:12px}
.sh2{font-family:var(--fh);font-size:clamp(1.9rem,3vw,2.7rem);font-weight:900;color:var(--ink);letter-spacing:-.02em;line-height:1.15;margin-bottom:14px}
.sh2.lt{color:var(--cream)}
.ssub{font-size:.96rem;color:var(--muted);max-width:560px;line-height:1.72;margin-bottom:48px}
.ssub.lt{color:rgba(246,241,233,.5)}

/* CONTENT PROSE */
.prose{max-width:780px}
.prose h2{font-family:var(--fh);font-size:1.7rem;font-weight:700;color:var(--ink);margin:40px 0 14px;line-height:1.2}
.prose h3{font-family:var(--fh);font-size:1.2rem;font-weight:700;color:var(--ink);margin:28px 0 10px}
.prose p{font-size:.96rem;color:var(--muted);line-height:1.8;margin-bottom:16px}
.prose ul{margin:0 0 16px 20px}
.prose ul li{font-size:.94rem;color:var(--muted);line-height:1.75;margin-bottom:6px}
.prose strong{color:var(--ink);font-weight:600}

/* STEPS */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.step{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:30px 26px;transition:box-shadow .2s,transform .2s}
.step:hover{box-shadow:var(--sh-md);transform:translateY(-3px)}
.snum{font-family:var(--fh);font-size:3rem;font-weight:900;color:var(--gold-pale);line-height:1;margin-bottom:16px}
.step h3{font-family:var(--fh);font-size:1.15rem;font-weight:700;color:var(--ink);margin-bottom:8px}
.step p{font-size:.86rem;color:var(--muted);line-height:1.7}

/* BENEFIT GRID */
.benefits{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.benefit{background:rgba(246,241,233,.05);border:1px solid rgba(246,241,233,.1);border-radius:12px;padding:26px 22px;transition:all .2s}
.benefit:hover{background:rgba(200,146,42,.08);border-color:rgba(200,146,42,.3)}
.ben-ico{font-size:1.8rem;margin-bottom:12px;display:block}
.benefit h3{font-family:var(--fh);font-size:1rem;font-weight:700;color:var(--cream);margin-bottom:8px}
.benefit p{font-size:.82rem;color:rgba(246,241,233,.48);line-height:1.65}

/* FAQ */
.faq-list{max-width:740px;margin:0 auto}
.faq-item{border-bottom:1px solid var(--border)}
.faq-q{width:100%;background:none;border:none;display:flex;justify-content:space-between;align-items:center;padding:18px 0;font-family:var(--fb);font-size:.95rem;font-weight:600;color:var(--ink);text-align:left;cursor:pointer;gap:14px;transition:color .2s}
.faq-q:hover{color:var(--gold)}
.faq-q svg{width:16px;height:16px;flex-shrink:0;color:var(--gold);transition:transform .2s}
.faq-q[aria-expanded="true"] svg{transform:rotate(45deg)}
.faq-a{display:none;padding:0 0 18px;font-size:.88rem;color:var(--muted);line-height:1.75}
.faq-a.open{display:block}

/* CITY GRID */
.city-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:10px}
.city-lnk{background:var(--white);border:1px solid var(--border);border-radius:var(--r);padding:10px 14px;font-size:.8rem;font-weight:500;color:var(--ink);transition:all .15s;text-align:center}
.city-lnk:hover{background:var(--ink);color:var(--cream);border-color:var(--ink)}

/* SITUATION GRID */
.sit-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.sit-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:28px;transition:all .2s;display:flex;gap:16px;align-items:flex-start}
.sit-card:hover{box-shadow:var(--sh-md);transform:translateY(-2px)}
.sit-card-ico{font-size:1.8rem;flex-shrink:0;margin-top:2px}
.sit-card h3{font-family:var(--fh);font-size:1.05rem;font-weight:700;color:var(--ink);margin-bottom:6px}
.sit-card p{font-size:.84rem;color:var(--muted);line-height:1.65}
.sit-card a{display:inline-flex;align-items:center;gap:5px;margin-top:10px;font-size:.8rem;font-weight:600;color:var(--gold)}

/* FOOTER CTA */
.fcta{background:var(--ink);padding:88px 0;text-align:center;position:relative;overflow:hidden}
.fcta::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(200,146,42,.1) 0%,transparent 65%);pointer-events:none}
.fcta-in{position:relative;z-index:1}
.fcta h2{font-family:var(--fh);font-size:clamp(2rem,4vw,3.2rem);font-weight:900;color:var(--cream);letter-spacing:-.025em;line-height:1.15;margin-bottom:16px}
.fcta h2 em{font-style:italic;color:var(--gold)}
.fcta p{font-size:.96rem;color:rgba(246,241,233,.5);max-width:440px;margin:0 auto 36px;line-height:1.7}
.fcta-btns{display:flex;justify-content:center;gap:14px;flex-wrap:wrap}

/* FOOTER */
.footer{background:#080807;padding:32px 0;border-top:1px solid rgba(246,241,233,.06)}
.footer-in{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px}
.flogo{font-family:var(--fh);font-size:1rem;font-weight:900;color:rgba(246,241,233,.35)}
.flogo span{color:var(--gold)}
.fcopy{font-size:.75rem;color:rgba(246,241,233,.2)}
.flinks{display:flex;gap:16px}
.flinks a{font-size:.75rem;color:rgba(246,241,233,.28);transition:color .2s}
.flinks a:hover{color:var(--gold)}

/* MOBILE STICKY */
.mcta{display:none;position:fixed;bottom:0;left:0;right:0;background:var(--ink);border-top:1px solid rgba(246,241,233,.1);padding:10px 16px;z-index:150;gap:8px}
.mcta a{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:12px;border-radius:var(--r);font-size:.85rem;font-weight:700}
.mcta .mc{background:var(--gold);color:var(--ink)}
.mcta .mf{background:rgba(246,241,233,.08);color:var(--cream);border:1px solid rgba(246,241,233,.12)}

/* REVEAL */
.rv{opacity:0;transform:translateY(16px);transition:opacity .5s ease,transform .5s ease}
.rv.vis{opacity:1;transform:translateY(0)}

/* BREADCRUMB */
.breadcrumb{display:flex;align-items:center;gap:8px;font-size:.76rem;color:rgba(246,241,233,.4);margin-bottom:20px;flex-wrap:wrap}
.breadcrumb a{color:rgba(246,241,233,.4);transition:color .2s}
.breadcrumb a:hover{color:var(--gold)}
.breadcrumb span{color:rgba(246,241,233,.2)}

/* RESPONSIVE */
@media(max-width:1024px){
  .page-hero-in{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr;gap:16px}
  .benefits{grid-template-columns:repeat(2,1fr)}
  .city-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:768px){
  .nav-lk{display:none}
  .benefits{grid-template-columns:1fr}
  .sit-grid{grid-template-columns:1fr}
  .city-grid{grid-template-columns:repeat(2,1fr)}
  .sec{padding:60px 0}
  .mcta{display:flex}
  body{padding-bottom:64px}
  .page-h1{font-size:2.1rem}
}
@media(max-width:480px){
  .wrap{padding:0 16px}
  .city-grid{grid-template-columns:repeat(2,1fr)}
}
