/* ============================================================
   Diatlov — глобальні стилі
   Контейнер: --maxw 1440px зовнішній, --pad-x автоматично
   дає 1200px контентної зони при viewport ≥ 1440px.
   ============================================================ */
:root{
  --bg:#EFEAE1; --bg-soft:#E4D8C3; --bg-gradient: #E9E0CE; --white:#FCFBF8;
  --graphite:#2B2D33; --graphite-deep:#212329;
  --gold:#C5A35B; --gold-soft:#D8BC7E;
  --text:#262521; --text-2:#6E6A62; --muted:#9A958C;
  --on-dark:#EDEAE3; --muted-dark:#9CA0A6;
  --line:rgba(38,37,33,.10); --card-line:rgba(38,37,33,.06);
  --shadow:0 18px 40px -24px rgba(43,45,51,.25);
  --shadow-sm:0 8px 20px -14px rgba(43,45,51,.22);
  --shadow-lg:0 30px 70px -30px rgba(43,45,51,.35);
  --gold-shadow:0 14px 30px -14px rgba(197,163,91,.7);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',system-ui,sans-serif;
  /* 1440px зовнішній фрейм; --pad-x = 8.33vw → при 1440px viewport
     дає рівно 120px паддінг з кожного боку = 1200px контент */
  --maxw:1440px;   /* зовнішня рамка */
  --content:1200px; /* контентна зона — однакова в усіх секціях */
  --pad-x:clamp(20px,8.33vw,120px);
  --section-y:clamp(72px,9vw,120px);
  --r-card:18px; --r-pill:999px;
  --ease:cubic-bezier(.22,.61,.36,1); --tr:.18s ease;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{font-family:var(--sans);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;overflow-x:hidden;}
html{scroll-behavior:smooth;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}

/* ---- shared type ---- */
.eyebrow{font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);display:inline-flex;align-items:center;gap:11px;margin-bottom:14px;}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);flex:0 0 auto;opacity:.85;}
.h2{font-family:var(--serif);font-size:clamp(30px,4vw,46px);font-weight:600;line-height:1.12;
  color:var(--text);margin:0;letter-spacing:-.01em;}
.body{font-family:var(--sans);font-size:16px;line-height:1.75;color:var(--text-2);}

/* Section: 1440 outer → 1200 content */
.section{max-width:var(--maxw);margin:0 auto;padding:var(--section-y) var(--pad-x);}
.section--soft{background:var(--bg-gradient);max-width:none;}
.section--soft > *{max-width:var(--content);margin-left:auto;margin-right:auto;}
.section__head{margin-bottom:48px;max-width:680px;}
.section__head--center{text-align:center;margin-left:auto;margin-right:auto;}
.section__head--center .eyebrow{justify-content:center;}

/* ---- buttons ---- */
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--sans);font-size:14px;
  font-weight:500;letter-spacing:.02em;padding:14px 26px;border-radius:var(--r-pill);
  border:1px solid transparent;cursor:pointer;transition:transform var(--tr),
  box-shadow var(--tr),background var(--tr),color var(--tr),border-color var(--tr);
  white-space:nowrap;text-decoration:none;}
.btn:hover{transform:translateY(-2px) scale(1.015);box-shadow:var(--shadow-sm);}
.btn:active{transform:scale(.99);}
.btn--gold{background:var(--gold);color:var(--graphite-deep);box-shadow:var(--gold-shadow);}
.btn--gold:hover{background:var(--gold-soft);box-shadow:0 20px 38px -16px rgba(197,163,91,.85);}
.btn--dark{background:var(--graphite);color:var(--on-dark);}
.btn--dark:hover{background:var(--graphite-deep);}
.btn--outline{background:transparent;color:#9c7c34;border-color:rgba(197,163,91,.55);}
.btn--outline:hover{background:rgba(197,163,91,.1);border-color:var(--gold);}
.btn--ghost-light{background:transparent;border-color:rgba(237,234,227,.4);color:var(--on-dark);}
.btn--ghost-light:hover{background:rgba(237,234,227,.1);}
.btn--block{width:100%;justify-content:center;}

/* ---- wordmark ---- */
.wordmark{display:inline-flex;align-items:center;gap:12px;line-height:1;}
.wordmark__logo{display:inline-flex;}
.wordmark__logo img{height:40px;width:auto;display:block;}
.wordmark__txt{display:inline-flex;flex-direction:column;gap:4px;}
.wordmark__name{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.05em;
  font-size:17px;line-height:1;color:var(--graphite-deep);white-space:nowrap;}
.wordmark__sub{font-family:var(--sans);font-weight:600;text-transform:uppercase;letter-spacing:.1em;
  font-size:9px;color:var(--text-2);white-space:nowrap;}
.wordmark--light{flex-direction:column;align-items:flex-start;gap:4px;}
.wordmark--light .wordmark__name{color:var(--on-dark);}
.wordmark--light .wordmark__sub{color:var(--gold);letter-spacing:.1em;}

/* ============================================================ NAV */
.nav{position:sticky;top:0;z-index:50;background:rgba(239,234,225,0);
  transition:background .3s,box-shadow .3s,border-color .3s;border-bottom:1px solid transparent;}
.nav--scrolled{background:rgba(245,241,234,.88);backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);box-shadow:0 6px 24px -22px rgba(43,45,51,.5);}
.nav__inner{max-width:var(--maxw);margin:0 auto;padding:18px var(--pad-x);
  display:flex;align-items:center;justify-content:space-between;gap:24px;}
/* десктоп: обгортка меню «прозора» — діти течуть у flex nav__inner */
.nav__menu{display:contents;}
.nav__toggle{display:none;}
.nav__lang-bar{display:none;}
.nav__links{display:flex;gap:30px;}
.nav__links{align-items:center;}
.nav__links a{font-size:14px;font-weight:500;color:var(--text);transition:color var(--tr);letter-spacing:.01em;}
.nav__links a:hover{color:var(--gold);}
/* Випадаюче меню послуг */
.nav__has-drop{position:relative;}
.nav__drop-trigger{display:inline-flex;align-items:center;gap:5px;cursor:pointer;}
.nav__drop-trigger svg{transition:transform var(--tr);}
.nav__has-drop:hover .nav__drop-trigger svg,.nav__has-drop:focus-within .nav__drop-trigger svg{transform:rotate(180deg);}
.nav__drop{position:absolute;top:100%;left:50%;transform:translate(-50%,8px);min-width:288px;
  background:var(--white);border:1px solid var(--card-line);border-radius:14px;box-shadow:var(--shadow-lg);
  padding:10px;display:flex;flex-direction:column;gap:1px;
  opacity:0;visibility:hidden;transition:opacity .2s var(--ease),transform .2s var(--ease),visibility .2s;z-index:60;}
.nav__drop::before{content:"";position:absolute;top:-12px;left:0;right:0;height:12px;}
.nav__has-drop:hover .nav__drop,.nav__has-drop:focus-within .nav__drop{opacity:1;visibility:visible;transform:translate(-50%,6px);}
.nav__drop a{font-size:14px;font-weight:500;padding:10px 14px;border-radius:9px;color:var(--text);
  transition:background var(--tr),color var(--tr);white-space:nowrap;}
.nav__drop a:hover{background:rgba(197,163,91,.1);color:var(--gold);}
.nav__right{display:flex;align-items:center;gap:18px;}
.lang{display:flex;align-items:center;gap:2px;border:1px solid var(--line);border-radius:var(--r-pill);
  padding:3px;background:rgba(252,251,248,.6);}
.lang__btn{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.04em;color:var(--text-2);
  background:none;border:none;padding:6px 13px;border-radius:var(--r-pill);cursor:pointer;
  transition:all var(--tr);text-decoration:none;}
.lang__btn:hover{color:var(--text);}
.lang__btn.is-active{background:var(--graphite);color:var(--on-dark);}

/* ============================================================ FOOTER */
.footer{background:var(--graphite);color:var(--on-dark);margin-top:0;}
.footer__inner{max-width:var(--maxw);margin:0 auto;padding:clamp(48px,6vw,72px) var(--pad-x) 40px;
  display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px;}
.footer__tagline{font-size:14px;line-height:1.65;color:var(--muted-dark);margin:20px 0 0;max-width:360px;}
.footer__col h4{font-family:var(--sans);font-size:12px;font-weight:600;letter-spacing:.12em;
  text-transform:uppercase;color:var(--gold);margin:0 0 18px;}
.footer__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px;}
.footer__col a{font-size:14px;color:var(--muted-dark);transition:color var(--tr);}
.footer__col a:hover{color:var(--on-dark);}
.footer__bar{border-top:1px solid rgba(237,234,227,.12);padding:20px var(--pad-x);
  font-size:12.5px;color:var(--muted-dark);max-width:var(--maxw);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;}
.footer__legal{display:flex;gap:18px;flex-wrap:wrap;}
.footer__legal a{color:var(--muted-dark);transition:color var(--tr);}
.footer__legal a:hover{color:var(--gold-soft);}
.footer__copy{color:var(--muted-dark);}
@media(max-width:640px){.footer__bar{flex-direction:column;text-align:center;}.footer__legal{justify-content:center;}}

/* Соцмережі */
.socials{display:flex;flex-wrap:wrap;gap:10px;margin-top:22px;}
.socials__link{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;
  border-radius:11px;background:rgba(237,234,227,.07);border:1px solid rgba(237,234,227,.16);color:var(--on-dark);
  transition:background var(--tr),color var(--tr),border-color var(--tr),transform var(--tr);}
.socials__link:hover{background:var(--gold);border-color:var(--gold);color:var(--graphite-deep);transform:translateY(-2px);}
.socials--light .socials__link{background:rgba(197,163,91,.08);border-color:rgba(197,163,91,.3);color:var(--gold);}
.socials--light .socials__link:hover{background:var(--gold);border-color:var(--gold);color:var(--graphite-deep);}

/* Cookie-банер */
.cookie-bar{position:fixed;left:clamp(12px,3vw,24px);right:clamp(12px,3vw,24px);bottom:clamp(12px,3vw,24px);
  z-index:9000;display:flex;align-items:center;gap:18px;flex-wrap:wrap;justify-content:center;
  background:var(--graphite);color:var(--on-dark);border:1px solid rgba(237,234,227,.12);border-radius:16px;
  padding:15px 22px;box-shadow:var(--shadow-lg);max-width:780px;margin:0 auto;
  opacity:0;transform:translateY(16px);transition:opacity .3s var(--ease),transform .3s var(--ease);}
.cookie-bar[hidden]{display:none;}
.cookie-bar.is-visible{opacity:1;transform:none;}
.cookie-bar__text{display:flex;align-items:flex-start;gap:11px;margin:0;font-size:13.5px;line-height:1.55;color:var(--muted-dark);}
.cookie-bar__text svg{color:var(--gold);flex:0 0 auto;margin-top:1px;}
.cookie-bar__text a{color:var(--gold-soft);text-decoration:underline;}
.cookie-bar__accept{flex:0 0 auto;padding:11px 24px;font-size:13px;}
@media(max-width:560px){.cookie-bar{flex-direction:column;align-items:stretch;text-align:left;}.cookie-bar__accept{width:100%;justify-content:center;}}

/* reCAPTCHA v3 — ховаємо плаваючий бейдж (атрибуція Google — у формі) */
.grecaptcha-badge{visibility:hidden!important;}
.recaptcha-note{font-size:11px;line-height:1.5;color:var(--muted);margin:14px 0 0;}
.recaptcha-note a{color:var(--text-2);text-decoration:underline;}
.recaptcha-note a:hover{color:var(--gold);}

/* ============================================================ FORM (Contact Form 7) — underline */
.ds-form .wpcf7{font-family:var(--sans);}
.ds-form .field{display:block;margin-bottom:24px;}
.ds-form .field__lbl{display:block;font-size:11px;font-weight:600;letter-spacing:.16em;
  color:var(--muted);margin-bottom:9px;text-transform:uppercase;}
.ds-form input[type=text],.ds-form input[type=email],.ds-form input[type=tel],.ds-form textarea{
  width:100%;font-family:var(--sans);font-size:16px;color:var(--text);background:transparent;
  border:none;border-bottom:1px solid var(--line);border-radius:0;padding:10px 2px;outline:none;
  transition:border-color var(--tr),box-shadow var(--tr);resize:vertical;}
.ds-form input::placeholder,.ds-form textarea::placeholder{color:var(--muted);}
.ds-form input:focus,.ds-form textarea:focus{border-bottom-color:var(--gold);box-shadow:0 1px 0 0 var(--gold);}
.ds-form .wpcf7-form-control-wrap{display:block;}
.ds-form .wpcf7-submit{width:100%;justify-content:center;background:var(--gold);color:var(--graphite-deep);
  font-family:var(--sans);font-size:14px;font-weight:500;letter-spacing:.02em;padding:15px 26px;
  border:1px solid transparent;border-radius:var(--r-pill);cursor:pointer;margin-top:8px;
  box-shadow:var(--gold-shadow);transition:transform var(--tr),box-shadow var(--tr),background var(--tr);}
.ds-form .wpcf7-submit:hover{background:var(--gold-soft);transform:translateY(-2px) scale(1.01);
  box-shadow:0 20px 38px -16px rgba(197,163,91,.85);}
.ds-form .wpcf7-spinner{margin:10px auto 0;display:block;}
.ds-form .wpcf7 form .wpcf7-response-output{margin:14px 0 0;border-radius:10px;font-size:13.5px;padding:12px 14px;}
.ds-form__fallback{color:var(--text-2);font-size:15px;}
.form-notes{display:flex;flex-wrap:wrap;gap:18px;margin-top:18px;}
.form-notes span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);}
.form-notes svg{color:var(--gold);}

/* ============================================================ POPUP */
.popup-overlay{position:fixed;inset:0;background:rgba(33,35,41,.62);z-index:9998;
  display:none;align-items:center;justify-content:center;padding:20px;
  opacity:0;transition:opacity .3s ease;}
.popup-overlay.is-open{display:flex;opacity:1;}
.popup{position:relative;background:var(--white);border-radius:var(--r-card);box-shadow:var(--shadow-lg);
  padding:clamp(28px,4vw,44px);width:100%;max-width:460px;max-height:90vh;overflow:auto;}
.popup__close{position:absolute;top:16px;right:16px;width:34px;height:34px;border-radius:50%;
  border:1px solid var(--line);background:var(--bg-soft);color:var(--text-2);font-size:14px;
  cursor:pointer;transition:all var(--tr);line-height:1;}
.popup__close:hover{background:var(--gold);color:var(--graphite-deep);border-color:transparent;}
.popup__h2{font-family:var(--serif);font-size:26px;font-weight:600;color:var(--text);margin:0 0 8px;}
.popup__text{font-size:14px;line-height:1.6;color:var(--text-2);margin:0 0 22px;}

/* ============================================================ REVEAL */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.is-visible{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================ FALLBACK */
.fallback{padding-top:clamp(40px,6vw,72px);}
.fallback__content{margin-top:20px;}
.fallback__content :is(h2,h3){font-family:var(--serif);color:var(--text);}

/* ============================================================ RESPONSIVE (global) */
@media (max-width:980px){
  :root { --pad-x: 20px; }
  .nav__inner{position:relative;padding-left:clamp(16px,4vw,32px);padding-right:clamp(16px,4vw,32px);gap:14px;}

  /* перемикач мов — у барі, по центру (поза бургер-меню) */
  .nav__lang-bar{display:block;position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);}
  .nav__menu .lang{display:none;}        /* у дропдауні мов нема — лише навігація + CTA */

  /* бургер */
  .nav__toggle{display:inline-flex;flex-direction:column;justify-content:center;gap:5px;
    width:44px;height:44px;flex:0 0 auto;padding:0 11px;cursor:pointer;
    border:1px solid var(--line);border-radius:11px;background:rgba(252,251,248,.7);}
  .nav__toggle-bar{display:block;height:2px;width:100%;background:var(--graphite);border-radius:2px;
    transition:transform .25s var(--ease),opacity .2s;}
  .nav__toggle.is-open .nav__toggle-bar:nth-child(1){transform:translateY(7px) rotate(45deg);}
  .nav__toggle.is-open .nav__toggle-bar:nth-child(2){opacity:0;}
  .nav__toggle.is-open .nav__toggle-bar:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

  /* меню — дропдаун-панель під шапкою */
  .nav__menu{display:block;position:absolute;top:100%;left:0;right:0;
    background:var(--white);border-top:1px solid var(--line);box-shadow:var(--shadow);
    padding:clamp(14px,4vw,22px) clamp(16px,4vw,32px) clamp(20px,5vw,28px);
    opacity:0;visibility:hidden;pointer-events:none;transform:translateY(-10px);
    transition:opacity .25s var(--ease),transform .25s var(--ease),visibility .25s;}
  .nav__menu.is-open{opacity:1;visibility:visible;pointer-events:auto;transform:none;}

  .nav__links{display:flex;flex-direction:column;gap:0;align-items:stretch;}
  .nav__links a{padding:14px 2px;font-size:16px;border-bottom:1px solid var(--card-line);}
  /* у бургер-меню підменю послуг — статичний вкладений список */
  .nav__has-drop{position:static;}
  .nav__drop-trigger svg{display:none;}
  .nav__drop{position:static;opacity:1;visibility:visible;transform:none;min-width:0;
    background:transparent;border:none;box-shadow:none;border-radius:0;padding:2px 0 8px 14px;gap:0;}
  .nav__has-drop:hover .nav__drop,.nav__has-drop:focus-within .nav__drop{transform:none;}
  .nav__drop a{font-size:14px;padding:10px 2px;border-bottom:1px solid var(--card-line);border-radius:0;color:var(--text-2);}
  .nav__drop::before{display:none;}
  .nav__right{flex-direction:column;align-items:stretch;gap:16px;margin-top:18px;}
  .nav__right .lang{align-self:flex-start;}
  .nav .btn--dark{width:100%;justify-content:center;padding:14px 22px;font-size:14px;}

  .footer__inner{grid-template-columns:1fr 1fr;}
  
  .btn--hero-wa { display: none !important; }
}
@media (max-width:560px){
  .footer__inner{grid-template-columns:1fr;}
  /* у шапці лише логотип-SVG, без тексту */
  .nav .wordmark__txt{display:none;}
  .wordmark__logo img{height:34px;}
  .nav__inner{padding-left:16px;padding-right:16px;}
}

/* ============================================================ FLOATING WHATSAPP */
.floating-wa {
  position: fixed;
  bottom: 24px;
  right: 24px;
  width: 56px;
  height: 56px;
  background-color: #25D366;
  color: #fff;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 99;
  box-shadow: 0 10px 24px rgba(37,211,102,.4);
  transition: transform var(--tr), box-shadow var(--tr);
}
.floating-wa:hover {
  transform: translateY(-4px) scale(1.05);
  box-shadow: 0 14px 28px rgba(37,211,102,.5);
}
@media (min-width: 981px) {
  .floating-wa { display: none !important; }
}
