/* Valley Stream Lock & Safe */

@import url('https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Outfit:wght@600;700;800;900&display=swap');

:root{
  --gold:#f0b832;
  --gold-dark:#d9a21e;
  --gold-glow:rgba(240,184,50,.25);
  --navy:#0b1a30;
  --navy-mid:#132744;
  --blue:#2874a6;
  --blue-light:#3498db;
  --blue-dark:#1a5276;
  --slate:#1e3a5f;
  --cream:#f7f9fc;
  --smoke:#e8eef4;
  --txt:#0b1a30;
  --txt-mid:#3d5a80;
  --white:#ffffff;
  --r:8px;
  --r-lg:12px;
  --shadow-sm:0 2px 8px rgba(11,26,48,.08);
  --shadow-md:0 6px 24px rgba(11,26,48,.12);
  --shadow-lg:0 16px 48px rgba(11,26,48,.18);
  --ease:cubic-bezier(.4,0,.2,1)
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;color:var(--txt);background:var(--cream);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
a{text-decoration:none;color:inherit;transition:color .25s var(--ease)}
img{max-width:100%;height:auto;display:block}

/* ── Header ── */
.site-header{background:var(--navy);padding:14px 32px;display:flex;justify-content:space-between;align-items:center}
.brand{display:flex;align-items:center;gap:10px;font-family:'Outfit',sans-serif;color:var(--white);font-size:1.35rem;font-weight:800;letter-spacing:.8px;text-transform:uppercase}
.brand svg{color:var(--gold);flex-shrink:0}
.brand em{font-style:normal;color:var(--gold)}
.header-phone{color:var(--gold);font-family:'Outfit',sans-serif;font-size:1.05rem;font-weight:700;display:flex;align-items:center;gap:8px}
.header-phone:hover{color:var(--white)}

/* ── Navigation ── */
.main-nav{background:var(--blue);position:relative;z-index:100}
.nav-inner{display:flex;justify-content:center;max-width:1200px;margin:0 auto}
.nav-inner>a,.nav-inner>.dd>a{color:var(--white);padding:13px 17px;font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:600;letter-spacing:.4px;display:flex;align-items:center;gap:6px;white-space:nowrap;transition:background .25s var(--ease)}
.nav-inner>a:hover,.nav-inner>a.on,.nav-inner>.dd:hover>a{background:var(--blue-dark)}
.dd{position:relative}
.dd-menu{display:none;position:absolute;top:100%;left:0;background:var(--navy);min-width:230px;border-radius:0 0 var(--r) var(--r);box-shadow:var(--shadow-lg);z-index:200;overflow:hidden}
.dd-menu a{display:flex;align-items:center;gap:10px;padding:11px 18px;color:rgba(255,255,255,.82);font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(255,255,255,.05);transition:all .25s var(--ease)}
.dd-menu a:last-child{border-bottom:none}
.dd-menu a:hover{background:var(--gold);color:var(--navy);padding-left:24px}
.dd:hover .dd-menu{display:block}

/* hamburger */
.mob-toggle-wrap{display:none;background:var(--blue);width:100%;padding:10px 20px;justify-content:center}
.mob-toggle{display:none;background:none;border:2px solid rgba(255,255,255,.25);border-radius:6px;cursor:pointer;padding:7px 11px}
.mob-toggle i{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:all .3s var(--ease);margin:5px 0}
.mob-toggle.open i:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.mob-toggle.open i:nth-child(2){opacity:0}
.mob-toggle.open i:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ── Hero (homepage) ── */
.hero-banner{position:relative;background:var(--navy);overflow:hidden}
.hero-banner img{width:100%;height:auto;display:block}

/* ── Service Cards Grid ── */
.cards-row{max-width:1200px;margin:-36px auto 0;padding:0 20px 50px;position:relative;z-index:3;display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.scard{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease);border:3px solid transparent;cursor:pointer}
.scard:hover{transform:translateY(-6px) scale(1.015);box-shadow:var(--shadow-lg);border-color:var(--gold)}
.scard a{display:block}
.scard .scard-img{aspect-ratio:16/10;overflow:hidden;position:relative}
.scard .scard-img::after{content:"";position:absolute;inset:0;background:rgba(11,26,48,.12);transition:opacity .4s var(--ease)}
.scard:hover .scard-img::after{opacity:0}
.scard .scard-img img{width:100%;height:100%;object-fit:cover;transition:transform .5s var(--ease)}
.scard:hover .scard-img img{transform:scale(1.06)}

/* ── Two-Column Layout ── */
.page-body{max-width:1200px;margin:0 auto;padding:28px 20px 50px;display:grid;grid-template-columns:1fr 340px;gap:36px}
.page-body.full-width{grid-template-columns:1fr;max-width:860px}

/* main content */
.article h1{font-family:'Outfit',sans-serif;color:var(--blue);font-size:1.9rem;font-weight:800;margin-bottom:18px;line-height:1.25}
.article h2{font-family:'Outfit',sans-serif;color:var(--blue);font-size:1.7rem;font-weight:800;margin-bottom:18px;line-height:1.25}
.article p{line-height:1.85;margin-bottom:15px;color:var(--txt-mid);font-size:.96rem}
.article h3{font-family:'Outfit',sans-serif;color:var(--blue);font-size:1.22rem;font-weight:700;margin:28px 0 12px;display:flex;align-items:center;gap:9px}
.article h3 svg{color:var(--gold);flex-shrink:0}
.article a{color:var(--blue);font-weight:600;text-decoration:underline;text-decoration-color:rgba(40,116,166,.25);text-underline-offset:3px}
.article a:hover{color:var(--navy);text-decoration-color:var(--navy)}
.article .feat-img{border-radius:var(--r-lg);margin:18px 0 22px;overflow:hidden;box-shadow:var(--shadow-sm)}
.article .feat-img img{width:100%;border-radius:var(--r-lg)}

/* sidebar */
.aside{background:var(--blue);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-md);height:fit-content;position:sticky;top:20px}
.aside-head{background:var(--blue-dark);padding:22px;text-align:center}
.aside-head h3{font-family:'Outfit',sans-serif;color:var(--white);font-size:1.1rem;font-weight:700;letter-spacing:.8px}
.aside-head p{color:var(--gold);font-family:'Outfit',sans-serif;font-size:.95rem;margin-top:3px;font-weight:600}
.aside-head .badge{color:rgba(255,255,255,.65);font-family:'Outfit',sans-serif;font-size:.78rem;margin-top:5px;letter-spacing:1.8px;text-transform:uppercase}
.aside-info{padding:22px}
.aside-info h4{font-family:'Outfit',sans-serif;color:var(--white);font-size:.95rem;margin-bottom:9px;font-weight:700}
.aside-info .loc{color:rgba(255,255,255,.88);font-size:.85rem;margin-bottom:14px;display:flex;align-items:center;gap:8px}
.aside-info .loc svg{color:var(--gold);flex-shrink:0}
.aside-info iframe{border:0;border-radius:var(--r);width:100%;height:190px}
.aside-btn{display:flex;align-items:center;justify-content:center;gap:9px;margin:14px 22px 22px;background:var(--gold);color:var(--navy);font-family:'Outfit',sans-serif;font-weight:700;padding:13px;border-radius:var(--r);text-transform:uppercase;letter-spacing:.8px;font-size:.88rem;transition:transform .2s var(--ease),background .25s var(--ease);box-shadow:0 4px 14px var(--gold-glow)}
.aside-btn:hover{transform:translateY(-2px);background:var(--gold-dark)}
.aside-links{margin:0 22px 22px;background:var(--blue-dark);border-radius:var(--r);overflow:hidden}
.aside-links h4{font-family:'Outfit',sans-serif;color:var(--gold);font-size:.82rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;padding:14px 16px 10px;border-bottom:1px solid rgba(255,255,255,.06)}
.aside-links a{display:flex;align-items:center;gap:9px;padding:11px 16px;color:rgba(255,255,255,.82);font-size:.85rem;font-weight:500;border-bottom:1px solid rgba(255,255,255,.05);transition:all .25s var(--ease)}
.aside-links a:last-child{border-bottom:none}
.aside-links a:hover{background:rgba(255,255,255,.07);color:var(--gold);padding-left:22px}
.aside-links a svg{color:var(--gold);flex-shrink:0}

/* ── Contact Page ── */
.contact-split{max-width:1100px;margin:0 auto;padding:40px 20px 60px;display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.contact-info{background:var(--navy);border-radius:var(--r-lg);padding:36px;color:var(--white)}
.contact-info h2{font-family:'Outfit',sans-serif;font-size:1.6rem;font-weight:800;margin-bottom:10px;color:var(--gold)}
.contact-info p{color:rgba(255,255,255,.8);font-size:.95rem;line-height:1.75;margin-bottom:20px}
.contact-info .ci-item{display:flex;align-items:flex-start;gap:12px;margin-bottom:18px}
.contact-info .ci-item svg{color:var(--gold);flex-shrink:0;margin-top:3px}
.contact-info .ci-item span{color:rgba(255,255,255,.9);font-size:.93rem;line-height:1.6}
.contact-info .ci-item a{color:var(--gold);font-weight:600}
.contact-info .ci-item a:hover{color:var(--white)}
.contact-info .ci-hours{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.contact-info .ci-hours h4{font-family:'Outfit',sans-serif;font-size:1rem;font-weight:700;margin-bottom:8px;color:var(--white)}
.contact-info .ci-hours p{margin-bottom:4px;font-size:.9rem}
.contact-info iframe{border:0;border-radius:var(--r);width:100%;height:220px;margin-top:20px}

.contact-form-wrap{background:var(--white);border-radius:var(--r-lg);padding:36px;box-shadow:var(--shadow-md)}
.contact-form-wrap h2{font-family:'Outfit',sans-serif;font-size:1.5rem;font-weight:800;color:var(--blue);margin-bottom:6px}
.contact-form-wrap .sub{color:var(--txt-mid);font-size:.93rem;margin-bottom:24px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.cf-field{display:flex;flex-direction:column;margin-bottom:14px}
.cf-field label{font-family:'Outfit',sans-serif;font-size:.82rem;font-weight:600;color:var(--navy);margin-bottom:5px;letter-spacing:.3px}
.cf-field input,.cf-field select,.cf-field textarea{border:1.5px solid var(--smoke);border-radius:var(--r);padding:11px 14px;font-family:'DM Sans',sans-serif;font-size:.93rem;color:var(--txt);background:var(--cream);transition:border-color .25s var(--ease),box-shadow .25s var(--ease);outline:none}
.cf-field input:focus,.cf-field select:focus,.cf-field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(40,116,166,.12)}
.cf-field textarea{resize:vertical;min-height:120px}
.cf-submit{display:inline-flex;align-items:center;gap:8px;background:var(--gold);color:var(--navy);font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:700;padding:13px 32px;border:none;border-radius:var(--r);cursor:pointer;text-transform:uppercase;letter-spacing:.6px;transition:transform .2s var(--ease),background .25s var(--ease);box-shadow:0 4px 14px var(--gold-glow);margin-top:6px}
.cf-submit:hover{transform:translateY(-2px);background:var(--gold-dark)}

/* ── Footer ── */
.site-footer{background:var(--navy);padding:44px 20px 28px;text-align:center}
.site-footer .f-brand{font-family:'Outfit',sans-serif;color:var(--white);font-size:1.5rem;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:14px}
.site-footer .f-phone{color:var(--gold);font-family:'Outfit',sans-serif;font-size:1.2rem;font-weight:700;display:inline-flex;align-items:center;gap:9px;margin-bottom:12px}
.site-footer .f-phone:hover{color:var(--white)}
.site-footer .f-addr{color:rgba(255,255,255,.7);font-size:.88rem;margin-bottom:22px;display:flex;align-items:center;justify-content:center;gap:7px}
.site-footer .f-addr svg{color:var(--gold)}
.site-footer .f-nav{margin-bottom:22px;display:flex;flex-wrap:wrap;justify-content:center;gap:5px 16px}
.site-footer .f-nav a{color:rgba(255,255,255,.6);font-size:.84rem;font-weight:500;transition:color .25s var(--ease)}
.site-footer .f-nav a:hover{color:var(--gold)}
.site-footer .f-nav .dot{color:rgba(255,255,255,.18)}
.site-footer .f-copy{color:rgba(255,255,255,.35);font-size:.78rem;border-top:1px solid rgba(255,255,255,.07);padding-top:18px}

/* ── Scroll Top Button ── */
.go-top{position:fixed;bottom:28px;right:28px;width:42px;height:42px;background:var(--gold);color:var(--navy);border:none;border-radius:var(--r);cursor:pointer;box-shadow:0 4px 14px var(--gold-glow);transition:opacity .3s var(--ease),transform .2s var(--ease);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;z-index:50}
.go-top.show{opacity:1;pointer-events:auto}
.go-top:hover{transform:translateY(-3px);background:var(--gold-dark)}

/* ── Responsive ── */
@media(max-width:900px){
  .cards-row{grid-template-columns:repeat(2,1fr)}
  .page-body{grid-template-columns:1fr}
  .site-header{flex-direction:column;gap:7px;text-align:center;padding:12px 18px}
  .brand{font-size:1.15rem;justify-content:center}
  .mob-toggle-wrap{display:flex}
  .mob-toggle{display:block}
  .main-nav .nav-inner{display:none;flex-direction:column;width:100%}
  .main-nav .nav-inner.open{display:flex}
  .nav-inner>a,.nav-inner>.dd>a{padding:15px 22px;border-top:1px solid rgba(255,255,255,.07);justify-content:center;text-align:center}
  .dd{width:100%}
  .dd>a{width:100%;justify-content:center}
  .dd-menu{position:static;box-shadow:none;border-radius:0;background:rgba(0,0,0,.12);min-width:100%}
  .dd-menu a{padding:13px 22px;justify-content:center}
  .dd:hover .dd-menu{display:none}
  .dd .dd-menu.open{display:block!important}
  .contact-split{grid-template-columns:1fr}
}
@media(min-width:901px){
  .main-nav .nav-inner{display:flex!important;justify-content:center}
  .mob-toggle-wrap{display:none!important}
}
@media(max-width:550px){
  .cards-row{grid-template-columns:1fr}
  .brand{font-size:.95rem;letter-spacing:.5px}
  .article h1{font-size:1.45rem}
  .article h2{font-size:1.35rem}
  .contact-info{padding:24px}
  .contact-form-wrap{padding:24px}
  .cf-row{grid-template-columns:1fr}
}
