/* =============================================
   GOVABUO — css/style.css
   Mobile-first, Space Grotesk, Coral + Light Grey
   ============================================= */

@import url('https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@300;400;500;600;700&display=swap');

/* === ROOT VARIABLES === */
:root {
  --col-bg: #F5F5F5;
  --col-coral: #FF6B6B;
  --col-coral-dark: #e05555;
  --col-dark: #1a1a2e;
  --col-dark2: #16213e;
  --col-white: #ffffff;
  --col-text: #2d2d2d;
  --col-text-muted: #666;
  --col-border: #e0e0e0;
  --col-card-bg: #fff;
  --radius-card: 16px;
  --radius-img: 24px;
  --radius-btn: 6px;
  --shadow-card: 0 2px 16px rgba(0,0,0,0.07);
  --shadow-hover: 0 8px 32px rgba(255,107,107,0.18);
  --font: 'Space Grotesk', sans-serif;
  --sec-pad: 60px 16px;
  --nav-h: 68px;
}

/* === RESET === */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font);
  background: var(--col-bg);
  color: var(--col-text);
  line-height: 1.6;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }

/* === UTILITY === */
.gova-sec-head { text-align: center; margin-bottom: 40px; }
.gova-sec-head h2 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700;
  color: var(--col-dark);
  letter-spacing: -0.02em;
}
.gova-sec-head--light h2 { color: var(--col-white); }
.gova-sec-line {
  width: 56px; height: 4px;
  background: var(--col-coral);
  border-radius: 2px;
  margin: 12px auto 0;
}
.gova-sec-sub {
  margin-top: 14px;
  color: var(--col-text-muted);
  font-size: 1rem;
  max-width: 560px;
  margin-left: auto; margin-right: auto;
}
.gova-sec-sub--light { color: rgba(255,255,255,0.7); }

/* FADE-IN ANIMATION */
.fade-in {
  opacity: 0;
  transform: translateY(28px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.fade-in.visible {
  opacity: 1;
  transform: translateY(0);
}

/* === NAVBAR === */
.gova-nav {
  position: fixed; top: 0; left: 0; right: 0;
  z-index: 1000;
  background: var(--col-dark);
  height: var(--nav-h);
  border-bottom: 1px solid rgba(255,255,255,0.08);
  transition: box-shadow 0.3s;
}
.gova-nav.scrolled { box-shadow: 0 4px 24px rgba(0,0,0,0.3); }
.gova-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  height: 100%;
}
.gova-nav__links {
  display: none;
  gap: 28px;
  order: 1;
}
.gova-nav__links a {
  color: rgba(255,255,255,0.8);
  font-size: 0.9rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  transition: color 0.2s;
}
.gova-nav__links a:hover { color: var(--col-coral); }
.gova-nav__logo {
  order: 2;
  display: flex;
  align-items: center;
}
.gova-nav__logo img {
  height: 44px;
  width: 44px;
  border-radius: 8px;
  object-fit: cover;
}
.gova-nav__burger {
  order: 3;
  background: none; border: none;
  cursor: pointer;
  display: flex; flex-direction: column;
  gap: 5px; padding: 6px;
}
.gova-nav__burger span {
  display: block;
  width: 24px; height: 2px;
  background: #fff;
  border-radius: 2px;
  transition: all 0.3s;
}
.gova-nav__burger.open span:nth-child(1) { transform: rotate(45deg) translate(5px, 5px); }
.gova-nav__burger.open span:nth-child(2) { opacity: 0; }
.gova-nav__burger.open span:nth-child(3) { transform: rotate(-45deg) translate(5px, -5px); }
/* Mobile nav open */
.gova-nav__links.open {
  display: flex; flex-direction: column;
  position: fixed; top: var(--nav-h); left: 0; right: 0;
  background: var(--col-dark2);
  padding: 24px 20px;
  gap: 20px; z-index: 999;
}

/* === BUTTONS === */
.gova-cta-primary {
  display: inline-block;
  background: var(--col-coral);
  color: #fff;
  font-family: var(--font);
  font-weight: 600;
  font-size: 0.95rem;
  padding: 13px 28px;
  border-radius: var(--radius-btn);
  transition: background 0.2s, transform 0.2s, box-shadow 0.2s;
  border: none; cursor: pointer;
  text-align: center;
}
.gova-cta-primary:hover {
  background: var(--col-coral-dark);
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(255,107,107,0.35);
}
.gova-cta-primary--large { padding: 16px 36px; font-size: 1.05rem; }
.gova-cta-outline {
  display: inline-block;
  border: 1px solid rgba(255,255,255,0.5);
  color: #fff;
  font-family: var(--font);
  font-weight: 500;
  font-size: 0.95rem;
  padding: 13px 28px;
  border-radius: var(--radius-btn);
  transition: border-color 0.2s, color 0.2s;
}
.gova-cta-outline:hover {
  border-color: var(--col-coral);
  color: var(--col-coral);
}

/* === WAVES === */
.gova-wave { line-height: 0; display: block; }
.gova-wave svg { width: 100%; display: block; }

/* === HERO === */
.gova-hero {
  background: var(--col-dark);
  padding: calc(var(--nav-h) + 40px) 16px 60px;
  min-height: 100vh;
  display: flex; align-items: center;
}
.gova-hero__grid {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 40px;
  align-items: center;
}
.gova-hero__photo-col { position: relative; width: 100%; max-width: 520px; }
.gova-hero__img-frame {
  position: relative;
  border-radius: var(--radius-img);
  overflow: hidden;
}
.gova-hero__img-frame img {
  width: 100%;
  height: 360px;
  object-fit: cover;
  border-radius: var(--radius-img);
  display: block;
}
.gova-hero__badge {
  position: absolute;
  bottom: 20px; right: -10px;
  background: var(--col-coral);
  border-radius: 12px;
  padding: 12px 16px;
  display: flex; align-items: center; gap: 8px;
  box-shadow: 0 4px 16px rgba(255,107,107,0.4);
}
.gova-hero__badge-num { font-size: 1.8rem; font-weight: 700; color: #fff; line-height: 1; }
.gova-hero__badge-txt { font-size: 0.78rem; color: rgba(255,255,255,0.9); line-height: 1.3; }
.gova-hero__accent-line {
  position: absolute;
  bottom: -16px; left: 24px;
  width: 60%; height: 3px;
  background: var(--col-coral);
  border-radius: 2px;
}
.gova-hero__text-col { color: #fff; text-align: center; }
.gova-hero__tag {
  display: inline-block;
  border: 1px solid rgba(255,107,107,0.5);
  color: var(--col-coral);
  font-size: 0.82rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 5px 14px;
  border-radius: 4px;
  margin-bottom: 20px;
}
.gova-hero__title {
  font-size: clamp(2rem, 6vw, 3.2rem);
  font-weight: 700;
  line-height: 1.15;
  letter-spacing: -0.03em;
  margin-bottom: 20px;
}
.gova-hero__title em {
  font-style: normal;
  color: var(--col-coral);
  position: relative;
}
.gova-hero__sub {
  font-size: 1.05rem;
  color: rgba(255,255,255,0.72);
  margin-bottom: 32px;
  max-width: 440px;
  margin-left: auto; margin-right: auto;
}
.gova-hero__cta-row {
  display: flex; flex-wrap: wrap; gap: 12px;
  justify-content: center; margin-bottom: 36px;
}
.gova-hero__stats {
  display: flex; flex-wrap: wrap;
  justify-content: center;
  gap: 16px;
  border-top: 1px solid rgba(255,255,255,0.12);
  padding-top: 28px;
}
.gova-hero__stat { text-align: center; }
.gova-hero__stat strong { display: block; font-size: 1.5rem; font-weight: 700; color: #fff; }
.gova-hero__stat span { font-size: 0.8rem; color: rgba(255,255,255,0.5); }
.gova-hero__stat-sep {
  width: 1px; background: rgba(255,255,255,0.15);
  align-self: stretch; display: none;
}

/* === TRUST === */
.gova-trust { background: var(--col-dark); padding: var(--sec-pad); }
.gova-trust__inner { max-width: 1200px; margin: 0 auto; }
.gova-trust__inner .gova-sec-head h2 { color: #fff; }
.gova-trust__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.gova-trust__item {
  text-align: center;
  padding: 24px 16px;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: var(--radius-card);
  background: rgba(255,255,255,0.04);
  transition: background 0.2s, border-color 0.2s;
}
.gova-trust__item:hover {
  background: rgba(255,107,107,0.08);
  border-color: rgba(255,107,107,0.3);
}
.gova-trust__icon { display: flex; justify-content: center; margin-bottom: 12px; }
.gova-trust__icon svg { width: 44px; height: 44px; }
.gova-trust__num { font-size: 1.8rem; font-weight: 700; color: #fff; line-height: 1; }
.gova-trust__lbl { font-size: 0.82rem; color: rgba(255,255,255,0.55); margin-top: 4px; }

/* === PROBLEM-SOLUTION === */
.gova-problem { background: var(--col-white); padding: var(--sec-pad); }
.gova-problem__inner { max-width: 1000px; margin: 0 auto; }
.gova-problem__cols { display: flex; flex-direction: column; gap: 20px; }
.gova-problem__side {
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  padding: 28px 24px;
  background: #fff;
}
.gova-problem__side--bad { border-color: #ffd5d5; background: #fff8f8; }
.gova-problem__side--good { border-color: #d5f5e3; background: #f8fff8; }
.gova-problem__side-head {
  display: flex; align-items: center; gap: 10px;
  font-weight: 600; font-size: 1.05rem;
  margin-bottom: 18px;
  color: var(--col-dark);
}
.gova-problem__list li {
  padding: 8px 0;
  border-bottom: 1px solid var(--col-border);
  font-size: 0.95rem;
  color: var(--col-text);
  padding-left: 14px;
  position: relative;
}
.gova-problem__list li::before {
  content: '';
  position: absolute; left: 0; top: 50%;
  transform: translateY(-50%);
  width: 5px; height: 5px;
  border-radius: 50%;
  background: var(--col-coral);
}
.gova-problem__list li:last-child { border-bottom: none; }

/* === ADVANTAGES === */
.gova-advantages { background: var(--col-bg); padding: var(--sec-pad); }
.gova-advantages__inner { max-width: 1200px; margin: 0 auto; }
.gova-advantages__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 16px;
}
.gova-adv-card {
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  padding: 24px 20px;
  background: var(--col-card-bg);
  text-align: center;
  transition: box-shadow 0.25s, transform 0.25s;
}
.gova-adv-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
.gova-adv-card__icon { display: flex; justify-content: center; margin-bottom: 16px; }
.gova-adv-card__icon svg { width: 48px; height: 48px; }
.gova-adv-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 8px; }
.gova-adv-card p { font-size: 0.88rem; color: var(--col-text-muted); line-height: 1.55; }

/* === SERVICES === */
.gova-services { background: var(--col-white); padding: var(--sec-pad); }
.gova-services__inner { max-width: 1200px; margin: 0 auto; }
.gova-services__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
}
.gova-svc-card {
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  overflow: hidden;
  background: var(--col-card-bg);
  transition: box-shadow 0.25s, transform 0.25s;
}
.gova-svc-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
.gova-svc-card__img { height: 200px; overflow: hidden; }
.gova-svc-card__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  border-radius: 0;
  transition: transform 0.4s;
}
.gova-svc-card:hover .gova-svc-card__img img { transform: scale(1.04); }
.gova-svc-card__body { padding: 20px; }
.gova-svc-card__body h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 8px; }
.gova-svc-card__body p { font-size: 0.88rem; color: var(--col-text-muted); margin-bottom: 14px; }
.gova-svc-card__price { font-weight: 600; font-size: 1rem; color: var(--col-coral); }
.gova-svc-card__price strong { font-size: 1.15rem; }

/* === PRICES TABLE === */
.gova-prices { background: var(--col-dark); padding: var(--sec-pad); }
.gova-prices__inner { max-width: 900px; margin: 0 auto; }
.gova-prices__table-wrap { overflow-x: auto; margin-bottom: 20px; }
.gova-prices__table {
  width: 100%; border-collapse: collapse;
  background: rgba(255,255,255,0.04);
  border-radius: 12px;
  overflow: hidden;
  font-size: 0.9rem;
}
.gova-prices__table th, .gova-prices__table td {
  padding: 14px 16px;
  text-align: left;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  color: rgba(255,255,255,0.8);
}
.gova-prices__table thead th {
  background: rgba(255,255,255,0.06);
  font-weight: 600; color: #fff;
}
.gova-prices__th-ours {
  background: rgba(255,107,107,0.2) !important;
  color: var(--col-coral) !important;
}
.gova-prices__td-ours {
  color: var(--col-coral) !important;
  font-weight: 600;
}
.gova-prices__td-zero { font-weight: 700; font-size: 1.05rem; }
.gova-prices__table tr:last-child td { border-bottom: none; }
.gova-prices__note {
  font-size: 0.8rem;
  color: rgba(255,255,255,0.4);
  text-align: center;
  margin-top: 12px;
}

/* === HOW IT WORKS === */
.gova-how { background: var(--col-white); padding: var(--sec-pad); }
.gova-how__inner { max-width: 800px; margin: 0 auto; }
.gova-how__steps { display: flex; flex-direction: column; gap: 20px; }
.gova-how__step {
  display: flex; gap: 20px; align-items: flex-start;
  padding: 20px;
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  background: var(--col-card-bg);
  transition: box-shadow 0.25s;
}
.gova-how__step:hover { box-shadow: var(--shadow-card); }
.gova-how__step-num {
  font-size: 2rem; font-weight: 700;
  color: var(--col-coral);
  min-width: 52px; line-height: 1;
  opacity: 0.6;
}
.gova-how__step-body h3 { font-size: 1rem; font-weight: 600; margin-bottom: 6px; }
.gova-how__step-body p { font-size: 0.88rem; color: var(--col-text-muted); }

/* === CASES === */
.gova-cases { background: var(--col-bg); padding: var(--sec-pad); }
.gova-cases__inner { max-width: 1200px; margin: 0 auto; }
.gova-cases__grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
.gova-case-item {
  border-radius: var(--radius-card);
  overflow: hidden;
  position: relative;
  cursor: pointer;
}
.gova-case-item__img {
  position: relative;
  height: 260px;
  overflow: hidden;
  border-radius: var(--radius-card);
}
.gova-case-item__img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 0.4s;
  border-radius: var(--radius-img);
}
.gova-case-item:hover .gova-case-item__img img { transform: scale(1.06); }
.gova-case-item__overlay {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(transparent, rgba(26,26,46,0.92));
  padding: 40px 20px 20px;
  border-radius: 0 0 var(--radius-img) var(--radius-img);
}
.gova-case-item__overlay span {
  display: block; font-size: 0.78rem;
  color: var(--col-coral); margin-bottom: 4px;
  font-weight: 500;
}
.gova-case-item__overlay strong {
  display: block; font-size: 1rem;
  color: #fff; font-weight: 600;
}

/* === CALCULATOR === */
.gova-calc { background: var(--col-white); padding: var(--sec-pad); }
.gova-calc__inner { max-width: 860px; margin: 0 auto; }
.gova-calc__box {
  display: flex; flex-direction: column; gap: 28px;
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  padding: 28px 24px;
  background: var(--col-card-bg);
}
.gova-calc__form-area { display: flex; flex-direction: column; gap: 20px; }
.gova-calc__row { display: flex; flex-direction: column; gap: 8px; }
.gova-calc__row label { font-weight: 600; font-size: 0.92rem; color: var(--col-dark); }
.gova-calc__row select {
  font-family: var(--font);
  padding: 11px 14px;
  border: 1px solid var(--col-border);
  border-radius: var(--radius-btn);
  font-size: 0.92rem;
  background: var(--col-bg);
  color: var(--col-text);
  cursor: pointer;
  outline: none;
}
.gova-calc__row select:focus { border-color: var(--col-coral); }
.gova-calc__slider-wrap { display: flex; align-items: center; gap: 16px; }
.gova-calc__slider-wrap input[type=range] {
  flex: 1;
  accent-color: var(--col-coral);
  height: 4px;
  cursor: pointer;
}
#calc-area-val {
  font-weight: 600; color: var(--col-coral);
  font-size: 1rem; min-width: 50px;
}
.gova-calc__result-area {
  text-align: center;
  background: var(--col-dark);
  border-radius: 12px;
  padding: 28px 20px;
}
.gova-calc__result-label {
  font-size: 0.85rem;
  color: rgba(255,255,255,0.55);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-bottom: 8px;
}
.gova-calc__result-val {
  font-size: 2.4rem;
  font-weight: 700;
  color: var(--col-coral);
  margin-bottom: 12px;
}
.gova-calc__result-note {
  font-size: 0.78rem;
  color: rgba(255,255,255,0.4);
  margin-bottom: 20px;
  line-height: 1.5;
}

/* === ABOUT === */
.gova-about { background: var(--col-dark); padding: var(--sec-pad); }
.gova-about__inner { max-width: 1100px; margin: 0 auto; }
.gova-about__grid { display: flex; flex-direction: column; gap: 36px; align-items: center; }
.gova-about__text { color: rgba(255,255,255,0.85); order: 2; }
.gova-about__lead {
  font-size: 1.15rem; font-weight: 500;
  color: #fff; margin-bottom: 16px; line-height: 1.5;
}
.gova-about__text p { margin-bottom: 14px; font-size: 0.95rem; line-height: 1.65; }
.gova-about__vals { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 20px; }
.gova-about__val {
  display: flex; align-items: center; gap: 6px;
  font-size: 0.9rem; font-weight: 500;
  color: rgba(255,255,255,0.8);
  border: 1px solid rgba(255,107,107,0.3);
  padding: 6px 14px; border-radius: 6px;
}
.gova-about__img-wrap {
  position: relative; order: 1;
  width: 100%; max-width: 480px;
}
.gova-about__img-wrap img {
  width: 100%; height: 300px;
  object-fit: cover;
  border-radius: var(--radius-img);
  display: block;
}
.gova-about__img-deco {
  position: absolute;
  bottom: -12px; right: -12px;
  width: 100%; height: 100%;
  border: 2px solid rgba(255,107,107,0.4);
  border-radius: var(--radius-img);
  pointer-events: none; z-index: -1;
}

/* === TIMELINE === */
.gova-timeline { background: var(--col-bg); padding: var(--sec-pad); }
.gova-timeline__inner { max-width: 760px; margin: 0 auto; }
.gova-timeline__track { display: flex; flex-direction: column; gap: 0; position: relative; padding-left: 32px; }
.gova-timeline__track::before {
  content: '';
  position: absolute; left: 8px; top: 0; bottom: 0;
  width: 2px; background: var(--col-border);
}
.gova-tl-item { position: relative; padding-bottom: 28px; }
.gova-tl-item__dot {
  position: absolute; left: -28px; top: 4px;
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--col-coral);
  border: 2px solid var(--col-bg);
  z-index: 1;
}
.gova-tl-item__year {
  font-size: 1.05rem; font-weight: 700;
  color: var(--col-coral); margin-bottom: 4px;
}
.gova-tl-item__text { font-size: 0.9rem; color: var(--col-text-muted); line-height: 1.55; }

/* === TEAM === */
.gova-team { background: var(--col-white); padding: var(--sec-pad); }
.gova-team__inner { max-width: 1100px; margin: 0 auto; }
.gova-team__grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
.gova-team-card {
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  padding: 28px 20px;
  text-align: center;
  background: var(--col-card-bg);
  transition: box-shadow 0.25s, transform 0.25s;
}
.gova-team-card:hover {
  box-shadow: var(--shadow-hover);
  transform: translateY(-4px);
}
.gova-team-card__avatar { display: flex; justify-content: center; margin-bottom: 14px; }
.gova-team-card h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 4px; }
.gova-team-card__role {
  font-size: 0.82rem; color: var(--col-coral);
  font-weight: 500; margin-bottom: 10px;
}
.gova-team-card p { font-size: 0.88rem; color: var(--col-text-muted); }

/* === REVIEWS === */
.gova-reviews { background: var(--col-bg); padding: var(--sec-pad); }
.gova-reviews__inner { max-width: 1100px; margin: 0 auto; }
.gova-reviews__masonry {
  columns: 1;
  column-gap: 20px;
}
.gova-review-block {
  break-inside: avoid;
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  padding: 24px 20px;
  background: var(--col-card-bg);
  margin-bottom: 20px;
  transition: box-shadow 0.25s;
}
.gova-review-block:hover { box-shadow: var(--shadow-card); }
.gova-review-block__stars { display: flex; gap: 3px; margin-bottom: 12px; }
.gova-review-block p {
  font-size: 0.9rem; color: var(--col-text-muted);
  margin-bottom: 12px; line-height: 1.6;
}
.gova-review-block__author {
  display: flex; align-items: center; gap: 10px;
  margin-top: 14px; border-top: 1px solid var(--col-border);
  padding-top: 12px;
}
.gova-review-block__author strong { display: block; font-size: 0.9rem; }
.gova-review-block__author span { font-size: 0.78rem; color: var(--col-text-muted); }

/* === FAQ === */
.gova-faq { background: var(--col-dark); padding: var(--sec-pad); }
.gova-faq__inner { max-width: 1100px; margin: 0 auto; }
.gova-faq__cols { display: flex; flex-direction: column; gap: 16px; }
.gova-faq__col { display: flex; flex-direction: column; gap: 16px; }
.gova-faq-item {
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 12px;
  padding: 20px 20px 18px;
  background: rgba(255,255,255,0.04);
}
.gova-faq-item h3 {
  font-size: 0.97rem; font-weight: 600;
  color: #fff; margin-bottom: 8px;
}
.gova-faq-item p { font-size: 0.88rem; color: rgba(255,255,255,0.6); line-height: 1.6; }

/* === CTA BANNER === */
.gova-ctabanner {
  background: var(--col-coral);
  padding: 70px 20px;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.gova-ctabanner__inner { position: relative; z-index: 1; max-width: 660px; margin: 0 auto; }
.gova-ctabanner__deco {
  position: absolute; top: -60px; right: -60px;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: rgba(255,255,255,0.1);
  pointer-events: none;
}
.gova-ctabanner__sup {
  font-size: 0.82rem; letter-spacing: 0.08em;
  text-transform: uppercase; color: rgba(255,255,255,0.8);
  margin-bottom: 12px;
}
.gova-ctabanner__title {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 700; color: #fff;
  margin-bottom: 12px; letter-spacing: -0.02em;
}
.gova-ctabanner__sub {
  font-size: 1rem; color: rgba(255,255,255,0.85);
  margin-bottom: 28px;
}
.gova-ctabanner .gova-cta-primary {
  background: #fff;
  color: var(--col-coral);
}
.gova-ctabanner .gova-cta-primary:hover {
  background: var(--col-dark);
  color: #fff;
}

/* === CONTACTS === */
.gova-contacts { background: var(--col-bg); padding: var(--sec-pad); }
.gova-contacts__inner { max-width: 900px; margin: 0 auto; }
.gova-contacts__grid { display: grid; grid-template-columns: 1fr; gap: 20px; }
.gova-contacts__item {
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: 8px;
  padding: 28px 20px;
  border: 1px solid var(--col-border);
  border-radius: var(--radius-card);
  background: var(--col-card-bg);
  transition: box-shadow 0.25s;
}
.gova-contacts__item:hover { box-shadow: var(--shadow-card); }
.gova-contacts__icon svg { width: 48px; height: 48px; }
.gova-contacts__item h3 { font-size: 0.95rem; font-weight: 600; color: var(--col-dark); }
.gova-contacts__item a {
  font-size: 1.05rem; font-weight: 600; color: var(--col-coral);
}
.gova-contacts__item span { font-size: 0.85rem; color: var(--col-text-muted); }

/* === FOOTER === */
.gova-footer {
  background: var(--col-dark2);
  padding: 50px 20px 30px;
}
.gova-footer__inner {
  max-width: 1200px; margin: 0 auto;
  display: flex; flex-direction: column; gap: 32px; align-items: center;
  text-align: center;
}
.gova-footer__logo {
  width: 64px; height: 64px;
  border-radius: 12px; object-fit: cover;
  margin: 0 auto 12px;
  display: block;
}
.gova-footer__tagline {
  font-size: 0.88rem; color: rgba(255,255,255,0.5);
  font-style: italic; max-width: 260px; margin: 0 auto 8px;
}
.gova-footer__copy { font-size: 0.78rem; color: rgba(255,255,255,0.3); }
.gova-footer__nav {
  display: flex; flex-wrap: wrap;
  justify-content: center; gap: 12px 20px;
}
.gova-footer__nav a {
  font-size: 0.88rem; color: rgba(255,255,255,0.55);
  transition: color 0.2s;
}
.gova-footer__nav a:hover { color: var(--col-coral); }
.gova-footer__contacts-col {
  display: flex; flex-direction: column;
  align-items: center; gap: 8px;
}
.gova-footer__contacts-col a {
  font-size: 0.92rem; color: rgba(255,255,255,0.7);
  transition: color 0.2s;
}
.gova-footer__contacts-col a:hover { color: var(--col-coral); }
.gova-footer__contacts-col span {
  font-size: 0.82rem; color: rgba(255,255,255,0.4);
  text-align: center;
}
.gova-footer__legal-link {
  font-size: 0.78rem !important;
  color: rgba(255,255,255,0.3) !important;
  text-decoration: underline;
  cursor: pointer;
}

/* === COOKIE BANNER === */
.gova-cookies {
  position: fixed; bottom: 20px; left: 16px; right: 16px;
  background: var(--col-dark);
  border: 1px solid rgba(255,107,107,0.3);
  border-radius: 14px;
  padding: 20px;
  z-index: 2000;
  display: none;
  max-width: 580px;
  margin: 0 auto;
  box-shadow: 0 8px 32px rgba(0,0,0,0.35);
}
.gova-cookies.show { display: block; }
.gova-cookies__text strong {
  display: block; font-size: 0.95rem; color: #fff;
  margin-bottom: 6px;
}
.gova-cookies__text p { font-size: 0.82rem; color: rgba(255,255,255,0.6); margin-bottom: 14px; }
.gova-cookies__text a { color: var(--col-coral); text-decoration: underline; }
.gova-cookies__btns { display: flex; gap: 10px; flex-wrap: wrap; }
.gova-cookies__accept {
  background: var(--col-coral); color: #fff;
  border: none; border-radius: var(--radius-btn);
  padding: 10px 20px; font-family: var(--font);
  font-weight: 600; font-size: 0.88rem; cursor: pointer;
  transition: background 0.2s;
}
.gova-cookies__accept:hover { background: var(--col-coral-dark); }
.gova-cookies__reject {
  background: transparent; color: rgba(255,255,255,0.6);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: var(--radius-btn);
  padding: 10px 20px; font-family: var(--font);
  font-size: 0.88rem; cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
}
.gova-cookies__reject:hover { border-color: rgba(255,255,255,0.5); color: #fff; }

/* === MODAL === */
.gova-modal {
  display: none; position: fixed; inset: 0; z-index: 3000;
  background: rgba(0,0,0,0.65);
  align-items: center; justify-content: center;
  padding: 20px;
}
.gova-modal.open { display: flex; }
.gova-modal__box {
  background: var(--col-white);
  border-radius: 16px;
  padding: 36px 28px;
  max-width: 560px; width: 100%;
  position: relative;
  max-height: 80vh; overflow-y: auto;
}
.gova-modal__box h2 { font-size: 1.3rem; margin-bottom: 16px; color: var(--col-dark); }
.gova-modal__box p { font-size: 0.9rem; color: var(--col-text-muted); margin-bottom: 12px; line-height: 1.6; }
.gova-modal__close {
  position: absolute; top: 14px; right: 16px;
  background: none; border: none;
  font-size: 1.6rem; cursor: pointer;
  color: var(--col-text-muted); line-height: 1;
}
.gova-modal__close:hover { color: var(--col-coral); }

/* =============================================
   TABLET: min-width 640px
   ============================================= */
@media (min-width: 640px) {
  :root { --sec-pad: 80px 24px; }

  .gova-trust__grid { grid-template-columns: repeat(3, 1fr); }
  .gova-advantages__grid { grid-template-columns: repeat(2, 1fr); }
  .gova-services__grid { grid-template-columns: repeat(2, 1fr); }
  .gova-cases__grid { grid-template-columns: repeat(2, 1fr); }
  .gova-team__grid { grid-template-columns: repeat(2, 1fr); }
  .gova-contacts__grid { grid-template-columns: repeat(3, 1fr); }
  .gova-reviews__masonry { columns: 2; }
  .gova-faq__cols { flex-direction: row; gap: 24px; }
  .gova-faq__col { flex: 1; }
  .gova-problem__cols { flex-direction: row; }
  .gova-hero__stat-sep { display: block; }
  .gova-calc__box { flex-direction: row; }
  .gova-calc__form-area { flex: 1.2; }
  .gova-calc__result-area { flex: 1; }
}

/* =============================================
   DESKTOP: min-width 1024px
   ============================================= */
@media (min-width: 1024px) {
  .gova-nav__links { display: flex; }
  .gova-nav__burger { display: none; }

  .gova-hero__grid {
    flex-direction: row;
    gap: 60px;
    align-items: center;
  }
  .gova-hero__photo-col { flex: 1; max-width: none; }
  .gova-hero__img-frame img { height: 500px; }
  .gova-hero__text-col { flex: 1; text-align: left; }
  .gova-hero__cta-row { justify-content: flex-start; }
  .gova-hero__stats { justify-content: flex-start; }
  .gova-hero__sub { margin-left: 0; margin-right: 0; }

  .gova-advantages__grid { grid-template-columns: repeat(3, 1fr); }
  .gova-services__grid { grid-template-columns: repeat(3, 1fr); }
  .gova-cases__grid { grid-template-columns: repeat(3, 1fr); }
  .gova-team__grid { grid-template-columns: repeat(4, 1fr); }
  .gova-trust__grid { grid-template-columns: repeat(6, 1fr); }

  .gova-about__grid { flex-direction: row; gap: 60px; align-items: center; }
  .gova-about__text { order: 1; flex: 1; }
  .gova-about__img-wrap { order: 2; flex: 1; max-width: none; }
  .gova-about__img-wrap img { height: 400px; }

  .gova-footer__inner {
    flex-direction: row;
    align-items: flex-start;
    text-align: left;
    justify-content: space-between;
  }
  .gova-footer__logo { margin: 0 0 12px; }
  .gova-footer__tagline { margin: 0 0 8px; }
  .gova-footer__contacts-col { align-items: flex-start; }
  .gova-footer__nav { justify-content: flex-start; flex-direction: column; gap: 10px; }

  .gova-hero { min-height: 100vh; }
}

@media (min-width: 1200px) {
  .gova-hero__img-frame img { height: 560px; }
}
