/* ─── Variables ─── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
:root {
    --blue: #1d4ed8; --blue-deep: #1e3a8a; --blue-bright: #3b82f6;
    --red: #dc2626; --red-soft: rgba(220,38,38,0.08);
    --cream: #FAF9F6; --ink: #0A0A0A; --ink-80: #2A2A2A; --ink-60: #555;
    --ink-40: #888; --ink-20: #BBB; --ink-10: #DDD; --ink-05: #EEEDE9;
    --green: #16a34a; --green-soft: rgba(22,163,74,0.1);
    --serif: 'Instrument Serif', Georgia, serif;
    --sans: 'DM Sans', system-ui, sans-serif;
    --max-w: 1080px;
}
body { font-family: var(--sans); color: var(--ink); background: var(--cream); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
a { color: var(--blue); text-decoration: none; transition: color 0.15s; }
a:hover { color: var(--blue-deep); }
img { max-width: 100%; height: auto; }
ul { list-style: none; }

/* Grain overlay */
.grain{position:fixed;inset:0;pointer-events:none;z-index:9999;opacity:0.3;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E")}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(32px);transition:opacity 0.7s cubic-bezier(0.22,1,0.36,1),transform 0.7s cubic-bezier(0.22,1,0.36,1)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-delay-1{transition-delay:0.1s}.reveal-delay-2{transition-delay:0.2s}.reveal-delay-3{transition-delay:0.3s}

/* ─── Nav ─── */
.topnav{position:fixed;top:0;left:0;right:0;z-index:100;padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;transition:background 0.3s,box-shadow 0.3s}
.topnav.scrolled{background:rgba(250,249,246,0.92);backdrop-filter:blur(16px);box-shadow:0 1px 0 var(--ink-10)}
.topnav-logo{display:flex;align-items:center;gap:0.6rem;text-decoration:none;color:var(--ink)}
.topnav-logo .cross{width:30px;height:30px;background:var(--blue);border-radius:6px;display:grid;place-items:center;color:white;font-weight:700;font-size:1rem;line-height:1}
.topnav-logo .cross svg{width:18px;height:18px}
.topnav-logo .wordmark{font-weight:700;font-size:0.95rem;letter-spacing:-0.01em}
.topnav-logo .wordmark .wm-accent{color:var(--blue)}
.topnav-right{display:flex;align-items:center;gap:1rem}
.topnav-cta{font-size:0.8rem;font-weight:600;color:var(--ink-60);text-decoration:none;padding:0.5rem 1rem;border:1px solid var(--ink-10);border-radius:100px;transition:all 0.2s}
.topnav-cta:hover{border-color:var(--blue);color:var(--blue)}
.nav-link{font-size:0.85rem;font-weight:500;color:var(--ink-60);text-decoration:none;transition:color 0.15s}
.nav-link:hover{color:var(--ink)}

/* ─── Hero ─── */
.hero{min-height:100vh;min-height:100svh;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;padding:7rem 2rem 3rem;position:relative}
.hero::before{content:'';position:absolute;top:10%;right:6%;width:280px;height:280px;background:radial-gradient(circle,rgba(29,78,216,0.06) 0%,transparent 70%);pointer-events:none}
.hero::after{content:'';position:absolute;bottom:20%;left:8%;width:200px;height:200px;background:radial-gradient(circle,rgba(220,38,38,0.04) 0%,transparent 70%);pointer-events:none}
.hero-eyebrow{display:inline-flex;align-items:center;gap:0.5rem;font-size:0.75rem;font-weight:600;letter-spacing:0.12em;text-transform:uppercase;color:var(--blue);margin-bottom:2rem}
.hero-eyebrow::before,.hero-eyebrow::after{content:'';width:24px;height:1px;background:var(--blue)}
.hero h1{font-family:var(--serif);font-size:clamp(2.75rem,7vw,5.5rem);font-weight:400;line-height:1.05;letter-spacing:-0.03em;color:var(--ink);max-width:820px;margin-bottom:1.5rem}
.hero h1 em{font-style:italic;color:var(--blue)}

.hero-sub{font-size:1.1rem;color:var(--ink-40);max-width:480px;margin:0 auto 3rem;line-height:1.6}

/* Search */
.search-wrap{position:relative;width:100%;max-width:560px;margin:0 auto 4rem;z-index:10}
.search-box{display:flex;align-items:center;background:white;border:2px solid var(--ink);border-radius:100px;overflow:hidden;transition:border-color 0.2s,box-shadow 0.2s}
.search-box:focus-within{border-color:var(--blue);box-shadow:0 0 0 4px rgba(29,78,216,0.1)}
.search-box .s-icon{flex-shrink:0;margin-left:1.25rem;color:var(--ink-40)}
.search-box .s-icon svg{width:20px;height:20px;display:block}
.search-input{flex:1;border:none;background:none;padding:1.1rem 0.75rem;font-size:1rem;font-family:var(--sans);color:var(--ink);outline:none}
.search-input::placeholder{color:var(--ink-20)}
.search-btn{flex-shrink:0;background:var(--blue);color:white;border:none;padding:0.85rem 1.75rem;margin:0.35rem;border-radius:100px;font-size:0.875rem;font-weight:600;font-family:var(--sans);cursor:pointer;transition:background 0.15s}
.search-btn:hover{background:var(--blue-deep)}

/* Autocomplete / Search results */
.search-results,.autocomplete-list{position:absolute;top:calc(100% + 8px);left:0;right:0;background:white;border:1px solid var(--ink-10);border-radius:16px;box-shadow:0 24px 64px rgba(0,0,0,0.12);overflow:hidden;display:none;z-index:200;max-height:400px;overflow-y:auto}
.search-results.open,.autocomplete-list.visible{display:block}
.sr-item{display:flex;align-items:center;gap:0.85rem;padding:0.85rem 1.25rem;cursor:pointer;color:var(--ink);text-decoration:none;border-bottom:1px solid var(--ink-05);transition:background 0.1s}
.sr-item:last-child{border-bottom:none}
.sr-item:hover{background:#f0f4ff}
.sr-name{font-weight:600;font-size:0.9375rem}
.sr-loc{font-size:0.75rem;color:var(--ink-40)}
.sr-empty{padding:1.5rem;text-align:center;color:var(--ink-40)}

/* Carousel */
.carousel-section{padding:0 0 2rem;position:relative}
.carousel-wrap{overflow:hidden;mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%);-webkit-mask-image:linear-gradient(90deg,transparent 0%,black 6%,black 94%,transparent 100%)}
.carousel-track{display:flex;gap:0.5rem;animation:marquee 50s linear infinite;width:max-content}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.carousel-track:hover{animation-play-state:paused}
.c-pill{flex-shrink:0;display:inline-flex;align-items:center;gap:0.4rem;padding:0.5rem 1rem;background:transparent;border:1px solid var(--ink-10);border-radius:100px;text-decoration:none;color:var(--ink);font-size:0.8125rem;font-weight:500;white-space:nowrap;transition:all 0.2s}
.c-pill:hover{border-color:var(--blue);color:var(--blue);background:rgba(29,78,216,0.04)}
.c-pill .c-dot{width:6px;height:6px;background:var(--ink-20);border-radius:50%;transition:background 0.2s}
.c-pill:hover .c-dot{background:var(--blue)}

/* ─── Stats strip ─── */
.stats-strip{background:var(--ink);color:white;overflow:hidden}
.stats-inner{max-width:var(--max-w);margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr)}
.stat-block{padding:3rem 2rem;text-align:center;position:relative}
.stat-block:not(:last-child)::after{content:'';position:absolute;right:0;top:25%;bottom:25%;width:1px;background:rgba(255,255,255,0.12)}
.stat-val{font-family:var(--serif);font-size:clamp(2rem,4vw,3.25rem);font-weight:400;letter-spacing:-0.03em;line-height:1;margin-bottom:0.35rem}
.stat-val .accent{color:var(--blue-bright)}
.stat-lbl{font-size:0.8rem;color:rgba(255,255,255,0.5);letter-spacing:0.04em;text-transform:uppercase;font-weight:500}

/* ─── How section ─── */
.how-section{padding:6rem 2rem;max-width:var(--max-w);margin:0 auto}
.how-header{display:flex;align-items:flex-end;justify-content:space-between;gap:2rem;margin-bottom:4rem;flex-wrap:wrap}
.how-header h2{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:400;letter-spacing:-0.02em;line-height:1.15;max-width:460px}
.how-header p{font-size:0.9rem;color:var(--ink-40);max-width:320px;line-height:1.6}
.how-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.h-step{padding:2.5rem 2rem;border-top:2px solid var(--ink-10);position:relative;transition:border-color 0.3s}
.h-step:hover{border-top-color:var(--blue)}
.h-step-num{font-family:var(--serif);font-size:4rem;color:var(--ink-05);line-height:1;margin-bottom:1.25rem;transition:color 0.3s}
.h-step:hover .h-step-num{color:rgba(29,78,216,0.15)}
.h-step h3{font-size:1.05rem;font-weight:700;margin-bottom:0.5rem;letter-spacing:-0.01em}
.h-step p{font-size:0.875rem;color:var(--ink-40);line-height:1.6}

/* ─── States section ─── */
.states-section{padding:0 2rem 6rem;max-width:var(--max-w);margin:0 auto}
.states-header{margin-bottom:3rem}
.states-header h2{font-family:var(--serif);font-size:clamp(1.75rem,4vw,2.75rem);font-weight:400;letter-spacing:-0.02em;margin-bottom:0.5rem}
.states-header p{color:var(--ink-40);font-size:0.95rem}

/* State tiles (top states with images) */
.states-grid-featured{display:grid;grid-template-columns:repeat(4,1fr);grid-template-rows:auto auto;gap:1rem;margin-bottom:3rem}
.state-tile:nth-child(1),.state-tile:nth-child(2){grid-column:span 2;min-height:280px}
.state-tile{position:relative;display:flex;flex-direction:column;justify-content:flex-end;border-radius:12px;overflow:hidden;text-decoration:none;color:white;min-height:180px}
.state-tile .tile-bg{position:absolute;inset:0;background:linear-gradient(135deg,var(--blue-deep) 0%,#0f172a 100%)}
.state-tile:nth-child(2) .tile-bg{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%)}
.state-tile:nth-child(3) .tile-bg{background:linear-gradient(135deg,#064e3b 0%,#0f172a 100%)}
.state-tile:nth-child(4) .tile-bg{background:linear-gradient(135deg,#312e81 0%,#0f172a 100%)}
.state-tile:nth-child(5) .tile-bg{background:linear-gradient(135deg,#7c2d12 0%,#0f172a 100%)}
.state-tile:nth-child(6) .tile-bg{background:linear-gradient(135deg,#134e4a 0%,#0f172a 100%)}
.state-tile:nth-child(7) .tile-bg{background:linear-gradient(135deg,#3b0764 0%,#0f172a 100%)}
.state-tile:nth-child(8) .tile-bg{background:linear-gradient(135deg,#1e3a5f 0%,#0a1628 100%)}
.state-tile .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,0.5) 0%,rgba(0,0,0,0.05) 60%);z-index:1}
.tile-content{position:relative;z-index:2;padding:1.25rem 1.5rem}
.tile-name{font-family:var(--serif);font-size:1.35rem;line-height:1.2;margin-bottom:0.15rem}
.state-tile:nth-child(1) .tile-name,.state-tile:nth-child(2) .tile-name{font-size:1.75rem}
.tile-sub{font-size:0.7rem;text-transform:uppercase;letter-spacing:0.08em;color:rgba(255,255,255,0.6);font-weight:500}
.tile-arrow{position:absolute;top:1rem;right:1rem;z-index:2;width:32px;height:32px;background:rgba(255,255,255,0.12);backdrop-filter:blur(4px);border-radius:50%;display:flex;align-items:center;justify-content:center;opacity:0;transform:translate(-4px,4px);transition:all 0.3s cubic-bezier(0.22,1,0.36,1)}
.state-tile:hover .tile-arrow{opacity:1;transform:translate(0,0)}
.tile-arrow svg{width:14px;height:14px}
.tile-state-svg{position:absolute;top:50%;right:2rem;z-index:1;width:100px;height:100px;opacity:0.08;transform:translateY(-50%);filter:brightness(0) invert(1)}
.state-tile:nth-child(1) .tile-state-svg,.state-tile:nth-child(2) .tile-state-svg{width:140px;height:140px}

/* All states list */
.states-all{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:2rem}
.state-pill{padding:.5rem 1rem;font-size:.8rem;font-weight:500;background:white;border:1px solid var(--ink-10);border-radius:6px;text-decoration:none;color:var(--ink);transition:all .15s}
.state-pill:hover{border-color:var(--blue);color:var(--blue);background:rgba(29,78,216,0.04)}
.state-pill .pill-count{color:var(--ink-40);font-size:.7rem;margin-left:.3rem}

/* Banned states */
.banned-box{margin-top:2rem;background:white;border:1px solid var(--ink-05);border-radius:12px;padding:2rem;position:relative;overflow:hidden}
.banned-box h3{font-size:0.95rem;font-weight:600;margin-bottom:0.5rem}
.banned-box p{font-size:0.85rem;color:var(--ink-60);line-height:1.7;margin-bottom:0.8rem}
.banned-tags{display:flex;flex-wrap:wrap;gap:0.4rem}
.banned-tag{padding:0.3rem 0.7rem;background:var(--red-soft);color:var(--red);border-radius:6px;font-size:0.75rem;font-weight:600}

/* ─── Info content box ─── */
.info-box-home{background:white;border:1px solid var(--ink-05);border-radius:12px;padding:2.5rem;position:relative;overflow:hidden}
.info-box-home .deco{position:absolute;right:2rem;top:-.5rem;font-family:var(--serif);font-size:8rem;color:var(--ink-05);line-height:1;pointer-events:none}
.info-box-home h2{font-family:var(--serif);font-size:1.35rem;font-weight:400;margin-bottom:1rem;position:relative}
.info-box-home p{font-size:.875rem;color:var(--ink-60);line-height:1.75;margin-bottom:.6rem;max-width:680px;position:relative}
.info-box-home h3{font-size:.95rem;font-weight:600;margin:1.5rem 0 .6rem;position:relative}
.info-box-home a{color:var(--blue);font-weight:500}

/* ─── CTA ─── */
.cta-box{background:linear-gradient(135deg,#1a1a2e 0%,#16213e 100%);border-radius:16px;padding:3rem;text-align:center;color:white}
.cta-box h2{font-family:var(--serif);font-size:clamp(1.3rem,3vw,1.8rem);font-weight:400;margin-bottom:.5rem}
.cta-box h2 span{color:var(--blue-bright)}
.cta-box p{font-size:.9rem;color:rgba(255,255,255,.55);max-width:520px;margin:0 auto 1.5rem;line-height:1.6}
.cta-box .btn{display:inline-flex;align-items:center;gap:.5rem;background:var(--blue);color:white;border:none;padding:.85rem 2rem;border-radius:100px;font-size:.9rem;font-weight:600;font-family:var(--sans);cursor:pointer;transition:background .15s;text-decoration:none}
.cta-box .btn:hover{background:var(--blue-deep);color:white}

/* ─── FAQ ─── */
.faq-section{max-width:880px;margin:0 auto;padding:0 2rem 4rem}
.faq-section h2{font-family:var(--serif);font-size:clamp(1.3rem,2.5vw,1.7rem);font-weight:400;letter-spacing:-0.02em;margin-bottom:1.5rem}
.faq-list{display:flex;flex-direction:column;gap:.75rem}
.faq-item{background:white;border:1px solid var(--ink-05);border-radius:10px;padding:0}
.faq-item summary{padding:1.1rem 1.5rem;font-size:.9rem;font-weight:600;cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;color:var(--ink)}
.faq-item summary::after{content:'+';font-size:1.2rem;color:var(--ink-40);transition:transform .2s}
.faq-item[open] summary::after{content:'\2212'}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item p{padding:0 1.5rem 1.1rem;font-size:.85rem;color:var(--ink-60);line-height:1.75}

/* ─── Source bar ─── */
.source-bar{border-top:1px solid var(--ink-10);padding:1.5rem 2rem;display:flex;align-items:center;justify-content:center;gap:0.6rem;font-size:0.8rem;color:var(--ink-40)}
.source-bar .src-mark{display:inline-flex;align-items:center;gap:0.3rem;font-weight:600;color:var(--ink-60)}
.source-bar svg{width:14px;height:14px}

/* ─── Footer ─── */
footer{background:var(--ink);color:rgba(255,255,255,0.4);padding:3rem 2rem}
.footer-inner{max-width:var(--max-w);margin:0 auto;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1rem}
.footer-left{display:flex;align-items:center;gap:0.6rem}
.footer-left .f-icon{width:24px;height:24px;background:var(--blue);border-radius:4px;display:grid;place-items:center;color:white;font-size:0.8rem;line-height:1}
.footer-left .f-icon svg{width:14px;height:14px}
.footer-left span:last-child{font-size:0.8rem}
.footer-links{display:flex;gap:2rem}
.footer-links a{font-size:0.8rem;color:rgba(255,255,255,0.4);text-decoration:none;transition:color 0.15s}
.footer-links a:hover{color:white}
.footer-copy{width:100%;text-align:center;font-size:0.7rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,0.08);color:rgba(255,255,255,0.25)}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   INNER PAGES (state, city, agent)
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

.page-wrap{max-width:var(--max-w);margin:0 auto;padding:0 2rem 4rem}

/* Breadcrumbs */
.breadcrumbs{padding:6rem 0 0}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:0.3rem;font-size:0.8rem}
.breadcrumbs li{display:flex;align-items:center;gap:0.3rem;color:var(--ink-40)}
.breadcrumbs li::after{content:'/';color:var(--ink-20);margin-left:0.3rem}
.breadcrumbs li:last-child::after{display:none}
.breadcrumbs a{color:var(--ink-40)}
.breadcrumbs a:hover{color:var(--blue)}

/* Page header */
.page-header{display:flex;align-items:center;justify-content:space-between;gap:2rem;margin:2rem 0}
.page-header h1{font-family:var(--serif);font-size:clamp(1.8rem,4vw,2.8rem);font-weight:400;letter-spacing:-0.02em;line-height:1.15}
.page-header h1 em{font-style:italic;color:var(--blue)}
.page-sub{color:var(--ink-40);margin-top:0.5rem;font-size:0.95rem;line-height:1.6}
.page-header-img{width:100px;height:100px;opacity:0.15}

/* Info box */
.info-box{background:white;border:1px solid var(--ink-05);border-radius:12px;padding:2rem;margin-bottom:2rem}
.info-box h2{font-family:var(--serif);font-size:1.2rem;font-weight:400;margin-bottom:1rem}
.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1rem}
.info-item{text-align:center;padding:1rem;background:var(--cream);border-radius:8px}
.info-label{display:block;font-size:0.7rem;color:var(--ink-40);text-transform:uppercase;letter-spacing:0.06em;margin-bottom:0.3rem}
.info-value{display:block;font-family:var(--serif);font-size:1.1rem;color:var(--blue)}
.info-notes{color:var(--ink-40);font-size:0.85rem;line-height:1.7}

/* Emergency box */
.emergency-box{background:rgba(29,78,216,0.06);border:1px solid var(--blue);border-radius:12px;padding:1.5rem 2rem;margin-bottom:2rem}
.emergency-box h2{font-size:1.1rem;color:var(--blue);margin-bottom:0.3rem;font-weight:600}
.emergency-box p{color:var(--ink-60);font-size:0.9rem}

/* Section inner */
.section-inner{margin-top:3rem}
.section-inner h2{font-family:var(--serif);font-size:1.3rem;font-weight:400;margin-bottom:1.2rem}

/* Top cities grid */
.top-cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}
.city-card{background:white;border:1px solid var(--ink-05);border-radius:10px;padding:1.2rem;color:var(--ink);transition:all .2s;text-decoration:none}
.city-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(0,0,0,0.06)}
.city-card h3{font-size:1rem;font-weight:600;margin-bottom:.3rem;color:var(--ink)}
.city-count{display:block;font-size:.8rem;color:var(--blue);font-weight:500}
.city-county{display:block;font-size:.75rem;color:var(--ink-40);margin-top:.2rem}

/* Cities list */
.cities-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.3rem}
.city-link{display:flex;justify-content:space-between;align-items:center;padding:.55rem .8rem;border-radius:6px;color:var(--ink);text-decoration:none;transition:background .15s}
.city-link:hover{background:white;color:var(--ink)}
.city-link-name{font-weight:500;font-size:.88rem}
.city-link-count{background:rgba(29,78,216,0.08);color:var(--blue);padding:.15rem .5rem;border-radius:99px;font-size:.72rem;font-weight:600}

/* Counties */
.counties-grid{display:flex;flex-wrap:wrap;gap:.4rem}
.county-tag{display:flex;align-items:center;gap:.5rem;padding:.45rem .9rem;background:white;border:1px solid var(--ink-05);border-radius:6px;font-size:.82rem}
.county-name{font-weight:500}
.county-count{color:var(--ink-40);font-size:.75rem}

/* ─── Agent cards ─── */
.agents-list{display:grid;gap:1rem}
.agent-card{background:white;border:1px solid var(--ink-05);border-radius:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.agent-card:hover{border-color:var(--blue);box-shadow:0 4px 16px rgba(0,0,0,0.06)}
.agent-card-header{padding:1.2rem 1.5rem 0}
.agent-name{font-size:1.05rem;font-weight:600}
.agent-name a{color:var(--ink);text-decoration:none}
.agent-name a:hover{color:var(--blue)}
.agent-business{display:block;font-size:.82rem;color:var(--ink-40);margin-top:.2rem}
.agent-card-body{padding:.8rem 1.5rem}
.agent-detail{display:flex;align-items:flex-start;gap:.6rem;margin-bottom:.4rem;font-size:.88rem;color:var(--ink-60)}
.detail-icon{width:16px;height:16px;flex-shrink:0;margin-top:3px;color:var(--ink-20)}
.agent-phone{color:var(--blue);font-weight:600}
.agent-card-footer{padding:0 1.5rem 1.2rem;display:flex;gap:.5rem}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.3rem;border-radius:8px;font-weight:600;font-size:.85rem;border:1px solid var(--ink-10);background:white;color:var(--ink);cursor:pointer;transition:all .15s;text-decoration:none;font-family:var(--sans)}
.btn:hover{border-color:var(--blue);color:var(--blue)}
.btn-primary{background:var(--blue);border-color:var(--blue);color:white}
.btn-primary:hover{background:var(--blue-deep);border-color:var(--blue-deep);color:white}
.btn-sm{padding:.4rem .9rem;font-size:.78rem}
.btn-lg{padding:.9rem 2rem;font-size:1rem}
.btn-outline{background:transparent;border-color:var(--blue);color:var(--blue)}
.btn-icon{width:18px;height:18px}

/* ─── Agent detail page ─── */
.agent-detail-page{display:grid;grid-template-columns:1fr 300px;gap:2rem;margin:2rem 0}
.agent-main h1{font-family:var(--serif);font-size:1.8rem;font-weight:400}
.agent-biz-name{color:var(--ink-40);margin-top:.2rem}
.agent-badge-row{display:flex;flex-wrap:wrap;gap:.5rem;margin:1rem 0}
.badge{padding:.3rem .8rem;border-radius:6px;font-size:.75rem;font-weight:600;text-transform:capitalize}
.badge-active{background:var(--green-soft);color:var(--green)}
.badge-expired{background:var(--red-soft);color:var(--red)}
.badge-type{background:rgba(29,78,216,0.08);color:var(--blue)}

.agent-details-grid{margin:1.5rem 0}
.detail-row{display:flex;padding:.7rem 0;border-bottom:1px solid var(--ink-05)}
.detail-label{width:160px;flex-shrink:0;font-size:.82rem;color:var(--ink-40);font-weight:500}
.detail-value{font-size:.92rem}
.agent-phone-link{color:var(--blue);font-weight:600;font-size:1.05rem}

.agent-cta{margin:2rem 0;text-align:center;padding:2rem;background:rgba(29,78,216,0.06);border-radius:12px}
.cta-sub{color:var(--ink-40);font-size:.82rem;margin-top:.7rem}

/* Sidebar */
.agent-sidebar{position:sticky;top:5rem;align-self:start}
.agent-sidebar h2{font-size:1.05rem;margin-bottom:1rem;font-weight:600}
.nearby-list{display:grid;gap:.5rem;margin-bottom:1rem}
.nearby-card{display:block;padding:.8rem 1rem;background:white;border:1px solid var(--ink-05);border-radius:8px;color:var(--ink);transition:all .2s;text-decoration:none}
.nearby-card:hover{border-color:var(--blue);box-shadow:0 2px 8px rgba(0,0,0,0.04);color:var(--ink)}
.nearby-name{display:block;font-weight:600;font-size:.88rem}
.nearby-phone{display:block;font-size:.78rem;color:var(--blue);margin-top:.2rem}

/* ─── Pagination ─── */
.pagination{display:flex;justify-content:center;gap:.3rem;margin:2rem 0;flex-wrap:wrap}
.page-link{padding:.5rem .9rem;border-radius:6px;background:white;border:1px solid var(--ink-10);color:var(--ink-40);font-size:.88rem;font-weight:500;text-decoration:none}
.page-link:hover{border-color:var(--blue);color:var(--blue)}
.page-link.active{background:var(--blue);border-color:var(--blue);color:white}
.page-ellipsis{padding:.5rem .3rem;color:var(--ink-20)}

/* ─── Empty / Error ─── */
.empty-state{text-align:center;padding:4rem 2rem;color:var(--ink-40)}
.error-page{text-align:center;padding:10rem 2rem 6rem}
.error-page h1{font-family:var(--serif);font-size:6rem;color:var(--blue)}
.error-page p{color:var(--ink-40);margin:1rem 0 2rem}

/* Legal pages */
.legal-page{max-width:720px;margin:2rem 0 4rem}
.legal-page h1{font-family:var(--serif);font-size:2rem;font-weight:400;margin-bottom:1.5rem}
.legal-content h3{font-size:1rem;font-weight:600;margin:1.5rem 0 .5rem}
.legal-content p{font-size:.9rem;color:var(--ink-60);line-height:1.8;margin-bottom:.8rem}

/* ─── Responsive ─── */
@media(max-width:768px){
    .hero{min-height:auto;padding:8rem 1.5rem 3rem}
    .hero::before,.hero::after{display:none}
    .stats-inner{grid-template-columns:1fr}
    .stat-block{padding:2rem 1.5rem}
    .stat-block:not(:last-child)::after{display:none}
    .stat-block:not(:last-child){border-bottom:1px solid rgba(255,255,255,0.08)}
    .how-steps{grid-template-columns:1fr}
    .how-header{flex-direction:column;align-items:flex-start}
    .states-grid-featured{grid-template-columns:1fr 1fr}
    .state-tile:nth-child(1),.state-tile:nth-child(2){grid-column:span 1;min-height:200px}
    .footer-inner{flex-direction:column;text-align:center}
    .footer-links{justify-content:center;flex-wrap:wrap;gap:1rem}
    .topnav-cta{display:none}
    .nav-link{display:none}
    .agent-detail-page{grid-template-columns:1fr}
    .agent-sidebar{position:static}
    .page-header{flex-direction:column;align-items:flex-start}
    .page-header-img{display:none}
    .info-grid{grid-template-columns:1fr 1fr}
    .detail-row{flex-direction:column;gap:.2rem}
    .detail-label{width:auto}
    .breadcrumbs{padding:5rem 0 0}
}
@media(max-width:480px){
    .states-grid-featured{grid-template-columns:1fr}
    .state-tile:nth-child(1),.state-tile:nth-child(2){min-height:180px}
    .search-btn{padding:.75rem 1.25rem;font-size:.8rem}
    .info-grid{grid-template-columns:1fr}
}
