/* ===========================================================
   pages.css — спільні блоки багатосторінкового сайту:
   майстер у hero, sub-hero внутрішніх сторінок, CTA-банер,
   cookie-плашка, карта, легал-типографіка
   =========================================================== */

/* ---------- Майстер у hero ---------- */
.hero__wall { display: flex; align-items: flex-end; justify-content: center; }
.hero__master {
  width: min(300px, 78%);
  display: block; margin: 0 auto;
  filter: drop-shadow(0 20px 26px rgba(12, 47, 44, .22));
  animation: floaty 6s ease-in-out infinite;
}

/* ---------- Sub-hero (внутрішні сторінки) ---------- */
.subhero {
  position: relative;
  background:
    radial-gradient(900px 420px at 88% -20%, rgba(47,217,189,.18), transparent 60%),
    var(--petrol-800);
  color: var(--cloud);
  padding: clamp(40px, 7vw, 84px) 0 clamp(36px, 6vw, 64px);
}
.subhero h1 { color: var(--white); margin: 10px 0 12px; }
.subhero p { color: rgba(244,250,248,.78); max-width: 56ch; font-size: 1.08rem; margin: 0; }
.crumbs { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; font-size: .9rem; color: rgba(244,250,248,.6); }
.crumbs a { color: var(--mint-400); }
.crumbs a:hover { color: var(--mint-300); }
.crumbs span { color: rgba(244,250,248,.4); }

/* ---------- CTA-банер ---------- */
.cta { background: var(--cloud); padding: clamp(40px, 6vw, 72px) 0; }
.cta__inner {
  display: flex; align-items: center; justify-content: space-between; flex-wrap: wrap; gap: 24px;
  background: linear-gradient(135deg, var(--petrol-800), var(--petrol-700));
  border-radius: var(--r-xl);
  padding: clamp(28px, 4vw, 48px);
  color: var(--cloud);
  position: relative; overflow: hidden;
}
.cta__inner::after {
  content: ""; position: absolute; right: -60px; top: -60px; width: 220px; height: 220px;
  background: radial-gradient(circle, rgba(47,217,189,.35), transparent 70%);
}
.cta__inner h2 { color: var(--white); margin-bottom: .3rem; }
.cta__inner p { color: rgba(244,250,248,.78); margin: 0; max-width: 46ch; }
.cta__inner .btn { position: relative; z-index: 1; white-space: nowrap; }

/* ---------- Контакти: карта ---------- */
.map {
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  min-height: 340px;
}
.map iframe { display: block; width: 100%; height: 100%; min-height: 340px; border: 0; filter: grayscale(.2); }

/* ---------- Cookie-плашка ---------- */
.cookie {
  position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 80;
  max-width: 760px; margin: 0 auto;
  display: flex; align-items: center; gap: 18px; flex-wrap: wrap;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  padding: 16px 20px;
  box-shadow: var(--shadow-lg);
}
.cookie p { margin: 0; font-size: .92rem; color: var(--slate); flex: 1 1 280px; }
.cookie a { color: var(--mint-500); font-weight: 700; text-decoration: underline; }
.cookie__actions { display: flex; gap: 10px; flex-wrap: wrap; }
.cookie[hidden] { display: none; }

/* ---------- Легал-сторінки (політики) ---------- */
.legal { padding: clamp(40px, 6vw, 80px) 0; }
.legal__content { max-width: 800px; margin: 0 auto; }
.legal__content h2 { margin: 2em 0 .6em; font-size: 1.4rem; }
.legal__content h2:first-child { margin-top: 0; }
.legal__content h3 { margin: 1.4em 0 .4em; font-size: 1.1rem; }
.legal__content p, .legal__content li { color: var(--slate); }
.legal__content ul { list-style: disc; padding-left: 1.3em; margin: 0 0 1rem; display: grid; gap: 6px; }
.legal__content a { color: var(--mint-500); text-decoration: underline; }
.legal__updated { color: var(--slate); font-size: .9rem; margin-bottom: 2em; padding: 10px 16px; background: var(--cloud); border-radius: var(--r-sm); display: inline-block; }

/* ---------- Футер: легал-посилання ---------- */
.footer__legal { display: flex; gap: 18px; flex-wrap: wrap; }
.footer__legal a { color: rgba(244,250,248,.6); }
.footer__legal a:hover { color: var(--mint-400); }

/* ---------- Активний пункт меню ---------- */
.nav__link[aria-current="page"] { color: var(--petrol-800); background: var(--cloud); }

@media (max-width: 760px) {
  .nav__link[aria-current="page"] { background: transparent; color: var(--mint-500); }
  .cta__inner { flex-direction: column; align-items: flex-start; }
}
