/* =====================================================================
   ФЛОРИДИЗ · ЖИВОЙ АРХИВ — main.css
   Концепция: личный ботанический архив флориста-декоратора.
   Premium через отбор, тишину и точность. Музейная дисциплина.
   Шрифты: Prata (титулы) · Manrope (текст/UI) · IBM Plex Mono (микрометки).
   ===================================================================== */

/* ---------- 1. Токены ---------- */
:root{
  /* палитра */
  --paper:    #F4F0E8;  /* архивная бумага — фон */
  --ink:      #1B1A17;  /* тёплый почти-чёрный — текст */
  --sage:     #7F8A6B;  /* шалфей/стебель — живая линия, эко */
  --mat:      #D8CEC0;  /* паспарту, разделители */
  --wine:     #6E3F35;  /* глубокий бордовый — CTA, акценты */
  --brass:    #B7A36F;  /* состаренная латунь — только микро-метки */

  --paper-2:  #ECE6DA;  /* чуть глубже бумаги — секции-подложки */
  --ink-60:   rgba(27,26,23,.62);
  --ink-40:   rgba(27,26,23,.40);
  --line:     rgba(27,26,23,.14);

  /* типографика */
  --f-title: "Prata", Georgia, "Times New Roman", serif;
  --f-body:  "Manrope", -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  --f-mono:  "IBM Plex Mono", ui-monospace, Menlo, Consolas, monospace;

  /* ритм */
  --container: 1200px;
  --gutter: clamp(20px, 5vw, 64px);
  --section-y: clamp(64px, 9vw, 140px);
  --stem-w: clamp(40px, 6vw, 80px);   /* левое поле под стебель */
  --radius: 2px;

  --ease: cubic-bezier(.22,.61,.36,1);
}

/* ---------- 2. Сброс / база ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion: reduce){ html{scroll-behavior:auto} }

body{
  margin:0;
  background:var(--paper);
  color:var(--ink);
  font-family:var(--f-body);
  font-size:clamp(15px,1.05vw,17px);
  font-weight:400;
  line-height:1.65;
  letter-spacing:.005em;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer}
h1,h2,h3,h4{margin:0;font-weight:400;line-height:1.1}
p{margin:0}
ul,ol{margin:0;padding:0;list-style:none}

/* моно-микрометки — сквозной приём архива */
.mono{
  font-family:var(--f-mono);
  font-size:.72em;
  letter-spacing:.14em;
  text-transform:uppercase;
}

.container{
  width:100%;
  max-width:var(--container);
  margin:0 auto;
  padding-inline:var(--gutter);
}

/* доступность: видимый фокус */
a:focus-visible,button:focus-visible,
input:focus-visible,textarea:focus-visible,select:focus-visible,
summary:focus-visible,.work:focus-visible{
  outline:2px solid var(--wine);
  outline-offset:3px;
}

.skip-link{
  position:fixed;top:-60px;left:12px;z-index:200;
  background:var(--ink);color:var(--paper);
  padding:10px 16px;border-radius:var(--radius);
  font-family:var(--f-mono);font-size:13px;letter-spacing:.1em;
  transition:top .2s var(--ease);
}
.skip-link:focus{top:12px}

/* ---------- 3. Кнопки ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  gap:.5em;
  padding:.85em 1.7em;
  font-family:var(--f-body);
  font-size:.92rem;font-weight:600;letter-spacing:.02em;
  border:1px solid transparent;border-radius:var(--radius);
  transition:background .25s var(--ease),color .25s var(--ease),
             border-color .25s var(--ease),transform .25s var(--ease);
  white-space:nowrap;
}
.btn--lg{padding:1.05em 2.2em;font-size:1rem}
.btn--accent{background:var(--wine);color:var(--paper)}
.btn--accent:hover{background:#5a3229;transform:translateY(-1px)}
.btn--ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn--ghost:hover{background:var(--ink);color:var(--paper)}

/* =====================================================================
   СТЕБЕЛЬ — сквозная живая линия (signature)
   ===================================================================== */
.stem{
  position:absolute;
  top:0;left:0;
  width:var(--stem-w);
  height:100%;
  pointer-events:none;
  z-index:1;
}
.stem__svg{width:100%;height:100%}
.stem__track{
  stroke:var(--mat);
  stroke-width:1.4;
  vector-effect:non-scaling-stroke;
}
.stem__grow{
  stroke:var(--sage);
  stroke-width:1.6;
  vector-effect:non-scaling-stroke;
  /* dasharray/offset задаются в JS из реальной длины пути */
}
@media (max-width:760px){ .stem{opacity:.55} }

/* =====================================================================
   01 · ШАПКА
   ===================================================================== */
.site-header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(244,240,232,.82);
  backdrop-filter:saturate(140%) blur(10px);
  -webkit-backdrop-filter:saturate(140%) blur(10px);
  border-bottom:1px solid transparent;
  transition:border-color .3s var(--ease),background .3s var(--ease);
}
.site-header.is-scrolled{
  border-bottom-color:var(--line);
  background:rgba(244,240,232,.94);
}
.site-header__inner{
  display:flex;align-items:center;gap:24px;
  height:72px;
}

.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand__mark{width:42px;height:42px;object-fit:contain}
.brand__type{display:flex;flex-direction:column;line-height:1.05}
.brand__name{font-family:var(--f-title);font-size:1.32rem;letter-spacing:.01em}
.brand__tag{
  font-family:var(--f-mono);font-size:.56rem;
  letter-spacing:.16em;text-transform:uppercase;color:var(--ink-60);
  margin-top:3px;
}

.nav{margin-left:auto}
.nav__list{display:flex;gap:28px}
.nav__list a{
  position:relative;font-size:.92rem;font-weight:500;color:var(--ink);
  padding:4px 0;transition:color .2s var(--ease);
}
.nav__list a::after{
  content:"";position:absolute;left:0;bottom:-2px;
  width:0;height:1px;background:var(--wine);
  transition:width .25s var(--ease);
}
.nav__list a:hover{color:var(--wine)}
.nav__list a:hover::after{width:100%}

.header-cta{display:flex;align-items:center;gap:14px;flex-shrink:0}
.msg-icon{
  display:grid;place-items:center;width:38px;height:38px;
  border:1px solid var(--line);border-radius:50%;color:var(--ink);
  transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
}
.msg-icon:hover{background:var(--sage);color:var(--paper);border-color:var(--sage)}

/* бургер */
.burger{
  display:none;
  width:42px;height:42px;
  background:transparent;border:1px solid var(--line);border-radius:var(--radius);
  position:relative;flex-shrink:0;
}
.burger span{
  position:absolute;left:11px;right:11px;height:1.5px;background:var(--ink);
  transition:transform .3s var(--ease),opacity .2s var(--ease);
}
.burger span:nth-child(1){top:14px}
.burger span:nth-child(2){top:20px}
.burger span:nth-child(3){top:26px}
.burger[aria-expanded="true"] span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.burger[aria-expanded="true"] span:nth-child(2){opacity:0}
.burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}

/* Мобильная шапка: прячем десктоп-меню и CTA, показываем бургер */
@media (max-width:860px){
  .site-header__inner{justify-content:space-between;gap:14px}
  .nav{display:none}
  .header-cta{display:none}
  .burger{display:block}
}

/* мобильное меню — FULL-WIDTH overlay (inset:0), без justify-self */
.mobile-menu{
  position:fixed;
  inset:0;                 /* критично: занимает весь экран */
  width:100%;
  z-index:99;
  background:var(--paper);
  transform:translateX(100%);
  transition:transform .4s var(--ease);
  display:flex;align-items:center;
  padding:88px var(--gutter) 40px;
  overflow-y:auto;
}
.mobile-menu[hidden]{display:flex}     /* управляем видимостью только трансформом */
.mobile-menu.is-open{transform:translateX(0)}
.mobile-menu__nav{width:100%}
.mobile-menu__index{
  display:block;font-family:var(--f-mono);font-size:.7rem;
  letter-spacing:.2em;color:var(--brass);margin-bottom:24px;
}
.mobile-menu__nav ul{display:flex;flex-direction:column;gap:4px;margin-bottom:32px}
.mobile-menu__nav li a{
  display:flex;align-items:baseline;gap:16px;
  font-family:var(--f-title);font-size:clamp(1.6rem,8vw,2.4rem);
  padding:10px 0;border-bottom:1px solid var(--line);
  transition:color .2s var(--ease);
}
.mobile-menu__nav li a .mono{
  font-family:var(--f-mono);font-size:.7rem;color:var(--brass);
}
.mobile-menu__nav li a:hover{color:var(--wine)}
.mobile-menu__cta{width:100%}

/* =====================================================================
   02 · HERO
   ===================================================================== */
.hero{
  position:relative;
  min-height:100svh;
  display:flex;align-items:flex-end;
  padding-block:120px var(--section-y);
  overflow:hidden;
}
.hero__media{position:absolute;inset:0;z-index:0}
.hero__slide{position:absolute;inset:0;margin:0;opacity:0;transition:opacity 1.2s var(--ease)}
.hero__slide.is-active{opacity:1}
.hero__slide img{width:100%;height:100%;object-fit:cover;object-position:center}
/* мягкая вуаль для контраста текста (НЕ тяжёлая) */
.hero__veil{
  position:absolute;inset:0;
  background:
    linear-gradient(180deg, rgba(27,26,23,.20) 0%, rgba(27,26,23,.05) 35%, rgba(27,26,23,.58) 100%),
    linear-gradient(90deg, rgba(27,26,23,.64) 0%, rgba(27,26,23,.20) 46%, rgba(27,26,23,0) 72%);
}

.hero__inner{position:relative;z-index:2;color:var(--paper);max-width:920px}
.hero__eyebrow{color:var(--paper);opacity:.92;margin-bottom:22px;
  border-left:2px solid var(--brass);padding-left:12px}
.hero__title{
  font-family:var(--f-title);
  font-size:clamp(2.6rem,7vw,5.6rem);
  line-height:1.02;
  letter-spacing:-.01em;
  text-shadow:0 2px 30px rgba(0,0,0,.28);
}
.hero__title em{font-style:italic;color:#F0E3D6}
.hero__lead{
  margin-top:24px;max-width:48ch;
  font-size:clamp(1rem,1.5vw,1.18rem);
  color:rgba(244,240,232,.94);
  text-shadow:0 1px 14px rgba(0,0,0,.3);
}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:32px}
.hero__actions .btn--ghost{color:var(--paper);border-color:var(--paper)}
.hero__actions .btn--ghost:hover{background:var(--paper);color:var(--ink)}
.hero__micro{
  margin-top:18px;font-size:.85rem;
  color:rgba(244,240,232,.8);
}

/* паспорт бренда — моно-карточка на кальке */
.hero__passport{
  position:absolute;z-index:2;
  right:var(--gutter);bottom:var(--section-y);
  display:flex;flex-direction:column;gap:7px;
  padding:18px 20px;
  background:rgba(244,240,232,.16);
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  border:1px solid rgba(244,240,232,.28);
  color:var(--paper);
  max-width:300px;
}
.hero__passport-row{font-size:.62rem;letter-spacing:.1em}
.hero__passport-row b{color:var(--brass);font-weight:500;margin-right:6px}
@media (max-width:1000px){ .hero__passport{display:none} }

/* =====================================================================
   ОБЩЕЕ — секции и заголовки
   ===================================================================== */
.section{
  position:relative;
  padding-block:var(--section-y);
  padding-left:var(--stem-w);   /* освобождаем поле под стебель */
}
.section + .section{border-top:1px solid var(--line)}
.section--alt{background:var(--paper-2)}
.works{background:var(--paper-2)}
.process{background:var(--paper-2)}
.faq{background:var(--paper-2)}

.section-head{max-width:760px;margin-bottom:clamp(36px,5vw,64px)}
.section-head__no{
  color:var(--brass);margin-bottom:16px;display:inline-block;
}
.section-head__title{
  font-family:var(--f-title);
  font-size:clamp(2rem,5vw,3.6rem);
  line-height:1.05;letter-spacing:-.01em;
}
.section-head__lead{
  margin-top:18px;color:var(--ink-60);
  font-size:clamp(1rem,1.3vw,1.12rem);max-width:60ch;
}

/* узел стебля напротив каждого блока */
.section[data-node]::before{
  content:"";position:absolute;
  left:calc(var(--stem-w) / 2 - 4px);top:var(--section-y);
  width:8px;height:8px;border-radius:50%;
  background:var(--paper);border:1.5px solid var(--sage);
  transform:scale(.4);opacity:0;
  transition:transform .5s var(--ease),opacity .5s var(--ease);
  z-index:2;
}
.section[data-node].is-node-on::before{transform:scale(1);opacity:1}
@media (max-width:760px){ .section{padding-left:var(--stem-w)} }

/* =====================================================================
   03 · РАБОТЫ — curated archive wall + ПАСПОРТ (signature)
   ===================================================================== */
.filters{
  display:flex;flex-wrap:wrap;gap:10px;
  margin-bottom:clamp(28px,4vw,44px);
}
.filter{
  background:transparent;
  border:1px solid var(--line);
  border-radius:var(--radius);
  padding:.55em 1.1em;
  font-family:var(--f-mono);font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-60);
  transition:all .2s var(--ease);
}
.filter:hover{color:var(--ink);border-color:var(--ink-40)}
.filter.is-active{background:var(--ink);color:var(--paper);border-color:var(--ink)}

/* НЕ masonry — дисциплинированная сетка с паспарту */
.archive-wall{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:clamp(16px,2.2vw,30px);
}
@media (max-width:980px){ .archive-wall{grid-template-columns:repeat(3,1fr)} }
@media (max-width:680px){ .archive-wall{grid-template-columns:repeat(2,1fr)} }

.work{
  margin:0;cursor:pointer;
  transition:transform .5s var(--ease),opacity .5s var(--ease);
}
.work[hidden]{display:none}
.work__frame{
  position:relative;
  aspect-ratio:4/5;            /* единое паспарту для разных кадров */
  background:var(--paper);
  padding:clamp(8px,1vw,14px); /* поле/паспарту вокруг кадра */
  border:1px solid var(--mat);
  overflow:hidden;
}
.work__frame img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .8s var(--ease),filter .5s var(--ease);
}
.work:hover .work__frame img,
.work:focus-visible .work__frame img{transform:scale(1.04)}

/* ПАСПОРТ РАБОТЫ — моно-текст на полупрозрачной кальке */
.work__passport{
  position:absolute;
  inset:clamp(8px,1vw,14px);   /* совпадает с padding рамки */
  display:flex;flex-direction:column;justify-content:flex-end;gap:7px;
  padding:16px;
  background:rgba(244,240,232,.84);  /* калька */
  backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);
  color:var(--ink);
  opacity:0;transform:translateY(8px);
  transition:opacity .35s var(--ease),transform .35s var(--ease);
  pointer-events:none;
}
.work__passport span{font-size:.6rem;letter-spacing:.08em;line-height:1.5}
.work__passport b{color:var(--wine);font-weight:500;margin-right:5px}
.work:hover .work__passport,
.work:focus-visible .work__passport,
.work.is-open .work__passport{opacity:1;transform:translateY(0)}

.work__label{
  display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;
  margin-top:12px;font-size:.95rem;font-weight:500;
}
.work__tag{color:var(--brass);font-size:.62rem}

.works__empty{color:var(--ink-40);padding:40px 0;text-align:center}

/* =====================================================================
   04 · ОБ АННЕ
   ===================================================================== */
.about__grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);
  gap:clamp(32px,5vw,72px);align-items:start;
}
.about__media{display:grid;grid-template-columns:1.3fr 1fr;gap:16px;align-items:start}
.about__portrait{margin:0;position:relative}
.about__portrait img{
  width:100%;aspect-ratio:3/4;object-fit:cover;
  border:1px solid var(--mat);
}
.about__portrait--small{margin-top:40px}
.about__portrait figcaption{
  font-family:var(--f-mono);font-size:.58rem;letter-spacing:.14em;
  color:var(--brass);margin-top:10px;
}
.about__title{
  font-family:var(--f-title);
  font-size:clamp(2.2rem,4.5vw,3.6rem);line-height:1.04;margin-top:14px;
}
.about__lead{margin-top:22px;color:var(--ink);max-width:54ch}
.about__quote{
  margin:28px 0 0;padding:4px 0 4px 20px;
  border-left:2px solid var(--sage);
  font-family:var(--f-title);font-style:italic;
  font-size:clamp(1.1rem,1.8vw,1.4rem);line-height:1.4;color:var(--ink);
}
.about__sign{margin-top:14px;font-style:italic;color:var(--ink-60)}

.stats{
  display:flex;flex-wrap:wrap;gap:clamp(24px,4vw,48px);
  margin-top:36px;padding-top:28px;border-top:1px solid var(--line);
}
.stats__num{font-family:var(--f-title);font-size:clamp(2rem,3vw,2.8rem);line-height:1}
.stats__cap{display:block;margin-top:8px;color:var(--ink-60)}

@media (max-width:860px){
  .about__grid{grid-template-columns:1fr}
}

/* =====================================================================
   05 · УСЛУГИ
   ===================================================================== */
.svc-group{margin-top:clamp(40px,5vw,64px)}
.svc-group:first-of-type{margin-top:0}
.svc-group__title{
  display:flex;align-items:baseline;gap:14px;
  font-family:var(--f-title);font-size:clamp(1.4rem,2.6vw,2rem);
  padding-bottom:18px;margin-bottom:6px;border-bottom:1px solid var(--line);
}
.svc-group__no{
  font-family:var(--f-mono);font-size:.8rem;color:var(--brass);
  border:1px solid var(--mat);border-radius:50%;
  width:30px;height:30px;display:grid;place-items:center;flex-shrink:0;
}
.svc-list{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,40px);
  padding-top:clamp(24px,3vw,36px)}
.svc{
  padding-top:18px;border-top:1px solid var(--line);
  transition:transform .3s var(--ease);
}
.svc__name{
  font-family:var(--f-title);font-size:1.22rem;line-height:1.2;margin-bottom:10px;
}
.svc__desc{color:var(--ink-60);font-size:.96rem}
.svc__extra{
  display:block;margin-top:12px;color:var(--sage);
  font-size:.6rem;line-height:1.6;
}
@media (max-width:860px){ .svc-list{grid-template-columns:1fr 1fr} }
@media (max-width:560px){ .svc-list{grid-template-columns:1fr} }

/* =====================================================================
   06 · ПРОЦЕСС
   ===================================================================== */
.steps{
  display:grid;grid-template-columns:repeat(5,1fr);
  gap:clamp(16px,2vw,28px);counter-reset:none;
}
.step{
  padding-top:22px;border-top:2px solid var(--ink);
  position:relative;
}
.step__no{display:block;color:var(--brass);font-size:.85rem;margin-bottom:14px}
.step__title{font-family:var(--f-title);font-size:1.18rem;line-height:1.18;margin-bottom:10px}
.step__desc{color:var(--ink-60);font-size:.9rem}
@media (max-width:980px){ .steps{grid-template-columns:repeat(2,1fr);gap:28px} }
@media (max-width:560px){ .steps{grid-template-columns:1fr} }

/* =====================================================================
   07 · ЭКО — стебель замыкается в цикл
   ===================================================================== */
.eco{background:linear-gradient(180deg,var(--paper) 0%, #EEF0E8 100%)}
.eco__grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.1fr);
  gap:clamp(32px,5vw,72px);align-items:start;
}
.eco__intro{position:relative}
.eco__cycle{
  margin-top:40px;display:flex;align-items:center;gap:16px;
}
.eco__cycle svg{width:80px;height:80px;flex-shrink:0;transform:rotate(-90deg)}
.eco__cycle-track{stroke:var(--mat);stroke-width:2;fill:none}
.eco__cycle-grow{stroke:var(--sage);stroke-width:2.5;fill:none;stroke-linecap:round}
.eco__cycle span{color:var(--sage)}

.eco__list{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,3vw,36px)}
.eco__item{padding-top:20px;border-top:1px solid var(--sage)}
.eco__no{color:var(--sage);font-size:.8rem;display:block;margin-bottom:12px}
.eco__name{font-family:var(--f-title);font-size:1.18rem;line-height:1.2;margin-bottom:8px}
.eco__desc{color:var(--ink-60);font-size:.94rem}
@media (max-width:860px){
  .eco__grid{grid-template-columns:1fr}
  .eco__list{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){ .eco__list{grid-template-columns:1fr} }

/* =====================================================================
   08 · ОТЗЫВЫ
   ===================================================================== */
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,3vw,36px)}
.review{
  margin:0;padding:clamp(24px,3vw,36px);
  background:var(--paper);border:1px solid var(--mat);
  display:flex;flex-direction:column;justify-content:space-between;gap:24px;
}
.review__text{
  font-family:var(--f-title);font-style:italic;
  font-size:clamp(1.15rem,1.8vw,1.4rem);line-height:1.4;
}
.review__by{font-weight:600;display:flex;flex-direction:column;gap:6px}
.review__type{color:var(--brass);font-weight:400}
@media (max-width:860px){ .reviews__grid{grid-template-columns:1fr} }

/* =====================================================================
   09 · FAQ
   ===================================================================== */
.faq__wrap{max-width:880px}
.accordion{border-top:1px solid var(--line)}
.acc{border-bottom:1px solid var(--line)}
.acc__q{
  display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding:24px 0;
  font-family:var(--f-title);font-size:clamp(1.1rem,1.8vw,1.35rem);
  list-style:none;
}
.acc__q::-webkit-details-marker{display:none}
.acc__icon{position:relative;width:18px;height:18px;flex-shrink:0}
.acc__icon::before,.acc__icon::after{
  content:"";position:absolute;background:var(--wine);
  transition:transform .3s var(--ease),opacity .3s var(--ease);
}
.acc__icon::before{top:8px;left:0;width:18px;height:1.5px}
.acc__icon::after{top:0;left:8px;width:1.5px;height:18px}
.acc[open] .acc__icon::after{transform:rotate(90deg);opacity:0}
.acc__a{padding:0 0 26px;color:var(--ink-60);max-width:62ch}
.acc__a p{font-size:1rem}

/* плавное раскрытие при наличии JS (grid-rows трюк); без JS details работает нативно */
.js .acc__a{
  display:grid;grid-template-rows:0fr;padding-bottom:0;
  transition:grid-template-rows .35s var(--ease),padding-bottom .35s var(--ease);
}
.js .acc__a > p{overflow:hidden;min-height:0}
.js .acc[open] .acc__a{grid-template-rows:1fr;padding-bottom:26px}

/* =====================================================================
   10 · КОНТАКТЫ + ФОРМА
   ===================================================================== */
.contact__grid{
  display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);
  gap:clamp(32px,5vw,72px);align-items:start;
}
.contact__channels{margin-top:32px}
.contact__label{color:var(--brass);margin-bottom:16px}
.contact__msg{display:flex;flex-wrap:wrap;gap:12px}
.contact__lines{margin-top:28px;display:flex;flex-direction:column;gap:14px}
.contact__lines li{display:flex;gap:16px;align-items:baseline;
  font-size:.74rem;letter-spacing:.06em;border-bottom:1px solid var(--line);padding-bottom:12px}
.contact__lines li span{color:var(--ink-40);min-width:90px}
.contact__lines a{color:var(--ink);border-bottom:1px solid transparent;transition:border-color .2s}
.contact__lines a:hover{border-color:var(--wine)}
.contact__note{margin-top:18px;color:var(--ink-40);font-size:.6rem}

/* форма */
.contact__form{
  background:var(--paper-2);
  border:1px solid var(--mat);
  padding:clamp(24px,3.5vw,44px);
}
.contact__form-title{color:var(--brass);margin-bottom:24px}
.field{margin-bottom:20px;display:flex;flex-direction:column;gap:7px}
.field label{font-size:.85rem;font-weight:600;letter-spacing:.01em}
.req{color:var(--wine)}
.field__opt{font-weight:400;color:var(--ink-40);font-size:.78rem}
.field input,.field select,.field textarea{
  width:100%;
  font:inherit;font-size:.95rem;color:var(--ink);
  background:var(--paper);
  border:1px solid var(--mat);border-radius:var(--radius);
  padding:.8em .9em;
  transition:border-color .2s var(--ease);
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--sage);
}
.field textarea{resize:vertical;min-height:84px}
.field__err{
  display:none;color:var(--wine);font-size:.78rem;font-weight:500;
}
.field.has-error input,.field.has-error select{border-color:var(--wine)}
.field.has-error .field__err{display:block}

.contact__submit{width:100%;margin-top:6px}
.contact__micro{margin-top:14px;text-align:center;color:var(--ink-40);font-size:.82rem}

.form-success{
  margin-top:20px;padding:16px 18px;
  background:var(--sage);color:var(--paper);
  border-radius:var(--radius);
  font-weight:500;text-align:center;
}

@media (max-width:860px){ .contact__grid{grid-template-columns:1fr} }

/* =====================================================================
   11 · ПОДВАЛ
   ===================================================================== */
.site-footer{background:var(--ink);color:var(--paper);padding-block:clamp(48px,6vw,80px) 0}
.site-footer__inner{
  display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:clamp(28px,4vw,56px);
  padding-bottom:48px;border-bottom:1px solid rgba(244,240,232,.14);
}
.site-footer__brand img{height:40px;width:auto;filter:brightness(0) invert(1);opacity:.9}
.site-footer__slogan{
  margin-top:18px;font-family:var(--f-title);font-style:italic;
  font-size:1.15rem;line-height:1.4;color:rgba(244,240,232,.82);max-width:34ch;
}
.site-footer__nav{display:flex;flex-direction:column;gap:12px}
.site-footer__nav a{color:rgba(244,240,232,.78);transition:color .2s}
.site-footer__nav a:hover{color:var(--paper)}
.site-footer__social{display:flex;flex-direction:column;gap:12px}
.site-footer__social .mono{color:var(--brass);margin-bottom:4px}
.site-footer__social a{color:rgba(244,240,232,.78);transition:color .2s}
.site-footer__social a:hover{color:var(--paper)}

.site-footer__legal{
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;
  padding-block:24px;color:rgba(244,240,232,.5);font-size:.66rem;
}
.site-footer__legal a{color:rgba(244,240,232,.5);transition:color .2s}
.site-footer__legal a:hover{color:var(--paper)}
@media (max-width:760px){ .site-footer__inner{grid-template-columns:1fr 1fr} }
@media (max-width:520px){ .site-footer__inner{grid-template-columns:1fr} }

/* =====================================================================
   ЛАЙТБОКС
   ===================================================================== */
.lightbox{
  position:fixed;inset:0;z-index:150;
  display:flex;align-items:center;justify-content:center;
  background:rgba(27,26,23,.94);
  padding:clamp(16px,4vw,48px);
  opacity:0;visibility:hidden;transition:opacity .3s var(--ease),visibility .3s;
}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__figure{margin:0;max-width:min(92vw,1100px);display:flex;flex-direction:column;align-items:center;gap:16px}
.lightbox__img{
  max-width:100%;max-height:80vh;object-fit:contain;
  border:8px solid var(--paper);background:var(--paper);
}
.lightbox__cap{color:var(--brass);letter-spacing:.14em}
.lightbox__close{
  position:absolute;top:18px;right:24px;
  background:transparent;border:none;color:var(--paper);
  font-size:2.4rem;line-height:1;width:48px;height:48px;
}
.lightbox__nav{
  position:absolute;top:50%;transform:translateY(-50%);
  background:transparent;border:1px solid rgba(244,240,232,.4);
  color:var(--paper);width:52px;height:52px;border-radius:50%;
  font-size:1.8rem;line-height:1;
  transition:background .2s,border-color .2s;
}
.lightbox__nav:hover{background:rgba(244,240,232,.16);border-color:var(--paper)}
.lightbox__nav--prev{left:clamp(8px,2vw,28px)}
.lightbox__nav--next{right:clamp(8px,2vw,28px)}
@media (max-width:600px){
  .lightbox__nav{width:42px;height:42px;font-size:1.4rem}
}

/* =====================================================================
   REVEAL-АНИМАЦИИ (контент в DOM сразу; JS снимает .reveal)
   ===================================================================== */
.js .reveal{opacity:0;transform:translateY(26px);
  transition:opacity .7s var(--ease),transform .7s var(--ease)}
.js .reveal.is-visible{opacity:1;transform:none}

/* поэтапное появление работ внутри стены */
.js .work{opacity:0;transform:translateY(20px)}
.js .work.is-visible{opacity:1;transform:none}

/* =====================================================================
   PREFERS-REDUCED-MOTION — полная деградация анимаций
   ===================================================================== */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.001ms !important;
    scroll-behavior:auto !important;
  }
  .js .reveal,.js .work{opacity:1 !important;transform:none !important}
  .hero__slide{transition:none}
  .work__frame img{transition:none}
  .stem__grow{transition:none}
}
