
:root{
  --bg:#f6f8fb;
  --surface:#ffffff;
  --ink:#152033;
  --muted:#637189;
  --line:#dfe6ef;
  --primary:#1f5fbf;
  --primary-dark:#15488f;
  --accent:#f4b942;
  --soft:#eaf2ff;
  --success:#1f8a5b;
  --danger:#b33636;
  --radius:22px;
  --shadow:0 18px 45px rgba(21,32,51,.08);
  --max:1160px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Arial, Helvetica, sans-serif;
  color:var(--ink);
  background:linear-gradient(180deg,#f8fbff 0%,#eef3f9 100%);
  line-height:1.62;
}
a{color:inherit;text-decoration:none}
.container{width:min(92%,var(--max));margin:auto}
.topbar{
  background:#101b2e;
  color:#dce8fa;
  font-size:.92rem;
}
.topbar .container{
  display:flex;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
  padding:9px 0;
}
.header{
  position:sticky;
  top:0;
  z-index:100;
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.nav{
  min-height:74px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}
.brand{
  display:flex;
  align-items:center;
  gap:12px;
}
.logo-img{
  width:230px;
  max-width:42vw;
  height:auto;
  display:block;
}
.brand-text strong{display:block;font-size:1.18rem;color:#101b2e}
.brand-text span{display:block;font-size:.9rem;color:var(--muted);margin-top:-2px}
.footer-logo{
  width:220px;
  max-width:100%;
  height:auto;
  filter:brightness(0) invert(1);
  margin-bottom:12px;
}
.menu{
  display:flex;
  align-items:center;
  gap:18px;
  font-weight:700;
  color:#2b3d59;
}
.menu a:hover{color:var(--primary)}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  border-radius:16px;
  padding:12px 18px;
  font-weight:800;
  border:1px solid transparent;
  cursor:pointer;
  transition:.15s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{background:var(--primary);color:#fff}
.btn-primary:hover{background:var(--primary-dark)}
.btn-light{background:#fff;color:var(--primary);border-color:#c7d7ef}
.btn-ghost{background:transparent;border-color:#cfd9e8;color:#203450}
.hero{
  padding:58px 0 34px;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.12fr .88fr;
  gap:28px;
  align-items:center;
}
.badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 13px;
  border-radius:999px;
  background:var(--soft);
  border:1px solid #cfdef4;
  color:var(--primary-dark);
  font-weight:800;
  font-size:.92rem;
  margin-bottom:16px;
}
h1,h2,h3{line-height:1.14;color:#101b2e}
h1{
  font-size:clamp(2.25rem,4.4vw,4.35rem);
  margin:.1em 0 .35em;
}
h2{font-size:clamp(1.75rem,2.8vw,2.65rem);margin:0 0 12px}
h3{font-size:1.25rem;margin:0 0 10px}
.lead{
  font-size:1.08rem;
  color:var(--muted);
  max-width:790px;
  margin:0 0 24px;
}
.actions{display:flex;gap:12px;flex-wrap:wrap;margin:24px 0}
.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:24px;
}
.hero-card{
  background:#101b2e;
  color:white;
  border-radius:28px;
  padding:28px;
  box-shadow:0 25px 60px rgba(16,27,46,.24);
}
.hero-card h2,.hero-card h3{color:white}
.hero-card p{color:#dce8fa}
.hero-points{display:grid;gap:12px;margin-top:18px}
.hero-point{
  padding:14px 15px;
  border-radius:16px;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.12);
  color:#eef5ff;
}
.section{padding:38px 0}
.section-head{max-width:830px;margin-bottom:22px}
.section-head p{color:var(--muted);margin:0}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:18px}
.service-card{
  display:flex;
  flex-direction:column;
  min-height:230px;
}
.service-card p{color:var(--muted);margin:0 0 18px}
.mini{
  display:inline-block;
  align-self:flex-start;
  padding:6px 11px;
  border-radius:999px;
  background:var(--soft);
  color:var(--primary-dark);
  border:1px solid #cfdef4;
  font-weight:800;
  font-size:.82rem;
  margin-bottom:14px;
}
.service-link{margin-top:auto;color:var(--primary);font-weight:800}
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:24px}
.kpi{padding:18px}
.kpi strong{display:block;font-size:1.45rem;color:#101b2e}
.kpi span{color:var(--muted)}
.notice{
  padding:14px 16px;
  border-radius:16px;
  background:#fff8e7;
  border:1px solid #f0ddb2;
  color:#6c5013;
  margin:18px 0;
}
.checklist{padding-left:18px;margin:10px 0 0}
.checklist li{margin:7px 0}
.cta{
  background:linear-gradient(135deg,var(--primary),#16345f);
  color:white;
  border-radius:30px;
  padding:30px;
  box-shadow:0 22px 55px rgba(31,95,191,.22);
}
.cta h2{color:white}
.cta p{color:#e8f1ff}
.page-title{padding:40px 0 20px}
.breadcrumb{font-size:.92rem;color:var(--muted);margin-bottom:14px}
.breadcrumb a{color:var(--primary);font-weight:800}
.price{font-size:2rem;font-weight:900;color:#101b2e;margin:8px 0}
.form{
  display:grid;
  gap:12px;
}
.form label{font-weight:800;color:#283a55}
.form input,.form select,.form textarea{
  width:100%;
  border:1px solid #cfd9e8;
  border-radius:14px;
  padding:13px 14px;
  font:inherit;
  background:white;
}
.form textarea{min-height:150px;resize:vertical}
.form small{color:var(--muted)}
.footer{
  background:#101b2e;
  color:#dce8fa;
  margin-top:40px;
}
.footer .container{padding:32px 0}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr .7fr .7fr;
  gap:26px;
}
.footer a{color:#dce8fa}
.footer a:hover{color:white}
.footer h3{color:white}
.footer ul{list-style:none;padding:0;margin:0}
.footer li{margin:8px 0}
.subfooter{
  border-top:1px solid rgba(255,255,255,.12);
  padding:14px 0;
  color:#aac0df;
  font-size:.9rem;
}
.cookie-banner{
  position:fixed;
  left:16px;
  right:16px;
  bottom:16px;
  z-index:999;
  background:#101b2e;
  color:white;
  border-radius:20px;
  padding:16px;
  box-shadow:0 20px 60px rgba(0,0,0,.25);
  display:none;
  max-width:900px;
  margin:auto;
}
.cookie-banner p{margin:0 0 12px;color:#dce8fa}
.cookie-banner .actions{margin:0}
.mobile-note{display:none}
@media(max-width:980px){
  .hero-grid,.grid-3,.grid-2,.kpis,.footer-grid{grid-template-columns:1fr}
  .menu{display:none}
  .mobile-note{display:block;color:var(--muted);font-size:.92rem}
  .hero{padding-top:38px}
  .logo-img{width:190px;max-width:72vw}
}
