﻿/* =========================================================
   KAMENNYE KRASKI CRIMEA — Premium template
   Stone-paint application service, Republic of Crimea
   Palette: graphite stone × Crimean sand × bronze
   ========================================================= */

/* ---------- Reset & tokens ---------- */
*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

:root{
  /* FIRST · Navy + Gold — фирменный navy #18315A + тёплое золото
     (имена переменных сохранены намеренно: рекраска без правки разметки) */
  --color-bg:           #1E3560;   /* lifted brand navy */
  --color-surface:      #253F6F;   /* lifted surface */
  --color-surface-2:    #2E4B82;   /* lifted raised */
  --color-line:         #3B588C;   /* lifted hairline */
  --color-sand:         #F4EFE3;   /* warm cream — заголовки */
  --color-sand-dim:     #D8CDB5;   /* warm soft */
  --color-bronze:       #C9A867;   /* signature GOLD accent */
  --color-bronze-soft:  #DCC288;   /* hover gold */
  --color-text:         #E9EBF1;   /* body */
  --color-text-mute:    #9AA6BC;   /* secondary (контраст ≥4.5:1) */
  --color-success:      #8FB28A;
  --color-ink:          #1A2F56;   /* тёмный текст на золоте */

  /* Type */
  --font-display: "Cormorant Garamond", "Times New Roman", serif;
  --font-body:    "Manrope", "Inter", system-ui, -apple-system, "Segoe UI", sans-serif;

  /* Rhythm */
  --container: 1280px;
  --gutter: clamp(20px, 4vw, 56px);
  --radius-s: 4px;
  --radius-m: 10px;
  --radius-l: 20px;

  /* Motion */
  --ease: cubic-bezier(.22,.61,.36,1);
  --dur: .55s;

  /* Shadows */
  --shadow-soft: 0 30px 60px -30px rgba(0,0,0,.6);
  --shadow-card: 0 18px 40px -22px rgba(0,0,0,.7);
}

html { scroll-behavior: smooth; }
body{
  background: var(--color-bg);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

img, svg, video { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; transition: color var(--dur) var(--ease); }
button { font: inherit; cursor: pointer; border: 0; background: none; color: inherit; }

/* ---------- Typography ---------- */
.display{
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: -.01em;
  line-height: 1.02;
  color: var(--color-sand);
}
.h1   { font-size: clamp(2.6rem, 5.6vw, 5.4rem); }
.h2   { font-size: clamp(2rem,  3.6vw, 3.2rem); }
.h3   { font-size: clamp(1.4rem, 2vw, 1.85rem); }
.kicker{
  font-family: var(--font-body);
  font-size: .78rem;
  letter-spacing: .28em;
  text-transform: uppercase;
  color: var(--color-bronze);
  display: inline-flex;
  align-items: center;
  gap: 14px;
}
.kicker::before{
  content: "";
  width: 36px;
  height: 1px;
  background: currentColor;
  opacity: .7;
}
.lead { color: var(--color-text-mute); max-width: 60ch; }
em.gold { color: var(--color-bronze); font-style: normal; }

/* ---------- Layout ---------- */
.container{
  max-width: var(--container);
  padding-inline: var(--gutter);
  margin-inline: auto;
}
section { padding-block: clamp(48px, 5vw, 80px); position: relative; }
.section-head{
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  margin-bottom: clamp(28px, 4vw, 52px);
}
@media (min-width: 900px){
  .section-head { grid-template-columns: 1.1fr 1fr; align-items: end; }
}

/* ---------- Buttons ---------- */
.btn{
  --bg: var(--color-bronze);
  --fg: var(--color-ink);
  display: inline-flex; align-items: center; gap: 10px;
  padding: 16px 28px;
  background: var(--bg);
  color: var(--fg);
  border-radius: 999px;
  font-weight: 600;
  letter-spacing: .02em;
  transition: transform var(--dur) var(--ease), background var(--dur) var(--ease), color var(--dur) var(--ease);
  white-space: nowrap;
}
.btn:hover{ transform: translateY(-2px); background: var(--color-bronze-soft); }
.btn--ghost{
  --bg: transparent;
  --fg: var(--color-sand);
  border: 1px solid var(--color-line);
}
.btn--ghost:hover{ background: var(--color-surface-2); border-color: var(--color-bronze); }
.btn .arrow{ width:14px; height:14px; }

/* ---------- Header ---------- */
.site-header{
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 50;
  padding: 18px 0;
  backdrop-filter: blur(14px);
  background: rgba(30,53,96,.55);
  border-bottom: 1px solid transparent;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.site-header.is-scrolled{
  background: rgba(30,53,96,.92);
  border-bottom-color: var(--color-line);
}
.nav{
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.brand{
  display: inline-flex; align-items: center; gap: 12px;
  font-family: var(--font-display);
  font-size: 1.4rem;
  letter-spacing: .02em;
  color: var(--color-sand);
  flex-shrink: 0;
}
.brand .mark{
  width: 36px; height: 36px;
  display: block;
  flex-shrink: 0;
}
.nav-links{
  display: none;
  gap: 20px;
  list-style: none;
  font-size: .88rem;
  color: var(--color-text-mute);
}
.nav-links a:hover{ color: var(--color-sand); }
.nav-links .has-sub{ position: relative; }
.nav-links .submenu{
  position: absolute; top: 100%; left: -16px;
  margin-top: 16px;
  min-width: 240px;
  padding: 14px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  list-style: none;
  opacity: 0; visibility: hidden;
  transform: translateY(8px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease), visibility var(--dur);
}
.nav-links .has-sub:hover .submenu{ opacity: 1; visibility: visible; transform: translateY(0); }
.nav-links .submenu a{
  display: block; padding: 10px 12px;
  border-radius: var(--radius-s);
  color: var(--color-text);
  font-size: .9rem;
}
.nav-links .submenu a:hover{ background: var(--color-surface-2); color: var(--color-bronze); }
.nav-cta{ display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
/* CTA button in header — compact */
.nav-cta .btn{ padding: 10px 22px; font-size: .86rem; }
.nav-phone{
  display: none;
  font-weight: 600;
  letter-spacing: .02em;
}
.nav-toggle{
  width: 44px; height: 44px;
  display: grid; place-items: center;
  border: 1px solid var(--color-line);
  border-radius: 999px;
}
.nav-toggle span{
  position: relative;
  display: block; width: 18px; height: 1px;
  background: var(--color-sand);
}
.nav-toggle span::before, .nav-toggle span::after{
  content: ""; position: absolute; left: 0; width: 100%; height: 1px;
  background: currentColor;
}
.nav-toggle span::before{ top: -6px; }
.nav-toggle span::after{ top: 6px; }

@media (min-width: 1024px){
  .nav-links{ display: flex; }
  .nav-phone{ display: inline-flex; }
  .nav-toggle{ display: none; }
}
/* ---- Compact desktop nav (1024–1340px) ---- */
@media (min-width: 1024px) and (max-width: 1340px){
  .nav-links{ gap: 13px; font-size: .8rem; }
  .nav-phone{ display: none; }
  .nav-cta .btn{ padding: 9px 16px; font-size: .78rem; }
}

/* ---------- Mobile drawer ---------- */
.drawer{
  position: fixed; inset: 0;
  background: rgba(30,53,96,.96);
  backdrop-filter: blur(20px);
  z-index: 60;
  transform: translateX(100%);
  transition: transform var(--dur) var(--ease);
  padding: 90px var(--gutter) 40px;
  overflow-y: auto;
}
.drawer.is-open{ transform: translateX(0); }
.drawer__close{
  position: absolute; top: 22px; right: var(--gutter);
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid var(--color-line);
  display: grid; place-items: center;
  color: var(--color-sand);
  font-size: 1.4rem;
}
.drawer ul { list-style: none; display: grid; gap: 8px; }
.drawer a {
  display: block; padding: 14px 0;
  font-family: var(--font-display);
  font-size: 1.7rem;
  color: var(--color-sand);
  border-bottom: 1px solid var(--color-line);
}
.drawer .group-label{
  font-size: .75rem; letter-spacing: .25em; text-transform: uppercase;
  color: var(--color-bronze);
  margin: 28px 0 8px;
}

/* ---------- Hero ---------- */
.hero{
  position: relative;
  min-height: 100vh;
  padding-top: 180px;
  padding-bottom: 100px;
  display: flex; align-items: center;
  overflow: hidden;
  isolation: isolate;
}
/* Hero background slideshow — 4 фото продукции, авто-кроссфейд */
.hero__slideshow{
  position: absolute; inset: 0;
  z-index: -3;
  overflow: hidden;
}
.hero__slide{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  opacity: 0;
  will-change: opacity;
  animation: heroSlideFade 28s infinite;
  transform: scale(1.04);
}
.hero__slide:nth-child(1){ animation-delay: 0s; }
.hero__slide:nth-child(2){ animation-delay: 7s; }
.hero__slide:nth-child(3){ animation-delay: 14s; }
.hero__slide:nth-child(4){ animation-delay: 21s; }
@keyframes heroSlideFade{
  0%   { opacity: 0; transform: scale(1.04); }
  3%   { opacity: 1; }
  22%  { opacity: 1; }
  25%  { opacity: 0; }
  100% { opacity: 0; transform: scale(1.10); }
}
@media (prefers-reduced-motion: reduce){
  .hero__slide{ animation: none; }
  .hero__slide:nth-child(1){ opacity: 1; }
}
.hero::before{
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(80% 60% at 80% 20%, rgba(201,168,103,.20), transparent 70%),
    radial-gradient(60% 50% at 10% 90%, rgba(38,52,82,.55), transparent 70%),
    linear-gradient(180deg, rgba(30,53,96,.74) 0%, rgba(27,44,78,.82) 100%);
  z-index: -2;
}
.hero::after{
  /* subtle stone texture using noise */
  content: "";
  position: absolute; inset: 0;
  opacity: .35;
  z-index: -1;
  background-image:
    radial-gradient(1px 1px at 20% 30%, rgba(255,255,255,.05) 1px, transparent 2px),
    radial-gradient(1px 1px at 70% 60%, rgba(255,255,255,.04) 1px, transparent 2px),
    radial-gradient(1px 1px at 40% 80%, rgba(255,255,255,.03) 1px, transparent 2px);
  background-size: 220px 220px, 320px 320px, 180px 180px;
  mix-blend-mode: screen;
  pointer-events: none;
}
.hero__grid{
  display: grid; gap: 60px;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 1024px){
  .hero__grid{ grid-template-columns: 1.05fr .95fr; gap: 80px; }
}
.hero__copy .kicker{ margin-bottom: 28px; }
.hero__title{ margin-bottom: 28px; }
.hero__title .stroke{
  -webkit-text-stroke: 1px var(--color-bronze);
  color: transparent;
  font-style: italic;
}
.hero__lead{ font-size: 1.05rem; margin-bottom: 40px; max-width: 56ch; }
.hero__cta{ display: flex; flex-wrap: wrap; gap: 14px; margin-bottom: 56px; }
.hero__stats{
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  border-top: 1px solid var(--color-line);
  padding-top: 32px;
}
.hero__stats .stat .num{
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.2vw, 2.6rem);
  color: var(--color-bronze);
  line-height: 1;
}
.hero__stats .stat .lbl{
  margin-top: 8px;
  font-size: .82rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-text-mute);
}

/* Hero card – stone preview */
.hero__card{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-l);
  overflow: hidden;
  box-shadow: var(--shadow-soft);
  isolation: isolate;
  background: var(--color-surface-2);
}
.hero__card::after{
  content: "";
  position: absolute; inset: 0;
  background:
    linear-gradient(180deg, rgba(30,53,96,.05) 0%, rgba(30,53,96,.38) 60%, rgba(30,53,96,.80) 100%);
  z-index: 1;
  pointer-events: none;
}
/* Ken Burns slow zoom: video-like motion without a video */
.hero__card .hero__card-img{
  position: absolute; inset: 0;
  background: url('../img/works/fasad/005.jpg') center/cover no-repeat;
  animation: kenBurns 22s var(--ease) infinite alternate;
  transform-origin: 60% 40%;
  z-index: 0;
}
@keyframes kenBurns{
  0%   { transform: scale(1.0)  translate(0,0); }
  100% { transform: scale(1.12) translate(-2%, 1.5%); }
}
@media (prefers-reduced-motion: reduce){
  .hero__card .hero__card-img{ animation: none; }
}
.hero__card .tag, .hero__card .caption{ z-index: 2; }
.hero__card::before{
  content: "";
  position: absolute; inset: 0;
  background:
    radial-gradient(80% 60% at 80% 10%, rgba(201,168,103,.18), transparent 60%);
  pointer-events: none;
}
.hero__card .tag{
  position: absolute; top: 24px; left: 24px;
  display: inline-flex; gap: 10px; align-items: center;
  background: rgba(30,53,96,.6);
  border: 1px solid rgba(201,168,103,.4);
  padding: 10px 16px;
  border-radius: 999px;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-sand);
  backdrop-filter: blur(10px);
}
.hero__card .tag .dot{
  width: 8px; height: 8px; border-radius: 50%; background: var(--color-bronze);
  box-shadow: 0 0 0 4px rgba(201,168,103,.18);
}
.hero__card .caption{
  position: absolute; left: 24px; right: 24px; bottom: 24px;
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 16px;
}
.hero__card .caption h3{
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--color-sand);
  line-height: 1.05;
  max-width: 70%;
}
.hero__card .caption .price{
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--color-bronze);
  white-space: nowrap;
}
.hero__card .caption .price small{
  font-family: var(--font-body);
  font-size: .7rem;
  color: var(--color-text-mute);
  letter-spacing: .12em;
  text-transform: uppercase;
  display: block;
  margin-top: 4px;
}

/* ---------- Section: trust strip ---------- */
.trust{
  padding-block: 30px;
  border-block: 1px solid var(--color-line);
  background: var(--color-surface);
}
.trust__row{
  display: flex; flex-wrap: wrap;
  align-items: center; justify-content: space-between;
  gap: 24px;
}
.trust__item{
  display: inline-flex; align-items: center; gap: 12px;
  color: var(--color-text-mute);
  font-size: .9rem;
  letter-spacing: .04em;
}
.trust__item svg{ width: 22px; height: 22px; color: var(--color-bronze); }

/* ---------- Services ---------- */
.services-grid{
  display: grid; gap: 22px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){ .services-grid{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1100px){ .services-grid{ grid-template-columns: repeat(4,1fr); } }

.service-card{
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: 32px 28px 28px;
  overflow: hidden;
  isolation: isolate;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
  display: flex; flex-direction: column;
  min-height: 360px;
}
.service-card__media{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  z-index: -2;
  transition: transform 1.6s var(--ease);
}
.service-card:hover .service-card__media{ transform: scale(1.07); }
.service-card::before{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(30,53,96,.28) 0%, rgba(30,53,96,.55) 55%, rgba(30,53,96,.85) 100%);
  transition: background var(--dur) var(--ease);
  z-index: -1;
}
.service-card:hover{
  transform: translateY(-6px);
  border-color: rgba(201,168,103,.5);
}
.service-card:hover::before{
  background: linear-gradient(180deg, rgba(30,53,96,.05) 0%, rgba(30,53,96,.25) 55%, rgba(30,53,96,.65) 100%);
}
.service-card .num{
  font-family: var(--font-display);
  color: var(--color-bronze);
  letter-spacing: .04em;
  font-size: .95rem;
  margin-bottom: auto;
}
.service-card h3{
  font-family: var(--font-display);
  font-size: 1.55rem;
  color: var(--color-sand);
  margin: 90px 0 14px;
  line-height: 1.1;
}
.service-card p{ color: var(--color-text-mute); font-size: .94rem; }
.service-card .more{
  margin-top: 22px;
  display: inline-flex; gap: 8px; align-items: center;
  color: var(--color-bronze);
  font-size: .85rem;
  letter-spacing: .12em; text-transform: uppercase;
}
.service-card .more::after{
  content: "→"; transition: transform var(--dur) var(--ease);
}
.service-card:hover .more::after{ transform: translateX(6px); }

/* ---------- Cities hub ---------- */
.cities{
  background:
    linear-gradient(180deg, transparent 0%, rgba(31,33,40,.4) 100%),
    var(--color-bg);
  position: relative;
}
.cities-grid{
  display: grid; gap: 14px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){ .cities-grid{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 900px){ .cities-grid{ grid-template-columns: repeat(3,1fr); } }
@media (min-width: 1200px){ .cities-grid{ grid-template-columns: repeat(4,1fr); } }

.city-card{
  position: relative;
  display: block;
  padding: 24px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  overflow: hidden;
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.city-card:hover{
  border-color: rgba(201,168,103,.5);
  background: var(--color-surface-2);
  transform: translateY(-3px);
}
.city-card .city-name{
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--color-sand);
  display: flex; align-items: center; justify-content: space-between;
}
.city-card .city-name::after{
  content: "↗";
  color: var(--color-bronze);
  font-size: 1.2rem;
  transition: transform var(--dur) var(--ease);
}
.city-card:hover .city-name::after{ transform: translate(4px, -4px); }
.city-card .city-meta{
  margin-top: 8px;
  display: flex; gap: 14px;
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--color-text-mute);
}
.city-card .city-meta .dot{
  width: 6px; height: 6px; border-radius: 50%; background: var(--color-bronze); align-self: center;
}

/* ---------- Process ---------- */
.process-list{
  display: grid; gap: 12px;
}
.process-step{
  display: grid;
  grid-template-columns: 80px 1fr auto;
  align-items: center;
  gap: 24px;
  padding: 26px 0;
  border-top: 1px solid var(--color-line);
  transition: padding var(--dur) var(--ease);
}
.process-step:last-child{ border-bottom: 1px solid var(--color-line); }
.process-step .step-num{
  font-family: var(--font-display);
  font-size: 2.4rem;
  color: var(--color-bronze);
  line-height: 1;
}
.process-step h4{
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--color-sand);
  margin-bottom: 6px;
}
.process-step p{ color: var(--color-text-mute); font-size: .92rem; max-width: 60ch; }
.process-step .step-meta{
  font-size: .78rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--color-text-mute);
  white-space: nowrap;
}
.process-step:hover{ padding-left: 14px; }

/* ---------- Material / paint showcase ---------- */
.materials{
  display: grid; gap: 22px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){ .materials{ grid-template-columns: repeat(3,1fr); } }
.material{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
}
.material .swatch{ position: absolute; inset: 0; }
.material[data-tone="travertine"] .swatch{
  background:
    radial-gradient(2px 2px at 22% 24%, rgba(0,0,0,.18), transparent 3px),
    radial-gradient(2px 2px at 60% 60%, rgba(0,0,0,.12), transparent 3px),
    radial-gradient(2px 2px at 80% 30%, rgba(0,0,0,.1), transparent 3px),
    linear-gradient(135deg, #E8DEC7 0%, #C9B791 100%);
}
.material[data-tone="granite"] .swatch{
  background:
    radial-gradient(2px 2px at 30% 30%, rgba(255,255,255,.15), transparent 3px),
    radial-gradient(2px 2px at 70% 60%, rgba(255,255,255,.1), transparent 3px),
    radial-gradient(2px 2px at 50% 80%, rgba(255,255,255,.18), transparent 3px),
    linear-gradient(135deg, #3A3D45 0%, #1C1E22 100%);
}
.material[data-tone="marble"] .swatch{
  background:
    linear-gradient(120deg, rgba(255,255,255,.5), transparent 50%),
    linear-gradient(135deg, #F2EDE3 0%, #D6CDBC 100%);
}
.material .meta{
  position: absolute; left: 22px; right: 22px; bottom: 22px;
  padding: 16px 18px;
  background: rgba(30,53,96,.72);
  backdrop-filter: blur(12px);
  border-radius: var(--radius-m);
  border: 1px solid rgba(255,255,255,.08);
}
.material .meta h4{
  font-family: var(--font-display);
  font-size: 1.4rem;
  color: var(--color-sand);
}
.material .meta p{
  margin-top: 4px;
  font-size: .82rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-mute);
}

/* ---------- CTA banner ---------- */
.cta{
  position: relative;
  background:
    radial-gradient(60% 80% at 80% 30%, rgba(201,168,103,.25), transparent 70%),
    radial-gradient(50% 60% at 10% 90%, rgba(38,52,82,.6), transparent 70%),
    linear-gradient(180deg, #1A2A4B 0%, #1E3560 100%);
  border-block: 1px solid var(--color-line);
  overflow: hidden;
}
.cta__inner{
  display: grid; gap: 36px;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 900px){
  .cta__inner{ grid-template-columns: 1.2fr 1fr; }
}
.cta h2 { margin-bottom: 18px; }
.cta .lead{ margin-bottom: 28px; }
.cta__form{
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  padding: 32px;
  border-radius: var(--radius-l);
  display: grid;
  gap: 14px;
  box-shadow: var(--shadow-card);
}
.cta__form .form-row{
  display: grid; gap: 10px;
}
.cta__form label{
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-text-mute);
}
.cta__form input, .cta__form select, .cta__form textarea{
  width: 100%;
  padding: 14px 16px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-s);
  color: var(--color-text);
  font-family: inherit;
  font-size: .98rem;
  transition: border-color var(--dur) var(--ease);
}
.cta__form input:focus, .cta__form select:focus, .cta__form textarea:focus{
  border-color: var(--color-bronze);
  outline: none;
}
.cta__form .row-2{
  display: grid; gap: 10px;
  grid-template-columns: 1fr;
}
@media (min-width: 560px){
  .cta__form .row-2 { grid-template-columns: 1fr 1fr; gap: 14px; }
}
.cta__form .submit{ margin-top: 8px; justify-self: start; }
.cta__form .privacy{
  font-size: .78rem; color: var(--color-text-mute);
  margin-top: 6px;
}
.cta__form .privacy a{ color: var(--color-bronze); border-bottom: 1px dotted currentColor; }

/* ---------- Calculator (lite) ---------- */
.calc{
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: clamp(24px, 4vw, 44px);
}
.calc__head{ display: flex; justify-content: space-between; gap: 24px; flex-wrap: wrap; margin-bottom: 26px; }
.calc__row{
  display: grid; gap: 18px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){ .calc__row{ grid-template-columns: repeat(3, 1fr); } }
.calc-field label{
  display: block;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-text-mute);
  margin-bottom: 8px;
}
.calc-field input, .calc-field select{
  width: 100%; padding: 14px 16px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-s);
  color: var(--color-text);
  font: inherit;
}
.calc__row + .calc__row{ margin-top: 18px; }
.calc__result{
  margin-top: 28px;
  padding: 28px 0 0;
  border-top: 1px solid var(--color-line);
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
  align-items: end;
}
@media (min-width: 720px){
  .calc__result{ grid-template-columns: 1.4fr auto; gap: 32px; }
}
.calc__breakdown{
  display: grid;
  gap: 8px;
}
.calc__line{
  display: flex; align-items: baseline; justify-content: space-between;
  gap: 16px;
  padding: 8px 0;
  font-size: .92rem;
  color: var(--color-text-mute);
}
.calc__line span:last-child{
  color: var(--color-text);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.calc__line--total{
  margin-top: 8px;
  padding-top: 18px;
  border-top: 1px dashed var(--color-line);
  font-size: 1rem;
  color: var(--color-sand);
}
.calc__line--total small{
  font-size: .7rem;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--color-text-mute);
  margin-left: 6px;
}
.calc__line--total .value{
  font-family: var(--font-display);
  font-size: clamp(1.8rem, 3.6vw, 2.4rem);
  color: var(--color-bronze);
  line-height: 1;
}
.calc__line--unit{
  font-size: .78rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* ---------- FAQ ---------- */
.faq{ display: grid; gap: 8px; }
.faq__item{
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  background: var(--color-surface);
  overflow: hidden;
  transition: border-color var(--dur) var(--ease);
}
.faq__item[open]{ border-color: rgba(201,168,103,.5); }
.faq__item summary{
  list-style: none;
  cursor: pointer;
  padding: 22px 26px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--color-sand);
}
.faq__item summary::-webkit-details-marker{ display: none; }
.faq__item summary::after{
  content: "+";
  font-family: var(--font-body);
  color: var(--color-bronze);
  font-size: 1.4rem;
  transition: transform var(--dur) var(--ease);
}
.faq__item[open] summary::after{ transform: rotate(45deg); }
.faq__item .answer{
  padding: 0 26px 26px;
  color: var(--color-text-mute);
}

/* ---------- Footer ---------- */
.site-footer{
  background: #070A10;
  border-top: 1px solid var(--color-line);
  padding-block: 80px 30px;
  color: var(--color-text-mute);
}
.footer-grid{
  display: grid; gap: 36px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){
  .footer-grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 900px){
  .footer-grid{ grid-template-columns: repeat(3, 1fr); }
}
@media (min-width: 1100px){
  .footer-grid{ grid-template-columns: 1.6fr 1fr 1fr 1fr 1fr; }
}
.footer-col h5{
  font-family: var(--font-body);
  font-size: .78rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 18px;
}
.footer-col ul{ list-style: none; display: grid; gap: 10px; }
.footer-col a:hover{ color: var(--color-sand); }
.footer-brand p{ margin-top: 14px; max-width: 32ch; font-size: .92rem; }
.footer-bottom{
  margin-top: 60px;
  padding-top: 24px;
  border-top: 1px solid var(--color-line);
  display: flex; justify-content: space-between; gap: 16px;
  flex-wrap: wrap;
  font-size: .82rem;
}

/* ---------- Mobile sticky CTA bar ---------- */
.mobile-cta{
  position: fixed;
  left: 12px; right: 12px; bottom: 12px;
  z-index: 40;
  display: none;
  gap: 8px;
  padding: 6px;
  background: rgba(30,53,96,.94);
  backdrop-filter: blur(16px);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  box-shadow: 0 22px 50px -12px rgba(0,0,0,.7), 0 0 0 1px rgba(201,168,103,.15);
}
.mobile-cta__btn{
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 999px;
  font-weight: 600;
  font-size: .9rem;
  letter-spacing: .02em;
  white-space: nowrap;
  transition: background var(--dur) var(--ease);
}
.mobile-cta__btn svg{ width: 16px; height: 16px; }
.mobile-cta__btn--phone{ color: var(--color-sand); }
.mobile-cta__btn--phone:hover{ background: var(--color-surface-2); }
.mobile-cta__btn--primary{ background: var(--color-bronze); color: var(--color-ink); }
.mobile-cta__btn--primary:hover{ background: var(--color-bronze-soft); }
@media (max-width: 880px){
  .mobile-cta{ display: flex; }
  body{ padding-bottom: 100px; }
}

/* ---------- Cases (P2) ---------- */
.cases-grid{
  display: grid;
  gap: 24px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){ .cases-grid{ grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1100px){
  .cases-grid{
    grid-template-columns: repeat(6, 1fr);
    grid-auto-rows: minmax(280px, auto);
  }
  /* Asymmetric premium layout: 2 large + 3 small */
  .case-card:nth-child(1){ grid-column: span 4; grid-row: span 2; }
  .case-card:nth-child(2){ grid-column: span 2; grid-row: span 1; }
  .case-card:nth-child(3){ grid-column: span 2; grid-row: span 1; }
  .case-card:nth-child(4){ grid-column: span 3; grid-row: span 1; }
  .case-card:nth-child(5){ grid-column: span 3; grid-row: span 1; }
}
.case-card{
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: var(--radius-l);
  border: 1px solid var(--color-line);
  background: var(--color-surface);
  isolation: isolate;
  min-height: 340px;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.case-card:hover{ transform: translateY(-4px); border-color: rgba(201,168,103,.5); }
.case-card__media{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
  transition: transform 1.4s var(--ease);
  z-index: 0;
}
.case-card:hover .case-card__media{ transform: scale(1.04); }
.case-card::before{
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(30,53,96,.02) 0%, rgba(30,53,96,.35) 50%, rgba(30,53,96,.82) 100%);
  z-index: 1;
}
.case-card__body{
  position: absolute; left: 24px; right: 24px; bottom: 24px;
  z-index: 2;
  color: var(--color-sand);
}
.case-card__kicker{
  display: inline-flex; align-items: center; gap: 8px;
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 12px;
}
.case-card__kicker .dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--color-bronze); }
.case-card__title{
  font-family: var(--font-display);
  font-size: clamp(1.4rem, 2.2vw, 1.9rem);
  line-height: 1.1;
  color: var(--color-sand);
  margin-bottom: 14px;
}
.case-card__specs{
  display: flex; flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 0;
}
.case-card__spec{
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 10px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  color: var(--color-sand-dim);
  backdrop-filter: blur(8px);
}
.case-card__spec strong{ color: var(--color-sand); font-weight: 600; }

/* ---------- Map (P2) ---------- */
.map-section{ padding-block: clamp(60px, 7vw, 100px); }
.map-wrap{
  position: relative;
  height: 460px;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
  background: var(--color-surface);
}
.map-wrap .leaflet-container{
  width: 100%; height: 100%;
  background: #0E1422;
  font-family: var(--font-body);
}
/* Dark theme for tiles */
.map-wrap .leaflet-tile-pane{ filter: brightness(.7) saturate(.8) hue-rotate(190deg); }
.map-wrap .leaflet-control-attribution{
  background: rgba(30,53,96,.7) !important;
  color: var(--color-text-mute) !important;
  font-size: .68rem !important;
}
.map-wrap .leaflet-control-attribution a{ color: var(--color-bronze) !important; }
.map-wrap .leaflet-control-zoom a{
  background: rgba(30,53,96,.85) !important;
  color: var(--color-sand) !important;
  border: 1px solid var(--color-line) !important;
}
.map-pin{
  display: grid; place-items: center;
  width: 28px; height: 28px;
  background: var(--color-bronze);
  border: 2px solid var(--color-sand);
  border-radius: 50%;
  color: #fff;
  font-size: .72rem;
  font-weight: 700;
  box-shadow: 0 0 0 6px rgba(201,168,103,.25), 0 8px 20px rgba(0,0,0,.5);
  animation: mapPulse 2.4s var(--ease) infinite;
}
@keyframes mapPulse{
  0%, 100%{ box-shadow: 0 0 0 6px rgba(201,168,103,.25), 0 8px 20px rgba(0,0,0,.5); }
  50%    { box-shadow: 0 0 0 12px rgba(201,168,103,.05), 0 8px 20px rgba(0,0,0,.5); }
}
.map-wrap .leaflet-popup-content-wrapper{
  background: var(--color-surface) !important;
  color: var(--color-sand) !important;
  border: 1px solid var(--color-line) !important;
  border-radius: var(--radius-m) !important;
  box-shadow: var(--shadow-card) !important;
}
.map-wrap .leaflet-popup-content{ font-family: var(--font-body) !important; margin: 14px 18px !important; font-size: .88rem !important; }
.map-wrap .leaflet-popup-tip{ background: var(--color-surface) !important; }
.map-wrap .leaflet-popup-content strong{ color: var(--color-bronze); display: block; margin-bottom: 4px; font-family: var(--font-display); font-size: 1.1rem; }

/* ---------- Team (P2) ---------- */
.team-grid{
  display: grid; gap: 22px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){ .team-grid{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 980px){ .team-grid{ grid-template-columns: repeat(4,1fr); } }
.team-card{
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: 32px 26px 28px;
  text-align: center;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.team-card:hover{ border-color: rgba(201,168,103,.4); transform: translateY(-3px); }
.team-card__avatar{
  width: 96px; height: 96px;
  margin: 0 auto 22px;
  border-radius: 50%;
  display: grid; place-items: center;
  background: linear-gradient(135deg, rgba(201,168,103,.25) 0%, rgba(38,52,82,.5) 100%);
  border: 1px solid rgba(201,168,103,.4);
  font-family: var(--font-display);
  font-size: 2rem;
  color: var(--color-sand);
  letter-spacing: .04em;
}
.team-card__name{
  font-family: var(--font-display);
  font-size: 1.3rem;
  color: var(--color-sand);
  margin-bottom: 4px;
}
.team-card__role{
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 16px;
}
.team-card__bio{
  color: var(--color-text-mute);
  font-size: .9rem;
  line-height: 1.6;
}

/* ---------- Works gallery (service pages) ---------- */
.works-section{ background: linear-gradient(180deg, transparent 0%, rgba(38,52,82,.3) 100%), var(--color-bg); }
.work-gallery{
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (min-width: 720px){ .work-gallery{ grid-template-columns: repeat(3, 1fr); gap: 16px; } }
@media (min-width: 1100px){ .work-gallery{ grid-template-columns: repeat(4, 1fr); } }
/* Premium rhythm: every 7th tile spans 2 cols + 2 rows for an editorial feel */
@media (min-width: 1100px){
  .work-gallery__item:nth-child(7n+1){ grid-column: span 2; grid-row: span 2; }
}
.work-gallery__item{
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  overflow: hidden;
  cursor: zoom-in;
  background: var(--color-surface);
  isolation: isolate;
  padding: 0;
}
.work-gallery__item img{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.4s var(--ease), filter var(--dur) var(--ease);
}
.work-gallery__item::after{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(30,53,96,.28) 100%);
  opacity: 0;
  transition: opacity var(--dur) var(--ease);
}
.work-gallery__item::before{
  content: "↗";
  position: absolute; top: 12px; right: 14px;
  z-index: 2;
  width: 34px; height: 34px;
  display: grid; place-items: center;
  border-radius: 50%;
  background: rgba(30,53,96,.65);
  border: 1px solid rgba(201,168,103,.4);
  color: var(--color-bronze);
  font-size: 1rem;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity var(--dur) var(--ease), transform var(--dur) var(--ease);
  backdrop-filter: blur(8px);
}
.work-gallery__item:hover{ border-color: rgba(201,168,103,.5); }
.work-gallery__item:hover img{ transform: scale(1.07); }
.work-gallery__item:hover::after{ opacity: 1; }
.work-gallery__item:hover::before{ opacity: 1; transform: translateY(0); }

/* ---------- Reveal on scroll ---------- */
.reveal{
  opacity: 0;
  transform: translateY(24px);
  transition: opacity .9s var(--ease), transform .9s var(--ease);
}
.reveal.is-visible{ opacity: 1; transform: none; }

/* ---------- Utils ---------- */
.center { text-align: center; }
.muted  { color: var(--color-text-mute); }
.divider{
  height: 1px;
  background: var(--color-line);
  margin-block: clamp(40px, 6vw, 80px);
}

/* ---------- Brand-bar / dealer status ---------- */
.dealer-bar{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 6px 14px 6px 8px;
  background: rgba(201,168,103,.08);
  border: 1px solid rgba(201,168,103,.3);
  border-radius: 999px;
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: var(--color-bronze-soft);
}
.dealer-bar .dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--color-bronze); }
.dealer-bar .yr{ color: var(--color-text-mute); }

/* ---------- About-brand block ---------- */
.brand-block{
  display: grid; gap: 56px;
  grid-template-columns: 1fr;
  align-items: center;
}
@media (min-width: 980px){ .brand-block{ grid-template-columns: 1fr 1fr; gap: 80px; } }
.brand-block__visual{
  position: relative;
  aspect-ratio: 5 / 6;
  border-radius: var(--radius-l);
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(30,53,96,.25) 0%, rgba(30,53,96,.15) 45%, rgba(30,53,96,.60) 100%),
    url('../img/brand/factory.webp?v=2') center/cover no-repeat;
  background-color: #131A2B;
  border: 1px solid var(--color-line);
}
.brand-block__visual::before{
  content: ""; position: absolute; inset: 0;
  background-image:
    radial-gradient(2px 2px at 25% 35%, rgba(255,255,255,.18), transparent 3px),
    radial-gradient(2px 2px at 70% 60%, rgba(255,255,255,.12), transparent 3px),
    radial-gradient(2px 2px at 45% 80%, rgba(255,255,255,.16), transparent 3px);
  background-size: 240px 240px;
  mix-blend-mode: screen;
}
.brand-block__visual .seal{
  position: absolute; top: 28px; left: 28px;
  width: 110px; height: 110px;
  border: 1px solid rgba(201,168,103,.6);
  border-radius: 50%;
  display: grid; place-items: center;
  font-family: var(--font-display);
  text-align: center;
  color: var(--color-sand);
  font-size: .78rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  line-height: 1.3;
  background: rgba(30,53,96,.4);
  backdrop-filter: blur(8px);
}
.brand-block__visual .seal strong{
  display: block;
  font-size: 1.6rem;
  letter-spacing: .04em;
  color: var(--color-bronze);
  margin-top: 4px;
}
.brand-block__visual .ribbon{
  position: absolute; bottom: 28px; left: 28px; right: 28px;
  padding: 18px 22px;
  background: rgba(30,53,96,.7);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: var(--radius-m);
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.brand-block__visual .ribbon .r-num{
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--color-bronze);
  line-height: 1;
}
.brand-block__visual .ribbon .r-lbl{
  font-size: .68rem; letter-spacing: .14em; text-transform: uppercase;
  color: var(--color-text-mute); margin-top: 4px;
}

/* ---------- Advantages (8-grid) ---------- */
.adv-grid{
  display: grid; gap: 14px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){ .adv-grid{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1024px){ .adv-grid{ grid-template-columns: repeat(4,1fr); } }
.adv{
  padding: 26px 24px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  transition: border-color var(--dur) var(--ease), background var(--dur) var(--ease);
}
.adv:hover{ border-color: rgba(201,168,103,.4); background: var(--color-surface-2); }
.adv .ico{
  width: 38px; height: 38px;
  color: var(--color-bronze);
  margin-bottom: 18px;
}
.adv h4{
  font-family: var(--font-display);
  font-size: 1.2rem;
  color: var(--color-sand);
  line-height: 1.2;
  margin-bottom: 8px;
}
.adv p{ font-size: .88rem; color: var(--color-text-mute); }

/* ---------- Before / After switcher ---------- */
.compare-wrap{ display: grid; gap: 22px; }
.compare-switcher{
  display: flex; flex-wrap: wrap; gap: 10px;
  padding: 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  width: max-content;
  max-width: 100%;
}
.compare-tab{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 10px 18px;
  border-radius: 999px;
  font-size: .82rem;
  letter-spacing: .04em;
  color: var(--color-text-mute);
  cursor: pointer;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  white-space: nowrap;
}
.compare-tab .ix{
  font-family: var(--font-display);
  font-size: .9rem;
  color: var(--color-bronze);
  letter-spacing: .04em;
}
.compare-tab:hover{ color: var(--color-sand); }
.compare-tab.is-active{
  background: var(--color-bronze);
  color: #fff;
}
.compare-tab.is-active .ix{ color: rgba(255,255,255,.85); }

/* ---------- Before / After slider ---------- */
.compare{
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 10;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
  user-select: none;
  cursor: ew-resize;
}
.compare__before, .compare__after{
  position: absolute; inset: 0;
  background-size: cover;
  background-position: center;
}
/* clip-path для правой стороны — общий */
.compare__after{ clip-path: inset(0 0 0 50%); }

.compare__before{ background-color: #e9eae8; }
/* Реальные пары «до / после» одного объекта (производитель FIRST) */
.compare[data-example="1"] .compare__before{ background: url('../img/compare-1-before.webp') center/cover no-repeat; }
.compare[data-example="1"] .compare__after { background: url('../img/compare-1-after.webp')   center/cover no-repeat; }
.compare[data-example="2"] .compare__before{ background: url('../img/compare-2-before.webp') center/cover no-repeat; }
.compare[data-example="2"] .compare__after { background: url('../img/compare-2-after.webp')   center/cover no-repeat; }
.compare[data-example="3"] .compare__before{ background: url('../img/compare-3-before.webp') center/cover no-repeat; }
.compare[data-example="3"] .compare__after { background: url('../img/compare-3-after.webp')   center/cover no-repeat; }
.compare[data-example="4"] .compare__before{ background: url('../img/compare-4-before.webp') center/cover no-repeat; }
.compare[data-example="4"] .compare__after { background: url('../img/compare-4-after.webp')   center/cover no-repeat; }
.compare[data-example] .compare__after{ clip-path: inset(0 0 0 50%); }
.compare__divider{
  position: absolute; top: 0; bottom: 0;
  left: 50%;
  width: 2px;
  background: var(--color-bronze);
  transform: translateX(-50%);
  pointer-events: none;
  box-shadow: 0 0 30px rgba(201,168,103,.5);
}
.compare__handle{
  position: absolute; top: 50%; left: 50%;
  width: 48px; height: 48px;
  transform: translate(-50%, -50%);
  border-radius: 50%;
  background: var(--color-bg);
  border: 2px solid var(--color-bronze);
  display: grid; place-items: center;
  color: var(--color-bronze);
  font-family: var(--font-body);
  font-size: 1.2rem;
  pointer-events: none;
  box-shadow: 0 10px 30px rgba(0,0,0,.5);
}
.compare__handle::before, .compare__handle::after{
  content: "‹"; font-size: 1.3rem; line-height: 1;
  width: 14px; text-align: center;
}
.compare__handle::after{ content: "›"; }
.compare__tag{
  position: absolute; top: 18px;
  padding: 8px 14px;
  background: rgba(30,53,96,.75);
  border: 1px solid rgba(255,255,255,.1);
  backdrop-filter: blur(10px);
  border-radius: 999px;
  font-size: .7rem;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--color-sand);
}
.compare__tag--before{ left: 18px; }
.compare__tag--after{ right: 18px; color: var(--color-bronze); border-color: rgba(201,168,103,.4); }

/* ---------- Textures carousel ---------- */
.tx-carousel{ position: relative; }
.tx-carousel__track{
  display: flex;
  gap: 22px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.tx-carousel__track::-webkit-scrollbar{ display: none; }
.tx-carousel__track .tx-card{
  flex: 0 0 calc(33.333% - 15px);
  scroll-snap-align: start;
}
@media (min-width: 720px) and (max-width: 1099px){
  .tx-carousel__track .tx-card{ flex: 0 0 calc(50% - 11px); }
}
@media (max-width: 719px){
  .tx-carousel__track .tx-card{ flex: 0 0 85%; }
}
.tx-carousel__nav{
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: 22px;
}
.tx-carousel__btn{
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(30,53,96,.9);
  border: 1px solid rgba(201,168,103,.5);
  color: var(--color-bronze);
  font-size: 2rem; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur) var(--ease), opacity var(--dur) var(--ease);
  flex-shrink: 0;
}
.tx-carousel__btn:hover{ background: rgba(201,168,103,.2); }
.tx-carousel__btn:disabled{ opacity: .25; pointer-events: none; }
.tx-carousel__count{
  font-family: var(--font-display);
  font-size: .85rem;
  color: var(--color-bronze-soft);
  letter-spacing: .08em;
  min-width: 48px;
  text-align: center;
}

.tx-card{
  position: relative;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
  isolation: isolate;
  min-height: 480px;
  display: flex; flex-direction: column; justify-content: flex-end;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.tx-card:hover{ transform: translateY(-4px); border-color: rgba(201,168,103,.5); }

.tx-card .tx-surface{ position: absolute; inset: 0; transition: transform 1.4s var(--ease); }
.tx-card:hover .tx-surface{ transform: scale(1.04); }

.tx-card .tx-overlay{
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 35%, rgba(7,10,16,.6) 70%, rgba(7,10,16,.92) 100%);
}

.tx-card .tx-zoom{
  position: absolute; top: 22px; right: 22px;
  padding: 8px 14px;
  background: rgba(30,53,96,.7);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(201,168,103,.3);
  border-radius: 999px;
  font-size: .68rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--color-bronze-soft);
  display: inline-flex; gap: 8px; align-items: center;
}
.tx-card .tx-zoom .dot{ width: 6px; height: 6px; border-radius: 50%; background: var(--color-bronze); }

.tx-card .tx-meta{
  position: relative;
  padding: 28px;
  z-index: 2;
}
.tx-card .tx-meta .tx-num{
  font-family: var(--font-display);
  color: var(--color-bronze);
  font-size: .92rem;
  letter-spacing: .06em;
}
.tx-card .tx-meta h3{
  font-family: var(--font-display);
  font-size: 1.8rem;
  color: var(--color-sand);
  margin: 8px 0 10px;
  line-height: 1.1;
}
.tx-card .tx-meta p{ color: var(--color-sand-dim); font-size: .92rem; max-width: 38ch; }
.tx-card .tx-meta .tx-specs{
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 18px;
}
.tx-card .tx-meta .tx-spec{
  padding: 6px 12px;
  background: rgba(201,168,103,.1);
  border: 1px solid rgba(201,168,103,.3);
  border-radius: 999px;
  font-size: .7rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--color-bronze-soft);
}

/* Realistic stone-paint textures — pure CSS */
.tx-card[data-texture="granite"] .tx-surface{
  background: url('../img/textures/h3000/001_01.webp') center/cover no-repeat;
  background-color: #2a2d33;
}

.tx-card[data-texture="travertine"] .tx-surface{
  background: url('../img/textures/t125-126-136/001_1.webp') center/cover no-repeat;
  background-color: #b59c75;
}

.tx-card[data-texture="marble"] .tx-surface{
  background: url('../img/textures/t526/004_MY004.webp') center/cover no-repeat;
  background-color: #e6e1d8;
}

/* ---------- In-Stock Carousel (homepage §instock) — portrait cards ---------- */
.stock-carousel{ position: relative; }
.stock-carousel__track{
  display: flex;
  gap: 18px;
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-bottom: 6px;
}
.stock-carousel__track::-webkit-scrollbar{ display: none; }

/* Portrait full-bleed card */
.stock-card{
  position: relative;
  flex: 0 0 calc(25% - 14px);
  min-height: 500px;
  scroll-snap-align: start;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.07);
  display: flex; flex-direction: column; justify-content: flex-end;
  text-decoration: none; color: inherit;
  isolation: isolate;
  cursor: pointer;
  transition: transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.stock-card:hover{
  transform: translateY(-7px) scale(1.015);
  box-shadow: 0 28px 64px -18px rgba(0,0,0,.75);
}

/* texture background — fills full card */
.stock-card__bg{
  position: absolute; inset: 0;
  background: var(--color-surface-2) center/cover no-repeat;
  z-index: 0;
  transition: transform 1.3s var(--ease);
}
.stock-card:hover .stock-card__bg{ transform: scale(1.07); }

/* dark gradient overlay — bottom-heavy */
.stock-card__overlay{
  position: absolute; inset: 0;
  background: linear-gradient(
    180deg,
    rgba(8,13,26,0)   0%,
    rgba(8,13,26,.18) 40%,
    rgba(8,13,26,.82) 68%,
    rgba(8,13,26,.97) 100%
  );
  z-index: 1;
}

/* info block at bottom */
.stock-card__info{
  position: relative;
  z-index: 2;
  padding: 22px 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.stock-card__title{
  font-family: var(--font-display);
  font-size: 1.3rem;
  font-weight: 500;
  color: #fff;
  line-height: 1.15;
  margin: 0;
}
.stock-card__stars{
  color: var(--color-bronze);
  font-size: .85rem;
  letter-spacing: 3px;
  margin: 2px 0;
}
.stock-card__art{
  font-size: .72rem;
  letter-spacing: .1em;
  color: rgba(255,255,255,.55);
  font-family: var(--font-body);
}
.stock-card__price{
  font-size: .82rem;
  color: rgba(255,255,255,.65);
  margin-top: 1px;
}
.stock-card__price strong{
  color: var(--color-bronze-soft);
  font-weight: 700;
}
.stock-card__btn{
  display: inline-block;
  margin-top: 12px;
  padding: 10px 22px;
  background: rgba(20,34,64,.72);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(201,168,103,.35);
  border-radius: 999px;
  font-size: .8rem;
  font-family: var(--font-body);
  letter-spacing: .04em;
  color: var(--color-sand);
  text-align: center;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.stock-card:hover .stock-card__btn{
  background: rgba(201,168,103,.22);
  border-color: rgba(201,168,103,.65);
  color: #fff;
}

/* nav */
.stock-carousel__nav{
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
  margin-top: 24px;
}
.stock-carousel__btn{
  width: 48px; height: 48px;
  border-radius: 50%;
  background: rgba(30,53,96,.9);
  border: 1px solid rgba(201,168,103,.5);
  color: var(--color-bronze);
  font-size: 2rem; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--dur) var(--ease);
  flex-shrink: 0;
}
.stock-carousel__btn:hover{ background: rgba(201,168,103,.2); }
.stock-carousel__btn:disabled{ opacity: .25; pointer-events: none; }
.stock-carousel__count{
  font-family: var(--font-display);
  font-size: .85rem;
  color: var(--color-bronze-soft);
  letter-spacing: .08em;
  min-width: 52px;
  text-align: center;
}

/* responsive */
@media (min-width: 900px) and (max-width: 1199px){
  .stock-card{ flex: 0 0 calc(33.333% - 12px); }
}
@media (min-width: 600px) and (max-width: 899px){
  .stock-card{ flex: 0 0 calc(50% - 9px); min-height: 440px; }
}
@media (max-width: 599px){
  .stock-card{ flex: 0 0 78%; min-height: 400px; }
  .stock-card__title{ font-size: 1.15rem; }
  .stock-card__info{ padding: 18px 16px 20px; }
}

/* ---------- Catalog (3 directions) ---------- */
.catalog{
  display: grid; gap: 18px;
  grid-template-columns: 1fr;
}
@media (min-width: 720px){ .catalog{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 1100px){ .catalog{ grid-template-columns: repeat(3,1fr); } }
.cat-card{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
  isolation: isolate;
  display: block;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.cat-card:hover{ transform: translateY(-4px); border-color: rgba(201,168,103,.5); }
.cat-card .cat-bg{ position: absolute; inset: 0; }
.cat-card[data-cat="paint"] .cat-bg{
  background:
    radial-gradient(2px 2px at 30% 30%, rgba(0,0,0,.18), transparent 3px),
    radial-gradient(2px 2px at 60% 70%, rgba(0,0,0,.15), transparent 3px),
    linear-gradient(135deg, #d8c4a0 0%, #9c8359 100%);
}
.cat-card[data-cat="floor"] .cat-bg{
  background:
    radial-gradient(2px 2px at 25% 25%, rgba(255,255,255,.1), transparent 3px),
    linear-gradient(135deg, #3a3a3e 0%, #1c1c1f 100%);
}
.cat-card[data-cat="panel"] .cat-bg{
  background:
    linear-gradient(120deg, rgba(255,255,255,.18), transparent 50%),
    linear-gradient(135deg, #e4dbcb 0%, #b3a78f 100%);
}
.cat-card[data-cat="ceramic"] .cat-bg{
  background:
    radial-gradient(70% 60% at 40% 30%, rgba(255,255,255,.2), transparent 60%),
    linear-gradient(135deg, #d6cdbc 0%, #7b6e58 100%);
}
.cat-card .cat-overlay{
  position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(22,32,52,.85) 100%);
}
.cat-card .cat-meta{
  position: absolute; bottom: 24px; left: 24px; right: 24px;
}
.cat-card .cat-meta .num{
  color: var(--color-bronze);
  font-family: var(--font-display);
  font-size: .9rem;
}
.cat-card .cat-meta h3{
  font-family: var(--font-display);
  font-size: 1.6rem;
  color: var(--color-sand);
  margin: 6px 0 8px;
  line-height: 1.1;
}
.cat-card .cat-meta p{ font-size: .85rem; color: var(--color-text-mute); }
.cat-card .cat-meta .more{
  margin-top: 14px;
  display: inline-flex; gap: 8px; align-items: center;
  color: var(--color-bronze); font-size: .78rem;
  letter-spacing: .14em; text-transform: uppercase;
}

/* ---------- Price card ---------- */
.price-card{
  display: grid; gap: 28px;
  grid-template-columns: 1fr;
  align-items: center;
  padding: clamp(28px, 4vw, 48px);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  position: relative;
  overflow: hidden;
}
@media (min-width: 720px){
  .price-card{ grid-template-columns: 1.4fr auto; }
}
.price-card::before{
  content: ""; position: absolute; inset: 0;
  background: radial-gradient(60% 80% at 100% 50%, rgba(201,168,103,.18), transparent 70%);
  pointer-events: none;
}
.price-card h3{
  font-family: var(--font-display);
  font-size: clamp(1.5rem, 3vw, 2.2rem);
  color: var(--color-sand);
  margin-bottom: 10px;
}
.price-card p{ color: var(--color-text-mute); max-width: 50ch; }
.price-card .actions{ display: flex; gap: 12px; flex-wrap: wrap; }

/* ---------- Catalog filter tabs ---------- */
.cat-filter{
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  width: max-content;
  max-width: 100%;
}
.cat-filter button{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 22px;
  border-radius: 999px;
  font-size: .82rem;
  letter-spacing: .04em;
  color: var(--color-text-mute);
  cursor: pointer;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  white-space: nowrap;
}
.cat-filter button:hover{ color: var(--color-sand); }
.cat-filter button.is-active{
  background: var(--color-bronze);
  color: #fff;
}
.cat-filter button .badge{
  display: inline-grid; place-items: center;
  min-width: 24px; height: 22px; padding: 0 6px;
  background: rgba(201,168,103,.18);
  border: 1px solid rgba(201,168,103,.35);
  color: var(--color-bronze-soft);
  border-radius: 999px;
  font-size: .68rem;
  letter-spacing: .04em;
}
.cat-filter button.is-active .badge{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.4);
  color: #fff;
}

/* ---------- Product grid ---------- */
.product-grid{
  display: grid; gap: 18px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){ .product-grid{ grid-template-columns: repeat(2,1fr); gap: 22px; } }
@media (min-width: 960px){ .product-grid{ grid-template-columns: repeat(3,1fr); } }
@media (min-width: 1280px){ .product-grid{ grid-template-columns: repeat(4,1fr); } }

/* ---------- PRODUCT CARD (Premium redesign) ---------- */
.product-card{
  display: flex; flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  overflow: hidden;
  cursor: pointer;
  position: relative;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  text-align: left;
  width: 100%;
  isolation: isolate;
}
.product-card::before{
  content: "";
  position: absolute; inset: 0;
  background: radial-gradient(120% 60% at 0% 0%, rgba(201,168,103,.12), transparent 60%);
  opacity: 0;
  pointer-events: none;
  z-index: -1;
  transition: opacity var(--dur) var(--ease);
}
.product-card:hover{
  transform: translateY(-6px);
  border-color: rgba(201,168,103,.55);
  box-shadow: 0 30px 60px -28px rgba(0,0,0,.7), 0 0 0 1px rgba(201,168,103,.15);
}
.product-card:hover::before{ opacity: 1; }

.product-card__media{
  position: relative;
  aspect-ratio: 5 / 4;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(201,168,103,.12), transparent 70%),
    linear-gradient(135deg, #131A2B 0%, #0A0E18 100%);
  overflow: hidden;
}
.product-card__media::after{
  content: "";
  position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(30,53,96,.0) 40%, rgba(30,53,96,.28) 100%);
  pointer-events: none;
  z-index: 1;
}
.product-card__media img{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.6s var(--ease), filter var(--dur) var(--ease);
  filter: saturate(1.05);
}
.product-card:hover .product-card__media img{ transform: scale(1.07); filter: saturate(1.15); }
.product-card__media .ph{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 2.8rem;
  color: var(--color-bronze);
  letter-spacing: .04em;
}
.product-card__oos{
  position: absolute; bottom: 12px; left: 0; right: 0;
  text-align: center;
  padding: 7px 14px;
  background: rgba(180,40,40,.82);
  backdrop-filter: blur(8px);
  font-size: .68rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: #fff;
  font-family: var(--font-body);
}
.product-card.is-oos .product-card__media{ opacity: .7; }
.product-card__badge{
  position: absolute; top: 16px; left: 16px;
  padding: 7px 14px;
  background: rgba(30,53,96,.78);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(201,168,103,.35);
  border-radius: 999px;
  font-size: .66rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--color-bronze-soft);
  z-index: 2;
}
.product-card__body{
  padding: 26px 24px 24px;
  display: flex; flex-direction: column;
  gap: 10px;
  flex: 1;
}
.product-card__sub{
  font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
  color: var(--color-bronze);
  display: inline-flex; align-items: center; gap: 10px;
}
.product-card__sub::before{
  content: "";
  width: 22px; height: 1px;
  background: currentColor;
  opacity: .7;
}
.product-card__title{
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 1.4rem;
  line-height: 1.15;
  color: var(--color-sand);
  margin: 0;
  letter-spacing: -.005em;
}
.product-card__desc{
  margin-top: 4px;
  font-size: .9rem;
  line-height: 1.55;
  color: var(--color-text-mute);
  display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical;
  overflow: hidden;
}
.product-card__foot{
  margin-top: auto;
  padding-top: 18px;
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 12px;
  border-top: 1px solid var(--color-line);
}
.product-card__price{
  font-family: var(--font-display);
  font-weight: 500;
  color: var(--color-bronze);
  font-size: 1.4rem;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -.01em;
}
.product-card__price small{
  font-family: var(--font-body);
  font-weight: 400;
  display: block;
  font-size: .64rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-text-mute);
  margin-top: 6px;
}
.product-card__more{
  font-size: .72rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--color-bronze);
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
  transition: gap var(--dur) var(--ease);
}
.product-card:hover .product-card__more{ gap: 14px; }
.product-card__more::after{
  content: "→";
  font-size: 1rem;
  transition: transform var(--dur) var(--ease);
}
.product-card:hover .product-card__more::after{ transform: translateX(4px); }

/* ---------- PRODUCT CARD palette swatches strip (hidden) ---------- */
.product-card__palette{ display: none !important; }

/* ---------- PRODUCT CARD shade count badge ---------- */
.product-card__shade-count{
  position: absolute;
  bottom: 12px;
  left: 12px;
  background: rgba(14,26,48,.72);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--color-bronze);
  font-size: .7rem;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  padding: 5px 11px;
  border-radius: 20px;
  pointer-events: none;
  transition: opacity .3s;
}
.product-card:hover .product-card__shade-count{ opacity: .85; }
.product-card__palette-hidden{
  position: absolute; left: 16px; right: 16px; bottom: 16px;
  display: flex; align-items: center;
  gap: 6px;
  z-index: 2;
  pointer-events: none;
}
.product-card__palette .sw{
  width: 34px; height: 34px;
  border-radius: 50%;
  border: 2px solid rgba(30,53,96,.85);
  box-shadow: 0 0 0 1px rgba(201,168,103,.35), 0 6px 14px rgba(0,0,0,.45);
  background-size: cover;
  background-position: center;
  transition: transform var(--dur) var(--ease), margin-left var(--dur) var(--ease);
  margin-left: -10px;
}
.product-card__palette .sw:first-child{ margin-left: 0; }
.product-card:hover .product-card__palette .sw{ margin-left: -4px; transform: translateY(-2px); }
.product-card:hover .product-card__palette .sw:first-child{ margin-left: 0; }
.product-card__palette .sw--more{
  background: rgba(30,53,96,.85);
  backdrop-filter: blur(10px);
  display: grid; place-items: center;
  color: var(--color-sand);
  font-family: var(--font-display);
  font-size: .82rem;
  font-weight: 500;
  letter-spacing: .02em;
}

/* ---------- Product detail PAGE (product.html) ---------- */
.product-page-section{
  padding-top: clamp(110px, 14vw, 150px);
  padding-bottom: clamp(50px, 8vw, 100px);
}
.product-page-section .breadcrumbs{ margin-bottom: 24px; }
.product-page{
  display: grid;
  grid-template-columns: 1fr;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  max-width: 100%;
}
@media (min-width: 900px){
  .product-page{ grid-template-columns: 1fr 1.2fr; }
}
/* Защита от grid-blowout: грид-айтемы не должны раздуваться шире колонки */
.product-page > *{ min-width: 0; }
.product-page .product-modal__media,
.product-page .product-modal__body{ min-width: 0; max-width: 100%; }
.product-page .product-modal__thumbs{ max-width: 100%; }
.product-page .product-modal__title{ overflow-wrap: anywhere; }
.product-page .product-modal__specs .row{ min-width: 0; }
.product-page .product-modal__specs .val{ overflow-wrap: anywhere; }
.product-page__visual{
  display: flex;
  flex-direction: column;
  min-width: 0;
  align-self: start;
  position: sticky;
  top: 90px;
}
.product-page .product-modal__media{
  position: relative;
  aspect-ratio: 4 / 3;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(201,168,103,.18), transparent 70%),
    linear-gradient(135deg, #131A2B 0%, #0A0E18 100%);
  overflow: hidden;
  flex-shrink: 0;
}
/* Палитра под фото — встроена в визуальную колонку, без внешних отступов */
.product-page__visual .product-modal__gallery{
  margin: 0;
  border: 0;
  border-top: 1px solid var(--color-line);
  border-radius: 0;
  background: var(--color-surface-2);
}
.product-page .product-modal__media img{ width: 100%; height: 100%; object-fit: cover; }
.product-page .product-modal__media .ph{
  position: absolute; inset: 0; display: grid; place-items: center;
  font-family: var(--font-display); font-size: 3.4rem; color: var(--color-bronze);
}
.product-page .product-modal__body{
  padding: clamp(28px, 4vw, 48px);
  max-height: none;
  overflow: visible;
}
.product-page__loading, .product-page__empty{
  grid-column: 1 / -1;
  padding: clamp(50px, 9vw, 100px) 30px;
  text-align: center;
  color: var(--color-text-mute);
}
.product-page__empty h2{
  font-family: var(--font-display);
  color: var(--color-sand);
  font-size: clamp(1.6rem, 3vw, 2.2rem);
  margin-bottom: 12px;
}
.product-page__empty p{ max-width: 44ch; margin: 0 auto 22px; }

/* ---------- Product modal ---------- */
.product-modal{
  position: fixed; inset: 0;
  background: rgba(7,10,16,.78);
  backdrop-filter: blur(10px);
  z-index: 70;
  /* Flex с прижатием к верху — надёжнее grid+place-items в моб. браузерах */
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  padding: 80px 20px 20px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  opacity: 0; visibility: hidden;
  transition: opacity var(--dur) var(--ease), visibility var(--dur);
}
.product-modal.is-open{ opacity: 1; visibility: visible; }
.product-modal__panel{
  width: 100%;
  max-width: 1100px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr;
  position: relative;
  transform: translateY(20px);
  transition: transform var(--dur) var(--ease);
}
.product-modal.is-open .product-modal__panel{ transform: none; }
@media (min-width: 900px){
  .product-modal__panel{ grid-template-columns: 1fr 1.2fr; }
}
.product-modal__close{
  position: absolute; top: 14px; right: 14px;
  width: 44px; height: 44px;
  background: rgba(30,53,96,.8);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  display: grid; place-items: center;
  color: var(--color-sand);
  font-size: 1.4rem;
  cursor: pointer;
  z-index: 2;
  transition: background var(--dur) var(--ease);
}
.product-modal__close:hover{ background: var(--color-bronze); color: var(--color-ink); }
.product-modal__media{
  position: relative;
  aspect-ratio: 1 / 1;
  background:
    radial-gradient(60% 60% at 30% 30%, rgba(201,168,103,.18), transparent 70%),
    linear-gradient(135deg, #131A2B 0%, #0A0E18 100%);
  overflow: hidden;
}
@media (min-width: 900px){ .product-modal__media{ aspect-ratio: auto; height: 100%; } }
.product-modal__media img{ width: 100%; height: 100%; object-fit: cover; }
.product-modal__media .ph{
  position: absolute; inset: 0;
  display: grid; place-items: center;
  font-family: var(--font-display);
  font-size: 3.4rem;
  color: var(--color-bronze);
  letter-spacing: .04em;
}
.product-modal__body{
  padding: 36px clamp(22px, 3vw, 40px);
  overflow-y: auto;
  max-height: 80vh;
}
.product-modal__sub{
  font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--color-bronze);
  margin-bottom: 12px;
}
.product-modal__title{
  font-family: var(--font-display);
  font-size: clamp(1.6rem, 2.6vw, 2.2rem);
  color: var(--color-sand);
  line-height: 1.1;
  margin-bottom: 18px;
}
.product-modal__desc{ color: var(--color-text-mute); margin-bottom: 26px; line-height: 1.7; }
.product-modal h4{
  font-size: .72rem; letter-spacing: .2em; text-transform: uppercase;
  color: var(--color-bronze);
  margin: 22px 0 12px;
}
.product-modal ul{
  list-style: none;
  display: grid; gap: 8px;
}
.product-modal ul li{
  position: relative;
  padding-left: 22px;
  font-size: .92rem;
  color: var(--color-text);
}
.product-modal ul li::before{
  content: "";
  position: absolute; left: 0; top: 10px;
  width: 12px; height: 1px;
  background: var(--color-bronze);
}
.product-modal__specs{
  display: grid; gap: 6px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  padding: 18px 22px;
  margin: 14px 0;
}
.product-modal__specs .row{
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 16px;
  padding: 10px 0;
  border-bottom: 1px solid var(--color-line);
  align-items: baseline;
}
.product-modal__specs .row:last-child{ border-bottom: 0; }
.product-modal__specs .lbl{
  font-size: .82rem;
  color: var(--color-text-mute);
}
.product-modal__specs .val{
  font-family: var(--font-display);
  color: var(--color-sand);
  font-size: 1.05rem;
  text-align: right;
}
.product-modal__price{
  display: grid; gap: 8px;
  grid-template-columns: 1fr 1fr;
  margin: 18px 0 22px;
}
.product-modal__price .pill{
  padding: 14px 18px;
  background: rgba(201,168,103,.08);
  border: 1px solid rgba(201,168,103,.3);
  border-radius: var(--radius-m);
}
.product-modal__price .pill .lbl{ font-size: .68rem; letter-spacing: .14em; text-transform: uppercase; color: var(--color-text-mute); }
.product-modal__price .pill .val{ font-family: var(--font-display); color: var(--color-bronze); font-size: 1.6rem; margin-top: 4px; }
.product-modal__actions{ display: flex; gap: 10px; flex-wrap: wrap; margin-top: 22px; }

/* (legacy palette-count badge removed — replaced by .product-card__palette swatches strip) */

/* ---------- Product modal — palette gallery ---------- */
.product-modal__shade-meta{
  position: absolute; left: 18px; bottom: 18px; right: 18px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(30,53,96,.78);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(201,168,103,.3);
  border-radius: var(--radius-m);
  pointer-events: none;
  z-index: 3;
}
.product-modal__shade-meta .grp{
  font-size: .66rem; letter-spacing: .16em; text-transform: uppercase;
  color: var(--color-text-mute);
}
.product-modal__shade-meta .shade{
  font-family: var(--font-display);
  color: var(--color-sand);
  font-size: 1.1rem;
  margin-top: 4px;
}
.product-modal__shade-meta .counter{
  font-family: var(--font-display);
  color: var(--color-bronze);
  font-size: .98rem;
  white-space: nowrap;
}

.product-modal__gallery{
  margin: 18px 0 26px;
  padding: 14px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
}
.product-modal__gallery-head{
  display: flex; justify-content: space-between; align-items: center; gap: 16px;
  padding: 0 4px 12px;
  border-bottom: 1px solid var(--color-line);
  margin-bottom: 12px;
}
.product-modal__gallery-head h4{
  margin: 0;
  color: var(--color-bronze);
  font-size: .72rem;
  letter-spacing: .2em;
  text-transform: uppercase;
}
.product-modal__gallery-head .nav{
  display: flex; gap: 6px;
}
.product-modal__gallery-head .nav button{
  width: 32px; height: 32px;
  display: grid; place-items: center;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-sand);
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.product-modal__gallery-head .nav button:hover{
  background: var(--color-bronze);
  border-color: var(--color-bronze);
  color: #fff;
}

.product-modal__thumbs{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: 130px;
  gap: 12px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: thin;
  scrollbar-color: var(--color-bronze) transparent;
  padding: 4px 4px 10px;
}
.product-modal__thumbs::-webkit-scrollbar{ height: 8px; }
.product-modal__thumbs::-webkit-scrollbar-thumb{ background: var(--color-bronze); border-radius: 999px; }
.product-modal__thumbs::-webkit-scrollbar-track{ background: var(--color-surface); border-radius: 999px; }

.product-modal__thumb{
  position: relative;
  aspect-ratio: 1 / 1;
  border-radius: var(--radius-m);
  overflow: hidden;
  border: 2px solid var(--color-line);
  cursor: pointer;
  background: var(--color-surface);
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
  padding: 0;
  isolation: isolate;
}
.product-modal__thumb img{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur) var(--ease);
}
.product-modal__thumb:hover{
  border-color: rgba(201,168,103,.6);
  transform: translateY(-3px);
  box-shadow: 0 12px 24px -10px rgba(0,0,0,.6);
}
.product-modal__thumb:hover img{ transform: scale(1.06); }
.product-modal__thumb.is-active{
  border-color: var(--color-bronze);
  box-shadow: 0 0 0 3px rgba(201,168,103,.25), 0 14px 28px -10px rgba(0,0,0,.7);
  transform: translateY(-3px);
}
.product-modal__thumb .name{
  position: absolute; left: 6px; right: 6px; bottom: 6px;
  padding: 5px 9px;
  background: rgba(30,53,96,.85);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 6px;
  font-size: .68rem;
  color: var(--color-sand);
  text-align: center;
  letter-spacing: .04em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  pointer-events: none;
}

/* Loading state */
.catalog-loading{ padding: 60px 0; text-align: center; color: var(--color-text-mute); }

/* ---------- Works carousel (homepage) ---------- */
.works-carousel{
  position: relative;
}
.works-carousel__head{
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
  margin-bottom: 28px;
}
.works-carousel__nav{ display: flex; gap: 10px; }
.works-carousel__nav button{
  width: 44px; height: 44px;
  display: grid; place-items: center;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-sand);
  cursor: pointer;
  font-size: 1.2rem;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.works-carousel__nav button:hover{
  background: var(--color-bronze);
  border-color: var(--color-bronze);
  color: #fff;
}
.works-carousel__track{
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: clamp(280px, 30vw, 380px);
  gap: 18px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scroll-snap-type: x mandatory;
  scrollbar-width: thin;
  scrollbar-color: var(--color-bronze) transparent;
  padding-bottom: 6px;
}
.works-carousel__track::-webkit-scrollbar{ height: 6px; }
.works-carousel__track::-webkit-scrollbar-thumb{ background: var(--color-bronze); border-radius: 999px; }
.works-carousel__track::-webkit-scrollbar-track{ background: transparent; }

.work-tile{
  position: relative;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-l);
  overflow: hidden;
  border: 1px solid var(--color-line);
  scroll-snap-align: start;
  cursor: pointer;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease);
  background: var(--color-surface);
  padding: 0;
  width: 100%;
}
.work-tile:hover{ transform: translateY(-4px); border-color: rgba(201,168,103,.5); }
.work-tile img{
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform 1.4s var(--ease);
}
.work-tile:hover img{ transform: scale(1.06); }
.work-tile__cat{
  position: absolute; left: 16px; bottom: 16px;
  padding: 8px 14px;
  background: rgba(30,53,96,.78);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(201,168,103,.35);
  border-radius: 999px;
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-sand);
}

/* ---------- Works full grid (works.html) ---------- */
.works-grid{
  columns: 1;
  column-gap: 18px;
}
@media (min-width: 600px){ .works-grid{ columns: 2; } }
@media (min-width: 900px){ .works-grid{ columns: 3; } }
@media (min-width: 1280px){ .works-grid{ columns: 4; } }

.work-photo{
  break-inside: avoid;
  margin-bottom: 18px;
  border-radius: var(--radius-m);
  overflow: hidden;
  border: 1px solid var(--color-line);
  background: var(--color-surface);
  cursor: pointer;
  display: block;
  width: 100%;
  padding: 0;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease);
}
.work-photo:hover{ border-color: rgba(201,168,103,.6); transform: translateY(-3px); }
.work-photo img{
  display: block;
  width: 100%; height: auto;
}

.works-empty{ padding: 60px 0; text-align: center; color: var(--color-text-mute); }

/* ---------- Lightbox ---------- */
.lightbox{
  position: fixed; inset: 0;
  background: rgba(7,10,16,.92);
  backdrop-filter: blur(8px);
  z-index: 80;
  display: none;
  align-items: center; justify-content: center;
  padding: 40px;
}
.lightbox.is-open{ display: flex; }
.lightbox__image{
  max-width: 100%;
  max-height: calc(100vh - 120px);
  object-fit: contain;
  border-radius: var(--radius-m);
  box-shadow: 0 30px 80px -20px rgba(0,0,0,.7);
}
.lightbox__close, .lightbox__prev, .lightbox__next{
  position: absolute;
  width: 50px; height: 50px;
  display: grid; place-items: center;
  background: rgba(30,53,96,.7);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  color: var(--color-sand);
  font-size: 1.4rem;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.lightbox__close{ top: 24px; right: 24px; }
.lightbox__prev{ left: 24px; top: 50%; transform: translateY(-50%); }
.lightbox__next{ right: 24px; top: 50%; transform: translateY(-50%); }
.lightbox__close:hover, .lightbox__prev:hover, .lightbox__next:hover{
  background: var(--color-bronze);
  border-color: var(--color-bronze);
  color: #fff;
}
.lightbox__counter{
  position: absolute; bottom: 24px; left: 50%; transform: translateX(-50%);
  padding: 8px 18px;
  background: rgba(30,53,96,.75);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  font-family: var(--font-display);
  color: var(--color-sand);
  font-size: 1rem;
}

/* ---------- Certificates block ---------- */
.cert-tabs{
  display: flex; flex-wrap: wrap; gap: 8px;
  padding: 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: 999px;
  margin-bottom: 32px;
  max-width: 100%;
}
.cert-tabs button{
  display: inline-flex; align-items: center; gap: 10px;
  padding: 12px 22px;
  border-radius: 999px;
  font-size: .82rem;
  letter-spacing: .04em;
  color: var(--color-text-mute);
  cursor: pointer;
  transition: color var(--dur) var(--ease), background var(--dur) var(--ease);
  white-space: nowrap;
}
.cert-tabs button:hover{ color: var(--color-sand); }
.cert-tabs button.is-active{
  background: var(--color-bronze);
  color: #fff;
}
.cert-tabs button .badge{
  display: inline-grid; place-items: center;
  min-width: 24px; height: 22px; padding: 0 6px;
  background: rgba(201,168,103,.18);
  border: 1px solid rgba(201,168,103,.35);
  color: var(--color-bronze-soft);
  border-radius: 999px;
  font-size: .68rem;
}
.cert-tabs button.is-active .badge{
  background: rgba(255,255,255,.18);
  border-color: rgba(255,255,255,.4);
  color: #fff;
}

.cert-grid{
  display: grid; gap: 16px;
  grid-template-columns: 1fr;
}
@media (min-width: 600px){ .cert-grid{ grid-template-columns: repeat(2,1fr); } }
@media (min-width: 960px){ .cert-grid{ grid-template-columns: repeat(3,1fr); } }
@media (min-width: 1280px){ .cert-grid{ grid-template-columns: repeat(4,1fr); } }

.cert-card{
  position: relative;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: 24px 22px 22px;
  display: flex; flex-direction: column;
  gap: 12px;
  transition: transform var(--dur) var(--ease), border-color var(--dur) var(--ease), background var(--dur) var(--ease);
  isolation: isolate;
  overflow: hidden;
}
.cert-card::before{
  content: ""; position: absolute; inset: -1px;
  background: radial-gradient(60% 80% at 100% 0%, rgba(201,168,103,.16), transparent 70%);
  opacity: 0; transition: opacity var(--dur) var(--ease);
  z-index: -1;
}
.cert-card:hover{
  transform: translateY(-4px);
  border-color: rgba(201,168,103,.5);
  background: var(--color-surface-2);
}
.cert-card:hover::before{ opacity: 1 }

.cert-icon{
  width: 54px; height: 64px;
  border-radius: 6px;
  background: linear-gradient(180deg, #1A2540 0%, #131A2B 100%);
  border: 1px solid rgba(201,168,103,.35);
  position: relative;
  flex: 0 0 auto;
  display: grid; place-items: center;
  color: var(--color-bronze-soft);
  font-family: var(--font-display);
  font-weight: 500;
  letter-spacing: .04em;
  font-size: .82rem;
}
.cert-icon::after{
  content: "";
  position: absolute; top: 0; right: 0;
  border-style: solid;
  border-width: 0 14px 14px 0;
  border-color: transparent var(--color-bronze) transparent transparent;
}
.cert-icon::before{
  content: "";
  position: absolute; top: 0; right: 0;
  width: 14px; height: 14px;
  background: linear-gradient(135deg, rgba(255,255,255,.18) 0%, transparent 50%);
  pointer-events: none;
}

.cert-card__cat{
  font-size: .68rem; letter-spacing: .18em; text-transform: uppercase;
  color: var(--color-bronze);
}
.cert-card__title{
  font-family: var(--font-display);
  font-size: 1.05rem;
  line-height: 1.3;
  color: var(--color-sand);
  margin: 4px 0 6px;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.cert-card__meta{
  font-size: .74rem;
  letter-spacing: .08em;
  color: var(--color-text-mute);
  margin-top: auto;
}
.cert-card__actions{
  margin-top: 14px;
  display: flex; gap: 8px;
  border-top: 1px solid var(--color-line);
  padding-top: 14px;
}
.cert-card__btn{
  flex: 1;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  padding: 10px 14px;
  border-radius: var(--radius-s);
  font-size: .78rem;
  letter-spacing: .06em;
  transition: background var(--dur) var(--ease), color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.cert-card__btn--primary{
  background: var(--color-bronze);
  color: #fff;
}
.cert-card__btn--primary:hover{ background: var(--color-bronze-soft); color: #1E3560; }
.cert-card__btn--ghost{
  background: transparent;
  border: 1px solid var(--color-line);
  color: var(--color-text);
}
.cert-card__btn--ghost:hover{ border-color: var(--color-bronze); color: var(--color-bronze); }

/* ---------- Page header (inner pages) ---------- */
.page-hero{
  position: relative;
  padding-top: 200px;
  padding-bottom: 80px;
  background:
    radial-gradient(50% 80% at 80% 0%, rgba(201,168,103,.18), transparent 70%),
    linear-gradient(180deg, #192848 0%, #1E3560 100%);
}
/* Blog hero with background image */
.page-hero--bg{
  background-color: #0e1a30;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
.page-hero--bg::before{
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(50% 80% at 80% 0%, rgba(201,168,103,.12), transparent 70%),
    linear-gradient(180deg, rgba(10,18,38,.40) 0%, rgba(18,34,64,.48) 100%);
  z-index: 0;
}
.page-hero--bg > .container{ position: relative; z-index: 1; }
.page-hero .breadcrumbs{
  display: flex; gap: 10px;
  font-size: .8rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--color-text-mute);
  margin-bottom: 22px;
}
.page-hero .breadcrumbs a:hover{ color: var(--color-bronze); }
.page-hero h1{ margin-bottom: 24px; }
.page-hero .lead{ font-size: 1.1rem; }

/* ---------- Print friendliness ---------- */
@media (prefers-reduced-motion: reduce){
  *, *::before, *::after{
    transition: none !important;
    animation: none !important;
  }
}

/* =========================================================
   MOBILE ADAPTATION  (≤ 900 px)
   Iterates from broad tablet rules to tight phone rules
   ========================================================= */

/* ---- Tablet & smaller (≤ 900px) ---- */
@media (max-width: 900px){
  :root{ --gutter: clamp(16px, 4vw, 40px); }
  section{ padding-block: clamp(36px, 5vw, 60px); }
  .section-head{ gap: 14px; margin-bottom: 36px; }
  .h1{ font-size: clamp(2.2rem, 7vw, 3.6rem); }
  .h2{ font-size: clamp(1.7rem, 4.8vw, 2.6rem); }
  .h3{ font-size: clamp(1.25rem, 3.4vw, 1.6rem); }

  /* Hero */
  .hero{ padding-top: 130px; padding-bottom: 60px; min-height: auto; }
  .hero__grid{ gap: 40px; }
  .hero__card{ aspect-ratio: 5 / 6; }
  .hero__lead{ font-size: 1rem; margin-bottom: 28px; }
  .hero__cta{ margin-bottom: 36px; }
  .hero__stats{ padding-top: 24px; gap: 12px; }
  .hero__stats .stat .num{ font-size: clamp(1.4rem, 5vw, 2rem); }
  .hero__stats .stat .lbl{ font-size: .68rem; }

  /* Pill tabs — horizontal scroll on narrow screens */
  .cat-filter, .cert-tabs, .compare-switcher{
    flex-wrap: nowrap;
    overflow-x: auto;
    width: 100%;
    max-width: 100%;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    scrollbar-color: var(--color-bronze) transparent;
  }
  .cat-filter::-webkit-scrollbar,
  .cert-tabs::-webkit-scrollbar,
  .compare-switcher::-webkit-scrollbar{ height: 4px; }
  .cat-filter::-webkit-scrollbar-thumb,
  .cert-tabs::-webkit-scrollbar-thumb,
  .compare-switcher::-webkit-scrollbar-thumb{ background: var(--color-bronze); border-radius: 999px; }
  .cat-filter button, .cert-tabs button, .compare-tab{ flex-shrink: 0; }

  /* CTA section — reduce gap */
  .cta__inner{ gap: 28px; }
  .cta__form{ padding: 24px; }

  /* Process steps — stack meta */
  .process-step{
    grid-template-columns: 60px 1fr;
    gap: 16px;
    padding: 20px 0;
  }
  .process-step .step-num{ font-size: 2rem; }
  .process-step .step-meta{
    grid-column: 1 / -1;
    margin-left: 76px;
    margin-top: -8px;
    white-space: normal;
    font-size: .72rem;
  }
  .process-step:hover{ padding-left: 0; }

  /* Calculator */
  .calc__head{ flex-direction: column; gap: 16px; }
  .calc__result{ flex-direction: column; align-items: flex-start; }
  .calc__result .value{ font-size: 1.8rem; }

  /* Product PAGE — на мобиле фото компактнее */
  .product-page .product-modal__media{ aspect-ratio: auto; height: 42vh; max-height: 340px; min-height: 200px; }
  .product-page .product-modal__body{ padding: 24px 18px 28px; }
  /* Отключаем sticky для визуальной колонки на мобилке — иначе thumbs наезжают на заголовок */
  .product-page__visual{ position: static; }

  /* Product modal — на мобиле максимально компактно */
  .product-modal{ padding: 16px 10px 100px; }
  .product-modal__panel{ grid-template-columns: 1fr; max-width: 100%; }
  /* Фото сильно уменьшено — занимает максимум 32vh, чтобы заголовок и описание сразу попадали в первый экран */
  .product-modal__media{
    aspect-ratio: auto;
    height: 32vh;
    max-height: 280px;
    min-height: 180px;
  }
  .product-modal__body{ padding: 20px 18px 22px; max-height: none; overflow: visible; }
  .product-modal__close{ top: 10px; right: 10px; width: 40px; height: 40px; }
  .product-modal__title{ font-size: 1.4rem; margin-bottom: 12px; }
  .product-modal__desc{ font-size: .92rem; margin-bottom: 18px; }
  .product-modal__sub{ margin-bottom: 8px; font-size: .68rem; }
  .product-modal__shade-meta{ left: 12px; right: 12px; bottom: 12px; padding: 10px 12px; }
  .product-modal__shade-meta .shade{ font-size: .95rem; }
  .product-modal__price{ grid-template-columns: 1fr; }

  /* Lightbox — buttons below on mobile */
  .lightbox{ padding: 20px; }
  .lightbox__close{ top: 12px; right: 12px; width: 42px; height: 42px; }
  .lightbox__prev, .lightbox__next{
    top: auto; bottom: 70px; transform: none;
    width: 44px; height: 44px;
  }
  .lightbox__prev{ left: 16px; }
  .lightbox__next{ right: 16px; }
  .lightbox__counter{ bottom: 14px; font-size: .9rem; padding: 6px 14px; }
  .lightbox__image{ max-height: calc(100vh - 160px); }

  /* Footer */
  .footer-bottom{ flex-direction: column; align-items: flex-start; }
}

/* ---- Phones (≤ 600px) ---- */
@media (max-width: 600px){
  :root{ --gutter: 16px; }
  section{ padding-block: 40px; }
  .section-head{ margin-bottom: 28px; }

  /* Header — keep room for phone & burger only */
  .site-header{ padding: 12px 0; }
  .brand{ font-size: 1.1rem; gap: 8px; }
  .brand .mark{ width: 30px; height: 30px; }
  .nav-cta{ gap: 10px; }
  .nav-cta .btn:not(.nav-toggle){ display: none; }
  .nav-toggle{ width: 40px; height: 40px; }
  .nav-phone{ font-size: .9rem; }

  /* Drawer */
  .drawer{ padding: 80px 20px 30px; }
  .drawer a{ font-size: 1.4rem; padding: 12px 0; }
  .drawer .group-label{ margin: 22px 0 6px; font-size: .7rem; }

  /* Hero */
  .hero{ padding-top: 110px; padding-bottom: 110px; }
  .hero__grid{ gap: 32px; }
  .hero__copy .kicker{ margin-bottom: 18px; font-size: .7rem; letter-spacing: .22em; }
  .hero__title{ margin-bottom: 20px; }
  .hero__lead{ font-size: .95rem; line-height: 1.55; }
  .hero__cta{ flex-direction: column; align-items: stretch; gap: 10px; }
  .hero__cta .btn{ justify-content: center; padding: 14px 22px; }
  .hero__stats{ grid-template-columns: 1fr 1fr; gap: 18px 12px; }
  .hero__stats .stat:nth-child(3){ grid-column: 1 / -1; padding-top: 14px; border-top: 1px solid var(--color-line); }
  .hero__card .caption{ flex-direction: column; align-items: flex-start; gap: 10px; }
  .hero__card .caption h3{ max-width: 100%; font-size: 1.3rem; }
  .hero__card .tag{ top: 16px; left: 16px; font-size: .68rem; padding: 8px 12px; }

  /* Trust strip */
  .trust{ padding-block: 20px; }
  .trust__row{ gap: 12px; justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; -webkit-overflow-scrolling: touch; }
  .trust__item{ font-size: .8rem; flex-shrink: 0; }

  /* Services grid */
  .services-grid{ gap: 14px; }
  .service-card{ min-height: auto; padding: 26px 22px; }
  .service-card h3{ margin: 60px 0 10px; font-size: 1.35rem; }

  /* Cities grid */
  .cities-grid{ gap: 10px; }
  .city-card{ padding: 18px; }
  .city-card .city-name{ font-size: 1.3rem; }
  .city-card .city-meta{ font-size: .7rem; gap: 10px; flex-wrap: wrap; }

  /* Materials & textures cards */
  .materials, .textures{ gap: 14px; }
  .tx-carousel__track{ gap: 14px; }
  .tx-carousel__btn{ width: 44px; height: 44px; font-size: 1.6rem; }
  .tx-card{ min-height: 340px; }
  .tx-card .tx-meta{ padding: 22px; }
  .tx-card .tx-meta h3{ font-size: 1.5rem; }
  .tx-card .tx-meta .tx-specs{ gap: 6px; }
  .tx-card .tx-meta .tx-spec{ font-size: .64rem; padding: 5px 10px; }

  /* Advantages */
  .adv-grid{ gap: 10px; }
  .adv{ padding: 22px 20px; }
  .adv .ico{ width: 32px; height: 32px; margin-bottom: 14px; }
  .adv h4{ font-size: 1.1rem; }

  /* Compare */
  .compare{ aspect-ratio: 4 / 5; }
  .compare__handle{ width: 38px; height: 38px; }
  .compare__tag{ font-size: .64rem; padding: 6px 10px; top: 12px; }
  .compare__tag--before{ left: 12px; }
  .compare__tag--after{ right: 12px; }
  .compare-tab{ padding: 10px 16px; font-size: .76rem; }
  .compare-tab .ix{ font-size: .8rem; }

  /* Catalog */
  .catalog{ grid-template-columns: 1fr; gap: 14px; }
  .cat-card{ aspect-ratio: 16 / 11; }
  .product-grid{ grid-template-columns: 1fr 1fr; gap: 12px; }
  .product-card__body{ padding: 16px 14px 18px; gap: 4px; }
  .product-card__title{ font-size: 1rem; }
  .product-card__desc{ font-size: .8rem; -webkit-line-clamp: 2; }
  .product-card__price{ font-size: .9rem; }
  .product-card__price small{ font-size: .58rem; }
  .product-card__more{ font-size: .68rem; }
  .product-card__palette-count{ bottom: 10px; right: 10px; padding: 4px 9px; font-size: .62rem; gap: 4px; }
  .product-card__palette-count strong{ font-size: .85rem; }
  .product-card__badge{ top: 10px; left: 10px; padding: 5px 10px; font-size: .62rem; }

  /* Product modal */
  .product-modal__title{ font-size: 1.5rem; }
  .product-modal__thumbs{ grid-auto-columns: 100px; gap: 8px; }
  .product-modal__gallery{ padding: 12px; margin: 14px 0 22px; }
  .product-modal__shade-meta .grp{ font-size: .58rem; }
  .product-modal__price .pill{ padding: 12px 14px; }
  .product-modal__price .pill .val{ font-size: 1.4rem; }

  /* Process steps */
  .process-step{ grid-template-columns: 50px 1fr; padding: 16px 0; }
  .process-step .step-num{ font-size: 1.8rem; }
  .process-step .step-meta{ margin-left: 64px; }
  .process-step h4{ font-size: 1.2rem; }

  /* Calculator */
  .calc{ padding: 22px; }
  .calc__row{ grid-template-columns: 1fr; gap: 14px; }

  /* CTA / Form */
  .cta__form{ padding: 20px; gap: 12px; }
  .cta__form .row-2{ grid-template-columns: 1fr; gap: 10px; }
  .cta__form input, .cta__form select, .cta__form textarea{ padding: 12px 14px; font-size: .95rem; }
  .cta__form .btn{ width: 100%; justify-content: center; }
  .cta__form .submit{ justify-self: stretch; }

  /* Price card */
  .price-card{ padding: 24px; gap: 18px; }
  .price-card h3{ font-size: 1.3rem; }
  .price-card .actions{ flex-direction: column; }
  .price-card .actions .btn{ width: 100%; justify-content: center; }

  /* FAQ */
  .faq__item summary{ padding: 18px 20px; font-size: 1.05rem; gap: 16px; }
  .faq__item .answer{ padding: 0 20px 22px; font-size: .9rem; }

  /* Certificates */
  .cert-grid{ gap: 12px; }
  .cert-card{ padding: 20px 18px; }
  .cert-card__title{ font-size: 1rem; }
  .cert-card__actions{ flex-direction: column; gap: 8px; padding-top: 12px; margin-top: 12px; }
  .cert-card__btn{ padding: 10px 16px; }

  /* Works carousel */
  .works-carousel__head{ flex-direction: column; align-items: flex-start; gap: 16px; }
  .works-carousel__nav{ align-self: flex-end; }
  .works-carousel__nav button{ width: 40px; height: 40px; }
  .works-carousel__track{ grid-auto-columns: 75%; gap: 12px; }
  .work-tile{ aspect-ratio: 4 / 5; }
  .work-tile__cat{ font-size: .64rem; padding: 6px 11px; left: 12px; bottom: 12px; }

  /* Works grid (works.html) */
  .works-grid{ columns: 2; column-gap: 10px; }
  .work-photo{ margin-bottom: 10px; }

  /* Footer */
  .footer-grid{ gap: 28px; }
  .footer-bottom{ font-size: .76rem; }

  /* Brand block */
  .brand-block{ gap: 36px; }
  .brand-block__visual{ aspect-ratio: 4 / 5; }
  .brand-block__visual .seal{ width: 88px; height: 88px; font-size: .68rem; top: 18px; left: 18px; }
  .brand-block__visual .seal strong{ font-size: 1.3rem; }
  .brand-block__visual .ribbon{ left: 18px; right: 18px; bottom: 18px; padding: 14px 16px; gap: 8px; }
  .brand-block__visual .ribbon .r-num{ font-size: 1.2rem; }
  .brand-block__visual .ribbon .r-lbl{ font-size: .56rem; }

  /* Dealer-bar */
  .dealer-bar{ font-size: .64rem; letter-spacing: .18em; padding: 5px 12px 5px 6px; gap: 8px; }

  /* Page-hero */
  .page-hero{ padding-top: 130px; padding-bottom: 60px; }
  .page-hero .breadcrumbs{ font-size: .72rem; margin-bottom: 18px; flex-wrap: wrap; }
  .page-hero h1{ margin-bottom: 18px; }
  .page-hero .lead{ font-size: 1rem; }
}

/* ---------- Price Gate Modal ---------- */
.pricegate{
  position: fixed; inset: 0;
  z-index: 300;
  display: flex; align-items: center; justify-content: center;
  padding: var(--gutter);
  visibility: hidden; opacity: 0;
  transition: opacity .3s var(--ease), visibility .3s;
}
.pricegate.is-open{ visibility: visible; opacity: 1; }
.pricegate__overlay{
  position: absolute; inset: 0;
  background: rgba(8,14,28,.80);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.pricegate__card{
  position: relative; z-index: 1;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: 44px 40px 36px;
  max-width: 460px; width: 100%;
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.85);
  transform: translateY(24px);
  transition: transform .35s var(--ease);
}
.pricegate.is-open .pricegate__card{ transform: translateY(0); }
.pricegate__close{
  position: absolute; top: 14px; right: 14px;
  width: 36px; height: 36px;
  border-radius: 50%;
  border: 1px solid var(--color-line);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; line-height: 1;
  color: var(--color-text-mute); cursor: pointer;
  transition: color var(--dur) var(--ease), border-color var(--dur) var(--ease);
}
.pricegate__close:hover{ color: var(--color-sand); border-color: var(--color-bronze); }
.pricegate__title{
  font-family: var(--font-display);
  font-size: 1.7rem; font-weight: 500;
  color: var(--color-sand);
  margin: 12px 0 8px; line-height: 1.12;
}
.pricegate__sub{
  color: var(--color-text-mute); font-size: .9rem;
  margin-bottom: 24px; line-height: 1.5;
}
.pricegate__form{ display: flex; flex-direction: column; gap: 12px; }
.pricegate__input{
  width: 100%; padding: 14px 18px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-m);
  color: var(--color-text);
  font-family: var(--font-body); font-size: .95rem;
  outline: none;
  transition: border-color var(--dur) var(--ease);
}
.pricegate__input:focus{ border-color: var(--color-bronze); }
.pricegate__input::placeholder{ color: var(--color-text-mute); }
.pricegate__submit{ width: 100%; justify-content: center; margin-top: 4px; }
.pricegate__note{
  font-size: .72rem; color: var(--color-text-mute);
  text-align: center; margin: 0;
}
@media (max-width: 520px){
  .pricegate__card{ padding: 32px 20px 26px; }
  .pricegate__title{ font-size: 1.4rem; }
}

/* ---- Tiny phones (≤ 380px) ---- */
@media (max-width: 380px){
  :root{ --gutter: 14px; }
  .hero__title{ font-size: 2rem; line-height: 1.05; }
  .h1{ font-size: 1.9rem; }
  .h2{ font-size: 1.5rem; }
  .nav-phone{ display: none; }
  .nav-cta{ gap: 8px; }
  .product-grid{ grid-template-columns: 1fr; }
  .works-grid{ columns: 1; }
  .works-carousel__track{ grid-auto-columns: 88%; }
}


/* ===== City hero v2 — 2 колонки + карточка-палитра + УТП-кнопки ===== */
.page-hero--city{
  padding-top:200px;padding-bottom:90px;
  background:
    linear-gradient(180deg, rgba(30,53,96,.80) 0%, rgba(30,53,96,.60) 42%, rgba(30,53,96,.93) 100%),
    url('/assets/img/works/fasad/005.jpg') center/cover no-repeat;
}
.page-hero--city .container.ph2{ display:grid;gap:52px;grid-template-columns:1fr;align-items:center; }
@media(min-width:980px){ .page-hero--city .container.ph2{ grid-template-columns:1.05fr .95fr;gap:72px; } }
.ph2__cta{ display:flex;flex-wrap:wrap;gap:14px;margin:34px 0 6px; }
.page-hero--city .hero__stats{ margin-top:40px;border-top:1px solid var(--color-line);padding-top:30px; }

.palette-card{ position:relative;display:block;border-radius:var(--radius-l);
  background:var(--color-surface);border:1px solid var(--color-line);
  box-shadow:var(--shadow-soft);overflow:hidden;
  transition:transform var(--dur) var(--ease),border-color var(--dur) var(--ease); }
.palette-card:hover{ transform:translateY(-4px);border-color:var(--color-bronze); }
.palette-card__tag{ position:absolute;z-index:2;top:18px;left:18px;display:inline-flex;align-items:center;gap:9px;
  font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--color-sand);
  background:rgba(30,53,96,.6);border:1px solid rgba(201,168,103,.45);padding:9px 15px;border-radius:999px;backdrop-filter:blur(8px); }
.palette-card__tag .dot{ width:7px;height:7px;border-radius:50%;background:var(--color-bronze); }
.palette-card__grid{ display:grid;grid-template-columns:1fr 1fr;gap:3px;background:var(--color-line); }
.palette-card__grid span{ display:block;aspect-ratio:1/1;background-size:cover;background-position:center;transition:transform .6s var(--ease); }
.palette-card:hover .palette-card__grid span{ transform:scale(1.05); }
.palette-card__cap{ display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding:20px 22px; }
.palette-card__cap h3{ font-family:var(--font-display);font-size:1.35rem;color:var(--color-sand);line-height:1.1; }
.palette-card__cap p{ color:var(--color-text-mute);font-size:.85rem;margin-top:4px; }
.palette-card__count{ font-family:var(--font-display);font-size:1.9rem;color:var(--color-bronze);line-height:1;white-space:nowrap;text-align:right; }
.palette-card__count small{ display:block;font-family:var(--font-body);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--color-text-mute);margin-top:5px; }
@media(max-width:560px){ .palette-card__cap h3{ font-size:1.15rem; } .palette-card__count{ font-size:1.5rem; } }


/* ===== SEO-блок: лид + редакционная сетка карточек ===== */
.seo-rich__lead{ position:relative; max-width:64ch; margin:0 0 44px; padding-left:26px; }
.seo-rich__lead::before{ content:""; position:absolute; left:0; top:7px; bottom:7px; width:3px; border-radius:3px;
  background:linear-gradient(180deg, var(--color-bronze), rgba(201,168,103,0)); }
.seo-rich__lead p{ font-size:1.16rem; line-height:1.7; color:var(--color-text); }
.seo-rich__lead p + p{ margin-top:14px; }
.seo-rich__lead strong{ color:var(--color-sand); font-weight:600; }
.seo-rich__grid{ display:grid; gap:20px; grid-template-columns:1fr; }
@media(min-width:720px){ .seo-rich__grid{ grid-template-columns:repeat(auto-fit, minmax(300px,1fr)); } }
.seo-rich__card{ position:relative; overflow:hidden; background:var(--color-surface);
  border:1px solid var(--color-line); border-radius:var(--radius-l); padding:32px 30px;
  transition:transform var(--dur) var(--ease), border-color var(--dur) var(--ease), box-shadow var(--dur) var(--ease); }
.seo-rich__card::after{ content:""; position:absolute; left:0; top:0; height:100%; width:3px;
  background:var(--color-bronze); transform:scaleY(0); transform-origin:top; transition:transform var(--dur) var(--ease); }
.seo-rich__card:hover{ transform:translateY(-4px); border-color:var(--color-bronze); box-shadow:var(--shadow-card); }
.seo-rich__card:hover::after{ transform:scaleY(1); }
.seo-rich__no{ font-family:var(--font-display); font-size:2.3rem; line-height:1; color:var(--color-bronze);
  opacity:.34; display:block; margin-bottom:12px; }
.seo-rich__card h3{ font-family:var(--font-display); font-size:1.4rem; color:var(--color-sand);
  line-height:1.18; margin-bottom:13px; }
.seo-rich__card p{ color:var(--color-text-mute); font-size:.97rem; line-height:1.82; }
.seo-rich__card p + p{ margin-top:13px; }
.seo-rich__card a{ color:var(--color-bronze); border-bottom:1px dotted currentColor; }
@media(max-width:560px){
  .seo-rich__card{ padding:26px 22px; }
  .seo-rich__lead{ padding-left:20px; }
  .seo-rich__lead p{ font-size:1.05rem; }
  .seo-rich__no{ font-size:1.9rem; }
}

/* ---------- Swatch carousel (product page — palette under main image) ---------- */
.swatch-carousel{
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 0 4px;
  border-top: 1px solid var(--color-line);
}
.swatch-carousel__track{
  flex: 1;
  display: flex;
  gap: 6px;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  padding: 4px 0 8px;
}
.swatch-carousel__track::-webkit-scrollbar{ display: none; }
.swatch-carousel__arrow{
  flex-shrink: 0;
  width: 34px; height: 34px;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-s);
  color: var(--color-text);
  font-size: 1.5rem;
  line-height: 1;
  display: grid; place-items: center;
  cursor: pointer;
  transition: background var(--dur) var(--ease), border-color var(--dur) var(--ease), color var(--dur) var(--ease);
}
.swatch-carousel__arrow:hover{
  background: var(--color-bronze);
  border-color: var(--color-bronze);
  color: var(--color-ink);
}
.swatch-carousel__item{
  flex-shrink: 0;
  width: 72px; height: 72px;
  border-radius: var(--radius-s);
  overflow: hidden;
  border: 2px solid transparent;
  padding: 0;
  cursor: pointer;
  background: none;
  transition: border-color var(--dur) var(--ease), transform var(--dur) var(--ease), box-shadow var(--dur) var(--ease);
}
.swatch-carousel__item img{
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--dur) var(--ease);
}
.swatch-carousel__item:hover{
  border-color: rgba(201,168,103,.5);
  transform: translateY(-2px);
}
.swatch-carousel__item:hover img{ transform: scale(1.06); }
.swatch-carousel__item.is-active{
  border-color: var(--color-bronze);
  box-shadow: 0 0 0 3px rgba(201,168,103,.2);
  transform: translateY(-2px);
}
@media(max-width:600px){
  .swatch-carousel__item{ width: 56px; height: 56px; }
  .swatch-carousel__arrow{ width: 30px; height: 30px; font-size: 1.2rem; }
}

/* ===================================================================
   MARKETING FIX PACK — p13max
   WhatsApp float · Promo strip · Reviews · Submenu wide
   =================================================================== */

/* ---------- Info-banner (inline promo blocks on service pages) ---------- */
.info-banner{
  margin-top: 48px;
  padding: 32px 36px;
  background: var(--color-surface);
  border-radius: var(--radius-l);
  display: flex;
  gap: 40px;
  align-items: center;
  flex-wrap: wrap;
}
.info-banner__body{ flex: 1; min-width: 220px; }
.info-banner__body .info-banner__title{
  font-family: var(--font-display);
  font-size: 1.35rem;
  color: var(--color-sand);
  line-height: 1.4;
  margin-bottom: 12px;
}
.info-banner__body p{
  font-size: .88rem;
  color: var(--color-text-mute);
  line-height: 1.7;
}
@media (max-width: 900px){
  .info-banner{ gap: 28px; padding: 26px 28px; }
}
@media (max-width: 600px){
  .info-banner{ padding: 20px 20px; gap: 20px; margin-top: 28px; }
  .info-banner .btn{ width: 100%; justify-content: center; }
}

/* ---------- Promo strip (urgency/seasonal) ---------- */
.promo-strip{
  background: linear-gradient(90deg, rgba(201,168,103,.10) 0%, rgba(201,168,103,.04) 100%);
  border-bottom: 1px solid rgba(201,168,103,.18);
  padding: 11px 0;
}
.promo-strip__inner{
  display: flex; align-items: center; justify-content: center; gap: 18px; flex-wrap: wrap;
}
.promo-strip__dot{
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--color-bronze); flex-shrink: 0;
  animation: ps-pulse 2s ease infinite;
}
@keyframes ps-pulse{
  0%,100%{ opacity:1; transform:scale(1); }
  50%{ opacity:.5; transform:scale(.8); }
}
.promo-strip__text{
  font-size: .82rem; color: var(--color-text-mute);
}
.promo-strip__text strong{ color: var(--color-bronze-soft); }
.promo-strip__cta{
  white-space: nowrap;
  padding: 7px 20px;
  background: var(--color-bronze);
  color: var(--color-ink);
  border-radius: 40px;
  font-size: .74rem; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; text-decoration: none;
  transition: background var(--dur) var(--ease);
}
.promo-strip__cta:hover{ background: var(--color-bronze-soft); }
@media (max-width: 600px){
  .promo-strip__text{ font-size: .78rem; }
  .promo-strip__cta{ width: 100%; text-align: center; }
}

/* ---------- Submenu wide (12 городов — 2 колонки) ---------- */
.submenu--wide{
  min-width: 300px;
  columns: 2;
  column-gap: 0;
}
.submenu--wide li{ break-inside: avoid; }

/* ---------- Reviews section ---------- */
.reviews-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}
@media (max-width: 980px){ .reviews-grid{ grid-template-columns: 1fr 1fr; } }
@media (max-width: 600px){ .reviews-grid{ grid-template-columns: 1fr; gap: 14px; } }

.review-card{
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-l);
  padding: 32px 28px;
  display: flex; flex-direction: column; gap: 18px;
  transition: border-color var(--dur) var(--ease);
}
.review-card:hover{ border-color: rgba(201,168,103,.3); }
.review-stars{ color: var(--color-bronze); font-size: 1.05rem; letter-spacing: 3px; line-height: 1; }
.review-text{
  font-size: .93rem; line-height: 1.78;
  color: var(--color-text); flex: 1;
  font-style: italic;
}
.review-author{ margin-top: auto; padding-top: 16px; border-top: 1px solid var(--color-line); }
.review-author__name{ font-weight: 600; color: var(--color-sand); font-size: .88rem; }
.review-author__detail{
  font-size: .76rem; color: var(--color-text-mute);
  margin-top: 3px; letter-spacing: .04em;
}
@media (max-width: 600px){
  .review-card{ padding: 22px 20px; gap: 14px; }
}

/* ---------- WhatsApp float button ---------- */
.wa-float{
  position: fixed; right: 24px; bottom: 108px;
  width: 52px; height: 52px;
  background: #25D366; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: white; text-decoration: none;
  box-shadow: 0 4px 20px rgba(37,211,102,.35);
  z-index: 49;
  transition: transform .25s ease, box-shadow .25s ease;
}
.wa-float:hover{ transform: scale(1.1); box-shadow: 0 8px 28px rgba(37,211,102,.55); }
.wa-float svg{ width: 28px; height: 28px; flex-shrink: 0; }
@media (max-width: 600px){
  .wa-float{ right: 14px; bottom: 90px; width: 46px; height: 46px; }
  .wa-float svg{ width: 24px; height: 24px; }
}
/* Если мобильная панель видна — двигаем выше */
.mobile-cta ~ .wa-float{ bottom: 90px; }