/* ============================================================
   DUI.guru - Joel Brand, Esq. | California DUI Defense
   Firm-brand theme (distinct identity from DUIAnalysis.com)
   Palette: deep navy ink + crisp paper white + brass/gold accent
   Type:    Lora (serif display) + Inter (grotesk UI/body)
   ============================================================ */

:root {
  --navy:#11253d; --navy-deep:#0b1a2c; --navy-700:#16314f; --navy-600:#21466e; --navy-tint:#eef2f7;
  --ink:#15212e; --ink-soft:#3f4b58; --ink-mute:#6a7682; --ink-faint:#97a1ab;
  --paper:#f6f8fb; --paper-warm:#fbfbf9; --surface:#ffffff; --surface-2:#f1f4f8;
  --brass:#b4884a; --brass-deep:#936b32; --brass-soft:#d2ab68; --brass-glow:rgba(180,136,74,.14);
  --red:#a8392b; --red-soft:rgba(168,57,43,.08); --green:#2f8f5b;
  --line:rgba(17,37,61,.12); --line-soft:rgba(17,37,61,.06); --line-on-navy:rgba(255,255,255,.14);
  --font-display:'Lora',Georgia,'Times New Roman',serif;
  --font-body:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --container-w:1180px;
  --radius-sm:6px; --radius-md:10px; --radius-lg:18px;
  --shadow-sm:0 1px 2px rgba(11,26,44,.06),0 2px 8px rgba(11,26,44,.05);
  --shadow-md:0 4px 14px rgba(11,26,44,.08),0 12px 32px rgba(11,26,44,.08);
  --shadow-lg:0 18px 50px rgba(11,26,44,.16);
}

* { box-sizing: border-box; }
html { font-size:17px; -webkit-text-size-adjust:100%; scroll-behavior:smooth; }
body { margin:0; font-family:var(--font-body); font-weight:400; line-height:1.6; color:var(--ink); background:var(--paper); -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale; }
img { max-width:100%; height:auto; display:block; }
button,input,select,textarea { font-family:inherit; font-size:inherit; color:inherit; }
a { color:var(--navy-600); text-decoration:none; transition:color 150ms ease; }
a:hover { color:var(--brass-deep); }
h1,h2,h3,h4 { font-family:var(--font-display); font-weight:600; line-height:1.16; letter-spacing:-.005em; color:var(--navy); margin:0 0 .55em; }

.container { width:100%; max-width:var(--container-w); margin:0 auto; padding:0 24px; }
.eyebrow { font-family:var(--font-body); font-size:.78rem; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--brass-deep); margin-bottom:.7rem; }
.section-head { max-width:740px; margin:0 auto 2.2rem; text-align:center; }
.section-head h2 { font-size:clamp(1.8rem,3.2vw,2.4rem); }
.section-head p { color:var(--ink-soft); font-size:1.04rem; margin:0; }

/* Buttons */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:.5rem; font-family:var(--font-body); font-weight:600; font-size:.97rem; padding:.8rem 1.5rem; border-radius:var(--radius-sm); border:1px solid transparent; cursor:pointer; transition:all 160ms ease; text-align:center; white-space:nowrap; }
.btn-primary { background:var(--brass); color:#fff; box-shadow:var(--shadow-sm); }
.btn-primary:hover { background:var(--brass-deep); color:#fff; transform:translateY(-1px); box-shadow:var(--shadow-md); }
.btn-navy { background:var(--navy); color:#fff; }
.btn-navy:hover { background:var(--navy-700); color:#fff; transform:translateY(-1px); }
.btn-ghost { background:transparent; color:var(--navy); border-color:var(--line); }
.btn-ghost:hover { border-color:var(--navy); color:var(--navy); }
.btn-large { padding:.95rem 1.9rem; font-size:1.04rem; }

/* Social icon links (robust centering) */
.social { display:inline-flex; align-items:center; gap:.5rem; }
.social a { width:34px; height:34px; border-radius:8px; display:inline-flex; align-items:center; justify-content:center; line-height:0; color:currentColor; transition:all 150ms ease; }
.social svg { width:17px; height:17px; fill:currentColor; display:block; margin:0; }
.topbar .social a { color:rgba(255,255,255,.78); }
.topbar .social a:hover { color:#fff; background:rgba(255,255,255,.10); }
.footer-col .footer-social a { display:inline-flex; align-items:center; justify-content:center; margin-bottom:0; border:1px solid var(--line-on-navy); color:rgba(255,255,255,.8); }
.footer-social a:hover { border-color:var(--brass); color:var(--brass-soft); }

/* Top utility bar */
.topbar { background:var(--navy-deep); color:rgba(255,255,255,.82); font-size:.8rem; }
.topbar-inner { display:flex; align-items:center; justify-content:space-between; min-height:38px; }
.topbar-left { display:flex; align-items:center; gap:1.2rem; }
.topbar .dot { width:7px; height:7px; border-radius:50%; background:#43c47a; display:inline-block; margin-right:.5rem; box-shadow:0 0 0 3px rgba(67,196,122,.18); animation:dotBlink 1.3s ease-in-out infinite; }
@keyframes dotBlink { 0%,100% { opacity:1; box-shadow:0 0 0 0 rgba(67,196,122,.55); } 50% { opacity:.45; box-shadow:0 0 0 6px rgba(67,196,122,0); } }
@media (prefers-reduced-motion: reduce) { .topbar .dot { animation:none; } }

/* Header */
.site-header { position:sticky; top:0; z-index:50; background:rgba(255,255,255,.94); backdrop-filter:saturate(160%) blur(10px); border-bottom:1px solid var(--line); }
.header-inner { display:flex; align-items:center; gap:1.4rem; min-height:72px; }
.brand { display:flex; align-items:center; gap:.7rem; }
.brand-monogram { width:44px; height:44px; flex:none; border-radius:8px; background:var(--navy); color:var(--brass-soft); display:grid; place-items:center; font-family:var(--font-body); font-weight:800; font-size:1.02rem; letter-spacing:.04em; }
.brand-text { display:flex; flex-direction:column; line-height:1.12; }
.brand-name { font-family:var(--font-display); font-weight:600; font-size:1.18rem; color:var(--navy); white-space:nowrap; }
.brand-name .esq { font-weight:500; color:var(--ink-mute); }
.brand-sub { font-size:.67rem; font-weight:600; letter-spacing:.13em; text-transform:uppercase; color:var(--ink-mute); margin-top:1px; }
.main-nav { display:flex; align-items:center; gap:1.5rem; margin-left:auto; }
.main-nav a { font-size:.92rem; font-weight:500; color:var(--ink-soft); }
.main-nav a:hover { color:var(--navy); }
.header-phone { display:inline-flex; align-items:center; gap:.5rem; white-space:nowrap; background:var(--navy); color:#fff; font-weight:600; font-size:.95rem; padding:.6rem 1.05rem; border-radius:var(--radius-sm); }
.header-phone:hover { background:var(--brass); color:#fff; }
.header-phone .ic { color:var(--brass-soft); }
.header-phone:hover .ic { color:#fff; }

/* Hero */
.hero { position:relative; overflow:hidden; background:radial-gradient(120% 90% at 85% 0%,#fff 0%,var(--paper) 60%); }
.hero-grid { display:grid; grid-template-columns:1.1fr .9fr; gap:2.6rem; align-items:center; padding:3rem 24px 2.6rem; }
.hero-headline { font-size:clamp(2.2rem,4.2vw,3.2rem); line-height:1.08; margin-bottom:.9rem; }
.hero-headline .accent { color:var(--brass-deep); }
.hero-sub { font-size:1.12rem; color:var(--ink-soft); max-width:42ch; margin-bottom:1.4rem; }
.hero-actions { display:flex; flex-wrap:wrap; gap:.8rem; margin-bottom:1.4rem; }

/* Ratings bar */
.ratings-bar { display:flex; flex-direction:column; gap:.6rem; align-items:center; padding-top:1.3rem; border-top:1px solid var(--line); }
.ratings-row { display:flex; flex-wrap:wrap; gap:.7rem; justify-content:center; align-items:stretch; }
.rating-chip { display:flex; align-items:center; gap:.55rem; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:.5rem .8rem; box-shadow:var(--shadow-sm); }
.rating-chip .rc-score { font-family:var(--font-display); font-weight:700; color:var(--navy); font-size:1.15rem; line-height:1; }
.rating-chip .rc-meta { display:flex; flex-direction:column; line-height:1.25; }
.rating-chip .rc-stars { color:var(--brass); font-size:.8rem; letter-spacing:.06em; }
.rating-chip .rc-src { font-size:.8rem; font-weight:600; color:var(--ink); }
.award-chip { display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; background:var(--navy); color:#fff; border-radius:var(--radius-md); padding:.5rem .9rem; line-height:1.25; }
.award-chip b { font-size:.85rem; color:#fff; }
.award-chip span { font-size:.72rem; letter-spacing:.04em; color:var(--brass-soft); }

/* Hero portrait */
.hero-photo { position:relative; justify-self:center; }
.hero-photo .ring { position:absolute; inset:auto 0 0 50%; transform:translateX(-50%); width:108%; aspect-ratio:1/1; border-radius:50%; background:radial-gradient(closest-side,var(--brass-glow),transparent 72%); z-index:0; }
.hero-photo .disc { position:absolute; left:50%; bottom:-2%; transform:translateX(-50%); width:86%; aspect-ratio:1/1; border-radius:50%; background:linear-gradient(180deg,var(--surface-2),#e7edf4); border:1px solid var(--line); z-index:0; }
.hero-photo img.portrait { position:relative; z-index:1; width:min(400px,80vw); filter:drop-shadow(0 24px 34px rgba(11,26,44,.22)); }
.photo-caption { position:absolute; right:-8px; bottom:24px; z-index:2; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); box-shadow:var(--shadow-md); padding:.6rem .85rem; display:flex; align-items:center; gap:.55rem; }
.photo-caption .pc-name { font-family:var(--font-display); font-weight:600; color:var(--navy); font-size:.95rem; line-height:1.1; }
.photo-caption .pc-role { font-size:.7rem; color:var(--ink-mute); text-transform:uppercase; letter-spacing:.08em; }
.photo-caption .pc-bar { width:3px; align-self:stretch; background:var(--brass); border-radius:3px; }

/* Promise strip */
.promise-strip { background:var(--navy); }
.promise-grid { display:grid; grid-template-columns:repeat(4,1fr); }
.promise { display:flex; align-items:center; gap:.75rem; padding:1.15rem 1.4rem; color:rgba(255,255,255,.9); border-left:1px solid var(--line-on-navy); }
.promise:first-child { border-left:0; }
.promise .pic { width:32px; height:32px; flex:none; display:grid; place-items:center; color:var(--brass-soft); }
.promise .pic svg { width:26px; height:26px; fill:none; stroke:currentColor; stroke-width:1.6; }
.promise b { display:block; color:#fff; font-size:.94rem; font-weight:700; line-height:1.2; }
.promise span { font-size:.8rem; color:rgba(255,255,255,.66); }

/* Section scaffolding (tightened) */
section.block { padding:3.4rem 0; }
.bg-paper { background:var(--paper); } .bg-white { background:var(--surface); } .bg-warm { background:var(--paper-warm); }

/* Evaluation section */
.eval-section { background:linear-gradient(180deg,var(--navy) 0%,var(--navy-deep) 100%); color:#fff; }
.eval-grid { display:grid; grid-template-columns:.85fr 1.15fr; gap:2.6rem; align-items:start; padding:3.4rem 24px; }
.eval-pitch .eyebrow { color:var(--brass-soft); }
.eval-pitch h2 { color:#fff; font-size:clamp(1.8rem,3.2vw,2.4rem); }
.eval-pitch p { color:rgba(255,255,255,.8); font-size:1.04rem; margin:.4rem 0 0; }
.eval-points { list-style:none; padding:0; margin:1.2rem 0 0; display:grid; gap:.65rem; }
.eval-points li { display:flex; gap:.7rem; align-items:flex-start; color:rgba(255,255,255,.9); font-size:.97rem; }
.eval-points .tick { color:var(--brass-soft); flex:none; margin-top:.1rem; font-weight:700; }
.eval-pitch .eval-reassure { margin-top:1.2rem; }

/* Form card */
.form-card { background:var(--surface); color:var(--ink); border-radius:var(--radius-lg); box-shadow:var(--shadow-lg); overflow:hidden; }
.form-card-header { padding:1.4rem 1.7rem 1rem; border-bottom:1px solid var(--line); background:var(--paper-warm); }
.form-eyebrow { font-size:.74rem; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--brass-deep); }
.form-title { font-size:1.35rem; margin:.3rem 0 .8rem; }
.progress-bar { height:6px; background:var(--surface-2); border-radius:6px; overflow:hidden; }
.progress-fill { height:100%; width:10%; background:linear-gradient(90deg,var(--brass),var(--brass-soft)); border-radius:6px; transition:width 280ms ease; }
.progress-label { font-size:.8rem; color:var(--ink-mute); margin-top:.45rem; }
#evalForm { padding:1.5rem 1.7rem 1.7rem; }
fieldset.step { border:0; margin:0; padding:0; display:none; }
fieldset.step.active { display:block; animation:fadeIn 240ms ease; }
@keyframes fadeIn { from{opacity:0;transform:translateY(6px);} to{opacity:1;transform:none;} }
fieldset.step legend { font-family:var(--font-display); font-weight:600; font-size:1.22rem; color:var(--navy); padding:0; margin-bottom:.9rem; }
.legend-hint { font-family:var(--font-body); font-size:.82rem; font-weight:500; color:var(--ink-mute); }
.choices { display:grid; gap:.5rem; }
.choices-inline { grid-auto-flow:column; grid-auto-columns:1fr; }
.choice { position:relative; display:flex; align-items:center; gap:.7rem; padding:.75rem .9rem; border:1px solid var(--line); border-radius:var(--radius-sm); cursor:pointer; transition:all 140ms ease; font-size:.95rem; }
.choice:hover { border-color:var(--brass-soft); background:var(--brass-glow); }
.choice input { accent-color:var(--brass-deep); width:18px; height:18px; flex:none; }
.choice input:checked ~ span { font-weight:600; color:var(--navy); }
.choice:has(input:checked) { border-color:var(--brass); background:var(--brass-glow); box-shadow:inset 0 0 0 1px var(--brass); }
.sub-question { margin-bottom:1.1rem; }
.sub-label { font-size:.95rem; font-weight:500; color:var(--ink); margin:0 0 .55rem; }
.field { margin-bottom:.9rem; }
.field-grid { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.field label { display:block; font-size:.85rem; font-weight:600; color:var(--ink-soft); margin-bottom:.35rem; }
.field input,.field select,.field textarea { width:100%; padding:.7rem .85rem; border:1px solid var(--line); border-radius:var(--radius-sm); background:var(--surface); transition:border 140ms ease,box-shadow 140ms ease; }
.field input:focus,.field select:focus,.field textarea:focus { outline:none; border-color:var(--brass); box-shadow:0 0 0 3px var(--brass-glow); }
.optional { color:var(--ink-faint); font-weight:400; }
.consent { font-size:.78rem; color:var(--ink-mute); line-height:1.5; margin-top:.9rem; }
.form-nav { display:flex; align-items:center; justify-content:space-between; gap:1rem; margin-top:1.3rem; }
.form-nav .btn-primary,.form-nav .btn[type="submit"] { margin-left:auto; }
.screen-message .screen-text { color:var(--ink-soft); }
.screen-message .screen-cta { background:var(--brass-glow); border-radius:var(--radius-sm); padding:.85rem 1rem; }

/* Approach */
.approach-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:1.2rem; }
.approach-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:1.4rem 1.4rem; box-shadow:var(--shadow-sm); transition:transform 160ms ease,box-shadow 160ms ease; }
.approach-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); }
.approach-card .num { font-family:var(--font-display); font-size:1.1rem; color:var(--brass); font-weight:700; }
.approach-card h3 { font-size:1.16rem; margin:.4rem 0 .4rem; }
.approach-card p { color:var(--ink-soft); font-size:.95rem; margin:0; }

/* Value (4 across, no empty cells) */
.value-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.2rem; }
.value-card { background:var(--surface); border:1px solid var(--line); border-top:3px solid var(--brass); border-radius:var(--radius-md); padding:1.4rem 1.3rem; box-shadow:var(--shadow-sm); }
.value-card .vic { width:38px; height:38px; color:var(--brass-deep); margin-bottom:.6rem; }
.value-card .vic svg { width:34px; height:34px; fill:none; stroke:currentColor; stroke-width:1.5; }
.value-card h3 { font-size:1.12rem; margin:0 0 .4rem; }
.value-card p { color:var(--ink-soft); font-size:.93rem; margin:0; }
.pay-note { display:inline-flex; align-items:center; gap:.5rem; margin-top:.7rem; font-size:.8rem; font-weight:600; color:var(--navy); background:var(--surface-2); padding:.3rem .65rem; border-radius:999px; }

/* Meet Joel */
.meet { display:grid; grid-template-columns:.8fr 1.2fr; gap:2.6rem; align-items:center; }
.meet-photo { background:linear-gradient(180deg,var(--surface-2),#e8eef4); border:1px solid var(--line); border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-md); }
.meet-photo img { width:100%; }
.meet h2 { font-size:clamp(1.7rem,3vw,2.3rem); }
.meet p { color:var(--ink-soft); font-size:1.03rem; margin:0 0 .8rem; }
.sig { margin-top:1.1rem; padding-left:1rem; border-left:3px solid var(--brass); }
.sig .sig-name { font-family:var(--font-display); font-weight:600; font-size:1.22rem; color:var(--navy); }
.sig .sig-role { font-size:.78rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute); }

/* Library teaser (4 across, 8 cards = 2 full rows) */
.lib-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1rem; }
.lib-card { display:block; background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--brass); border-radius:var(--radius-sm); padding:1rem 1.1rem; transition:all 150ms ease; }
.lib-card:hover { box-shadow:var(--shadow-md); transform:translateY(-2px); border-left-color:var(--brass-deep); }
.lib-card .lib-kicker { font-size:.7rem; text-transform:uppercase; letter-spacing:.1em; color:var(--ink-mute); }
.lib-card h3 { font-size:1.02rem; margin:.3rem 0 0; color:var(--navy); line-height:1.25; }
.lib-card:hover h3 { color:var(--brass-deep); }

/* Testimonials (3 across, 6 cards = 2 full rows) */
.tmon-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.2rem; }
.tmon-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:1.4rem 1.4rem; box-shadow:var(--shadow-sm); display:flex; flex-direction:column; }
.tmon-card .stars { color:var(--brass); letter-spacing:.08em; margin-bottom:.45rem; }
.tmon-card .tmon-title { font-family:var(--font-display); font-weight:600; color:var(--navy); font-size:1.05rem; margin-bottom:.45rem; }
.tmon-card blockquote { margin:0; font-size:.95rem; color:var(--ink-soft); line-height:1.55; }
.tmon-card .who { margin-top:1rem; padding-top:.8rem; border-top:1px solid var(--line-soft); font-size:.85rem; color:var(--ink-mute); display:flex; align-items:center; justify-content:space-between; }
.tmon-card .who b { color:var(--navy); font-weight:600; }
.tmon-card .src { font-size:.7rem; text-transform:uppercase; letter-spacing:.05em; color:var(--brass-deep); font-weight:600; }
.tmon-foot { margin-top:1.6rem; text-align:center; }
.tmon-foot .btn { margin:0 .3rem; }
.tmon-foot .disclaimer { font-size:.8rem; color:var(--ink-mute); max-width:780px; margin:1rem auto 0; }
.reviews-masonry { columns:3 340px; column-gap:1.2rem; }
.reviews-masonry .tmon-card { break-inside:avoid; margin-bottom:1.2rem; }

/* Locations */
.loc-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:1rem; }
.loc-card { background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:1rem 1.15rem; }
.loc-card.primary { border-color:var(--brass); box-shadow:inset 0 0 0 1px var(--brass); }
.loc-card .loc-city { font-family:var(--font-display); font-weight:600; color:var(--navy); font-size:1.04rem; }
.loc-card .loc-addr { font-size:.88rem; color:var(--ink-soft); margin-top:.3rem; line-height:1.45; }

/* Urgency */
.urgency { background:var(--navy-deep); color:#fff; border-top:3px solid var(--brass); }
.urgency-inner { display:flex; align-items:center; gap:1.4rem; padding:2.4rem 24px; }
.urgency .ic { font-size:1.9rem; flex:none; color:var(--brass-soft); }
.urgency h3 { color:#fff; font-size:1.35rem; margin:0 0 .35rem; }
.urgency p { color:rgba(255,255,255,.78); margin:0; font-size:.97rem; }
.urgency a { color:var(--brass-soft); } .urgency a:hover { color:#fff; }

/* Final CTA */
.cta { background:radial-gradient(120% 120% at 50% 0%,var(--navy-700),var(--navy-deep)); color:#fff; text-align:center; }
.cta-inner { padding:3.6rem 24px; }
.cta h2 { color:#fff; font-size:clamp(1.9rem,3.4vw,2.6rem); margin-bottom:.5rem; }
.cta h2 .accent { color:var(--brass-soft); }
.cta p { color:rgba(255,255,255,.82); max-width:660px; margin:0 auto 1.3rem; }
.cta-phone { font-family:var(--font-display); font-weight:700; font-size:clamp(2rem,5vw,2.7rem); color:#fff; display:inline-block; white-space:nowrap; }
.cta-phone:hover { color:var(--brass-soft); }
.cta-or { font-size:.85rem; text-transform:uppercase; letter-spacing:.12em; color:rgba(255,255,255,.5); margin:.9rem 0; }

/* Footer */
.site-footer { background:var(--navy-deep); color:rgba(255,255,255,.66); font-size:.9rem; }
.footer-top { display:grid; grid-template-columns:1.5fr 1fr 1.1fr 1fr; gap:2.2rem; padding:3rem 24px 2rem; }
.footer-brand .brand-name { color:#fff; }
.footer-brand .brand-name .esq { color:var(--brass-soft); }
.footer-brand .brand-sub { color:var(--brass-soft); }
.footer-brand p { margin:.9rem 0; max-width:34ch; }
.footer-phone { font-family:var(--font-display); font-size:1.45rem; color:#fff; font-weight:700; white-space:nowrap; }
.footer-phone:hover { color:var(--brass-soft); }
.footer-col h4 { color:#fff; font-family:var(--font-body); font-size:.78rem; text-transform:uppercase; letter-spacing:.12em; font-weight:700; margin:0 0 .9rem; }
.footer-col a,.footer-col p { color:rgba(255,255,255,.66); display:block; margin-bottom:.5rem; }
.footer-col a:hover { color:var(--brass-soft); }
.footer-col .addr { line-height:1.5; }
.footer-social { margin-top:.6rem; }
.footer-disclaimer { border-top:1px solid var(--line-on-navy); padding:1.8rem 24px; }
.footer-disclaimer p { font-size:.8rem; line-height:1.6; color:rgba(255,255,255,.5); margin:0; }
.footer-disclaimer a { color:rgba(255,255,255,.72); text-decoration:underline; }
.footer-meta { border-top:1px solid var(--line-on-navy); padding:1.1rem 24px 88px; display:flex; flex-wrap:wrap; justify-content:space-between; gap:.8rem; font-size:.8rem; color:rgba(255,255,255,.5); }
.footer-meta nav { display:flex; flex-wrap:wrap; gap:1.2rem; }

/* Live chat button (delayed reveal + attention pulse) */
.chat-fab { position:fixed; right:22px; bottom:22px; z-index:60; display:inline-flex; align-items:center; gap:.55rem; background:var(--brass); color:#fff; font-weight:700; font-size:.95rem; padding:.85rem 1.3rem; border-radius:999px; box-shadow:var(--shadow-lg); border:0; cursor:pointer; opacity:0; transform:translateY(14px); pointer-events:none; transition:opacity .45s ease, transform .45s ease; }
.chat-fab.show { opacity:1; transform:none; pointer-events:auto; animation:chatPulse 2.6s ease-in-out infinite; }
.chat-fab:hover { background:var(--brass-deep); color:#fff; }
.chat-fab .dot { width:9px; height:9px; border-radius:50%; background:#43c47a; box-shadow:0 0 0 3px rgba(67,196,122,.3); }
@keyframes chatPulse { 0%,100% { box-shadow:var(--shadow-lg),0 0 0 0 rgba(180,136,74,.55); } 50% { box-shadow:var(--shadow-lg),0 0 0 14px rgba(180,136,74,0); } }
@media (prefers-reduced-motion: reduce) { .chat-fab.show { animation:none; } }

/* Library article pages */
.breadcrumb { font-size:.82rem; color:var(--ink-mute); padding-top:1.3rem; }
.breadcrumb a { color:var(--brass-deep); }
.article-hero { padding:1.3rem 0 1.4rem; border-bottom:1px solid var(--line); margin-bottom:2rem; }
.article-hero .eyebrow { margin-bottom:.5rem; }
.article-hero h1 { font-size:clamp(1.9rem,3.6vw,2.6rem); max-width:24ch; margin:0; }
.article-wrap { max-width:760px; margin:0 auto; }
.article-body { font-size:1.06rem; line-height:1.75; color:var(--ink-soft); }
.article-body h2 { font-family:var(--font-body); font-weight:700; font-size:1.4rem; margin:1.9rem 0 .6rem; color:var(--navy); letter-spacing:-.01em; }
.article-body h3 { font-family:var(--font-body); font-weight:700; font-size:1.16rem; margin:1.4rem 0 .5rem; color:var(--navy); }
.article-body h4 { font-family:var(--font-body); font-weight:700; font-size:1.02rem; margin:1.2rem 0 .4rem; color:var(--navy); }
.article-body p { margin:0 0 1.1rem; }
.article-body a { color:var(--brass-deep); text-decoration:underline; }
.article-body ul,.article-body ol { margin:0 0 1.1rem 1.3rem; }
.article-body li { margin-bottom:.45rem; }
.article-body img { height:auto; border-radius:var(--radius-md); margin:1.3rem 0; }
.article-body blockquote { border-left:3px solid var(--brass); padding-left:1.1rem; margin:1.3rem 0; color:var(--ink); }
.article-body table { width:100%; border-collapse:collapse; margin:1.3rem 0; font-size:.95rem; }
.article-body th,.article-body td { border:1px solid var(--line); padding:.6rem .7rem; text-align:left; }
.article-back { display:inline-block; margin-top:2rem; font-weight:600; color:var(--brass-deep); }
.lib-index-head { text-align:center; max-width:720px; margin:0 auto 2rem; }

/* ===== Ported components for migrated tools / cities / counties (firm palette) ===== */
.hero-copy { min-width:0; }
.hero-grid-single { grid-template-columns:1fr; max-width:780px; margin:0 auto; }
.hero-meta { display:flex; flex-wrap:wrap; gap:1.2rem 2.2rem; margin:1.3rem 0; }
.meta-item { display:flex; flex-direction:column; }
.meta-num { font-family:var(--font-display); font-size:1.7rem; font-weight:700; color:var(--navy); line-height:1; }
.meta-label { font-size:.76rem; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-mute); margin-top:.25rem; }
.hero-note { font-size:.85rem; color:var(--ink-mute); margin-top:1rem; max-width:50ch; }

.content-section { padding:.5rem 0; }
.county-content { max-width:820px; margin:0 auto; font-size:1.05rem; line-height:1.7; color:var(--ink-soft); }
.county-content h2 { font-family:var(--font-display); font-weight:600; font-size:1.55rem; color:var(--navy); margin:1.9rem 0 .6rem; }
.county-content h3 { font-family:var(--font-body); font-weight:700; font-size:1.18rem; color:var(--navy); margin:1.4rem 0 .5rem; }
.county-content p { margin:0 0 1.1rem; }
.county-content ul, .county-content ol { margin:0 0 1.1rem 1.3rem; }
.county-content li { margin-bottom:.45rem; }
.county-content a { color:var(--brass-deep); text-decoration:underline; }
.county-content strong { color:var(--ink); }

.info-box { background:var(--surface); border:1px solid var(--line); border-left:3px solid var(--brass); border-radius:var(--radius-md); padding:1.1rem 1.3rem; margin:1.4rem 0; box-shadow:var(--shadow-sm); }
.info-box p { margin:0; color:var(--ink-soft); }
.info-label { display:block; font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--brass-deep); margin-bottom:.4rem; }
.badge { display:inline-block; font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; padding:.18rem .55rem; border-radius:999px; background:rgba(47,143,91,.12); color:var(--green); margin-bottom:.5rem; }

/* FAQ accordion */
.faq-inner { max-width:800px; margin:0 auto; }
.faq-list { display:grid; gap:.6rem; margin-top:1.2rem; }
.faq-item { border:1px solid var(--line); border-radius:var(--radius-md); background:var(--surface); padding:0 1.1rem; }
.faq-item summary { cursor:pointer; font-family:var(--font-display); font-weight:600; color:var(--navy); padding:.95rem 0; font-size:1.04rem; list-style:none; }
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::marker { content:""; }
.faq-item[open] summary { color:var(--brass-deep); }
.faq-body { color:var(--ink-soft); padding:0 0 1rem; font-size:.97rem; line-height:1.65; }
.faq-body p { margin:0 0 .8rem; }

/* CTA strip */
.cta-strip { background:radial-gradient(120% 120% at 50% 0%, var(--navy-700), var(--navy-deep)); color:#fff; text-align:center; padding:3rem 0; border-top:3px solid var(--brass); }
.cta-strip h2 { color:#fff; font-size:clamp(1.7rem,3vw,2.3rem); }
.cta-strip h2 .cta-now, .cta-now { color:var(--brass-soft); font-style:normal; }
.cta-strip p { color:rgba(255,255,255,.82); max-width:640px; margin:.4rem auto 1.3rem; }

/* Phone CTAs */
.phone-cta { display:inline-flex; align-items:center; gap:.5rem; background:var(--brass); color:#fff; font-weight:600; padding:.8rem 1.4rem; border-radius:var(--radius-sm); white-space:nowrap; }
.phone-cta:hover { background:var(--brass-deep); color:#fff; }
.phone-cta-large { font-size:1.4rem; padding:1rem 1.9rem; font-family:var(--font-display); font-weight:700; }
.phone-icon { font-size:1.05em; }
.btn-call { display:inline-flex; align-items:center; gap:.5rem; background:var(--navy); color:#fff; font-weight:600; padding:.8rem 1.4rem; border-radius:var(--radius-sm); white-space:nowrap; }
.btn-call:hover { background:var(--brass); color:#fff; }

/* Calculator form helpers */
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-hint { font-size:.82rem; color:var(--ink-mute); margin-top:.3rem; }
.form-disclaimer { font-size:.78rem; color:var(--ink-mute); line-height:1.5; margin-top:1rem; }

/* Tools hub */
.tools-section-heading { font-family:var(--font-display); font-weight:600; color:var(--navy); font-size:1.4rem; margin:2.2rem 0 1rem; padding-bottom:.5rem; border-bottom:1px solid var(--line); }
.tools-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1rem; }
.tool-card { display:block; background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-md); padding:1.3rem 1.4rem; box-shadow:var(--shadow-sm); transition:transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease; }
.tool-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md); border-color:var(--brass-soft); }
.tool-card h3 { font-size:1.12rem; margin:.2rem 0 .4rem; color:var(--navy); }
.tool-card:hover h3 { color:var(--brass-deep); }
.tool-card p { font-size:.92rem; color:var(--ink-soft); margin:0; line-height:1.55; }
@media (max-width:560px) { .form-row { grid-template-columns:1fr; } }

/* Responsive */
@media (max-width:1040px) { .value-grid { grid-template-columns:repeat(2,1fr); } .lib-grid { grid-template-columns:repeat(3,1fr); } }
@media (max-width:1000px) { .promise-grid { grid-template-columns:repeat(2,1fr); } .promise:nth-child(3) { border-left:0; } }
@media (max-width:940px) {
  .hero-grid,.eval-grid,.meet { grid-template-columns:1fr; }
  .hero-grid { padding-top:2.4rem; gap:1.6rem; }
  .hero-photo { order:-1; }
  .hero-photo img.portrait { width:min(300px,68vw); }
  .meet-photo { max-width:340px; margin:0 auto; }
  .tmon-grid { grid-template-columns:repeat(2,1fr); }
  .footer-top { grid-template-columns:1fr 1fr; }
}
@media (max-width:720px) {
  .main-nav { display:none; }
  .choices-inline { grid-auto-flow:row; }
  .field-grid,.footer-top,.value-grid,.lib-grid,.tmon-grid { grid-template-columns:1fr; }
  .promise-grid { grid-template-columns:1fr; } .promise { border-left:0; }
}
