/* ============================================================
   Шафран и Ладан — лавка специй прямых поставок, Казань
   Тёплая восточная палитра, тёмная тема, serif-display
   ============================================================ */

:root {
  /* — палитра — */
  --ink:        #1a120b;   /* глубокий пряно-коричневый фон */
  --ink-soft:   #241810;
  --ink-card:   #2c1d12;
  --ink-line:   #4a3220;
  --clay:       #b5532a;   /* терракота */
  --clay-deep:  #8a3a1c;
  --saffron:    #e2a13c;   /* шафраново-золотой акцент */
  --saffron-hi: #f4c361;
  --cumin:      #c98a3e;
  --cream:      #f3e7d3;   /* основной текст */
  --cream-dim:  #cdb79a;
  --paprika:    #d96b3d;

  /* — шрифты: характерные системные пары — */
  --display: "Hoefler Text", "Iowan Old Style", "Palatino Linotype", Palatino, "Book Antiqua", Georgia, "Times New Roman", serif;
  --body:    "Optima", "Segoe UI", "Gill Sans", "Gill Sans MT", "Trebuchet MS", Candara, sans-serif;
  --mono:    "Courier New", "Courier Prime", monospace;

  /* — ритм — */
  --gut: clamp(1.1rem, 3vw, 2.4rem);
  --rail: clamp(1.2rem, 5vw, 5.5rem);
  --round: 3px;
  --shadow: 0 22px 60px -28px rgba(0,0,0,.85);
  --shadow-lift: 0 30px 80px -30px rgba(0,0,0,.9);
  --ease: cubic-bezier(.21,.62,.34,1);
}

*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: var(--body);
  background:
    radial-gradient(1100px 700px at 78% -8%, rgba(226,161,60,.10), transparent 60%),
    radial-gradient(900px 600px at 8% 12%, rgba(181,83,42,.12), transparent 58%),
    var(--ink);
  color: var(--cream);
  line-height: 1.62;
  font-size: clamp(1rem, .55vw + .9rem, 1.12rem);
  letter-spacing: .003em;
  overflow-x: hidden;
}

/* мешковина — едва уловимый шумовой паттерн фоном */
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .05;
  background-image:
    repeating-linear-gradient(0deg, rgba(243,231,211,.6) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(90deg, rgba(243,231,211,.5) 0 1px, transparent 1px 3px);
  background-size: 3px 3px;
}

img { max-width: 100%; display: block; height: auto; }
a { color: inherit; text-decoration: none; }

h1, h2, h3 {
  font-family: var(--display);
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -.01em;
  margin: 0;
}

p { margin: 0 0 1rem; }

/* — служебное — */
.skip {
  position: absolute;
  left: -999px;
  top: 0;
  background: var(--saffron);
  color: var(--ink);
  padding: .7rem 1.2rem;
  z-index: 200;
  font-weight: 700;
  border-radius: 0 0 var(--round) 0;
}
.skip:focus { left: 0; }

:focus-visible {
  outline: 3px solid var(--saffron-hi);
  outline-offset: 3px;
  border-radius: 2px;
}

.shell {
  width: min(1220px, 100%);
  margin-inline: auto;
  padding-inline: var(--rail);
}

.kicker {
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .34em;
  text-transform: uppercase;
  color: var(--saffron);
  display: inline-block;
  margin-bottom: 1rem;
}
.kicker::before { content: "✦ "; color: var(--clay); }

/* ===================== ШАПКА ===================== */
.topbar {
  position: fixed;
  inset: 0 0 auto 0;
  z-index: 100;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.15rem var(--rail);
  transition: padding .4s var(--ease), background .4s var(--ease), box-shadow .4s var(--ease);
}
.topbar.is-stuck {
  padding-block: .6rem;
  background: rgba(20,13,8,.92);
  backdrop-filter: blur(11px);
  box-shadow: 0 1px 0 var(--ink-line), 0 16px 40px -28px #000;
}

.mark {
  display: flex;
  align-items: center;
  gap: .65rem;
  font-family: var(--display);
  font-size: 1.32rem;
  letter-spacing: .01em;
}
.mark__glyph {
  width: 2.1rem; height: 2.1rem;
  flex: none;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: radial-gradient(circle at 35% 30%, var(--saffron-hi), var(--clay-deep));
  color: var(--ink);
  font-weight: 800;
  font-family: var(--display);
  box-shadow: inset 0 0 0 1px rgba(0,0,0,.25);
}
.mark__name b { color: var(--saffron); font-weight: 600; }
.mark small {
  display: block;
  font-family: var(--mono);
  font-size: .56rem;
  letter-spacing: .28em;
  color: var(--cream-dim);
  text-transform: uppercase;
}

.helm { display: flex; align-items: center; gap: clamp(1rem, 2.4vw, 2.2rem); }
.helm__nav { display: flex; gap: clamp(1rem, 2vw, 1.9rem); }
.helm__nav a {
  font-size: .92rem;
  letter-spacing: .02em;
  color: var(--cream-dim);
  position: relative;
  padding-block: .3rem;
  transition: color .25s;
}
.helm__nav a::after {
  content: "";
  position: absolute;
  left: 0; bottom: 0;
  width: 0; height: 2px;
  background: var(--saffron);
  transition: width .3s var(--ease);
}
.helm__nav a:hover { color: var(--cream); }
.helm__nav a:hover::after { width: 100%; }

.btn {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-family: var(--body);
  font-weight: 600;
  letter-spacing: .03em;
  padding: .82rem 1.5rem;
  border-radius: var(--round);
  border: 1px solid transparent;
  cursor: pointer;
  font-size: .95rem;
  transition: transform .2s var(--ease), box-shadow .25s, background .25s, color .25s;
}
.btn--solid {
  background: linear-gradient(165deg, var(--saffron-hi), var(--clay));
  color: var(--ink);
  box-shadow: 0 12px 30px -14px rgba(226,161,60,.6);
}
.btn--solid:hover { transform: translateY(-2px); box-shadow: 0 18px 38px -14px rgba(226,161,60,.75); }
.btn--ghost {
  background: transparent;
  border-color: var(--ink-line);
  color: var(--cream);
}
.btn--ghost:hover { border-color: var(--saffron); color: var(--saffron-hi); }

.burger {
  display: none;
  width: 2.8rem; height: 2.8rem;
  background: transparent;
  border: 1px solid var(--ink-line);
  border-radius: var(--round);
  cursor: pointer;
  position: relative;
}
.burger span, .burger span::before, .burger span::after {
  content: "";
  position: absolute;
  left: 50%; top: 50%;
  width: 1.2rem; height: 2px;
  background: var(--cream);
  transform: translate(-50%, -50%);
  transition: transform .3s var(--ease), opacity .2s;
}
.burger span::before { transform: translate(-50%, -8px); }
.burger span::after  { transform: translate(-50%, 6px); }
.burger[aria-expanded="true"] span { background: transparent; }
.burger[aria-expanded="true"] span::before { transform: translate(-50%,-50%) rotate(45deg); }
.burger[aria-expanded="true"] span::after  { transform: translate(-50%,-50%) rotate(-45deg); }

/* ===================== ГЕРОЙ ===================== */
.opening {
  position: relative;
  min-height: 100svh;
  display: grid;
  align-items: end;
  padding-block: 9rem 3.2rem;
  isolation: isolate;
  overflow: hidden;
}
.opening__photo {
  position: absolute;
  inset: 0;
  z-index: -2;
}
.opening__photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.02);
}
.opening__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(20,13,8,.62) 0%, rgba(20,13,8,.28) 38%, rgba(20,13,8,.95) 100%),
    linear-gradient(90deg, rgba(20,13,8,.78), transparent 62%);
}

.opening__inner { max-width: 760px; }
.opening h1 {
  font-size: clamp(2.7rem, 7.2vw, 5.6rem);
  margin-bottom: 1.3rem;
}
.opening h1 em {
  font-style: italic;
  color: var(--saffron-hi);
  display: block;
}
.opening__lead {
  font-size: clamp(1.05rem, 1.4vw, 1.32rem);
  color: var(--cream);
  max-width: 56ch;
  margin-bottom: 2rem;
}
.opening__cta { display: flex; flex-wrap: wrap; gap: .9rem; }

.scrollcue {
  position: absolute;
  right: var(--rail); bottom: 2.6rem;
  display: flex; align-items: center; gap: .7rem;
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .25em;
  text-transform: uppercase;
  color: var(--cream-dim);
}
.scrollcue i {
  width: 1px; height: 2.4rem;
  background: linear-gradient(var(--saffron), transparent);
  animation: drip 1.9s var(--ease) infinite;
}
@keyframes drip { 0%,100%{transform:scaleY(.4);opacity:.4} 50%{transform:scaleY(1);opacity:1} }

/* — лента-бегущая строка под героем — */
.creep {
  border-block: 1px solid var(--ink-line);
  background: var(--ink-soft);
  overflow: hidden;
  white-space: nowrap;
}
.creep__track {
  display: inline-flex;
  gap: 3rem;
  padding-block: .9rem;
  animation: creep 34s linear infinite;
  font-family: var(--display);
  font-size: 1.05rem;
  color: var(--cumin);
}
.creep__track span::after { content: "✦"; color: var(--clay); margin-left: 3rem; }
@keyframes creep { to { transform: translateX(-50%); } }

/* ===================== УНИВЕРСАЛЬНЫЕ БЛОКИ ===================== */
.band { padding-block: clamp(4rem, 9vw, 7.5rem); }
.band--alt { background: var(--ink-soft); border-block: 1px solid var(--ink-line); }

.head { max-width: 64ch; margin-bottom: clamp(2.2rem, 5vw, 3.6rem); }
.head h2 { font-size: clamp(1.9rem, 4.4vw, 3.1rem); margin-bottom: .9rem; }
.head p { color: var(--cream-dim); font-size: 1.08rem; }

/* — витрина полок: товарные карточки — */
.shelf {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: clamp(1.1rem, 2.4vw, 1.8rem);
}
.crock {
  background: var(--ink-card);
  border: 1px solid var(--ink-line);
  border-radius: var(--round);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  transition: transform .35s var(--ease), border-color .35s, box-shadow .35s;
}
.crock:hover { transform: translateY(-6px); border-color: var(--clay); box-shadow: var(--shadow-lift); }
.crock__pic { position: relative; aspect-ratio: 4 / 3; overflow: hidden; }
.crock__pic img { width: 100%; height: 100%; object-fit: cover; transition: transform .6s var(--ease); }
.crock:hover .crock__pic img { transform: scale(1.07); }
.crock__tag {
  position: absolute;
  top: .7rem; left: .7rem;
  font-family: var(--mono);
  font-size: .64rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  background: rgba(20,13,8,.82);
  color: var(--saffron-hi);
  padding: .32rem .6rem;
  border-radius: 2px;
  border: 1px solid var(--ink-line);
}
.crock__body { padding: 1.25rem 1.3rem 1.4rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.crock__body h3 { font-size: 1.32rem; }
.crock__from {
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .1em;
  color: var(--cream-dim);
}
.crock__note { font-size: .96rem; color: var(--cream-dim); flex: 1; }
.crock__foot {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-top: .5rem; padding-top: .9rem;
  border-top: 1px dashed var(--ink-line);
}
.crock__price { font-family: var(--display); font-size: 1.5rem; color: var(--saffron-hi); }
.crock__price small { font-size: .8rem; color: var(--cream-dim); font-family: var(--body); }
.crock__buy {
  font-family: var(--mono); font-size: .72rem; letter-spacing: .12em;
  text-transform: uppercase; color: var(--clay);
  border-bottom: 1px solid transparent; transition: border-color .25s, color .25s;
}
.crock:hover .crock__buy { color: var(--saffron); border-color: var(--saffron); }

/* ===================== ИСТОРИЯ (split) ===================== */
.saga {
  display: grid;
  grid-template-columns: 1.05fr .95fr;
  gap: clamp(2rem, 5vw, 4.5rem);
  align-items: center;
}
.saga__frame {
  position: relative;
  border-radius: var(--round);
  overflow: hidden;
  box-shadow: var(--shadow);
}
.saga__frame img { width: 100%; aspect-ratio: 4 / 5; object-fit: cover; }
.saga__frame::after {
  content: "";
  position: absolute; inset: 0;
  border: 1px solid rgba(243,231,211,.14);
  border-radius: var(--round);
  pointer-events: none;
}
.saga__stamp {
  position: absolute;
  bottom: 1.1rem; right: 1.1rem;
  background: var(--ink);
  border: 1px solid var(--saffron);
  color: var(--saffron-hi);
  font-family: var(--mono);
  font-size: .68rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  padding: .6rem .85rem;
  border-radius: 2px;
}
.saga__text h2 { font-size: clamp(1.9rem, 4vw, 2.9rem); margin-bottom: 1.2rem; }
.saga__text p { color: var(--cream-dim); }
.saga__sign {
  margin-top: 1.6rem;
  font-family: var(--display);
  font-style: italic;
  font-size: 1.5rem;
  color: var(--saffron-hi);
}
.saga__sign small { display: block; font-family: var(--mono); font-size: .68rem; letter-spacing: .2em; color: var(--cream-dim); text-transform: uppercase; margin-top: .3rem; font-style: normal; }

/* ===================== ПУТЬ ЗЕРНА (process) ===================== */
.road {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 2.5vw, 2rem);
  counter-reset: step;
}
.road__stop {
  position: relative;
  padding-top: 2.6rem;
  border-top: 2px solid var(--ink-line);
}
.road__stop::before {
  counter-increment: step;
  content: "0" counter(step);
  position: absolute; top: -1.05rem; left: 0;
  font-family: var(--display);
  font-size: 1.05rem;
  background: var(--ink);
  color: var(--saffron);
  padding-right: .7rem;
}
.road__stop h3 { font-size: 1.28rem; margin-bottom: .55rem; }
.road__stop p { font-size: .96rem; color: var(--cream-dim); margin: 0; }

/* ===================== ЦИФРЫ ===================== */
.tally {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: clamp(1rem, 3vw, 2.5rem);
  text-align: center;
}
.tally__n {
  font-family: var(--display);
  font-size: clamp(2.4rem, 6vw, 3.8rem);
  color: var(--saffron-hi);
  line-height: 1;
}
.tally__l {
  font-family: var(--mono);
  font-size: .76rem;
  letter-spacing: .15em;
  text-transform: uppercase;
  color: var(--cream-dim);
  margin-top: .6rem;
}

/* ===================== ОТЗЫВЫ ===================== */
.voices {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(1.1rem, 2.5vw, 1.8rem);
}
.voice {
  background: var(--ink-card);
  border: 1px solid var(--ink-line);
  border-radius: var(--round);
  padding: 1.8rem 1.7rem 1.5rem;
  position: relative;
}
.voice::before {
  content: "„";
  position: absolute;
  top: -.3rem; left: 1rem;
  font-family: var(--display);
  font-size: 4.4rem;
  color: var(--clay);
  opacity: .55;
  line-height: 1;
}
.voice p { font-size: 1.04rem; color: var(--cream); margin-bottom: 1.1rem; padding-top: 1.4rem; }
.voice__who { display: flex; align-items: center; gap: .8rem; }
.voice__av {
  width: 2.6rem; height: 2.6rem;
  border-radius: 50%;
  display: grid; place-items: center;
  background: linear-gradient(150deg, var(--clay), var(--cumin));
  color: var(--ink);
  font-family: var(--display);
  font-weight: 700;
}
.voice__who b { display: block; font-size: .98rem; }
.voice__who span { font-size: .82rem; color: var(--cream-dim); }

/* ===================== КОНТАКТ + ФОРМА ===================== */
.reach {
  display: grid;
  grid-template-columns: .9fr 1.1fr;
  gap: clamp(2rem, 5vw, 4rem);
  align-items: start;
}
.reach__info dl { margin: 1.6rem 0 0; display: grid; gap: 1.15rem; }
.reach__info dt {
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--saffron);
  margin-bottom: .25rem;
}
.reach__info dd { margin: 0; font-size: 1.06rem; color: var(--cream); }
.reach__info dd a:hover { color: var(--saffron-hi); }

.kit {
  background: var(--ink-card);
  border: 1px solid var(--ink-line);
  border-radius: var(--round);
  padding: clamp(1.6rem, 3vw, 2.4rem);
  box-shadow: var(--shadow);
}
.kit h3 { font-size: 1.6rem; margin-bottom: .4rem; }
.kit > p { color: var(--cream-dim); font-size: .98rem; margin-bottom: 1.5rem; }
.field { margin-bottom: 1.15rem; }
.field label {
  display: block;
  font-family: var(--mono);
  font-size: .72rem;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--cream-dim);
  margin-bottom: .45rem;
}
.field input, .field select, .field textarea {
  width: 100%;
  background: var(--ink);
  border: 1px solid var(--ink-line);
  border-radius: var(--round);
  color: var(--cream);
  font-family: var(--body);
  font-size: 1rem;
  padding: .8rem .9rem;
  transition: border-color .25s, box-shadow .25s;
}
.field textarea { resize: vertical; min-height: 6.5rem; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none;
  border-color: var(--saffron);
  box-shadow: 0 0 0 3px rgba(226,161,60,.18);
}
.field.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-bottom: 1.15rem; }
.field.row2 .field { margin: 0; }
.field__err {
  display: none;
  color: var(--paprika);
  font-size: .82rem;
  margin-top: .35rem;
}
.field.is-bad input, .field.is-bad select, .field.is-bad textarea { border-color: var(--paprika); }
.field.is-bad .field__err { display: block; }
.kit__send { width: 100%; justify-content: center; margin-top: .5rem; }
.kit__ok {
  display: none;
  margin-top: 1rem;
  padding: .85rem 1rem;
  border-radius: var(--round);
  background: rgba(226,161,60,.14);
  border: 1px solid var(--saffron);
  color: var(--saffron-hi);
  font-size: .95rem;
}
.kit__ok.show { display: block; }

/* ===================== ПОДВАЛ ===================== */
.basement {
  background: var(--ink-soft);
  border-top: 1px solid var(--ink-line);
  padding-block: clamp(3rem, 6vw, 4.5rem) 2rem;
}
.basement__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: clamp(1.6rem, 4vw, 3rem);
  margin-bottom: 2.4rem;
}
.basement__about p { color: var(--cream-dim); font-size: .96rem; max-width: 40ch; margin-top: 1rem; }
.basement__col h4 {
  font-family: var(--mono);
  font-size: .74rem;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--saffron);
  margin: 0 0 1rem;
}
.basement__col ul { list-style: none; margin: 0; padding: 0; display: grid; gap: .65rem; }
.basement__col a { color: var(--cream-dim); font-size: .96rem; transition: color .2s; }
.basement__col a:hover { color: var(--cream); }
.basement__bar {
  display: flex; flex-wrap: wrap; gap: 1rem;
  justify-content: space-between; align-items: center;
  padding-top: 1.8rem;
  border-top: 1px solid var(--ink-line);
  font-size: .85rem;
  color: var(--cream-dim);
}
.basement__bar nav { display: flex; gap: 1.4rem; }

/* ===================== SCROLL-REVEAL ===================== */
.rise {
  opacity: 0;
  transform: translateY(26px);
  transition: opacity .7s var(--ease), transform .7s var(--ease);
}
.rise.lit { opacity: 1; transform: none; }
.rise[data-lag="1"] { transition-delay: .08s; }
.rise[data-lag="2"] { transition-delay: .16s; }
.rise[data-lag="3"] { transition-delay: .24s; }
.rise[data-lag="4"] { transition-delay: .32s; }

/* staggered-вход героя при загрузке */
.boot { opacity: 0; transform: translateY(18px); }
.is-booted .boot { opacity: 1; transform: none; transition: opacity .8s var(--ease), transform .8s var(--ease); }
.is-booted .boot[data-b="1"] { transition-delay: .15s; }
.is-booted .boot[data-b="2"] { transition-delay: .32s; }
.is-booted .boot[data-b="3"] { transition-delay: .5s; }
.is-booted .boot[data-b="4"] { transition-delay: .66s; }

/* ===================== АДАПТИВ ===================== */
@media (max-width: 900px) {
  .saga, .reach { grid-template-columns: 1fr; }
  .road { grid-template-columns: repeat(2, 1fr); }
  .tally { grid-template-columns: repeat(2, 1fr); }
  .basement__grid { grid-template-columns: 1fr 1fr; }
  .basement__about { grid-column: 1 / -1; }
}

@media (max-width: 720px) {
  .helm__nav, .helm .btn--ghost { display: none; }
  .burger { display: block; }
  .helm__nav.is-open {
    display: flex;
    flex-direction: column;
    position: absolute;
    inset: 100% 0 auto 0;
    background: rgba(20,13,8,.97);
    backdrop-filter: blur(12px);
    border-bottom: 1px solid var(--ink-line);
    padding: 1.4rem var(--rail) 2rem;
    gap: 1.2rem;
  }
  .helm__nav.is-open a { font-size: 1.15rem; color: var(--cream); }
}

@media (max-width: 560px) {
  .road, .tally, .basement__grid { grid-template-columns: 1fr; }
  .field.row2 { grid-template-columns: 1fr; }
  .opening__cta { flex-direction: column; align-items: stretch; }
  .opening__cta .btn { justify-content: center; }
  .scrollcue { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: .001ms !important; transition-duration: .001ms !important; }
  .rise, .boot { opacity: 1; transform: none; }
  html { scroll-behavior: auto; }
}
