:root{
  --navy:#1e2522;     /* primary warm charcoal */
  --navy-2:#27302b;
  --navy-3:#333d37;
  --green:#15452f;    /* green accent */
  --green-2:#1f5238;
  --green-soft:#7fa893;
  --gold:#c4a24a;
  --gold-soft:#d8bd76;
  --cream:#f7f3ec;
  --cream-2:#efe9dd;
  --ink:#16202c;
  --muted:#5d6b7a;
  --line:rgba(196,162,74,.28);
  --shadow:0 18px 50px rgba(8,18,32,.16);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Source Sans 3',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--ink);background:var(--cream);line-height:1.65;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4{font-family:var(--serif);line-height:1.12;font-weight:700;color:var(--navy)}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:1200px;margin:0 auto;padding:0 28px}
.eyebrow{font-family:var(--sans);font-weight:700;letter-spacing:.22em;text-transform:uppercase;font-size:.72rem;color:var(--gold)}
.btn{display:inline-flex;align-items:center;gap:10px;font-weight:700;letter-spacing:.02em;padding:15px 28px;border-radius:2px;transition:.25s;font-size:1.02rem;cursor:pointer;border:none}
.btn-gold{background:var(--gold);color:var(--navy)}
.btn-gold:hover{background:var(--gold-soft);transform:translateY(-2px);box-shadow:0 12px 30px rgba(196,162,74,.35)}
.btn-ghost{background:transparent;color:var(--cream);border:1.5px solid rgba(247,243,236,.45)}
.btn-ghost:hover{border-color:var(--gold);color:var(--gold)}

/* ===== TOP UTILITY BAR ===== */
.utility{background:var(--green);color:#d3e2d8;font-size:.86rem;border-bottom:1px solid rgba(196,162,74,.35)}
.utility .wrap{display:flex;justify-content:space-between;align-items:center;height:42px}
.utility .u-left span{margin-right:22px}
.utility .u-left b{color:var(--gold-soft)}
.utility a:hover{color:var(--gold-soft)}

/* ===== HEADER ===== */
header{position:sticky;top:0;z-index:60;background:var(--navy);color:var(--cream);box-shadow:0 2px 20px rgba(8,18,32,.35)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px}
.brand{display:flex;flex-direction:column;line-height:1}
.brand .name{font-family:var(--serif);font-weight:700;font-size:1.5rem;letter-spacing:.04em;color:var(--cream)}
.brand .name b{color:var(--gold)}
.brand .sub{font-size:.68rem;letter-spacing:.42em;text-transform:uppercase;color:#9fb0c2;margin-top:6px;padding-left:3px}
nav ul{display:flex;gap:30px;list-style:none;align-items:center}
nav ul a{font-weight:600;font-size:.93rem;letter-spacing:.02em;color:#dde4ec;padding:6px 0;border-bottom:2px solid transparent;transition:.2s}
nav ul a:hover, nav ul a.active{color:var(--gold);border-color:var(--gold)}
.nav-cta{display:flex;align-items:center;gap:18px}
.phone-pill{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}
.phone-pill small{font-size:.66rem;letter-spacing:.18em;text-transform:uppercase;color:#9fb0c2}
.phone-pill a{font-family:var(--serif);font-size:1.35rem;font-weight:700;color:var(--gold)}

/* ===== MOBILE NAVIGATION (HAMBURGER) ===== */
.hamburger{display:none;flex-direction:column;justify-content:space-between;width:26px;height:19px;background:transparent;border:none;cursor:pointer;z-index:110}
.hamburger span{width:100%;height:3px;background-color:var(--cream);transition:all 0.3s ease;border-radius:2px}

/* ===== AS SEEN ON ===== */
.seenon{background:var(--cream-2);border-bottom:1px solid var(--line)}
.seenon .wrap{display:flex;align-items:center;justify-content:center;gap:34px;padding:16px 28px;flex-wrap:wrap}
.seenon span{font-weight:700;letter-spacing:.2em;text-transform:uppercase;font-size:.74rem;color:var(--muted)}
.seenon img{height:62px;width:auto;max-width:100%;opacity:.95}

/* ===== HERO ===== */
.hero{position:relative;background:var(--navy);color:var(--cream);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:url("../images/williamson-county-courthouse.jpg") center 26%/cover no-repeat}
.hero::after{content:"";position:absolute;inset:0;z-index:1;background:
    linear-gradient(102deg,rgba(20,25,23,.95) 0%,rgba(22,28,25,.88) 36%,rgba(22,28,25,.60) 72%,rgba(20,25,23,.72) 100%),
    radial-gradient(circle at 80% 8%,rgba(196,162,74,.16),transparent 46%)}
.hero .wrap{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:30px;align-items:center;min-height:600px;padding-top:54px;padding-bottom:0}
.hero-copy .eyebrow{margin-bottom:20px;display:block}
.hero h1{font-size:4rem;color:var(--cream);letter-spacing:.01em}
.hero h1 .gold{color:var(--gold);display:block;font-style:italic;font-weight:600;font-size:2.55rem;margin-top:14px}
.hero .tag{font-family:var(--serif);font-style:italic;font-size:1.5rem;color:var(--gold-soft);margin:26px 0 8px;border-left:3px solid var(--gold);padding-left:18px}
.hero p.lead{color:#c3cedb;font-size:1.08rem;max-width:520px;margin:22px 0 32px}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center}
.hero-note{margin-top:22px;font-size:.9rem;color:#9fb0c2;display:flex;align-items:center;gap:10px}
.hero-note::before{content:"";width:26px;height:1px;background:var(--gold)}
.hero-figure{position:relative;align-self:end;justify-self:start}
.hero-figure img{max-height:660px;width:auto;display:block;filter:drop-shadow(0 18px 34px rgba(0,0,0,.45))}
.hero-figure .ring{position:absolute;bottom:40px;left:50%;transform:translateX(-50%);width:108%;height:60%;background:radial-gradient(ellipse at center bottom,rgba(196,162,74,.22),transparent 70%);z-index:0}
.badge-float{display:none;position:absolute;top:30px;right:-6px;background:var(--cream);color:var(--navy);border-radius:4px;padding:14px 18px;box-shadow:var(--shadow);text-align:center;z-index:3}
.badge-float .num{font-family:var(--serif);font-size:1.9rem;font-weight:800;color:var(--gold)}
.badge-float .lbl{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* ===== HERO AWARD BADGES ===== */
.hero-badges{--ab-navy:#1c3f6e;--ab-red:#df4f2d;--ab-star:#f5a623;--ab-blue:#1f63aa;
  display:flex;flex-direction:column;gap:18px;align-items:center;justify-self:center;margin:auto;width:100%;max-width:230px}
.abadge{background:#fff;width:198px;text-align:center;box-shadow:0 14px 34px rgba(0,0,0,.4);font-family:var(--sans);color:var(--ab-navy)}
.abadge .avvo-logo{font-weight:800;color:var(--ab-blue);font-size:1.12rem;letter-spacing:.01em}
.abadge .ribbon{background:var(--ab-navy);color:#fff;font-weight:700;font-size:.64rem;letter-spacing:.06em;padding:6px 5px}
.abadge .stars{color:var(--ab-star);font-size:.98rem;letter-spacing:3px;padding:9px 0}
.ab-cc{border:2px solid var(--ab-navy)}
.ab-cc .pad{padding:13px 12px 3px}
.ab-cc .title{color:var(--ab-red);font-weight:800;font-size:.95rem;line-height:1.18;margin-top:7px}
.ab-rev{width:180px;height:180px;border-radius:50%;border:3px solid var(--ab-navy);overflow:visible;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:0 14px}
.ab-rev .title{color:var(--ab-red);font-weight:800;font-size:1.1rem}
.ab-rev .stars{padding:5px 0}
.ab-rev .sub{color:#8a929b;font-size:.68rem}
.ab-rev .ribbon{width:198px;margin:6px 0}
.ab-rat{border:2px solid var(--ab-navy)}
.ab-rat .pad{padding:12px 12px 5px}
.ab-rat .head{font-weight:700;color:var(--ab-navy);font-size:.85rem}
.ab-rat .head .avvo-logo{font-size:.95rem}
.ab-rat .num{color:var(--ab-red);font-family:var(--serif);font-weight:800;font-size:2.5rem;line-height:1;margin:2px 0 8px}
.ab-rat .sub{padding:7px 0;font-weight:700;color:var(--ab-navy);font-size:.82rem}

/* ===== STATS BAND ===== */
.stats{background:var(--navy-2);color:var(--cream);border-top:3px solid var(--gold)}
.stats .wrap{display:grid;grid-template-columns:repeat(4,1fr);text-align:center;padding:0}
.stat{padding:36px 18px;border-right:1px solid rgba(255,255,255,.08)}
.stat:last-child{border-right:none}
.stat .n{font-family:var(--serif);font-size:2.5rem;font-weight:800;color:var(--gold)}
.stat .t{font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:#b9c5d4;margin-top:4px}

/* ===== SECTION SHELL ===== */
section.block{padding:92px 0}
.sec-head{text-align:center;max-width:680px;margin:0 auto 54px}
.sec-head .eyebrow{margin-bottom:14px;display:block}
.sec-head h2{font-size:2.6rem}
.sec-head p{color:var(--muted);margin-top:16px;font-size:1.06rem}
.rule{width:64px;height:3px;background:var(--gold);margin:20px auto 0}

/* ===== PRACTICE AREAS ===== */
.areas{background:var(--cream)}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card{background:#fff;border:1px solid #e7e0d2;border-top:3px solid var(--gold);padding:34px 30px;transition:.28s;position:relative}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-top-color:var(--green)}
.card .ico{width:46px;height:46px;color:var(--green-2);margin-bottom:18px}
.card:hover .ico{color:var(--gold)}
.card h3{font-size:1.4rem;margin-bottom:10px}
.card p{color:var(--muted);font-size:.95rem}
.card .more{margin-top:18px;display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--green-2);font-size:.9rem;letter-spacing:.04em}
.card:hover .more{color:var(--gold)}

/* ===== ABOUT / WHAT I CAN DO ===== */
.about{background:
    radial-gradient(circle at 85% 0%,rgba(196,162,74,.14),transparent 45%),
    linear-gradient(155deg,var(--green) 0%,var(--green-2) 55%,#0f3325 100%);
    color:var(--cream)}
.about .wrap{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.about-photo{position:relative}
.about-photo img{border-radius:3px;box-shadow:var(--shadow);filter:grayscale(.15) contrast(1.02)}
.about-photo .frame{position:absolute;inset:18px -18px -18px 18px;border:1.5px solid var(--gold);z-index:-1;border-radius:3px}
.about h2{color:var(--cream);font-size:2.5rem}
.about h2 em{color:var(--gold);font-style:italic}
.about p{color:#c3cedb;margin-top:18px}
.quote-sig{font-family:var(--serif);font-style:italic;font-size:1.3rem;color:var(--gold-soft);margin-top:26px;border-left:3px solid var(--gold);padding-left:18px}

/* ===== REVIEWS ===== */
.reviews{background:var(--cream-2)}
.stars-row{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:6px}
.stars-row img{height:34px}
.grid3.tcards{margin-top:10px}
.tcard{background:#fff;padding:32px 30px;border:1px solid #e7e0d2;position:relative}
.tcard .mark{font-family:var(--serif);font-size:3.4rem;color:var(--gold);line-height:.6;height:26px}
.tcard p{color:#33404e;font-style:italic;font-size:1rem}
.tcard .who{margin-top:18px;font-weight:700;color:var(--navy);letter-spacing:.04em}
.tcard .who small{display:block;font-weight:400;color:var(--muted);font-style:normal;letter-spacing:0}
.review-actions{display:flex;gap:16px;justify-content:center;margin-top:44px;flex-wrap:wrap}
.btn-navy{background:var(--navy);color:var(--cream)}
.btn-navy:hover{background:var(--navy-2)}
.btn-line{background:transparent;border:1.5px solid var(--navy);color:var(--navy)}
.btn-line:hover{background:var(--navy);color:var(--cream)}
.badges-strip{display:flex;gap:30px;justify-content:center;align-items:center;margin-top:48px;flex-wrap:wrap;opacity:.95}
.badges-strip img{height:62px;width:auto}

/* ===== ATTORNEYS ===== */
.team .grid2{display:grid;grid-template-columns:1fr 1fr;gap:34px}
.att{background:#fff;border:1px solid #e7e0d2;display:flex;gap:24px;padding:26px;align-items:center}
.att img{width:140px;height:170px;object-fit:cover;border-radius:2px;filter:grayscale(.1)}
.att h3{font-size:1.5rem}
.att .role{color:var(--gold);font-weight:700;letter-spacing:.1em;text-transform:uppercase;font-size:.74rem;margin:6px 0 12px}
.att p{color:var(--muted);font-size:.92rem}
.att a.mail{display:inline-block;margin-top:12px;color:var(--navy);font-weight:600;border-bottom:1px solid var(--gold)}

/* ===== CONTACT ===== */
.contact{background:
    linear-gradient(155deg,rgba(30,37,34,.95),rgba(18,23,21,.96)),url("../images/contact-section-bg.jpg") center/cover fixed;
    color:var(--cream)}
.contact .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:54px;align-items:center}
.contact h2{color:var(--cream);font-size:2.7rem}
.contact h2 em{color:var(--gold);font-style:italic}
.contact .big-call{font-family:var(--serif);font-size:2.6rem;font-weight:800;color:var(--gold);display:inline-block;margin:18px 0 6px}
.contact .sub{color:#c3cedb}
.info-list{margin-top:30px;list-style:none}
.info-list li{display:flex;gap:14px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.1)}
.info-list .k{color:var(--gold);font-weight:700;min-width:96px;letter-spacing:.08em;text-transform:uppercase;font-size:.74rem;padding-top:3px}
.info-list .v{color:#dbe3ec}
.hours-card{background:rgba(255,255,255,.05);border:1px solid rgba(196,162,74,.3);padding:34px}
.hours-card h3{color:var(--cream);font-size:1.4rem;margin-bottom:18px}
.hours-card .row{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed rgba(255,255,255,.12);font-size:.96rem;color:#cfd8e2}
.hours-card .row b{color:var(--gold-soft)}
.hours-card .note{font-size:.82rem;color:#9fb0c2;margin-top:16px;font-style:italic}
.hours-card .btn{width:100%;justify-content:center;margin-top:24px}

/* ===== FOOTER ===== */
footer{background:#141917;color:#929b95;font-size:.88rem}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:60px 0 40px;border-bottom:1px solid rgba(255,255,255,.08)}
.foot-top .name{font-family:var(--serif);font-size:1.4rem;color:var(--cream)}
.foot-top .name b{color:var(--gold)}
.foot-top h4{color:var(--cream);font-family:var(--sans);font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;margin-bottom:16px}
.foot-top ul{list-style:none}
.foot-top ul li{margin-bottom:9px}
.foot-top a:hover{color:var(--gold-soft)}
.disclaimer{padding:24px 0 40px;color:#5e6e7f;font-size:.78rem;line-height:1.7}
.copy{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;padding-top:18px;border-top:1px solid rgba(255,255,255,.06);color:#6c7a8b}

/* floating mobile call */
.float-call{position:fixed;bottom:18px;right:18px;z-index:80;display:none;background:var(--gold);color:var(--navy);width:60px;height:60px;border-radius:50%;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.35)}

/* ===== INTERIOR PAGE SPECIFIC STYLES ===== */
.interior-hero {
  position: relative;
  background: var(--navy);
  color: var(--cream);
  padding: 80px 0 70px;
  text-align: center;
  border-bottom: 3px solid var(--gold);
  overflow: hidden;
}
.interior-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: url("../images/williamson-county-courthouse.jpg") center 26%/cover no-repeat;
  opacity: 0.12;
}
.interior-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 1;
  background: linear-gradient(180deg, rgba(30, 37, 34, 0.85) 0%, rgba(20, 25, 23, 0.95) 100%);
}
.interior-hero .wrap {
  position: relative;
  z-index: 2;
}
.interior-hero h1 {
  font-size: 3.2rem;
  color: var(--cream);
  margin-top: 10px;
}
.interior-hero .breadcrumbs {
  font-size: 0.8rem;
  color: var(--gold-soft);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  margin-bottom: 8px;
}
.breadcrumbs span {
  margin: 0 8px;
  opacity: 0.5;
}

.interior-body {
  background: var(--cream);
  padding: 80px 0;
}
.interior-grid {
  display: grid;
  grid-template-columns: 2.1fr 1fr;
  gap: 60px;
  align-items: start;
}
.content-area {
  background: #fff;
  border: 1px solid #e7e0d2;
  padding: 50px 45px;
  border-radius: 2px;
  box-shadow: 0 4px 15px rgba(0,0,0,0.02);
}
.content-area h2 {
  font-size: 2rem;
  margin: 36px 0 16px;
  color: var(--navy);
  border-bottom: 2px solid var(--cream-2);
  padding-bottom: 10px;
}
.content-area h2:first-of-type {
  margin-top: 0;
}
.content-area h3 {
  font-size: 1.4rem;
  margin: 28px 0 12px;
}
.content-area p {
  margin-bottom: 20px;
  color: #33404e;
  font-size: 1.05rem;
  line-height: 1.75;
}
.content-area p:last-child {
  margin-bottom: 0;
}
.content-area ul, .content-area ol {
  margin: 0 0 24px 20px;
}
.content-area li {
  margin-bottom: 10px;
  color: #33404e;
  font-size: 1.02rem;
}
.content-area li::marker {
  color: var(--gold);
}

/* Sidebar Styles */
.sidebar {
  display: flex;
  flex-direction: column;
  gap: 30px;
}
.sidebar-card {
  background: #fff;
  border: 1px solid #e7e0d2;
  padding: 34px 30px;
  border-radius: 2px;
}
.sidebar-card.accent {
  background: var(--navy);
  color: var(--cream);
  border: 1px solid rgba(196,162,74,0.3);
}
.sidebar-card.accent h3 {
  color: var(--cream);
}
.sidebar-card h3 {
  font-size: 1.35rem;
  margin-bottom: 18px;
  border-bottom: 1.5px solid var(--gold);
  padding-bottom: 8px;
}
.sidebar-card.accent h3 {
  border-bottom-color: rgba(196,162,74,0.4);
}
.sidebar-card .sidebar-hours {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sidebar-card .sidebar-hours .row {
  display: flex;
  justify-content: space-between;
  border-bottom: 1px dashed rgba(0,0,0,0.08);
  padding-bottom: 8px;
  font-size: 0.94rem;
}
.sidebar-card.accent .sidebar-hours .row {
  border-bottom-color: rgba(255,255,255,0.08);
}
.sidebar-card .sidebar-hours .row b {
  color: var(--green);
}
.sidebar-card.accent .sidebar-hours .row b {
  color: var(--gold-soft);
}
.sidebar-card .contact-info {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.sidebar-card .contact-info .item {
  display: flex;
  gap: 12px;
  font-size: 0.96rem;
}
.sidebar-card .contact-info .item .lbl {
  font-weight: 700;
  color: var(--gold);
  min-width: 65px;
  text-transform: uppercase;
  font-size: 0.72rem;
  padding-top: 3px;
}
.sidebar-card .badge-group {
  display: flex;
  flex-direction: column;
  gap: 16px;
  align-items: center;
}
.sidebar-card .badge-group img {
  height: 60px;
  width: auto;
}

/* Call to Action Band */
.cta-band {
  background: var(--green);
  color: var(--cream);
  padding: 70px 0;
  text-align: center;
  border-top: 4px solid var(--gold);
  border-bottom: 1px solid rgba(255,255,255,0.05);
}
.cta-band .wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  max-width: 800px;
}
.cta-band h2 {
  font-size: 2.4rem;
  color: var(--cream);
}
.cta-band h2 em {
  color: var(--gold-soft);
  font-style: italic;
}
.cta-band p {
  color: var(--green-soft);
  font-size: 1.1rem;
  max-width: 580px;
  margin-bottom: 10px;
}

/* ===== RESPONSIVE ===== */
@media(max-width:980px){
  nav ul,.utility .u-left{display:none}
  .nav{height:72px}
  
  /* Mobile Menu Toggle classes */
  .hamburger{display:flex}
  nav {display:none}
  nav.active{display:flex !important;position:fixed;top:114px;left:0;right:0;bottom:0;background:var(--navy);z-index:99;padding:40px 28px;overflow-y:auto;flex-direction:column}
  nav.active ul{display:flex;flex-direction:column;align-items:stretch;gap:20px;width:100%}
  nav.active ul li{width:100%}
  nav.active ul a{display:block;font-size:1.25rem;padding:12px 0;border-bottom:1px solid rgba(255,255,255,0.08);width:100%}
  
  /* Animate Hamburger */
  .hamburger.active span:nth-child(1){transform:translateY(8px) rotate(45deg)}
  .hamburger.active span:nth-child(2){opacity:0}
  .hamburger.active span:nth-child(3){transform:translateY(-8px) rotate(-45deg)}

  .hero .wrap{grid-template-columns:1fr;text-align:center;min-height:auto;padding-bottom:60px}
  .hero-figure,.hero-badges{display:none}
  .hero h1{font-size:2.9rem}
  .hero h1 .gold{font-size:1.9rem}
  .hero-note{justify-content:center}
  .hero .tag{border-left:none;padding-left:0}
  .hero p.lead{margin-left:auto;margin-right:auto}
  .hero-actions{justify-content:center}
  .stats .wrap{grid-template-columns:1fr 1fr}
  .stat{border-bottom:1px solid rgba(255,255,255,.08)}
  .grid3,.about .wrap,.contact .wrap,.team .grid2,.foot-top,.interior-grid{grid-template-columns:1fr}
  .about .wrap{gap:40px}
  .about-photo .frame{inset:12px -12px -12px 12px}
  .float-call{display:flex}
  .sec-head h2{font-size:2.05rem}
  
  .interior-hero {padding:60px 0 50px}
  .interior-hero h1 {font-size:2.2rem}
  .content-area {padding:35px 25px}
  .cta-band {padding:50px 0}
  .cta-band h2 {font-size:1.85rem}
}

@media(max-width:560px){
  .att{flex-direction:column;text-align:center}
  .seenon .wrap{gap:18px}
  .seenon img{height:26px}
  .stats .wrap{grid-template-columns:1fr}
  .stat{border-right:none;border-bottom:1px solid rgba(255,255,255,.08)}
}

/* ============================================================
   DESKTOP-LINK LEAD MODAL — mobile only
   Captures an email and posts to /api/lead (Resend + Supabase).
   ============================================================ */
.lead-modal-overlay{
  display:none;
  position:fixed;
  inset:0;
  /* Above the LeadConnector chat widget (uses a very high z-index) */
  z-index:2147483647;
  align-items:flex-end;
  justify-content:center;
  padding:0;
  background:rgba(30,37,34,.55);
  backdrop-filter:blur(3px);
  -webkit-backdrop-filter:blur(3px);
  opacity:0;
  transition:opacity .25s ease;
}
.lead-modal-overlay.open{display:flex;opacity:1}

.lead-modal{
  position:relative;
  width:100%;
  max-width:480px;
  background:#fff;
  border-radius:16px 16px 0 0;
  padding:2.25rem 1.5rem 2rem;
  box-shadow:var(--shadow);
  border-top:3px solid var(--gold);
  transform:translateY(100%);
  transition:transform .4s cubic-bezier(.16,1,.3,1);
}
.lead-modal-overlay.open .lead-modal{transform:translateY(0)}

.lead-modal-close{
  position:absolute;
  top:.5rem;
  right:.75rem;
  width:40px;
  height:40px;
  border:none;
  background:transparent;
  color:var(--muted);
  font-size:1.75rem;
  line-height:1;
  cursor:pointer;
}

.lead-modal-eyebrow{
  display:inline-block;
  font-family:var(--sans);
  font-size:.7rem;
  font-weight:700;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:.6rem;
}

.lead-modal-title{
  font-family:var(--serif);
  font-size:1.6rem;
  font-weight:700;
  line-height:1.15;
  color:var(--navy);
  margin:0 0 .6rem;
}

.lead-modal-text{
  font-family:var(--sans);
  font-size:.95rem;
  line-height:1.5;
  color:var(--muted);
  margin:0 0 1.25rem;
}

.lead-form{display:flex;flex-direction:column;gap:.6rem}

.lead-input{
  width:100%;
  font-family:var(--sans);
  font-size:1rem;
  padding:.9rem 1rem;
  border:1px solid var(--line);
  border-radius:8px;
  background:var(--cream);
  color:var(--ink);
  min-height:52px;
}
.lead-input:focus{
  outline:none;
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(21,69,47,.18);
}

.lead-submit{
  width:100%;
  font-family:var(--sans);
  font-size:1rem;
  font-weight:600;
  padding:.9rem 1rem;
  min-height:52px;
  border:none;
  border-radius:8px;
  background:var(--green);
  color:#fff;
  cursor:pointer;
  transition:background .25s ease;
}
.lead-submit:hover{background:var(--green-2)}
.lead-submit:disabled{opacity:.6;cursor:default}

.lead-error{
  margin:.2rem 0 0;
  font-family:var(--sans);
  font-size:.85rem;
  color:#b3261e;
}

.lead-success-check{
  width:56px;
  height:56px;
  margin:0 auto 1rem;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  background:rgba(21,69,47,.12);
  color:var(--green);
  font-size:1.75rem;
  font-weight:700;
}
#lead-view-success{text-align:center}

.lead-skip{
  display:block;
  width:100%;
  margin-top:.9rem;
  border:none;
  background:transparent;
  font-family:var(--sans);
  font-size:.85rem;
  color:var(--muted);
  text-decoration:underline;
  text-underline-offset:3px;
  cursor:pointer;
  padding:.4rem;
}

/* --- "Made by Creative Cowboys" credit --- */
.lead-modal-credit{
  margin-top:1.4rem;
  padding-top:1.1rem;
  border-top:1px solid var(--line);
  text-align:center;
}
.lead-credit-logo{display:block;width:130px;height:auto;margin:0 auto .6rem}
.lead-credit-text{
  font-family:var(--sans);
  font-size:.8rem;
  line-height:1.45;
  color:var(--muted);
  margin:0 0 .35rem;
}
.lead-credit-links{font-family:var(--sans);font-size:.8rem;margin:0;color:var(--muted)}
.lead-credit-links a{color:var(--navy);font-weight:600;text-decoration:underline;text-underline-offset:3px}
.lead-credit-links span{margin:0 .35rem}

/* Never show on tablet / desktop — this is a mobile-only prompt */
@media (min-width:769px){
  .lead-modal-overlay{display:none !important}
}
