
/* Reset & base */
*,*::before,*::after{box-sizing:border-box}
html{line-height:1.5;-webkit-text-size-adjust:100%}
body{margin:0;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Ubuntu,"Helvetica Neue",Arial,sans-serif;color:#1a1d1f;background:#f5f7fa}
img{max-width:100%;height:auto}
a{color:#0a3d62;text-decoration:none}
a:hover{text-decoration:underline}
:root{
  --brand:#0a3d62;
  --brand-2:#17609c;
  --accent:#f9a826;
  --text:#1a1d1f;
  --muted:#667085;
  --bg:#f5f7fa;
  --card:#ffffff;
  --success:#2e7d32;
  --danger:#c62828;
  --radius:14px;
  --shadow:0 10px 30px rgba(10,61,98,.12);
  --container:1160px;
}
.container{max-width:var(--container);padding:0 20px;margin:0 auto}
.sr-only{position:absolute;width:1px;height:1px;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden;white-space:nowrap}
.muted{color:var(--muted)}
.small{font-size:.9rem}
.btn{display:inline-block;padding:.7rem 1.1rem;border-radius:10px;border:1px solid transparent;box-shadow:none;transition:.25s ease;cursor:pointer;font-weight:600}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--brand);color:#fff;border-color:var(--brand)}
.btn-outline{background:transparent;color:var(--brand);border-color:var(--brand)}
.btn-secondary{background:#fff;color:var(--brand);border-color:#d0d5dd}
.btn-lg{padding:1rem 1.4rem;font-size:1.05rem}
.badge{display:inline-block;padding:.3rem .6rem;border-radius:999px;background:#eef2f6;color:#0a3d62;font-weight:600;margin:.25rem .4rem}
.section{padding:3rem 0}
h1,h2,h3{line-height:1.2}
h1{font-size:clamp(2rem,4vw,3rem);margin:0 0 .5rem}
h2{font-size:clamp(1.5rem,3vw,2.2rem);margin:0 0 1rem}
h3{font-size:1.25rem;margin:1.2rem 0 .5rem}

/* Header */
#site-header{position:sticky;top:0;background:#fff;box-shadow:0 4px 18px rgba(10,61,98,.06);z-index:20}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand img{display:block}
.nav-toggle{display:none;background:none;border:0}
.nav-menu{display:flex;gap:18px;align-items:center;margin:0;padding:0;list-style:none}
.nav-menu a{padding:.6rem .3rem;border-radius:8px}
.nav-menu .btn{margin-left:.4rem}
.nav-menu .active > a{color:var(--brand-2);font-weight:700}
.has-submenu{position:relative}
.submenu{display:none;position:absolute;top:100%;left:0;background:#fff;padding:.6rem;border-radius:10px;box-shadow:var(--shadow);list-style:none;margin:0;min-width:240px}
.has-submenu:hover .submenu{display:block}
.submenu li a{display:block;padding:.4rem .6rem;border-radius:8px}
.submenu li a:hover{background:#f1f5f9}
.header-cta .phone{font-weight:700}
@media (max-width:960px){
  .nav-toggle{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:8px;background:#eef2f6}
  .nav-toggle .bars, .nav-toggle .bars::before, .nav-toggle .bars::after{content:"";display:block;width:18px;height:2px;background:#0a3d62;border-radius:2px;position:relative}
  .nav-toggle .bars::before{top:-6px;position:absolute}
  .nav-toggle .bars::after{top:6px;position:absolute}
  .nav-menu{position:absolute;inset:64px 0 auto 0;background:#fff;flex-direction:column;padding:16px 20px;box-shadow:0 20px 40px rgba(10,61,98,.1);display:none}
  .nav-menu.open{display:flex}
  .has-submenu .submenu{position:static;box-shadow:none;padding-left:12px}
  .header-cta{display:none}
}

/* Hero */
.hero{position:relative;padding:3rem 0 0;background:linear-gradient(120deg,#0a3d62 0%,#17609c 60%,#1e86cf 100%);color:#fff;overflow:hidden}
.hero-content{padding:2rem 0 3rem}
.hero .lead{font-size:1.15rem;opacity:.95}
.hero-cta .btn{margin:.3rem .4rem .2rem 0}
.hero-bullets{display:flex;flex-wrap:wrap;gap:16px;margin:1rem 0 0;padding:0;list-style:none}
.hero-bullets li{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.25);padding:.4rem .6rem;border-radius:999px}
.hero-media{position:relative;height:0;padding-bottom:28%;}
.hero-media img{position:absolute;right:0;bottom:-2px;max-height:420px}

/* Split + cards */
.split{display:grid;grid-template-columns:1.1fr .9fr;gap:24px;align-items:start}
.card-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.card{background:var(--card);border-radius:var(--radius);padding:1rem;border:1px solid #e5e7eb;box-shadow:var(--shadow)}
.card .btn-link{font-weight:700}
@media (max-width:960px){
  .split{grid-template-columns:1fr}
  .card-grid{grid-template-columns:1fr}
}

/* CTA band */
.cta-band{background:#0a3d6211;padding:2rem 0;margin:2rem 0}
.cta-band .btn{margin-top:.5rem}

/* Reviews */
.review-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.review{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
@media (max-width:960px){.review-grid{grid-template-columns:1fr}}

/* Page hero */
.page-hero{padding:2.2rem 0}
.page-hero p{color:var(--muted)}

/* Forms */
.form{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.form-row{margin:.6rem 0;display:flex;flex-direction:column}
.form-row input,.form-row textarea,.form-row select{padding:.7rem;border:1px solid #cbd5e1;border-radius:10px;background:#fff}
.form-actions{display:flex;gap:12px;align-items:center}
.form-status{min-height:1.2em}
.form .hp{display:none}
fieldset{border:0;padding:0;margin:0}
legend{font-weight:700;margin:.6rem 0 .4rem}
.contact-grid{display:grid;grid-template-columns:1fr .65fr;gap:20px}
.contact-card{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:1rem}
@media (max-width:960px){.contact-grid{grid-template-columns:1fr}}

/* Pricing */
.pricing-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.price-card{background:#fff;border:1px solid #e5e7eb;border-radius:var(--radius);padding:1rem;box-shadow:var(--shadow)}
.price{font-size:1.35rem;color:#0a3d62;font-weight:800}
@media (max-width:1100px){.pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){.pricing-grid{grid-template-columns:1fr}}

/* Footer */
#site-footer{background:#0b1220;color:#c7d0dc;margin-top:2rem}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px;padding:2rem 0}
.footer-nav{list-style:none;margin:0;padding:0;columns:2}
.footer-nav li{margin:.25rem 0}
.footer-legal{border-top:1px solid #233047;padding:1rem 0;display:flex;justify-content:space-between;gap:12px}
.footer-legal a{color:#98b6d6}
.footer-logo{filter:brightness(1.2)}
.brand-name{font-weight:800;color:#fff}
@media (max-width:960px){
  .footer-grid{grid-template-columns:1fr}
  .footer-legal{flex-direction:column}
}

/* Cookie banner */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:#ffffff;border-top:1px solid #e5e7eb;box-shadow:0 -10px 30px rgba(0,0,0,.08);padding:1rem;z-index:50}
.cookie-modal{position:fixed;inset:0;background:rgba(2,6,23,.66);display:flex;align-items:center;justify-content:center;z-index:60}
.cookie-modal-inner{background:#fff;border-radius:12px;max-width:520px;width:92%;padding:1rem;border:1px solid #e5e7eb;box-shadow:var(--shadow)}
.cookie-opt{display:flex;align-items:center;gap:10px;margin:.4rem 0}

/* Utilities */
.ticks{list-style:none;padding-left:0}
.ticks li{position:relative;padding-left:24px}
.ticks li::before{content:"✓";position:absolute;left:0;top:0;color:var(--success);font-weight:800}

/* Animations (respect reduced motion) */
@media (prefers-reduced-motion:no-preference){
  .card,.price-card,.review{transition:transform .3s ease, box-shadow .3s ease}
  .card:hover,.price-card:hover,.review:hover{transform:translateY(-4px);box-shadow:0 16px 36px rgba(10,61,98,.18)}
/* Make sure hidden attribute actually hides banners/modals */
.cookie-modal[hidden],
.cookie-banner[hidden] { display: none !important; }

