/* ── TOKENS ──────────────────────────────────────────────── */
:root {
  --ff-body:    'Jost', ui-sans-serif, system-ui, sans-serif;
  --ff-display: 'Cormorant Garamond', Georgia, serif;

  --w-max: 1180px;
  --px:    clamp(16px, 4vw, 28px);

  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 33px;

  --bg:         #f8f5f0;
  --surface:    rgba(255,252,248,.92);
  --surface2:   rgba(255,252,248,.70);
  --text:       #1a1410;
  --muted:      #6b5e52;
  --border:     rgba(90,70,50,.13);

  --accent:     #7a5c3a;
  --accentL:    #b89c7a;
  --accentSoft: rgba(122,92,58,.11);

  --ring:    0 0 0 3px rgba(122,92,58,.22);
  --sh:      0 10px 36px rgba(40,24,8,.09);
  --shHard:  0 22px 64px rgba(40,24,8,.15);
  --glass:   rgba(248,245,240,.84);

  --ease:    cubic-bezier(.2,.8,.2,1);
  --easeOut: cubic-bezier(0,.6,.4,1);
  --tFast:   .15s;
  --tMed:    .26s;

  /* Высота хедера — вычитается из высоты героя */
  --header-h: 57.5px;
}

html[data-theme="dark"] {
  --bg:         #100d0a;
  --surface:    rgba(28,22,16,.84);
  --surface2:   rgba(28,22,16,.64);
  --text:       #ede8e0;
  --muted:      rgba(237,232,224,.66);
  --border:     rgba(200,180,150,.12);

  --accent:     #c4a06e;
  --accentL:    #d4b88a;
  --accentSoft: rgba(196,160,110,.13);

  --ring:   0 0 0 3px rgba(196,160,110,.26);
  --sh:     0 16px 54px rgba(0,0,0,.46);
  --shHard: 0 28px 90px rgba(0,0,0,.58);
  --glass:  rgba(16,13,10,.82);
}

/* ── RESET ───────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  font-family: var(--ff-body);
  background: var(--bg);
  color: var(--text);
  font-size: 17px;
  line-height: 1.68;
  letter-spacing: -.012em;
  overflow-x: hidden;
}
a   { color: inherit; text-decoration: none; }
ul  { list-style: none; }
img { display: block; max-width: 100%; }
video { display: block; }
button { font-family: var(--ff-body); cursor: pointer; }
:focus-visible { outline: none; box-shadow: var(--ring); border-radius: var(--r-sm); }

/* ── LAYOUT ──────────────────────────────────────────────── */
.container {
  max-width: var(--w-max);
  margin: 0 auto;
  padding-left: var(--px);
  padding-right: var(--px);
}
.sec { padding: clamp(64px, 9vw, 112px) 0; }

/* ── HEADER ──────────────────────────────────────────────── */
.header {
  position: sticky;
  top: 0;
  z-index: 200;
  background: var(--glass);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.nav {
  max-width: var(--w-max);
  margin: 0 auto;
  padding: 14px var(--px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

/* ── BRAND ───────────────────────────────────────────────── */
.brand {
  display: flex;
  flex-direction: column;
  gap: 1px;
  flex-shrink: 0;
  line-height: 1;
}
.brandName {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 22px;
  letter-spacing: -.025em;
  color: var(--text);
}
.brandName em { font-style: italic; color: var(--accent); }
.brandSub {
  font-size: 8.5px;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--muted);
}

/* ── DESKTOP NAV ─────────────────────────────────────────── */
.menu {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2px;
}
.menu a {
  font-size: 18.5px;
  font-weight: 500;
  color: var(--muted);
  padding: 8px 16px;
  border-radius: var(--r-sm);
  white-space: nowrap;
  transition: color var(--tFast) var(--ease), background var(--tFast) var(--ease);
}
.menu a:hover { color: var(--text); }

/* ── CONTROLS ────────────────────────────────────────────── */
.controls { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }

.lang {
  display: flex;
  gap: 3px;
  padding: 4px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface2);
}
.chip {
  border: none;
  background: transparent;
  color: var(--muted);
  font-family: var(--ff-body);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 6px 10px;
  border-radius: 999px;
  transition: background var(--tFast), color var(--tFast);
}
.chip[aria-pressed="true"] { background: var(--accent); color: #fff; }
.chip:hover:not([aria-pressed="true"]) { background: var(--accentSoft); }

.iconBtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px; height: 38px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface2);
  color: var(--text);
  font-size: 16px;
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease);
}
.iconBtn:hover { transform: translateY(-2px); box-shadow: var(--sh); }
.burger { display: none; }

/* ── BUTTONS ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: var(--r-xl);
  border: 1px solid var(--border);
  background: var(--surface2);
  color: var(--text);
  font-family: var(--ff-body);
  font-size: 15px;
  font-weight: 600;
  white-space: nowrap;
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease), background var(--tMed);
}
.btn:hover { transform: translateY(-2px); box-shadow: var(--sh); }

/* WhatsApp — тёплый терракот */
.waBtn { background: #6b4226; border-color: transparent; color: #f5e6d0; }
.waBtn:hover { background: #573418; box-shadow: 0 8px 28px rgba(107,66,38,.36); color: #faeedd; }
html[data-theme="dark"] .waBtn { background: #b8864a; color: #1a0f04; }
html[data-theme="dark"] .waBtn:hover { background: #c8965a; box-shadow: 0 8px 28px rgba(184,134,74,.28); }

.waBtn--sm   { padding: 9px 14px; font-size: 13px; border-radius: var(--r-sm); }
.waBtn--hero { padding: 15px 28px; font-size: 16px; border-radius: var(--r-md); }
.waBtn--cta  { margin-top: 20px; width: 100%; justify-content: center; }
.waBtn--full { width: 100%; justify-content: center; padding: 13px 20px; }

/* ── MOBILE MENU ─────────────────────────────────────────── */
.mobileMenu {
  display: none;
  flex-direction: column;
  gap: 8px;
  max-width: var(--w-max);
  margin: 0 auto;
  padding: 12px var(--px) 18px;
  border-top: 1px solid var(--border);
}
.mobileMenu.is-open { display: flex; }

.mmTop {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 4px;
}

.mmNav { display: flex; flex-direction: column; gap: 6px; }
.mmNav a {
  display: block;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface2);
  font-size: 16px;
  font-weight: 500;
  transition: background var(--tFast), padding-left var(--tFast);
}
.mmNav a:hover { background: var(--accentSoft); padding-left: 22px; }

/* ── HERO ────────────────────────────────────────────────── */
/*
  Хедер sticky = 57.5px. Вычитаем его из высоты вьюпорта,
  чтобы герой занимал ровно оставшееся видимое пространство.
*/
.hero {
  position: relative;
  height: calc(100dvh - var(--header-h));
  height: calc(100svh - var(--header-h)); /* fallback Safari */
  min-height: 500px;
  max-height: 1080px;
  overflow: hidden;
}

.heroBg { position: absolute; inset: 0; }
.heroBg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center 30%;
}
.heroOverlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(105deg,
    rgba(10,7,4,.78) 0%,
    rgba(10,7,4,.48) 50%,
    rgba(10,7,4,.16) 100%);
}

.heroBody {
  position: relative;
  z-index: 2;
  height: 100%;
  display: flex;
  align-items: center;
}

.heroInner {
  max-width: 600px;
  padding: clamp(28px, 5vh, 56px) 0;
}

.heroTag {
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--accentL);
  margin-bottom: 16px;
}

.hero h1 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(40px, 5.8vw, 74px);
  line-height: 1.04;
  letter-spacing: -.025em;
  color: #fff;
  margin-bottom: 18px;
}
.heroLead {
  font-size: clamp(16px, 1.35vw, 19px);
  font-weight: 400;
  color: rgba(255,255,255,.82);
  max-width: 48ch;
  margin-bottom: 28px;
  line-height: 1.65;
}
.heroCta { margin-bottom: 26px; }

/* Bullets в одну строку, горизонтальный скролл на мобиле */
.heroBullets {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 2px;
}
.heroBullets::-webkit-scrollbar { display: none; }
.heroBullets li {
  flex-shrink: 0;
  font-size: 13.5px;
  font-weight: 500;
  color: rgba(255,255,255,.84);
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.18);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 8px 16px;
  border-radius: 999px;
  transition: background var(--tFast), transform var(--tFast);
}
.heroBullets li:hover { background: rgba(255,255,255,.18); transform: translateY(-2px); }

.heroNote {
  position: absolute;
  bottom: 16px;
  left: 0; right: 0;
  z-index: 2;
  text-align: center;
  font-size: 11.5px;
  color: rgba(255,255,255,.36);
  padding: 0 var(--px);
  pointer-events: none;
}

/* ── SECTION COMMONS ─────────────────────────────────────── */
.secTag {
  display: inline-block;
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: .13em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 10px;
}
.secHead { margin-bottom: 44px; }
.secHead h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(30px, 3vw, 48px);
  letter-spacing: -.022em;
  line-height: 1.1;
  margin-bottom: 12px;
}
.secHead p {
  font-size: clamp(15px, 1.1vw, 17px);
  color: var(--muted);
  max-width: 68ch;
  line-height: 1.70;
}

/* ── ABOUT ───────────────────────────────────────────────── */
.secAbout { background: var(--bg); }
.aboutGrid {
  display: grid;
  grid-template-columns: 1.2fr .8fr;
  gap: clamp(32px, 5vw, 64px);
  align-items: center;
}
.aboutText h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(30px, 3.2vw, 50px);
  letter-spacing: -.022em;
  line-height: 1.1;
  margin-bottom: 16px;
}
.aboutText p {
  font-size: clamp(15px, 1.1vw, 17px);
  color: var(--muted);
  line-height: 1.74;
  max-width: 56ch;
}
.aboutStats { display: flex; flex-direction: column; gap: 12px; }
.stat {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 18px 22px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--sh);
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease);
}
.stat:hover { transform: translateX(6px); box-shadow: var(--shHard); }
.statNum {
  font-family: var(--ff-display);
  font-size: 36px;
  font-weight: 700;
  color: var(--accent);
  line-height: 1;
  min-width: 68px;
}
.statLabel { font-size: 15px; font-weight: 500; color: var(--muted); }

/* ── SERVICES ────────────────────────────────────────────── */
.secServices {
  background: linear-gradient(180deg, var(--bg) 0%,
    color-mix(in srgb, var(--accent) 6%, var(--bg)) 100%);
}
.serviceList { display: flex; flex-direction: column; gap: 10px; }
.serviceRow {
  display: grid;
  grid-template-columns: 52px 1fr auto;
  align-items: start;
  gap: 20px 24px;
  padding: 22px 24px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--sh);
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease), border-color var(--tMed);
}
.serviceRow:hover { transform: translateX(6px); box-shadow: var(--shHard); border-color: var(--accentL); }
.srvNum {
  font-family: var(--ff-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--accentL);
  line-height: 1.2;
  padding-top: 2px;
  transition: color var(--tFast);
}
.serviceRow:hover .srvNum { color: var(--accent); }
.srvBody h3 {
  font-family: var(--ff-display);
  font-size: 21px;
  font-weight: 700;
  letter-spacing: -.01em;
  margin-bottom: 7px;
  line-height: 1.2;
}
.srvBody p { font-size: 15px; color: var(--muted); line-height: 1.66; max-width: 56ch; }
.srvTags {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
  flex-shrink: 0;
  padding-top: 2px;
}
.srvTags span {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--muted);
  background: var(--accentSoft);
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}

/* ── GALLERY ─────────────────────────────────────────────── */
.secGallery { background: var(--bg); padding-bottom: 0; }
.galleryWrap { margin-top: 10px; }
.slider {
  position: relative;
  overflow: hidden;
  border-radius: var(--r-xl);
  border: 1px solid var(--border);
  background: var(--surface);
  box-shadow: var(--sh);
}
.sliderTrack {
  display: flex;
  transition: transform .5s var(--ease);
  will-change: transform;
}
.slide { min-width: 100%; }

#gallerySlider { height: clamp(440px, 86vh, 960px); }
#gallerySlider .sliderTrack,
#gallerySlider .slide { height: 100%; }
#gallerySlider .slide img { width: 100%; height: 100%; object-fit: cover; }

.sliderBtn {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px; height: 48px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: rgba(248,245,240,.84);
  color: var(--text);
  font-size: 22px;
  font-weight: 700;
  z-index: 4;
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease);
}
html[data-theme="dark"] .sliderBtn { background: rgba(28,22,16,.82); }
.sliderBtn:hover { transform: translateY(-50%) scale(1.08); box-shadow: var(--sh); }
.sliderBtn.prev { left: 14px; }
.sliderBtn.next { right: 14px; }
.dots {
  position: absolute;
  bottom: 14px;
  left: 0; right: 0;
  display: flex;
  justify-content: center;
  gap: 7px;
  z-index: 4;
}
.dots button {
  width: 8px; height: 8px;
  border-radius: 999px;
  border: none;
  background: rgba(255,255,255,.46);
  cursor: pointer;
  transition: width var(--tFast), background var(--tFast), transform var(--tFast);
}
.dots button[aria-current="true"] { background: var(--accent); width: 24px; }
.dots button:hover { transform: scale(1.3); }

/* ── VIDEO ───────────────────────────────────────────────── */

.secVideo {
  background: linear-gradient(180deg, var(--bg) 0%,
    color-mix(in srgb, var(--accent) 5%, var(--bg)) 100%);
}

.videoGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  margin-top: 10px;
}

.videoWrap {
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--border);
  box-shadow: var(--sh);
  background: #000;
  aspect-ratio: 16 / 9;
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease);
}
.videoWrap:hover { transform: translateY(-4px); box-shadow: var(--shHard); }

.videoWrap video {
  width: 100%;
  height: 100%;
  object-fit: contain; /* не обрезает портретное — поля #000 по бокам */
  display: block;
}

/* Мобиль — стаком */
@media (max-width: 768px) {
  .videoGrid { grid-template-columns: 1fr; max-width: 480px; margin-left: auto; margin-right: auto; }
}
@media (max-width: 480px) {
  .videoGrid { grid-template-columns: 1fr; max-width: 100%; }
}


/* ── PROCESS ─────────────────────────────────────────────── */
.secProcess {
  background: linear-gradient(180deg, var(--bg) 0%,
    color-mix(in srgb, var(--accent) 7%, var(--bg)) 100%);
}
.steps { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.step {
  display: grid;
  grid-template-columns: 52px 1fr;
  gap: 18px;
  align-items: start;
  padding: 18px 22px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--sh);
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity .65s var(--easeOut),
    transform .65s var(--easeOut),
    box-shadow var(--tMed) var(--ease);
  transition-delay: var(--d, 0s);
}
.step.is-in { opacity: 1; transform: translateY(0); }
.step.is-in:hover { transform: translateX(6px); box-shadow: var(--shHard); }
.stepNum {
  width: 52px; height: 52px;
  border-radius: var(--r-md);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 22px;
  color: #fff;
  background: var(--accent);
}
.stepBody h3 { font-family: var(--ff-display); font-weight: 700; font-size: 19px; margin-bottom: 6px; line-height: 1.2; }
.stepBody p  { font-size: 15px; color: var(--muted); line-height: 1.66; }

/* ── CONTACTS ────────────────────────────────────────────── */
.secContacts {
  background: linear-gradient(180deg, var(--bg) 0%,
    color-mix(in srgb, var(--accent) 9%, var(--bg)) 100%);
}
.contactCard {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: clamp(20px, 3vw, 32px);
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: var(--surface);
  box-shadow: var(--sh);
}
.contactInfo h2 {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: clamp(26px, 2.6vw, 40px);
  letter-spacing: -.022em;
  line-height: 1.1;
  margin-bottom: 10px;
}
.muted { color: var(--muted); font-size: 15px; line-height: 1.68; }
.infoGrid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin: 18px 0 0;
}
.infoItem {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--surface2);
  transition: transform var(--tMed) var(--ease), box-shadow var(--tMed) var(--ease);
}
.infoItem:hover { transform: translateY(-3px); box-shadow: var(--sh); }
.infoLabel { font-size: 10px; font-weight: 700; letter-spacing: .10em; text-transform: uppercase; color: var(--muted); }
.infoValue { font-size: 14px; font-weight: 600; }

.form {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(16px, 2.5vw, 22px);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface2);
}
.formGroup { display: flex; flex-direction: column; gap: 6px; }
.formGroup label { font-size: 13px; font-weight: 600; color: var(--text); letter-spacing: .01em; }
.form input, .form select, .form textarea {
  width: 100%;
  padding: 12px 14px;
  border-radius: var(--r-sm);
  border: 1px solid var(--border);
  background: rgba(255,252,248,.88);
  color: var(--text);
  font-family: var(--ff-body);
  font-size: 16px;
  outline: none;
  transition: border-color var(--tFast), box-shadow var(--tFast);
  -webkit-appearance: none;
  appearance: none;
}
html[data-theme="dark"] .form input,
html[data-theme="dark"] .form select,
html[data-theme="dark"] .form textarea { background: rgba(28,22,16,.72); color: var(--text); }
.form input:focus, .form select:focus, .form textarea:focus { border-color: var(--accent); box-shadow: var(--ring); }
.form textarea { resize: vertical; min-height: 96px; }
.formNote { font-size: 11px; color: var(--muted); line-height: 1.55; }
.formSuccess {
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  padding: 12px 16px;
  border-radius: var(--r-sm);
  background: var(--accentSoft);
  border: 1px solid var(--border);
}

/* ── FOOTER ──────────────────────────────────────────────── */

.footer {
  background: linear-gradient(150deg, #1a1208 0%, #2c1e0e 100%);
  position: relative;
  overflow: hidden;
}
.footer::before {
  content: "";
  position: absolute;
  top: -120px; right: -80px;
  width: 420px; height: 420px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(184,156,122,.07), transparent 58%);
  pointer-events: none;
}
.footer::after {
  content: "";
  position: absolute;
  bottom: -80px; left: -60px;
  width: 300px; height: 300px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(122,92,58,.05), transparent 60%);
  pointer-events: none;
}

.footerInner {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: auto auto;
  position: relative;
  z-index: 1;
}

.footerBrand {
  grid-column: 1; grid-row: 1;
  display: flex; flex-direction: column; gap: 6px;
  padding: clamp(36px, 5vw, 52px) var(--px) 32px;
}
.footerName {
  font-family: var(--ff-display);
  font-weight: 700;
  font-size: 30px;
  letter-spacing: -.022em;
  color: rgba(237,232,224,.95);
  line-height: 1;
}
.footerName em { font-style: italic; color: var(--accentL); }
.footerSub {
  font-size: 8.5px; font-weight: 600; letter-spacing: .16em;
  text-transform: uppercase; color: rgba(184,156,122,.42);
}
.footerTagline {
  margin-top: 10px; font-size: 13px;
  color: rgba(184,156,122,.40); line-height: 1.6;
}

.footerNav {
  grid-column: 2; grid-row: 1;
  display: flex; flex-direction: column; gap: 4px;
  padding: clamp(36px, 5vw, 52px) var(--px) 32px;
}
.footerNav a {
  font-size: 14px; font-weight: 400;
  color: rgba(237,232,224,.44);
  padding: 5px 0;
  transition: color var(--tFast), padding-left var(--tFast);
}
.footerNav a:hover { color: rgba(237,232,224,.88); padding-left: 6px; }

.footerContact {
  grid-column: 3; grid-row: 1;
  display: flex; flex-direction: column; gap: 6px;
  padding: clamp(36px, 5vw, 52px) var(--px) 32px;
}
.footerContact a,
.footerContact span {
  font-size: 14px;
  color: rgba(184,156,122,.56);
  transition: color var(--tFast);
}
.footerContact a:hover { color: rgba(237,232,224,.88); }

.footerBottom {
  grid-column: 1 / -1; grid-row: 2;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  padding: 20px var(--px) 28px;
  font-size: 12px;
  color: rgba(237,232,224,.22);
  /* тонкая линия через background-image, не border */
  background-image: linear-gradient(
    to right,
    transparent 0%,
    rgba(184,156,122,.10) 15%,
    rgba(184,156,122,.10) 85%,
    transparent 100%
  );
  background-repeat: no-repeat;
  background-size: 100% 1px;
  background-position: top center;
}
.footerCredit a {
  color: rgba(184,156,122,.44);
  text-decoration: underline;
  text-decoration-color: rgba(184,156,122,.16);
  text-underline-offset: 3px;
  transition: color var(--tFast);
}
.footerCredit a:hover { color: rgba(184,156,122,.88); }




/* ── ANIMATIONS ──────────────────────────────────────────── */
@keyframes fadeIn  { from { opacity:0 } to { opacity:1 } }
@keyframes slideUp { from { opacity:0; transform:translateY(26px) } to { opacity:1; transform:translateY(0) } }
.anim-fade { animation: fadeIn  .9s var(--easeOut) both; }
.anim-up   { animation: slideUp 1s  var(--easeOut) both; }
.d1 { animation-delay: .18s; }
.d2 { animation-delay: .34s; }
.d3 { animation-delay: .50s; }

.js-reveal {
  opacity: 0;
  transform: translateY(22px);
  transition: opacity .72s var(--easeOut), transform .72s var(--easeOut);
  transition-delay: var(--d, 0s);
}
.js-reveal.is-in { opacity: 1; transform: translateY(0); }


/* ══════════════════════════════════════════════════════════
   RESPONSIVE — 1280 / 1024 / 768 / 600 / 480 / 360
   ══════════════════════════════════════════════════════════ */

/* ── 1280px ─────────────────────────────────────────────── */
@media (max-width: 1280px) {
  .menu a { padding: 7px 10px; font-size: 13px; }
  .serviceRow { gap: 16px 20px; }
  .footerInner { grid-template-columns: 1fr 1fr; }
  .footerContact {
    grid-column: 1 / -1; grid-row: 2;
    flex-direction: row; flex-wrap: wrap; gap: 12px 24px;
    border-top: 1px solid rgba(122,92,58,.18); padding-top: 20px;
  }
  .footerBottom { grid-row: 3; }
}

/* ── 1024px — бургер ────────────────────────────────────── */
@media (max-width: 1024px) {
  .menu { display: none; }
  .burger { display: inline-flex; }

  .aboutGrid { grid-template-columns: 1fr; gap: 32px; }
  .aboutStats { flex-direction: row; flex-wrap: wrap; gap: 10px; }
  .stat { flex: 1 1 160px; }

  .serviceRow { grid-template-columns: 44px 1fr; padding: 18px 20px; }
  .srvTags { display: none; }

  .contactCard { grid-template-columns: 1fr; }

  .footerInner { grid-template-columns: 1fr 1fr; }
  .footerBrand { border-right: none; border-bottom: 1px solid rgba(122,92,58,.18); padding-bottom: 20px; }
  .footerNav { border-right: none; grid-column: 1; grid-row: 2; padding-top: 20px; }
  .footerContact { grid-column: 2; grid-row: 2; padding-top: 20px; border-top: none; flex-direction: column; }
  .footerBottom { grid-column: 1 / -1; grid-row: 3; }
}

/* ── 768px — планшет ────────────────────────────────────── */
@media (max-width: 768px) {
  :root { --header-h: 54px; }

  .sec { padding: clamp(52px, 7vw, 80px) 0; }

  .hero h1 { font-size: clamp(34px, 7vw, 52px); }
  .heroInner { max-width: 100%; }

  .aboutStats { flex-direction: column; }
  .stat { flex: none; }

  .videoGrid { grid-template-columns: 1fr; }
  .videoWrap--portrait { width: auto; max-width: 280px; margin: 0 auto; }
  .videoWrap--portrait video { max-height: 440px; }

  .infoGrid { grid-template-columns: 1fr 1fr; }
  #gallerySlider { height: clamp(340px, 72vw, 640px); }

  .footerInner { grid-template-columns: 1fr; }
  .footerBrand, .footerNav, .footerContact {
    grid-column: 1;
    border-right: none;
    border-bottom: 1px solid rgba(122,92,58,.18);
    padding: 20px var(--px);
  }
  .footerBrand { grid-row: 1; padding-top: clamp(24px,4vw,36px); }
  .footerNav   { grid-row: 2; display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px; }
  .footerNav a { padding: 4px 0; }
  .footerContact { grid-row: 3; flex-direction: row; flex-wrap: wrap; gap: 10px 20px; }
  .footerBottom  { grid-row: 4; padding: 14px var(--px) 24px; }
}

/* ── 600px — большой телефон ────────────────────────────── */
@media (max-width: 600px) {
  .controls .waBtn--sm { display: none; }
  .brandSub { display: none; }

  /* На мобиле хедер немного ниже — уточняем высоту */
  :root { --header-h: 52px; }

  .hero { min-height: calc(100dvh - var(--header-h)); min-height: calc(100svh - var(--header-h)); max-height: none; }
  .hero h1 { font-size: clamp(30px, 9.5vw, 46px); }
  .heroLead { font-size: 15px; margin-bottom: 20px; }
  .waBtn--hero { width: 100%; justify-content: center; }
  .heroBullets { flex-wrap: wrap; overflow-x: visible; }
  .heroBullets li { font-size: 12.5px; padding: 7px 13px; }

  .serviceRow { grid-template-columns: 36px 1fr; gap: 12px 14px; padding: 15px 16px; }
  .srvNum { font-size: 20px; }
  .srvBody h3 { font-size: 17px; }
  .srvBody p  { font-size: 14px; }

  .infoGrid { grid-template-columns: 1fr; }
  .contactCard { padding: 16px; }
  .waBtn--cta { margin-top: 16px; }

  #gallerySlider { height: clamp(240px, 76vw, 440px); }
  .sliderBtn { width: 40px; height: 40px; font-size: 18px; }

  .step { grid-template-columns: 44px 1fr; padding: 14px 16px; }
  .stepNum { width: 44px; height: 44px; font-size: 20px; }

  .aboutStats { flex-direction: row; flex-wrap: wrap; gap: 8px; }
  .stat { flex: 1 1 calc(33% - 6px); padding: 12px; min-width: 86px; }
  .statNum { font-size: 26px; min-width: auto; }
  .statLabel { font-size: 13px; }

  .videoWrap--portrait { max-width: 220px; }
  .videoWrap--portrait video { max-height: 380px; }
}

/* ── 480px — средний телефон ────────────────────────────── */
@media (max-width: 480px) {
  :root { --px: 14px; --header-h: 50px; }

  .nav { padding: 11px var(--px); }
  .brandName { font-size: 19px; }
  .chip { padding: 5px 9px; font-size: 10.5px; }
  .iconBtn { width: 34px; height: 34px; font-size: 15px; }

  .hero h1 { font-size: clamp(27px, 10vw, 38px); }
  .waBtn--hero { font-size: 14px; padding: 13px 18px; }

  .secHead h2 { font-size: clamp(22px, 6.5vw, 30px); }
  .secHead p  { font-size: 14px; }

  .serviceRow { padding: 13px 14px; gap: 10px 12px; }
  .srvBody h3 { font-size: 16px; }
  .srvBody p  { font-size: 13px; }

  .step { gap: 12px; }
  .stepBody h3 { font-size: 17px; }

  .aboutStats { flex-direction: column; }
  .stat { flex: none; }

  .form { padding: 14px; gap: 12px; }
  .formGroup label { font-size: 12px; }
  .contactCard { padding: 14px; gap: 14px; }
  .infoValue { font-size: 13px; }

  .footerName { font-size: 24px; }
  .footerNav  { grid-template-columns: 1fr; }

  .videoWrap--portrait { max-width: 180px; }
  .videoWrap--portrait video { max-height: 320px; }
}

/* ── 360px — маленький телефон ──────────────────────────── */
@media (max-width: 360px) {
  :root { --px: 12px; --header-h: 48px; }

  .brandName { font-size: 17px; }
  .chip { padding: 5px 8px; font-size: 10px; }
  .iconBtn { width: 32px; height: 32px; }

  .hero h1 { font-size: 26px; line-height: 1.1; }
  .heroLead { font-size: 14px; }
  .heroBullets li { font-size: 12px; padding: 6px 10px; }
  .waBtn--hero { padding: 12px 16px; font-size: 13.5px; }

  #gallerySlider { height: clamp(200px, 78vw, 320px); }
  .sliderBtn { width: 36px; height: 36px; font-size: 16px; }

  .step { grid-template-columns: 40px 1fr; gap: 10px; padding: 12px; }
  .stepNum { width: 40px; height: 40px; font-size: 18px; }

  .serviceRow { grid-template-columns: 30px 1fr; padding: 12px; }
  .srvNum { font-size: 17px; }

  .videoWrap--portrait { max-width: 160px; }
}

/* ── Landscape phone ─────────────────────────────────────── */
@media (max-height: 520px) and (orientation: landscape) {
  .hero {
    height: auto;
    min-height: auto;
    padding: 80px 0 56px;
  }
  .heroBody { height: auto; }
  .heroInner { padding: 0; }
  .hero h1 { font-size: clamp(26px, 5vw, 38px); margin-bottom: 12px; }
  .heroLead { font-size: 14px; margin-bottom: 16px; }
  .heroBullets { display: none; }
  .heroNote { position: static; margin-top: 12px; color: rgba(255,255,255,.38); }
}

/* ── Reduced motion ──────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .01ms !important; transition-duration: .01ms !important; }
  html { scroll-behavior: auto; }
}


