/* SPS Locksmith — sps-locksmith.com */
:root{
  --navy:#152A3E;
  --navy-deep:#0E1E2E;
  --steel:#33526E;
  --brass:#0F9159;          /* brand green from logo, softened */
  --brass-bright:#14A76B;   /* hover green */
  --purple:#8D78DF;         /* brand purple from logo */
  --green-soft:#2FBF7F;     /* light green for dark backgrounds */
  --bg:#F6F7F8;
  --white:#FFFFFF;
  --ink:#1C2833;
  --muted:#5A6B7A;
  --line:#DFE5EA;
  --radius:10px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Inter',system-ui,-apple-system,sans-serif;color:var(--ink);background:var(--bg);line-height:1.65;font-size:16px}
img,svg{display:block;max-width:100%}
a{color:var(--steel)}
h1,h2,h3,.display{font-family:'Barlow Condensed','Inter',sans-serif;line-height:1.1;color:var(--navy);letter-spacing:.2px}
h1{font-size:clamp(2.2rem,5.5vw,3.6rem);font-weight:700}
h2{font-size:clamp(1.7rem,3.6vw,2.4rem);font-weight:700}
h3{font-size:1.35rem;font-weight:600}
.wrap{max-width:1080px;margin:0 auto;padding:0 20px}
.eyebrow{font-family:'Barlow Condensed',sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.14em;font-size:.9rem;color:var(--brass)}
p+p{margin-top:1em}

/* header */
.site-header{background:var(--navy);position:sticky;top:0;z-index:50;border-bottom:3px solid;border-image:linear-gradient(90deg,var(--purple),var(--brass-bright)) 1}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 20px;max-width:1080px;margin:0 auto}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none}
.logo img{width:60px;height:60px;border-radius:14px;flex:none}
.logo .logo-text{font-family:'Barlow Condensed',sans-serif;font-weight:700;font-size:1.7rem;color:#fff;letter-spacing:.05em}
.nav{display:flex;gap:22px;align-items:center;flex-wrap:wrap}
.nav a{color:#D8E2EC;text-decoration:none;font-size:.95rem;font-weight:500}
.nav a:hover{color:var(--brass-bright)}
.call-btn{background:var(--brass);color:#fff!important;padding:9px 16px;border-radius:8px;font-weight:700!important;white-space:nowrap}
.call-btn:hover{background:var(--brass-bright);color:#fff!important}
.menu-toggle{display:none;background:none;border:1px solid #3D5A76;color:#fff;border-radius:8px;padding:8px 12px;font-size:1rem;cursor:pointer}
@media(max-width:820px){
  .menu-toggle{display:block}
  .nav{display:none;width:100%;flex-direction:column;align-items:flex-start;gap:14px;padding:14px 0 6px}
  .nav.open{display:flex}
  .header-inner{flex-wrap:wrap}
}

/* hero */
.hero{background:linear-gradient(160deg,var(--navy) 0%,var(--navy-deep) 100%);color:#EAF0F5;padding:64px 0 0;position:relative}
.hero .wrap{padding-bottom:56px}
.hero h1{color:#fff;max-width:760px}
.hero .lede{font-size:1.15rem;max-width:640px;margin-top:16px;color:#C4D2DE}
.hero-cta{display:flex;gap:14px;margin-top:28px;flex-wrap:wrap;align-items:center}
.btn{display:inline-block;text-decoration:none;font-weight:700;border-radius:8px;padding:14px 24px;font-size:1.05rem}
.btn-brass{background:var(--brass);color:#fff}
.btn-brass:hover{background:var(--brass-bright)}
.btn-ghost{border:1.5px solid #4E6B87;color:#EAF0F5}
.btn-ghost:hover{border-color:var(--brass-bright);color:var(--brass-bright)}
.trust-chips{display:flex;gap:10px;flex-wrap:wrap;margin-top:30px}
.chip{border:1px solid #3D5A76;border-radius:999px;padding:6px 14px;font-size:.85rem;color:#C4D2DE}


/* sections */
section{padding:56px 0}
.section-head{max-width:680px;margin-bottom:34px}
.section-head p{color:var(--muted);margin-top:10px}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media(max-width:820px){.grid-3,.grid-2{grid-template-columns:1fr}}
.card{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:26px;display:flex;flex-direction:column;gap:10px}
.card h3 a{color:var(--navy);text-decoration:none}
.card h3 a:hover{color:var(--brass)}
.card p{color:var(--muted);font-size:.95rem}
.card .more{margin-top:auto;font-weight:600;color:var(--brass);text-decoration:none;font-size:.92rem}
.card .more:hover{text-decoration:underline}
.icon{width:34px;height:34px;color:var(--brass)}

.band{background:var(--navy);color:#EAF0F5;text-align:center}
.band h2{color:#fff}
.band p{color:#C4D2DE;max-width:620px;margin:12px auto 0}
.band .btn{margin-top:24px}

.why li{padding:14px 0;border-bottom:1px solid var(--line);display:flex;gap:12px;align-items:flex-start}
.why li:last-child{border-bottom:none}
.why{list-style:none}
.why strong{color:var(--navy)}
.tick{color:var(--brass);flex:none;width:22px;height:22px;margin-top:2px}

.area-links{display:flex;flex-wrap:wrap;gap:10px;margin-top:8px}
.area-links a{background:var(--white);border:1px solid var(--line);border-radius:999px;padding:8px 16px;text-decoration:none;color:var(--navy);font-size:.93rem;font-weight:500}
.area-links a:hover{border-color:var(--brass);color:var(--brass)}

.faq details{background:var(--white);border:1px solid var(--line);border-radius:var(--radius);padding:18px 22px;margin-bottom:12px}
.faq summary{font-weight:600;color:var(--navy);cursor:pointer;font-size:1.02rem}
.faq details p{margin-top:10px;color:var(--muted)}

/* content pages */
.page-hero{background:linear-gradient(160deg,var(--navy),var(--navy-deep));color:#EAF0F5;padding:48px 0 0}
.page-hero .wrap{padding-bottom:40px}
.page-hero h1{color:#fff}
.page-hero .lede{color:#C4D2DE;margin-top:12px;max-width:680px;font-size:1.08rem}
.breadcrumbs{font-size:.85rem;margin-bottom:16px}
.breadcrumbs a{color:#9FB4C6;text-decoration:none}
.breadcrumbs a:hover{color:var(--brass-bright)}
.breadcrumbs span{color:#6E88A0}
.content{max-width:760px}
.content h2{margin:36px 0 14px}
.content ul{margin:14px 0 14px 22px}
.content li{margin-bottom:8px}
.content .cta-inline{margin-top:36px;background:var(--white);border:1px solid var(--line);border-left:4px solid var(--brass);border-radius:var(--radius);padding:24px}
.content .cta-inline h3{margin-bottom:8px}
.two-col{display:grid;grid-template-columns:2fr 1fr;gap:40px;align-items:start}
@media(max-width:820px){.two-col{grid-template-columns:1fr}}
.sidebar .card{position:sticky;top:90px}
.sidebar .phone-big{font-family:'Barlow Condensed',sans-serif;font-size:1.8rem;font-weight:700;color:var(--navy);text-decoration:none;display:block;margin:6px 0}
.sidebar .phone-big:hover{color:var(--brass)}
.sidebar ul{list-style:none}
.sidebar li{padding:7px 0;border-bottom:1px solid var(--line);font-size:.93rem}
.sidebar li:last-child{border:none}
.sidebar a{text-decoration:none}
.sidebar a:hover{color:var(--brass)}

/* footer */
.site-footer{background:var(--navy-deep);color:#AFC2D2;padding:52px 0 90px;margin-top:20px}
.site-footer h4{font-family:'Barlow Condensed',sans-serif;color:#fff;font-size:1.15rem;margin-bottom:14px;letter-spacing:.05em;text-transform:uppercase}
.footer-grid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:34px}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.footer-grid{grid-template-columns:1fr}}
.site-footer a{color:#AFC2D2;text-decoration:none;font-size:.92rem}
.site-footer a:hover{color:var(--brass-bright)}
.site-footer li{list-style:none;padding:4px 0}
.footer-bottom{border-top:1px solid #24384C;margin-top:38px;padding-top:20px;font-size:.85rem;color:#6E88A0;display:flex;justify-content:space-between;flex-wrap:wrap;gap:10px}
.nap{font-size:.95rem;line-height:1.9}
.nap a{font-weight:600;color:#fff}

/* sticky mobile call bar */
.mobile-call{display:none;position:fixed;bottom:0;left:0;right:0;z-index:60;background:var(--brass);text-align:center;padding:14px;font-weight:700;color:#fff;text-decoration:none;font-size:1.1rem;box-shadow:0 -4px 14px rgba(0,0,0,.25)}
@media(max-width:820px){.mobile-call{display:block}}

@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

/* --- mobile polish --- */
@media(max-width:820px){
  .nav a{padding:6px 0;font-size:1.05rem;width:100%}
  .nav .call-btn{width:100%;text-align:center;padding:13px 16px}
  .sidebar .card{position:static}
}
@media(max-width:600px){
  body{font-size:15.5px}
  section{padding:42px 0}
  .hero{padding-top:44px}
  h1{font-size:clamp(1.9rem,8vw,2.5rem)}
  .hero .lede,.page-hero .lede{font-size:1.02rem}
  .hero-cta{flex-direction:column;align-items:stretch}
  .hero-cta .btn{text-align:center;width:100%}
  .trust-chips{gap:8px}
  .chip{font-size:.8rem;padding:5px 12px}
  .card{padding:20px}
  .hero-fade{height:72px}.hero-fade .bar{transform:rotate(26deg) scale(.7)}
  .logo img{width:50px;height:50px}
  .logo .logo-text{font-size:1.4rem}
  .content h2{margin-top:28px}
  .faq details{padding:15px 16px}
  .footer-bottom{flex-direction:column}
}
@media(max-width:380px){
  .header-inner{padding:10px 14px}
  .wrap{padding:0 16px}
}

/* gradient transition from hero into page, with brand diagonal bars */
.hero-fade{position:relative;height:110px;background:linear-gradient(180deg,rgba(246,247,248,0) 0%,rgba(246,247,248,.45) 55%,var(--bg) 100%);overflow:hidden}
.hero-fade .bar{position:absolute;width:12px;border-radius:999px;transform:rotate(26deg)}
.hero-fade .b1{height:44px;right:calc(8% + 64px);bottom:30px;background:#F6F6F8;opacity:.85}
.hero-fade .b2{height:66px;right:calc(8% + 34px);bottom:32px;background:var(--purple)}
.hero-fade .b3{height:90px;right:8%;bottom:34px;background:var(--green-soft)}

/* hero illustration layout */
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:36px;align-items:center}
.hero-art{justify-self:end}
.hero-art svg{width:100%;max-width:330px;height:auto}
@media(max-width:820px){
  .hero-grid{grid-template-columns:1fr}
  .hero-art{justify-self:center;margin-top:10px}
  .hero-art svg{max-width:210px}
}
