/* ============================================================
   Свадебное приглашение в стиле «протокола задержания»
   Дизайн-система: бумага, машинописный шрифт, штампы, рукописные вставки
   ============================================================ */

/* ---- Шрифты ----
   Основной: машинописный (Courier New локально, Cousine как web-фолбэк с кириллицей)
   Рукописный: для вписанных «от руки» значений (номер дела, имена, даты)          */
@import url('https://fonts.googleapis.com/css2?family=Cousine:ital,wght@0,400;0,700;1,400&family=Marck+Script&display=swap');

:root {
  --paper: #ffffff;            /* лист дела */
  --bg: #e0dddd;               /* фон вокруг листа */
  --ink: #14110f;              /* основной текст */
  --ink-soft: #2a2a2a;         /* второстепенный текст */
  --faint: #8a8378;            /* линии/пунктир для «вписать» */
  --stamp: #cd3e3f;            /* красный штамп */
  --accent: #ff8562;           /* коралловый акцент (звук/ссылки) */

  /* дресс-код: беж → шоколад */
  --dc-1: #a3856b;
  --dc-2: #9b9183;
  --dc-3: #8a6042;
  --dc-4: #4f2615;

  --mono: "Courier New", "Cousine", "Courier", monospace;
  --hand: "Marck Script", "Segoe Script", cursive;

  --sheet-max: 720px;
  --ls: 0.06em;                /* трекинг машинописи */
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: var(--mono);
  font-size: 16px;
  line-height: 1.7;
  letter-spacing: var(--ls);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* Лист «дела»: белая бумага с лёгкой тенью на сером фоне */
.sheet {
  max-width: var(--sheet-max);
  margin: 0 auto;
  background: var(--paper);
  min-height: 100vh;
  padding: clamp(28px, 6vw, 90px) clamp(20px, 6vw, 74px) 120px;
  box-shadow: 0 0 60px rgba(0, 0, 0, 0.08);
  position: relative;
  overflow: hidden;
}

/* ---------- Типографика ---------- */
.doc-title {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  line-height: 1.05;
  margin: 0;
}
.h-xl { font-size: clamp(34px, 8vw, 56px); }
.h-lg { font-size: clamp(26px, 6vw, 40px); }
.h-md { font-size: clamp(20px, 4.5vw, 28px); }

.subtitle {
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: clamp(13px, 2.6vw, 16px);
  color: var(--ink-soft);
}

p { margin: 0 0 1.1em; }
.muted { color: var(--ink-soft); }
.center { text-align: center; }
.upper { text-transform: uppercase; letter-spacing: 0.12em; }

/* Рукописные вписанные значения (номер дела, имена, даты) */
.hand {
  font-family: var(--hand);
  letter-spacing: 0.01em;
  color: var(--ink);
  transform: rotate(-2deg);
  display: inline-block;
  line-height: 1;
}
.hand-lg { font-size: clamp(40px, 9vw, 64px); }
.hand-md { font-size: clamp(26px, 5vw, 38px); }

/* «Поле для заполнения» — подчёркнутый пунктир */
.fill {
  border-bottom: 2px solid var(--ink);
  min-width: 120px;
  display: inline-block;
  text-align: center;
  padding: 0 10px;
}
.fill-dotted { border-bottom-style: dashed; }

/* ---------- Разделы протокола ---------- */
.section { margin: clamp(48px, 9vw, 96px) 0; }

.section-label {
  display: flex;
  align-items: baseline;
  gap: 14px;
  margin-bottom: 18px;
  border-bottom: 2px solid var(--ink);
  padding-bottom: 10px;
}
.section-num {
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: clamp(15px, 3vw, 20px);
  white-space: nowrap;
}
.section-name {
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-size: clamp(15px, 3vw, 20px);
  font-weight: 700;
}

/* Нумерованные обстоятельства / распоряжения */
ol.legal, ul.legal { padding-left: 1.3em; margin: 0 0 1.2em; }
ol.legal li, ul.legal li { margin-bottom: 0.6em; }

/* ---------- Таймлайн (программа) ---------- */
.timeline { border-left: 2px solid var(--ink); margin-left: 6px; }
.tl-item {
  position: relative;
  padding: 0 0 34px 28px;
}
.tl-item::before {
  content: "";
  position: absolute;
  left: -7px; top: 6px;
  width: 12px; height: 12px;
  background: var(--paper);
  border: 2px solid var(--ink);
  border-radius: 50%;
}
.tl-time {
  font-weight: 700;
  font-size: clamp(20px, 4vw, 28px);
  letter-spacing: 0.04em;
}
.tl-desc { color: var(--ink-soft); }

/* ---------- Мугшот / фото ---------- */
.mugshot {
  display: block;
  width: min(300px, 70%);
  margin: 0 auto;
  filter: grayscale(1) contrast(1.05);
  border: 1px solid rgba(0,0,0,0.15);
}
.mug-caption {
  text-align: center;
  font-size: 13px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--faint);
  margin-top: 10px;
}

/* ---------- Красный штамп ---------- */
.stamp {
  color: var(--stamp);
  border: 4px double var(--stamp);
  border-radius: 8px;
  padding: 10px 22px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: clamp(20px, 5vw, 34px);
  display: inline-block;
  transform: rotate(-11deg);
  opacity: 0.9;
  mix-blend-mode: multiply;
}
.stamp--refuse { border-radius: 50%; }

/* Верёвочка-завязка папки (обложка «дела») */
.file-tie {
  position: absolute;
  top: 50%;
  right: -34px; /* заходит за правую кромку листа — завязка на торце папки */
  width: clamp(90px, 16vw, 140px);
  height: auto;
  z-index: 30;
  pointer-events: none;
  transform: translateY(-50%) rotate(4deg);
  filter: drop-shadow(0 5px 7px rgba(0, 0, 0, 0.22));
}

/* Печать-картинка (круглый оттиск на белом фоне) */
.stamp-img {
  display: block;
  width: clamp(200px, 60vw, 240px);
  max-width: 90%;
  height: auto;
  margin: 0 auto;
  mix-blend-mode: multiply; /* убирает белый фон, оставляет красный оттиск */
}

/* ---------- Дресс-код: палитра ---------- */
.palette { display: flex; gap: 0; margin: 18px 0; flex-wrap: wrap; }
.swatch {
  flex: 1 1 60px;
  height: 74px;
  min-width: 60px;
}
.sw1 { background: var(--dc-1); }
.sw2 { background: var(--dc-2); }
.sw3 { background: var(--dc-3); }
.sw4 { background: var(--dc-4); }

/* ---------- Кнопка звука ---------- */
.sound-toggle {
  position: fixed;
  top: 18px; right: 18px;
  z-index: 50;
  background: var(--paper);
  border: 2px solid var(--ink);
  color: var(--ink);
  font-family: var(--mono);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-size: 12px;
  padding: 9px 14px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: background 0.2s, color 0.2s;
}
.sound-toggle:hover { background: var(--ink); color: var(--paper); }
.sound-toggle .dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--faint);
}
.sound-toggle.on .dot { background: var(--accent); box-shadow: 0 0 0 3px rgba(255,133,98,.25); }

/* ---------- RSVP форма ---------- */
.form-field { margin-bottom: 26px; }
.form-label {
  display: block;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  font-weight: 700;
  margin-bottom: 12px;
  font-size: 15px;
}
.radio-row { display: flex; flex-direction: column; gap: 10px; }
.radio-opt { display: flex; align-items: center; gap: 12px; cursor: pointer; }
.radio-opt input { accent-color: var(--stamp); width: 18px; height: 18px; }

.input, .textarea {
  width: 100%;
  font-family: var(--mono);
  font-size: 16px;
  letter-spacing: var(--ls);
  padding: 12px 14px;
  border: 2px solid var(--ink);
  background: transparent;
  color: var(--ink);
  resize: vertical;
}
.input:focus, .textarea:focus { outline: 2px solid var(--accent); outline-offset: 2px; }

.check-row { display: flex; gap: 12px; align-items: flex-start; }
.check-row input { accent-color: var(--stamp); width: 18px; height: 18px; margin-top: 4px; }
.check-row label { font-size: 14px; color: var(--ink-soft); line-height: 1.6; }

.btn-submit {
  margin-top: 10px;
  background: var(--ink);
  color: var(--paper);
  border: none;
  font-family: var(--mono);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 700;
  font-size: 15px;
  padding: 16px 40px;
  cursor: pointer;
  transition: transform 0.15s, background 0.2s;
}
.btn-submit:hover { background: var(--stamp); transform: translateY(-2px); }

.form-note {
  margin-top: 14px;
  font-size: 12px;
  color: var(--faint);
}

/* ---------- Ссылка / кнопка перехода на обложке ---------- */
.enter-link {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-top: 40px;
  color: var(--ink);
  text-decoration: none;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-size: 14px;
  border-bottom: 2px solid var(--stamp);
  padding-bottom: 4px;
  transition: gap 0.2s, color 0.2s;
}
.enter-link:hover { gap: 18px; color: var(--stamp); }

/* Подпись автора */
.credit {
  text-align: center;
  color: var(--faint);
  font-size: 12px;
  letter-spacing: 0.1em;
  margin-top: 80px;
}

/* ============================================================
   Scroll-reveal: аналог Tilda "intoview" (сдвиг + прозрачность + лёгкий поворот)
   ============================================================ */
[data-reveal] {
  opacity: 0;
  transform: translateY(40px);
  transition:
    opacity 0.9s cubic-bezier(0.16, 1, 0.3, 1),
    transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
  will-change: opacity, transform;
}
[data-reveal="left"]   { transform: translateX(-70px); }
[data-reveal="right"]  { transform: translateX(70px); }
[data-reveal="up"]     { transform: translateY(60px); }
[data-reveal="scale"]  { transform: scale(0.9); }
[data-reveal="stamp"]  { transform: scale(1.6) rotate(-11deg); opacity: 0; }

[data-reveal].is-visible {
  opacity: 1;
  transform: none;
}
[data-reveal="stamp"].is-visible {
  opacity: 0.9;
  transform: rotate(-11deg);
  transition:
    opacity 0.5s ease,
    transform 0.6s cubic-bezier(0.34, 1.56, 0.64, 1); /* лёгкий «удар» печати */
}

/* Уважать пользователей с reduce-motion */
@media (prefers-reduced-motion: reduce) {
  [data-reveal] { opacity: 1 !important; transform: none !important; transition: none; }
  html { scroll-behavior: auto; }
}

/* ---------- Адаптив ---------- */
@media (max-width: 520px) {
  body { font-size: 15px; }
  .section-label { flex-direction: column; gap: 4px; }
}
