/* ===================================================================
   VANGUARD LOCKSMITHS — standalone marketing site
   Self-contained. No build step, no framework. Just open index.html.
   =================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=Hanken+Grotesk:wght@400;500;600;700;800&display=swap');

:root {
  /* Sacramento green */
  --green-950:#04231A; --green-900:#073226; --green-800:#0A4231; --green-700:#0F5640;
  --green-600:#166B50; --green-500:#20865F; --green-300:#88C6A6; --green-200:#BFE2D1;
  --green-100:#E2F1E9; --green-50:#F1F8F4;
  /* Brass */
  --brass-800:#8A6526; --brass-700:#A87E30; --brass-600:#BE933E; --brass-500:#CCA456;
  --brass-400:#D9B776; --brass-300:#E6CD9C; --brass-200:#F0E0C2; --brass-100:#F8EFDD;
  /* Neutrals */
  --paper:#F7F4ED; --paper-raised:#FFFFFF; --sand-100:#EFEADF; --sand-200:#E2DACB;
  --sand-300:#CFC4B0; --stone-400:#A99E8A; --stone-500:#7C7464;
  --ink-700:#3A3D38; --ink-900:#1A1D1A; --ink-950:#101210;
  /* status */
  --success:#20865F; --success-bg:#E2F1E9;
  /* aliases */
  --brand:var(--green-800); --accent:var(--brass-600); --accent-soft:var(--brass-100);
  --text-strong:var(--ink-900); --text-body:var(--ink-700); --text-muted:var(--stone-500);
  --text-accent:var(--brass-700); --border-subtle:var(--sand-200); --border-default:var(--sand-300);
  --font-display:"Bricolage Grotesque","Hanken Grotesk",system-ui,sans-serif;
  --font-body:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --radius-sm:6px; --radius-md:10px; --radius-lg:16px; --radius-xl:24px; --radius-pill:999px;
  --shadow-sm:0 2px 6px rgba(26,29,26,.07);
  --shadow-md:0 8px 24px -8px rgba(10,66,49,.16);
  --shadow-lg:0 20px 48px -16px rgba(10,66,49,.22);
  --shadow-brass:0 10px 30px -10px rgba(190,147,62,.45);
  --container:1200px;
}

*,*::before,*::after { box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  margin:0; font-family:var(--font-body); font-size:16px; line-height:1.5;
  color:var(--text-body); background:var(--paper); -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4 { font-family:var(--font-display); color:var(--text-strong); font-weight:700; line-height:1.1; letter-spacing:-.02em; margin:0; }
p { margin:0; }
img { max-width:100%; display:block; }
a { color:var(--green-700); text-decoration:none; }

.container { max-width:var(--container); margin:0 auto; padding:0 24px; }
.section { padding:96px 0; }
.section--sm { padding:64px 0; }
.bg-card { background:var(--paper-raised); }
.bg-dark { background:var(--green-900); color:var(--paper); }
.bg-darkest { background:var(--green-950); color:var(--paper); }

.eyebrow { font-size:13px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--text-accent); }
.bg-dark .eyebrow, .bg-darkest .eyebrow { color:var(--brass-300); }
.lead { font-size:20px; line-height:1.55; color:var(--text-body); }
.bg-dark .lead, .bg-darkest .lead { color:var(--green-200); }
.muted { color:var(--text-muted); }

/* ---- Buttons ---- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-body); font-weight:600; font-size:15px; line-height:1; letter-spacing:.01em;
  padding:13px 24px; border-radius:var(--radius-pill); border:1px solid transparent; cursor:pointer;
  transition:transform .14s ease, filter .14s ease, background .14s ease; white-space:nowrap; }
.btn:hover { filter:brightness(1.08); text-decoration:none; }
.btn:active { transform:translateY(1px) scale(.99); }
.btn svg { width:18px; height:18px; }
.btn-lg { padding:16px 30px; font-size:17px; }
.btn-sm { padding:9px 18px; font-size:14px; }
.btn-accent { background:var(--accent); color:var(--green-950); border-color:var(--accent); box-shadow:var(--shadow-brass); }
.btn-primary { background:var(--brand); color:var(--paper); border-color:var(--brand); }
.btn-secondary { background:transparent; color:var(--brand); border:1.5px solid var(--brand); }
.btn-inverse { background:var(--paper); color:var(--green-900); border-color:var(--paper); }
.btn-ghost { background:transparent; color:var(--brand); }

/* ---- Badges ---- */
.badge { display:inline-flex; align-items:center; gap:6px; padding:5px 12px; border-radius:var(--radius-pill);
  font-size:12.5px; font-weight:700; letter-spacing:.04em; white-space:nowrap; }
.badge .dot { width:7px; height:7px; border-radius:50%; }
.badge-brand { background:var(--green-100); color:var(--green-800); }
.badge-brand .dot { background:var(--green-600); }
.badge-accent { background:var(--accent-soft); color:var(--brass-800); }
.badge-accent .dot { background:var(--brass-600); }
.badge-solid { background:var(--green-800); color:var(--paper); }
.badge-neutral { background:var(--sand-100); color:var(--ink-700); }
.badge-success { background:var(--success-bg); color:var(--success); }
.badge-success .dot { background:var(--success); }

/* ---- Header ---- */
.site-header { position:sticky; top:0; z-index:50; background:rgba(247,244,237,.85);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px); border-bottom:1px solid var(--border-subtle); }
.header-inner { display:flex; align-items:center; gap:32px; padding:14px 24px; max-width:var(--container); margin:0 auto; }
.logo { display:inline-flex; align-items:center; gap:12px; }
.logo svg { width:42px; height:42px; display:block; flex:none; }
.logo .name { font-family:var(--font-display); font-weight:800; font-size:23px; letter-spacing:-.02em; color:var(--text-strong); line-height:1; }
.logo .sub { font-family:var(--font-body); font-weight:700; font-size:9px; letter-spacing:.32em; text-transform:uppercase; color:var(--text-accent); line-height:1; margin-top:4px; }
.logo .stack { display:flex; flex-direction:column; }
.nav { display:flex; gap:28px; margin-left:8px; }
.nav a { font-size:15px; font-weight:600; color:var(--text-body); padding-bottom:4px; border-bottom:2px solid transparent; }
.nav a:hover { color:var(--brand); text-decoration:none; }
.nav a.active { color:var(--brand); border-bottom-color:var(--accent); }
.header-cta { margin-left:auto; display:flex; align-items:center; gap:16px; }
.header-phone { display:inline-flex; align-items:center; gap:8px; font-weight:700; font-size:15px; color:var(--text-strong); white-space:nowrap; }
.header-phone svg { width:17px; height:17px; }
.nav-toggle { display:none; background:none; border:none; cursor:pointer; color:var(--text-strong); padding:6px; }
.nav-toggle svg { width:26px; height:26px; }

/* ---- Hero ---- */
.hero { padding:72px 0 84px; }
.hero-grid { display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center; }
.hero h1 { font-size:60px; font-weight:800; line-height:1.02; letter-spacing:-.03em; }
.hero-badges { display:flex; gap:10px; margin-bottom:22px; flex-wrap:wrap; }
.hero-photo { position:relative; }
.hero-photo .frame { border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--border-subtle); }
.hero-photo img { width:100%; height:560px; object-fit:cover; }
.floating-card { position:absolute; left:-22px; bottom:36px; background:var(--paper-raised); border-radius:var(--radius-lg);
  box-shadow:var(--shadow-lg); padding:16px 20px; display:flex; align-items:center; gap:14px; border:1px solid var(--border-subtle); }
.trust-row { display:flex; gap:28px; margin-top:40px; flex-wrap:wrap; }
.trust-item { display:flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--text-body); }
.trust-item svg { width:19px; height:19px; color:var(--green-700); }

/* ---- Section heads ---- */
.section-head { max-width:640px; }
.section-head.center { margin:0 auto; text-align:center; }
.section-head h2 { font-size:38px; margin-top:14px; line-height:1.08; }
.section-head .lead { margin-top:16px; }

/* ---- Icon badge ---- */
.icon-badge { display:inline-flex; align-items:center; justify-content:center; width:52px; height:52px;
  border-radius:var(--radius-md); background:var(--green-100); color:var(--brand); flex:none; }
.icon-badge svg { width:26px; height:26px; }
.bg-dark .icon-badge { background:rgba(217,183,118,.15); color:var(--brass-300); }

/* ---- Grids ---- */
.grid-3 { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.grid-2 { display:grid; grid-template-columns:repeat(2,1fr); gap:20px; }
.split { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }

/* ---- Service card ---- */
.service-card { display:flex; flex-direction:column; gap:14px; padding:28px; background:var(--paper-raised);
  border:1px solid var(--border-subtle); border-radius:var(--radius-lg); box-shadow:var(--shadow-sm);
  transition:transform .22s ease, box-shadow .22s ease; height:100%; }
.service-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-lg); text-decoration:none; }
.service-card h3 { font-size:21px; }
.service-card p { font-size:14.5px; line-height:1.6; color:var(--text-body); flex:1; }
.service-card .more { font-size:13.5px; font-weight:700; color:var(--text-accent); display:inline-flex; align-items:center; gap:7px; }
.service-card.featured { background:var(--green-900); border-color:var(--green-800); }
.service-card.featured h3 { color:var(--paper); }
.service-card.featured p { color:var(--green-200); }
.service-card.featured .more { color:var(--brass-300); }

/* ---- Stat ---- */
.stat .num { font-family:var(--font-display); font-weight:800; font-size:44px; line-height:1; letter-spacing:-.03em; color:var(--green-800); }
.stat .lbl { font-size:13.5px; font-weight:600; margin-top:8px; color:var(--text-muted); }
.bg-dark .stat .num, .bg-darkest .stat .num { color:var(--brass-300); }
.bg-dark .stat .lbl, .bg-darkest .stat .lbl { color:var(--green-200); }
.stat-row { display:flex; gap:44px; flex-wrap:wrap; }

/* ---- Testimonial ---- */
.testimonial { display:flex; flex-direction:column; gap:16px; background:var(--paper-raised);
  border:1px solid var(--border-subtle); border-radius:var(--radius-lg); padding:26px 28px; box-shadow:var(--shadow-sm); height:100%; }
.testimonial .stars { color:var(--brass-600); font-size:16px; letter-spacing:2px; }
.testimonial blockquote { margin:0; font-family:var(--font-display); font-weight:500; font-size:19px; line-height:1.45; letter-spacing:-.01em; color:var(--text-strong); }
.testimonial .who { font-size:13.5px; }
.testimonial .who b { color:var(--text-strong); }
.testimonial .who span { color:var(--text-muted); }

/* ---- CTA band ---- */
.cta-band { background:var(--green-800); border-radius:var(--radius-xl); padding:56px; display:flex;
  align-items:center; justify-content:space-between; gap:32px; box-shadow:var(--shadow-lg); flex-wrap:wrap; }
.cta-band h2 { color:var(--paper); font-size:34px; }
.cta-band p { color:var(--green-200); font-size:18px; margin-top:12px; max-width:520px; }
.cta-actions { display:flex; gap:14px; flex:none; }

/* ---- Feature tiles (industries / list) ---- */
.tile { display:flex; align-items:center; gap:12px; background:var(--paper-raised); border:1px solid var(--border-subtle);
  border-radius:var(--radius-md); padding:16px 18px; }
.tile svg { width:20px; height:20px; color:var(--green-700); flex:none; }
.tile span { font-size:15px; font-weight:600; color:var(--text-strong); }

/* ---- Process steps ---- */
.step h4 { font-size:18px; margin:0 0 8px; }
.step p { font-size:14.5px; line-height:1.6; }
.step .icon-badge { width:48px; height:48px; margin-bottom:16px; }

/* ---- Detailed service list rows ---- */
.svc-row { display:grid; grid-template-columns:56px 1fr; gap:20px; padding:28px 0; border-bottom:1px solid var(--border-subtle); align-items:start; }
.svc-row:last-child { border-bottom:none; }
.svc-row h3 { font-size:21px; margin:0 0 6px; }
.svc-row p { font-size:15px; line-height:1.6; color:var(--text-body); }

/* ---- Forms ---- */
.form-card { background:var(--paper-raised); border:1px solid var(--border-subtle); border-radius:var(--radius-xl);
  box-shadow:var(--shadow-md); padding:40px; }
.field { display:flex; flex-direction:column; gap:6px; }
.field label { font-size:13.5px; font-weight:600; color:var(--text-strong); }
.field label .req { color:var(--brass-700); }
.field input, .field textarea { font-family:var(--font-body); font-size:15px; color:var(--text-strong);
  background:var(--paper-raised); padding:11px 14px; border:1.5px solid var(--border-default); border-radius:var(--radius-sm);
  outline:none; transition:border-color .14s ease, box-shadow .14s ease; width:100%; }
.field input:focus, .field textarea:focus { border-color:var(--brand); box-shadow:0 0 0 3px var(--green-100); }
.field textarea { resize:vertical; line-height:1.5; }
.field .help { font-size:12.5px; color:var(--text-muted); }
.choice-row { display:flex; gap:10px; }
.choice { flex:1; padding:14px; border-radius:var(--radius-md); cursor:pointer; font-size:15px; font-weight:600; text-align:center;
  border:1.5px solid var(--border-default); background:var(--paper-raised); color:var(--text-body); transition:all .14s ease; }
.choice:hover { border-color:var(--brand); }
.choice.on { border-color:var(--brand); background:var(--green-100); color:var(--green-800); }
.chips { display:flex; flex-wrap:wrap; gap:9px; }
.chip { padding:9px 15px; border-radius:var(--radius-pill); cursor:pointer; font-size:13.5px; font-weight:600;
  border:1.5px solid var(--border-default); background:var(--paper-raised); color:var(--text-body); transition:all .14s ease; }
.chip:hover { border-color:var(--accent); }
.chip.on { border-color:var(--accent); background:var(--accent-soft); color:var(--brass-800); }
.form-foot { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.form-foot .privacy { display:inline-flex; align-items:center; gap:8px; font-size:13.5px; color:var(--text-muted); }
.form-foot .privacy svg { width:15px; height:15px; }
.form-success { text-align:center; padding:24px 0; }
.form-success .check { display:inline-flex; width:64px; height:64px; align-items:center; justify-content:center;
  border-radius:50%; background:var(--success-bg); color:var(--success); margin-bottom:20px; }
.form-success .check svg { width:32px; height:32px; }
.hidden { display:none !important; }

/* ---- Footer ---- */
.site-footer { background:var(--green-950); color:var(--green-200); padding:64px 0 40px; }
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; }
.footer-grid h4 { font-family:var(--font-body); font-size:12px; font-weight:700; letter-spacing:.16em; text-transform:uppercase; color:var(--brass-300); margin:0 0 16px; }
.footer-grid ul { list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.footer-grid a { font-size:14px; color:var(--green-200); }
.footer-grid a:hover { color:var(--paper); text-decoration:none; }
.footer-about p { margin-top:20px; font-size:14.5px; line-height:1.65; max-width:280px; color:var(--green-200); }
.footer-about .reg { margin-top:18px; font-size:13px; color:var(--green-300); }
.footer-about .logo .name { color:var(--paper); }
.footer-about .logo .sub { color:var(--brass-300); }
.footer-bottom { margin-top:48px; padding-top:24px; border-top:1px solid rgba(255,255,255,.1);
  display:flex; justify-content:space-between; font-size:13px; color:var(--green-300); flex-wrap:wrap; gap:12px; }
.footer-bottom a { color:var(--green-300); }

/* ---- Page hero (sub pages) ---- */
.page-hero { padding:64px 0; }
.page-hero h1 { font-size:48px; }
.page-hero .lead { margin-top:16px; max-width:640px; }

/* ---- Responsive ---- */
@media (max-width:980px) {
  .hero-grid, .split { grid-template-columns:1fr; gap:36px; }
  .hero h1 { font-size:46px; }
  .grid-3 { grid-template-columns:1fr 1fr; }
  .hero-photo img { height:420px; }
  .footer-grid { grid-template-columns:1fr 1fr; gap:32px; }
  .section { padding:64px 0; }
}
@media (max-width:720px) {
  .nav, .header-phone { display:none; }
  .nav-toggle { display:inline-flex; }
  .nav.open { display:flex; position:absolute; top:100%; left:0; right:0; flex-direction:column; gap:0;
    background:var(--paper); border-bottom:1px solid var(--border-subtle); padding:8px 24px 16px; margin:0; }
  .nav.open a { padding:12px 0; border-bottom:1px solid var(--border-subtle); }
  .header-inner { position:relative; }
  .hero h1 { font-size:38px; }
  .grid-3, .grid-2 { grid-template-columns:1fr; }
  .section-head h2 { font-size:30px; }
  .cta-band { padding:36px; }
  .cta-band h2 { font-size:28px; }
  .form-card { padding:24px; }
  .footer-grid { grid-template-columns:1fr; }
  .floating-card { left:0; }
}
