/* Home Buyers of Naples — production stylesheet (self-contained, no build step).
   Brand tokens + component styles compiled from the design system. */

/* ─── Tokens ─────────────────────────────────────────────── */
:root {
  --blue-50:#eff6ff; --blue-100:#dbeafe; --blue-300:#93c5fd; --blue-400:#60a5fa;
  --blue-500:#3b82f6; --blue-600:#2563eb; --blue-700:#1d4ed8; --blue-900:#1e3a8a;
  --gray-0:#fff; --gray-50:#f9fafb; --gray-100:#f3f4f6; --gray-200:#e5e7eb;
  --gray-300:#d1d5db; --gray-400:#9ca3af; --gray-500:#6b7280; --gray-600:#4b5563;
  --gray-700:#374151; --gray-800:#1f2937; --gray-900:#111827;
  --sand-100:#f7f1e6; --sand-500:#c9a44c; --sand-700:#97781f;
  --green-50:#ecfdf5; --green-700:#047857; --red-500:#ef4444; --red-700:#b91c1c;

  --primary:var(--blue-600); --primary-hover:var(--blue-700);
  --text-strong:var(--gray-900); --text-body:var(--gray-600); --text-muted:var(--gray-500);

  --font-display:'Playfair Display',Georgia,serif;
  --font-sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;

  --radius-md:.5rem; --radius-lg:.75rem; --radius-xl:1rem; --radius-full:9999px;
  --shadow-sm:0 1px 3px rgba(17,24,39,.08),0 1px 2px rgba(17,24,39,.04);
  --shadow-lg:0 12px 28px rgba(17,24,39,.12);
  --container:72rem; --container-sm:56rem; --gutter:1.5rem;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ─── Base ───────────────────────────────────────────────── */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--font-sans);color:var(--text-strong);background:var(--gray-0);
  font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin:0}
p{margin:0}
a{color:inherit}
img{max-width:100%;display:block}

.container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter);width:100%}
.container--sm{max-width:var(--container-sm)}
.section{padding:80px 0}
.section--subtle{background:var(--gray-50)}
.eyebrow{font-size:.875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}
.eyebrow--invert{color:var(--blue-300)}
.lead{font-size:1.125rem;line-height:1.65;color:var(--text-body)}
.section-head{max-width:46rem;margin:0 auto 48px;text-align:center;display:flex;flex-direction:column;gap:12px;align-items:center}
.section-head h2{font-size:1.875rem;color:var(--text-strong)}
.section-head.left{text-align:left;align-items:flex-start;margin-left:0;max-width:none}

/* ─── Buttons ────────────────────────────────────────────── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--font-sans);font-weight:600;line-height:1;border-radius:var(--radius-md);
  padding:.75rem 1.25rem;font-size:1rem;border:1px solid transparent;cursor:pointer;
  text-decoration:none;white-space:nowrap;transition:background .2s var(--ease),border-color .2s var(--ease)}
.btn--primary{background:var(--primary);color:#fff;border-color:var(--primary)}
.btn--primary:hover{background:var(--primary-hover);border-color:var(--primary-hover)}
.btn--dark{background:var(--gray-900);color:#fff;border-color:var(--gray-900)}
.btn--ondark{background:#fff;color:var(--gray-900);border-color:#fff}
.btn--ondark:hover{background:var(--gray-100)}
.btn--outline{background:transparent;color:var(--text-strong);border-color:var(--gray-300)}
.btn--outline:hover{background:var(--gray-50)}
.btn--lg{padding:1rem 2.5rem;font-size:1.125rem}
.btn--sm{padding:.5rem .875rem;font-size:.875rem}
.btn--block{width:100%}

/* ─── Badges ─────────────────────────────────────────────── */
.badge{display:inline-flex;align-items:center;gap:.375rem;font-size:.75rem;font-weight:600;
  letter-spacing:.04em;text-transform:uppercase;padding:.25rem .625rem;border-radius:var(--radius-full)}
.badge--primary{background:var(--blue-50);color:var(--blue-700)}
.badge--success{background:var(--green-50);color:var(--green-700)}
.badge--sand{background:var(--sand-100);color:var(--sand-700)}
.badge--dark{background:rgba(255,255,255,.12);color:#fff}

/* ─── Cards ──────────────────────────────────────────────── */
.card{background:#fff;border:1px solid var(--gray-200);border-radius:var(--radius-lg);
  padding:2rem;box-shadow:var(--shadow-sm);transition:box-shadow .2s var(--ease),transform .2s var(--ease)}
.card--md{padding:1.5rem}
.card--hover:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}
.card h3{font-size:1.25rem;color:var(--text-strong);margin-bottom:.5rem}
.card p{color:var(--text-body);line-height:1.6}

/* ─── Header ─────────────────────────────────────────────── */
.site-header{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--gray-200)}
.site-header .container{display:flex;align-items:center;justify-content:space-between;height:72px}
.wordmark{display:flex;align-items:center;gap:10px;flex-shrink:0;text-decoration:none}
.wordmark__icon{flex-shrink:0;width:40px;height:auto}
.wordmark__tx{line-height:1}
.wordmark b{display:block;font-family:var(--font-display);font-weight:700;font-size:22px;
  letter-spacing:-.01em;white-space:nowrap;color:var(--text-strong)}
.wordmark small{display:block;font-size:10px;font-weight:600;letter-spacing:.34em;text-transform:uppercase;
  white-space:nowrap;color:var(--primary);padding-left:.34em;margin-top:3px}
.wordmark--invert b{color:#fff}.wordmark--invert small{color:var(--blue-300)}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-size:.875rem;font-weight:500;color:var(--text-body);text-decoration:none}
.nav a:hover{color:var(--text-strong)}
.nav .phone{font-weight:600;color:var(--text-strong)}

/* ─── Hero ───────────────────────────────────────────────── */
.hero{background:var(--gray-900);color:#fff;position:relative;overflow:hidden}
.hero__glow{position:absolute;inset:0;background:radial-gradient(120% 80% at 80% -10%,rgba(37,99,235,.28),transparent 60%)}
.hero .container{position:relative;text-align:center;padding:96px var(--gutter)}
.hero h1{font-size:clamp(2.5rem,5vw,3.75rem);line-height:1.08;max-width:18ch;margin:24px auto 0}
.hero p{font-size:1.25rem;line-height:1.6;color:rgba(255,255,255,.82);max-width:46ch;margin:24px auto 36px}
.hero__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.stats{display:flex;gap:48px;justify-content:center;flex-wrap:wrap;margin-top:56px}
.stat{display:flex;flex-direction:column;gap:4px;text-align:center}
.stat b{font-family:var(--font-display);font-weight:700;font-size:2.25rem;line-height:1;color:var(--primary)}
.stat span{font-size:.875rem;font-weight:500;color:var(--text-muted)}
.stat--invert b{color:#fff}.stat--invert span{color:rgba(255,255,255,.75)}

/* ─── Trust bar ──────────────────────────────────────────── */
.trustbar{background:var(--gray-100);border-bottom:1px solid var(--gray-200)}
.trustbar .container{display:flex;flex-wrap:wrap;justify-content:space-between;gap:16px;padding:18px var(--gutter)}
.trustbar div{display:flex;align-items:center;gap:8px;font-size:.875rem;font-weight:600;color:var(--gray-700)}
.trustbar .check{color:var(--green-700)}

/* ─── Grids ──────────────────────────────────────────────── */
.grid{display:grid;gap:24px}
.grid--3{grid-template-columns:repeat(auto-fit,minmax(260px,1fr))}
.grid--2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.why{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:40px;align-items:center}
.why__cards{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chips{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}

.step__top{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.step__num{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:var(--radius-full);background:var(--blue-50);color:var(--primary);
  font-family:var(--font-display);font-weight:700;font-size:1.25rem;flex-shrink:0}
.step__label{font-size:.875rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--primary)}

.avatar{width:52px;height:52px;border-radius:var(--radius-full);background:var(--gray-900);color:#fff;
  display:inline-flex;align-items:center;justify-content:center;font-family:var(--font-display);
  font-weight:700;font-size:18px;flex-shrink:0}
.team__top{display:flex;align-items:center;gap:14px;margin-bottom:14px}

/* ─── FAQ ────────────────────────────────────────────────── */
.faq__item{border-bottom:1px solid var(--gray-200)}
.faq__q{display:flex;align-items:center;justify-content:space-between;gap:1rem;width:100%;
  background:transparent;border:none;cursor:pointer;padding:1.25rem 0;text-align:left;
  font-family:var(--font-sans);font-size:1.125rem;font-weight:600;color:var(--text-strong)}
.faq__icon{flex-shrink:0;width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;
  border-radius:var(--radius-full);background:var(--gray-100);color:var(--gray-600);font-size:1rem;
  transition:background .2s var(--ease),color .2s var(--ease)}
.faq__item[open] .faq__icon{background:var(--primary);color:#fff}
.faq__a{padding:0 0 1.25rem;color:var(--text-body);line-height:1.65;max-width:62ch}
.faq__q::-webkit-details-marker{display:none}
details.faq__item > summary{list-style:none}

/* ─── Areas ──────────────────────────────────────────────── */
.areas{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}
.area{text-decoration:none;text-align:center}
.area b{font-family:var(--font-display);font-weight:700;font-size:1.125rem;color:var(--text-strong)}
.area span{display:block;font-size:.75rem;color:var(--primary);font-weight:600;margin-top:4px}

/* ─── Final CTA + footer ─────────────────────────────────── */
.final-cta{background:var(--gray-900);color:#fff;text-align:center}
.final-cta h2{font-size:2.25rem;margin-bottom:16px}
.final-cta p{font-size:1.125rem;color:rgba(255,255,255,.82);max-width:42ch;margin:0 auto 32px}
.footer{background:var(--gray-800);color:var(--gray-400);padding:40px 0}
.footer .container{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px}
.footer a{color:var(--gray-400);text-decoration:none}.footer a:hover{color:#fff}
.footer__links{display:flex;gap:24px;font-size:.875rem}
.footer__copy{font-size:.75rem;color:var(--gray-500)}

/* ─── Prose (legal pages) ────────────────────────────────── */
.prose{max-width:var(--container-sm);margin:0 auto;padding:48px var(--gutter)}
.prose h1{font-size:2.25rem;margin-bottom:24px}
.prose h2{font-size:1.5rem;margin:32px 0 12px}
.prose p{color:var(--text-body);line-height:1.7;margin-bottom:16px}

/* ─── Forms / modal ──────────────────────────────────────── */
.field{display:flex;flex-direction:column;gap:.375rem;width:100%}
.field label{font-size:.875rem;font-weight:600;color:var(--text-strong)}
.field input,.field select,.field textarea{font-family:var(--font-sans);font-size:1rem;color:var(--text-strong);
  background:#fff;padding:.75rem .875rem;border-radius:var(--radius-md);border:1px solid var(--gray-300);outline:none;width:100%}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(37,99,235,.35)}
.checkbox{display:flex;align-items:flex-start;gap:.625rem;font-size:.875rem;color:var(--text-body);line-height:1.5;cursor:pointer}
.checkbox input{width:18px;height:18px;margin-top:1px;accent-color:var(--primary);flex-shrink:0}

.modal-scrim{position:fixed;inset:0;z-index:50;background:rgba(17,24,39,.6);backdrop-filter:blur(3px);
  display:none;align-items:center;justify-content:center;padding:20px}
.modal-scrim.open{display:flex}
.modal{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:460px;overflow:hidden}
.modal__head{background:var(--gray-900);color:#fff;padding:20px 24px}
.modal__head-row{display:flex;justify-content:space-between;align-items:center}
.modal__head b{font-family:var(--font-display);font-weight:700;font-size:1.25rem}
.modal__close{background:transparent;border:none;color:rgba(255,255,255,.7);font-size:22px;cursor:pointer;line-height:1}
.progress{display:flex;gap:6px;margin-top:16px}
.progress i{flex:1;height:4px;border-radius:2px;background:rgba(255,255,255,.2)}
.progress i.on{background:var(--blue-400)}
.modal__body{padding:24px;display:flex;flex-direction:column;gap:16px}
.modal__success{text-align:center;padding:12px 0 4px}
.modal__success .tick{width:64px;height:64px;border-radius:var(--radius-full);background:var(--green-50);
  color:var(--green-700);display:inline-flex;align-items:center;justify-content:center;font-size:32px;margin:0 auto 16px}

/* ─── Responsive ─────────────────────────────────────────── */
@media (max-width:768px){
  .section{padding:56px 0}
  .nav a:not(.phone){display:none}
  .nav{gap:14px}
  .why__cards{grid-template-columns:1fr}
  .stats{gap:28px}
  .footer .container{justify-content:center;text-align:center}
}
