:root {
  --ink: #132238;
  --muted: #5f7186;
  --navy: #10243f;
  --blue: #2767d8;
  --green: #17a073;
  --gold: #f2a51f;
  --red: #cf3346;
  --cyan: #18a8d8;
  --soft: #f5f9fc;
  --mist: #eaf2f6;
  --line: #d8e3eb;
  --page-gutter: clamp(24px, 5vw, 72px);
  --content-max: 1180px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: #fff; font-family: var(--font); line-height: 1.55; }
img { max-width: 100%; height: auto; display: block; }
a { color: inherit; }

.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0, 0, 0, 0); white-space: nowrap; }
.site-header { position: sticky; top: 0; z-index: 20; display: flex; align-items: center; justify-content: space-between; gap: 28px; min-height: 76px; padding: 12px var(--page-gutter); background: rgba(255,255,255,.96); border-bottom: 1px solid var(--line); backdrop-filter: blur(14px); }
.brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; }
.brand img { width: min(200px, 48vw); height: auto; }
.brand strong { display: block; font-size: 1.18rem; }
.brand small { color: var(--muted); }
.main-nav { display: flex; gap: 30px; align-items: center; }
.main-nav a, .header-contact a { text-decoration: none; color: #42556b; font-weight: 650; }
.main-nav a:hover, .header-contact a:hover { color: var(--blue); }
.header-contact { display: grid; text-align: right; line-height: 1.35; }
.header-contact a { color: var(--navy); font-weight: 850; }
.nav-toggle { display: none; width: 48px; height: 48px; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.nav-toggle span:not(.sr-only) { display: block; width: 22px; height: 3px; margin: 4px auto; background: var(--ink); border-radius: 2px; }

.hero { display: grid; grid-template-columns: minmax(320px, .95fr) minmax(320px, 1.05fr); gap: clamp(32px, 6vw, 84px); align-items: center; min-height: calc(100vh - 76px); padding: clamp(58px, 8vw, 106px) var(--page-gutter); background: linear-gradient(180deg, #fff 0%, #f7fbff 100%); }
.hero-content, .section, .service-extra-inner, .faq-inner { max-width: var(--content-max); }
.eyebrow { margin: 0 0 14px; color: #17664f; font-size: .78rem; font-weight: 900; letter-spacing: .04em; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 { max-width: 720px; margin-bottom: 22px; font-size: clamp(2.45rem, 5.6vw, 5.4rem); line-height: .98; letter-spacing: 0; }
h2 { margin-bottom: 18px; font-size: clamp(2rem, 4vw, 3.35rem); line-height: 1.08; letter-spacing: 0; }
h3 { margin-bottom: 10px; font-size: 1.1rem; line-height: 1.3; }
.hero-lead { max-width: 700px; color: var(--muted); font-size: clamp(1.02rem, 1.7vw, 1.25rem); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin: 30px 0; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 48px; padding: 12px 20px; border: 1px solid var(--line); border-radius: 8px; font-weight: 850; text-decoration: none; cursor: pointer; }
.button.primary { color: #fff; background: var(--blue); border-color: var(--blue); }
.button.secondary { color: var(--navy); background: #fff; }
.hero-points { display: flex; flex-wrap: wrap; gap: 12px 22px; padding: 0; margin: 0; list-style: none; color: var(--muted); }
.hero-points li::before { content: ""; display: inline-block; width: 8px; height: 8px; margin-right: 9px; background: var(--gold); border-radius: 50%; }
.hero-media { padding: 24px; background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 24px 70px rgba(19,34,56,.12); }

.section { padding: clamp(58px, 8vw, 108px) var(--page-gutter); margin: 0 auto; }
.intro { display: grid; grid-template-columns: minmax(260px, .9fr) minmax(300px, 1.1fr); gap: clamp(28px, 6vw, 84px); }
.intro p, .service-card p, .steps p, .benefit-list span, .service-extra p, .faq-item p, .contact-copy p, .form-note { color: var(--muted); }
.services, .benefits { background: #fff; }
.section-heading { max-width: 720px; margin-bottom: 34px; }
.service-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(230px, 1fr)); gap: 18px; }
.service-card { min-height: 245px; padding: 24px; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.service-card a { text-decoration: none; }
.service-card a:hover,
.steps a:hover { color: var(--blue); }
.steps a { text-decoration: none; }
.tech-icon { display: grid; place-items: center; width: 52px; height: 52px; margin-bottom: 22px; color: #fff; border-radius: 8px; font-size: .85rem; font-weight: 950; box-shadow: inset -8px 0 rgba(0,0,0,.13), 0 12px 22px rgba(19,34,56,.14); }
.tech-icon.blue { background: var(--blue); }
.tech-icon.green { background: var(--green); }
.tech-icon.red { background: var(--red); }
.tech-icon.gold { background: var(--gold); color: var(--ink); }
.tech-icon.cyan { background: var(--cyan); }
.tech-icon.navy { background: var(--navy); }
.e-icon {
  width: 54px;
  height: 64px;
  margin-bottom: 22px;
  border-radius: 8px;
  box-shadow: 0 12px 22px rgba(19,34,56,.12);
}
.e-icon.blue { background: #2767d8; }
.e-icon.green { background: #17a073; }
.e-icon.red { background: #cf3346; }
.e-icon.gold { background: #f2a51f; }
.e-icon.cyan { background: #18a8d8; }
.e-icon.navy { background: #10243f; }
.e-icon.orange { background: #f57b20; }
.process { background: var(--mist); }
.steps { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 18px; padding: 0; margin: 0; list-style: none; }
.steps li { min-height: 220px; padding: 28px; background: #fff; border: 1px solid rgba(216,227,235,.95); border-radius: 8px; }
.benefits { display: grid; grid-template-columns: minmax(260px, .95fr) minmax(300px, 1.05fr); gap: clamp(28px, 7vw, 90px); align-items: start; }
.benefits-copy p { max-width: 660px; }
.benefit-list { display: grid; gap: 14px; }
.benefit-list div { display: grid; gap: 4px; padding: 22px 0; border-bottom: 1px solid var(--line); }
.benefit-list strong { font-size: 1.08rem; }
.service-extra, .faq-section { padding: clamp(56px, 8vw, 104px) var(--page-gutter); }
.service-extra { background: var(--soft); }
.service-extra-inner, .faq-inner { margin: 0 auto; }
.service-extra-grid { display: grid; grid-template-columns: minmax(260px, .9fr) minmax(300px, 1.1fr); gap: clamp(24px, 5vw, 70px); align-items: start; }
.text-link { display: inline-flex; margin-top: 4px; color: var(--blue); font-weight: 850; text-decoration-thickness: 2px; text-underline-offset: 4px; }
.faq-section { background: #fff; }
.faq-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; margin-top: 28px; }
.faq-item { padding: 24px; border: 1px solid var(--line); border-radius: 8px; background: var(--soft); }
.contact { display: grid; grid-template-columns: minmax(260px, .9fr) minmax(300px, .82fr); gap: clamp(28px, 7vw, 90px); padding: clamp(64px, 9vw, 120px) var(--page-gutter); background: #f7faf9; }
.service-hero { display: grid; grid-template-columns: minmax(300px, 1fr) minmax(280px, 380px); gap: clamp(28px, 6vw, 84px); align-items: start; padding: clamp(58px, 8vw, 106px) var(--page-gutter); background: linear-gradient(180deg, #fff 0%, #f7fbff 100%); }
.service-panel { padding: 28px; border: 1px solid var(--line); border-radius: 8px; background: var(--soft); }
.service-panel ul, .service-content ul { padding-left: 20px; margin: 0; }
.service-panel li, .service-content li { margin-bottom: 10px; }
.service-body { display: grid; grid-template-columns: minmax(0, 1fr); max-width: 920px; padding: clamp(56px, 8vw, 104px) var(--page-gutter); margin: 0 auto; }
.policy-page { max-width: 920px; }
.policy-page section { margin-top: 32px; }
.policy-page h2 { font-size: clamp(1.45rem, 2.4vw, 2rem); }
.service-photo {
  max-width: var(--content-max);
  padding: 0 var(--page-gutter) clamp(18px, 4vw, 42px);
  margin: clamp(-30px, -3vw, -18px) auto 0;
}
.service-photo img {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 18px 48px rgba(19,34,56,.12);
}
.service-content section { margin-bottom: 34px; }
.service-content p, .service-content li { color: var(--muted); }
.blog-list { display: grid; gap: 18px; }
.blog-card { display: grid; grid-template-columns: minmax(180px, 0.42fr) minmax(0, 1fr); gap: 22px; align-items: stretch; padding: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 8px; background: #fff; box-shadow: 0 12px 30px rgba(19,34,56,.06); }
.blog-card-media { min-height: 210px; background: var(--soft); }
.blog-card-media img { width: 100%; height: 100%; object-fit: cover; }
.blog-card-content { display: grid; align-content: center; padding: 24px; }
.blog-card h2 { margin-bottom: 8px; font-size: clamp(1.35rem, 2.6vw, 2rem); }
.blog-card p { color: var(--muted); }
.blog-card a { color: var(--navy); text-decoration: none; }
.blog-card a:hover { color: var(--blue); }
.article-meta { color: var(--muted); font-size: .92rem; font-weight: 700; }
.article-figure { margin: 0 0 34px; }
.article-figure img { width: 100%; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 16px 42px rgba(19,34,56,.1); }
.article-body { max-width: 860px; padding: clamp(46px, 7vw, 90px) var(--page-gutter); margin: 0 auto; }
.article-body p, .article-body li { color: var(--muted); }
.article-body h2 { margin-top: 38px; font-size: clamp(1.55rem, 3vw, 2.35rem); }
.article-cta { padding: 24px; margin-top: 36px; border: 1px solid var(--line); border-radius: 8px; background: var(--soft); }
.service-next {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}
.next-links {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 14px;
}
.next-links a {
  display: inline-flex;
  align-items: center;
  min-height: 42px;
  padding: 9px 13px;
  color: var(--navy);
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-weight: 800;
  text-decoration: none;
}
.next-links a:hover {
  color: var(--blue);
  border-color: var(--blue);
}
address { margin-top: 28px; font-style: normal; }
address a { color: var(--navy); font-weight: 750; text-decoration: none; }
.contact-form { display: grid; gap: 16px; padding: clamp(22px, 4vw, 34px); background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 14px 34px rgba(19,34,56,.08); }
label { display: grid; gap: 7px; color: var(--ink); font-size: .94rem; font-weight: 750; }
input, select, textarea { width: 100%; border: 1px solid var(--line); border-radius: 8px; padding: 13px 14px; color: var(--ink); background: #fff; font: inherit; }
input:focus, select:focus, textarea:focus { border-color: var(--blue); outline: 3px solid rgba(39,103,216,.15); }
.checkbox-field { display: grid; grid-template-columns: 18px 1fr; gap: 10px; align-items: start; color: var(--muted); font-size: .88rem; font-weight: 500; line-height: 1.45; }
.checkbox-field input { width: 18px; height: 18px; margin-top: 2px; accent-color: var(--blue); }
.form-honeypot { position: absolute; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.recaptcha-field { min-height: 78px; overflow: hidden; }
.site-footer {
  color: #f1f5f9;
  background: #30363d;
}
.footer-main {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(280px, 1.15fr) minmax(220px, 0.8fr);
  gap: clamp(28px, 7vw, 90px);
  max-width: var(--content-max);
  padding: clamp(48px, 7vw, 78px) var(--page-gutter);
  margin: 0 auto;
}
.footer-column h2 {
  margin: 0 0 16px;
  color: #ffffff;
  font-size: 1.2rem;
  font-weight: 500;
}
.footer-column p {
  margin: 0 0 10px;
  color: #f1f5f9;
  font-size: 0.94rem;
}
.footer-column strong {
  color: #ffffff;
}
.footer-column a {
  color: #ffd36a;
  text-decoration: none;
}
.footer-column a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.footer-lead {
  margin-bottom: 18px;
  color: #ffffff;
  font-size: 1.1rem;
}
.footer-group p:nth-of-type(2),
.footer-group p:nth-of-type(4) {
  color: #e6edf5;
}
.footer-service-list {
  display: grid;
  gap: 6px;
  padding: 0;
  margin: 0;
  list-style: none;
}
.footer-bottom {
  display: grid;
  justify-items: center;
  gap: 12px;
  padding: 20px var(--page-gutter) 26px;
  color: #e8eef5;
  text-align: center;
  border-top: 1px solid rgba(255,255,255,.22);
}
.footer-bottom p {
  max-width: var(--content-max);
  margin: 0;
  font-size: 0.84rem;
}
.back-to-top {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  color: var(--ink);
  background: #e6e8ea;
  border-radius: 4px;
  font-size: 1.45rem;
  line-height: 1;
  text-decoration: none;
}
.back-to-top:hover {
  background: #ffffff;
}
.footer-social {
  display: flex;
  gap: 10px;
  font-weight: 850;
}
.footer-social a {
  color: #ffd36a;
  text-decoration: none;
}
.footer-social a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}
.cookie-banner { position: fixed; right: 18px; bottom: 18px; left: 18px; z-index: 40; display: grid; grid-template-columns: 1fr auto; gap: 18px; max-width: 980px; margin: 0 auto; padding: 18px; color: var(--ink); background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 18px 42px rgba(19,34,56,.18); }
.cookie-banner[hidden] { display: none; }
.cookie-banner strong { color: #0f1f35; }
.cookie-banner p { margin: 4px 0 0; color: #40546b; }
.cookie-actions { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }

@media (max-width: 980px) {
  .header-contact { display: none; }
  .hero, .intro, .benefits, .contact, .service-extra-grid, .service-hero { grid-template-columns: 1fr; }
  .hero { min-height: auto; }
  .steps { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-main { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
  :root { --page-gutter: 24px; }
  .site-header { min-height: 68px; }
  .nav-toggle { display: block; }
  .main-nav { position: absolute; top: 68px; right: var(--page-gutter); left: var(--page-gutter); display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 8px; background: #fff; border: 1px solid var(--line); border-radius: 8px; box-shadow: 0 18px 38px rgba(19,34,56,.14); }
  .main-nav.is-open { display: flex; }
  .main-nav a { padding: 13px 12px; }
  .hero, .section, .contact, .service-extra, .faq-section, .service-hero, .service-body { padding-right: var(--page-gutter); padding-left: var(--page-gutter); }
  h1 { font-size: clamp(2.35rem, 12vw, 3.6rem); }
  h2 { font-size: clamp(1.9rem, 9vw, 2.75rem); }
  .service-grid, .steps, .faq-grid { grid-template-columns: 1fr; }
  .blog-card { grid-template-columns: 1fr; }
  .blog-card-media { min-height: 190px; }
  .hero-media { padding: 12px; }
  .cookie-banner { grid-template-columns: 1fr; }
  .cookie-actions { align-items: stretch; }
  .cookie-actions .button { width: 100%; }
}
