
:root{
  --bg:#f5faff;
  --text:#0f2542;
  --muted:#5e7595;
  --primary:#0f6fe6;
  --primary-dark:#0a58b5;
  --line:#d8e8f8;
  --card:#ffffff;
  --shadow:0 22px 60px rgba(12,42,84,.10);
  --radius:26px;
  --max:1180px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at 8% 8%, rgba(15,111,230,.10), transparent 24%),
    radial-gradient(circle at 92% 14%, rgba(15,111,230,.08), transparent 18%),
    linear-gradient(180deg,#f8fbff 0%, #eef6ff 44%, #ffffff 100%);
  overflow-x:hidden;
}
body::before, body::after{
  content:"❄";
  position:fixed;
  line-height:1;
  color:rgba(15,111,230,.035);
  z-index:0;
  pointer-events:none;
}
body::before{font-size:220px; left:-24px; top:110px; transform:rotate(-12deg)}
body::after{font-size:180px; right:-20px; top:540px; transform:rotate(10deg)}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.wrap{width:min(var(--max), calc(100% - 30px)); margin:0 auto; position:relative; z-index:1}

.topbar{
  position:sticky; top:0; z-index:60;
  backdrop-filter:blur(12px);
  background:rgba(255,255,255,.9);
  border-bottom:1px solid rgba(216,232,248,.9);
}
.topbar-inner{
  min-height:92px; display:flex; align-items:center; justify-content:space-between; gap:18px;
}
.brand img{width:300px; max-width:100%; height:auto}
.nav-cluster{display:flex; align-items:center; gap:18px; flex:1; justify-content:flex-end}
.main-nav{display:flex; gap:18px; align-items:center; flex-wrap:wrap}
.main-nav a{font-weight:700; color:#22466f}
.nav-actions{display:flex; align-items:center; gap:12px; flex-wrap:wrap}
.phone-link{font-weight:800; color:#143765; white-space:nowrap}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  border:none; border-radius:999px; font-weight:800; padding:14px 22px; cursor:pointer; transition:.25s ease;
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{
  color:#fff; background:linear-gradient(135deg, var(--primary), #4fa6ff);
  box-shadow:0 16px 36px rgba(15,111,230,.22);
}
.btn-secondary{
  color:#173f70; background:#fff; border:1px solid #d4e6f8;
}
.menu-toggle{
  display:none;
  border:none;
  background:linear-gradient(135deg,var(--primary), #4fa6ff);
  color:#fff;
  font-size:1.1rem;
  border-radius:14px;
  padding:10px 14px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 12px 24px rgba(15,111,230,.22);
}
.mobile-nav{display:none; flex-direction:column; gap:10px; padding:0 0 16px}
.mobile-nav a{
  padding:12px 14px; background:#fff; border:1px solid #d8e8f8;
  border-radius:14px; font-weight:700; color:#173f70;
}
body.menu-open .mobile-nav{display:flex}

.hero{padding:46px 0 28px}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:28px; align-items:center}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px;
  padding:10px 16px; border-radius:999px; margin-bottom:18px;
  font-size:.88rem; font-weight:800; color:#155299;
  background:rgba(255,255,255,.85); border:1px solid #dbe9f8; box-shadow:0 10px 25px rgba(13,41,82,.06);
}
h1{
  margin:0 0 14px; font-size:clamp(2.35rem, 5.2vw, 5rem);
  line-height:.97; letter-spacing:-2px; color:#0c2a54; max-width:760px;
}
h1 .accent{color:var(--primary)}
.lead{
  margin:0 0 24px; max-width:720px; color:var(--muted);
  font-size:1.05rem; line-height:1.8;
}
.hero-actions{display:flex; gap:12px; flex-wrap:wrap; margin-bottom:24px}
.trust-row{display:grid; grid-template-columns:repeat(3,1fr); gap:14px}
.trust-card{
  background:rgba(255,255,255,.84); border:1px solid #dce9f8; border-radius:20px;
  padding:16px; box-shadow:var(--shadow);
}
.trust-card strong{display:block; margin-bottom:4px; color:#10315f; font-size:.98rem}
.trust-card span{color:var(--muted); font-size:.92rem}
.hero-panel{
  background:linear-gradient(180deg, rgba(255,255,255,.95), rgba(255,255,255,.90));
  border:1px solid #d9e8f8; border-radius:30px; padding:20px; box-shadow:var(--shadow); position:relative; overflow:hidden;
}
.hero-panel::before{
  content:"❄"; position:absolute; right:12px; top:-8px; font-size:110px; color:rgba(15,111,230,.08); transform:rotate(15deg)
}
.hero-image{
  background:linear-gradient(160deg, #0d2c56 0%, #0f6fe6 58%, #6bb5ff 100%);
  border-radius:24px; min-height:470px; position:relative; overflow:hidden;
  display:flex; align-items:flex-end; padding:24px;
}
.hero-image::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(8,24,48,.10), rgba(8,24,48,.30));
  pointer-events:none;
}
.hero-image .bg{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:.28; filter:saturate(.9) contrast(1.05);
}
.van-wrap{position:relative; z-index:2; width:100%; display:flex; justify-content:center; align-items:flex-end}
.van-wrap img{width:100%; max-width:540px; object-fit:contain; filter:drop-shadow(0 24px 40px rgba(0,0,0,.30))}
.hero-overlay-card{
  position:absolute; left:20px; top:20px; z-index:3; max-width:280px;
  background:rgba(255,255,255,.14); border:1px solid rgba(255,255,255,.18); color:#fff;
  padding:16px; border-radius:18px; backdrop-filter:blur(8px);
}
.hero-overlay-card strong{display:block; margin-bottom:4px; font-size:1rem}
.hero-overlay-card span{font-size:.9rem; color:rgba(255,255,255,.86)}

.section{padding:22px 0}
.panel{
  background:#fff; border:1px solid #e2edf9; border-radius:28px; padding:34px;
  box-shadow:0 18px 45px rgba(14,42,87,.07);
}
.section-head{
  margin:0 0 10px; font-size:clamp(1.75rem, 3vw, 2.8rem);
  line-height:1.05; letter-spacing:-1px; color:#102c57;
}
.section-sub{
  margin:0 0 24px; color:var(--muted); max-width:780px; font-size:1rem; line-height:1.78;
}
.grid-4,.grid-3,.grid-2{display:grid; gap:18px}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
.card{
  background:linear-gradient(180deg,#fff,#fbfdff); border:1px solid #dfebf8; border-radius:24px; padding:24px; transition:.25s ease;
}
.card:hover{transform:translateY(-4px); box-shadow:0 18px 35px rgba(12,45,98,.08)}
.icon{
  width:52px; height:52px; border-radius:16px; display:grid; place-items:center; margin-bottom:14px;
  background:linear-gradient(135deg,#e8f4ff,#fff); color:#1273ea; font-size:1.2rem; border:1px solid #d7e8f9;
}
.card h3{margin:0 0 8px; font-size:1.08rem; color:#0e2e5b; letter-spacing:-.2px}
.card p{margin:0; color:var(--muted); font-size:.95rem; line-height:1.7}
.split-band{display:grid; grid-template-columns:1.02fr .98fr; gap:18px}
.dark-panel{
  background:linear-gradient(135deg,#0c2950,#113d76 60%, #177bf1 100%);
  color:#fff; border:none; position:relative; overflow:hidden;
}
.dark-panel::before{
  content:"❄"; position:absolute; right:24px; bottom:-10px; font-size:120px; color:rgba(255,255,255,.08)
}
.dark-panel .section-head, .dark-panel .section-sub{color:#fff}
.dark-panel .section-sub{color:rgba(255,255,255,.86)}
.check-list{display:grid; gap:12px}
.check{
  padding:14px 16px; border-radius:18px; background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.14);
  font-weight:700; color:#eef6ff;
}
.service-pills{display:flex; flex-wrap:wrap; gap:12px}
.pill{
  padding:12px 16px; border-radius:999px; background:#eff6ff; color:#214771; font-weight:800; border:1px solid #d8e7f8;
}
.gallery-card{
  border-radius:24px; overflow:hidden; border:1px solid #deebf8; background:#fff;
  box-shadow:0 14px 35px rgba(13,41,82,.06);
}
.gallery-card img{width:100%; height:100%; object-fit:cover; min-height:360px}
.breadcrumbs{font-size:.92rem; color:var(--muted); margin-bottom:16px}
.breadcrumbs a{color:#1a61ba; font-weight:700}
.content-list{display:grid; gap:10px; margin:16px 0 0; padding:0}
.content-list li{list-style:none; padding-left:28px; position:relative; color:var(--muted); line-height:1.7}
.content-list li::before{content:"✓"; position:absolute; left:0; top:0; color:#1273ea; font-weight:800}
.cta-band{
  background:linear-gradient(135deg,#0e71e6,#35a1ff); color:#fff; border-radius:30px; padding:34px;
  box-shadow:0 24px 55px rgba(18,115,234,.22); display:grid; grid-template-columns:1.15fr .85fr; gap:20px; align-items:center; position:relative; overflow:hidden;
}
.cta-band::after{content:"❄"; position:absolute; right:26px; top:10px; font-size:110px; color:rgba(255,255,255,.10)}
.cta-band h2{margin:0 0 10px; font-size:clamp(1.8rem, 3.8vw, 3rem); line-height:1.03; letter-spacing:-1px}
.cta-band p{margin:0; color:rgba(255,255,255,.92); max-width:700px; line-height:1.7}
.cta-actions{display:flex; flex-direction:column; align-items:flex-end; gap:12px}

form{display:grid; gap:14px}
label{font-weight:700; color:#173f70; font-size:.95rem}
input,select,textarea{
  width:100%; margin-top:6px; padding:14px 16px; border-radius:14px; border:1px solid #d8e7f8;
  font:inherit; background:#fff; color:#10315f;
}
textarea{min-height:140px; resize:vertical}
.form-note{font-size:.92rem; color:var(--muted)}

.mobile-call-bar{display:none}
.footer{padding:34px 0 90px; text-align:center; color:#667b97; font-size:.95rem}

@media (max-width: 980px){
  .hero-grid,.split-band,.cta-band,.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}
  .trust-row{grid-template-columns:1fr}
  .cta-actions{align-items:flex-start}
  .main-nav{display:none}
  .menu-toggle{display:inline-flex}
  .brand img{width:240px}
  .nav-cluster{width:100%; justify-content:space-between}
}
@media (max-width: 768px){
  .mobile-call-bar{
    display:flex; position:fixed; left:12px; right:12px; bottom:12px; z-index:999;
    justify-content:center; align-items:center; padding:14px 18px; border-radius:999px;
    background:linear-gradient(135deg,#0f6fe6,#4fa6ff); color:#fff; font-weight:800;
    box-shadow:0 14px 30px rgba(15,111,230,.28)
  }
  body{padding-bottom:84px}
}
@media (max-width: 680px){
  body::before{font-size:140px} body::after{font-size:120px}
  .topbar-inner{padding:10px 0; min-height:auto; align-items:flex-start; flex-direction:column}
  .nav-cluster{width:100%; flex-direction:column; align-items:stretch}
  .nav-actions,.hero-actions{flex-direction:column; align-items:stretch}
  .btn,.phone-link,.menu-toggle{width:100%; justify-content:center; text-align:center}
  .panel,.cta-band,.hero-panel{padding:24px}
  .hero-image{min-height:380px}
  .hero-overlay-card{max-width:220px}
  .service-pills{gap:10px}
  .pill{width:100%; text-align:center}
  .brand img{width:210px}
}
