/* ============================================================
   Свадебный сайт · Кирилл и Татьяна · 08.08.2026
   ============================================================ */

:root{
  --paper:      #f4eee2;
  --paper-2:    #efe7d7;
  --ink:        #211d18;
  --ink-soft:   #514a3e;
  --ink-faint:  #8a8270;
  --accent:     #8c7a58;
  --line:       rgba(33,29,24,.16);

  --font-script: 'Marck Script', cursive;
  --font-display:'Cormorant Garamond', Georgia, serif;
  --font-caps:   'Forum', Georgia, serif;
  --font-body:   'PT Serif', Georgia, serif;

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

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

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

body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.7;
  font-size:18px;
  overflow-x:hidden;
  position:relative;
}

/* лёгкая бумажная текстура */
body::before{
  content:"";
  position:fixed; inset:0;
  pointer-events:none;
  z-index:1;
  opacity:.5;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.045'/%3E%3C/svg%3E");
}

img{ max-width:100%; display:block; }

/* линейные иллюстрации — PNG с прозрачным фоном, ложатся прямо на бумагу */

/* ---------- Контейнеры / секции ---------- */
.container{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; position:relative; z-index:2; }
.container--narrow{ max-width:680px; }

.section{ padding:96px 0; position:relative; z-index:2; }
.section--alt{ background:var(--paper-2); }
.section--alt::before,
.section--alt::after{
  content:""; position:absolute; left:0; right:0; height:1px; background:var(--line);
}
.section--alt::before{ top:0; } .section--alt::after{ bottom:0; }

/* ---------- Типографика-помощники ---------- */
.overline{
  font-family:var(--font-caps);
  text-transform:uppercase;
  letter-spacing:.42em;
  font-size:.74rem;
  color:var(--ink-faint);
  padding-left:.42em;
}
.overline--center{ text-align:center; }

.section-title{
  font-family:var(--font-display);
  font-weight:400;
  font-size:clamp(2rem,5vw,3.1rem);
  text-align:center;
  line-height:1.1;
  margin-bottom:.6em;
}
.script-title{
  font-family:var(--font-script);
  font-weight:400;
  font-size:clamp(2.2rem,6vw,3.4rem);
  line-height:1.2;
  color:var(--ink);
  text-align:center;
}
.lead{
  font-size:1.12rem;
  color:var(--ink-soft);
  margin-bottom:1.1em;
}
.lead--center{ text-align:center; }
.lead em{ font-style:italic; color:var(--ink); }

.ornament{ color:var(--accent); display:flex; justify-content:center; margin-top:1.4em; opacity:.8; }

/* ---------- Кнопки ---------- */
.btn{
  display:inline-block;
  font-family:var(--font-caps);
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.78rem;
  color:var(--ink);
  text-decoration:none;
  padding:.95em 2em .85em;
  border:1px solid var(--ink);
  border-radius:40px;
  background:transparent;
  cursor:pointer;
  transition:background .4s var(--ease), color .4s var(--ease), transform .3s var(--ease);
}
.btn:hover{ background:var(--ink); color:var(--paper); transform:translateY(-2px); }
.btn--lg{ padding:1.05em 2.6em .95em; font-size:.82rem; }

/* ============================================================
   Шапка
   ============================================================ */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px;
  transition:background .45s var(--ease), box-shadow .45s var(--ease), padding .45s var(--ease);
}
.nav.is-solid{
  background:rgba(244,238,226,.92);
  backdrop-filter:blur(8px);
  box-shadow:0 1px 0 var(--line);
  padding:12px 28px;
}
.nav__brand{
  font-family:var(--font-display);
  font-size:1.5rem; letter-spacing:.08em;
  color:var(--ink); text-decoration:none;
}
.nav__brand span{ color:var(--accent); margin:0 .1em; }
.nav__links{ display:flex; gap:30px; }
.nav__links a{
  font-family:var(--font-caps);
  text-transform:uppercase; letter-spacing:.18em;
  font-size:.72rem; color:var(--ink-soft); text-decoration:none;
  position:relative; padding:4px 0;
  transition:color .3s;
}
.nav__links a::after{
  content:""; position:absolute; left:0; bottom:0; height:1px; width:0; background:var(--ink);
  transition:width .35s var(--ease);
}
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ width:100%; }

.nav__burger{
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:6px;
}
.nav__burger span{ width:24px; height:1.5px; background:var(--ink); transition:transform .35s var(--ease), opacity .25s; }
.nav__burger.is-open span:nth-child(1){ transform:translateY(6.5px) rotate(45deg); }
.nav__burger.is-open span:nth-child(2){ opacity:0; }
.nav__burger.is-open span:nth-child(3){ transform:translateY(-6.5px) rotate(-45deg); }

/* ============================================================
   Hero
   ============================================================ */
.hero{
  min-height:100svh;
  display:flex; flex-direction:column; align-items:center; justify-content:center;
  text-align:center; padding:120px 24px 80px;
  position:relative; z-index:2;
}
.hero__inner{ display:flex; flex-direction:column; align-items:center; }
.hero__dove{ width:min(330px,68vw); margin:8px 0 4px; }
.hero .overline{ margin-bottom:6px; }

.hero__names{
  font-family:var(--font-script);
  font-weight:400;
  display:flex; align-items:center; justify-content:center;
  flex-wrap:wrap; gap:.25em;
  line-height:1;
  font-size:clamp(2.8rem,11vw,5.6rem);
}
.hero__amp{ color:var(--accent); font-size:.7em; }

.hero__tagline{
  font-family:var(--font-caps);
  text-transform:uppercase; letter-spacing:.4em;
  font-size:clamp(.8rem,2.6vw,1.05rem);
  margin:14px 0 26px; color:var(--ink-soft);
}
.hero__date{
  font-family:var(--font-display);
  font-size:clamp(1.4rem,4.5vw,2.2rem);
  letter-spacing:.14em; text-transform:uppercase;
  display:flex; gap:.5em; align-items:baseline;
}
.hero__sep{ color:var(--accent); }
.hero__sub{
  font-family:var(--font-caps);
  letter-spacing:.32em; text-transform:uppercase;
  font-size:.78rem; color:var(--ink-faint); margin-top:10px;
}

.hero__deco--tl{
  position:absolute; top:90px; left:6%; width:120px; height:120px; opacity:.25;
  background:no-repeat center/contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cpath d='M10 90 Q 30 30 90 12' fill='none' stroke='%238c7a58' stroke-width='1.2'/%3E%3Cpath d='M84 8 l8 4 -4 8' fill='none' stroke='%238c7a58' stroke-width='1.2'/%3E%3C/svg%3E");
}

.hero__scroll{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%);
  width:26px; height:42px; border:1px solid var(--ink-soft); border-radius:14px;
  display:flex; justify-content:center; padding-top:7px;
}
.hero__scroll span{ width:3px; height:8px; border-radius:2px; background:var(--ink-soft); animation:scroll 1.8s var(--ease) infinite; }
@keyframes scroll{ 0%{ opacity:0; transform:translateY(-3px);} 40%{opacity:1;} 80%,100%{ opacity:0; transform:translateY(12px);} }

/* ============================================================
   Обратный отсчёт
   ============================================================ */
.countdown{ padding:80px 0; text-align:center; position:relative; z-index:2; }
.countdown .overline{ margin-bottom:34px; }
.countdown__grid{
  display:flex; justify-content:center; gap:clamp(14px,4vw,56px);
  flex-wrap:wrap;
}
.cd-cell{ display:flex; flex-direction:column; align-items:center; min-width:64px; }
.cd-num{
  font-family:var(--font-display);
  font-size:clamp(2.6rem,9vw,4.6rem);
  font-weight:300; line-height:1; font-variant-numeric:tabular-nums;
}
.cd-label{
  font-family:var(--font-caps);
  text-transform:uppercase; letter-spacing:.24em;
  font-size:.66rem; color:var(--ink-faint); margin-top:10px;
}
.cd-cell + .cd-cell{ position:relative; }
.cd-cell + .cd-cell::before{
  content:":"; position:absolute; left:calc(-1 * clamp(7px,2vw,28px)); top:.1em;
  font-family:var(--font-display); font-size:clamp(2rem,7vw,3.4rem); color:var(--accent); opacity:.45;
}
.countdown__done{
  font-family:var(--font-script); font-size:1.8rem; color:var(--accent); margin-top:10px;
}

/* ============================================================
   Приглашение
   ============================================================ */
.invite__frame{
  border:1px solid var(--line);
  border-radius:2px;
  padding:clamp(34px,6vw,64px) clamp(24px,5vw,56px);
  text-align:center;
  position:relative;
  background:rgba(255,255,255,.18);
}
.invite__frame::before,
.invite__frame::after{
  content:"♡"; position:absolute; left:50%; transform:translateX(-50%);
  color:var(--accent); font-size:1.4rem; background:var(--paper); padding:0 12px;
}
.invite__frame::before{ top:-14px; }
.invite__frame::after{ bottom:-18px; }
.invite__frame .script-title{ margin-bottom:.5em; }

/* ============================================================
   Когда и где
   ============================================================ */
.details__grid{
  display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:clamp(18px,4vw,48px);
}
.detail-card{ text-align:center; }
.detail-card__icon{ color:var(--accent); display:flex; justify-content:center; margin-bottom:16px; }
.detail-card__label{
  font-family:var(--font-caps); text-transform:uppercase; letter-spacing:.28em;
  font-size:.7rem; color:var(--ink-faint); margin-bottom:12px;
}
.detail-card__big{
  font-family:var(--font-display); font-size:1.7rem; line-height:1.2; margin-bottom:8px;
}
.detail-card__sub{ color:var(--ink-soft); font-size:1rem; line-height:1.5; }
.detail-card__sub + .btn{ margin-top:20px; }
.detail-card--center{ padding:0 8px; }
.detail-card__art{ width:min(200px,34vw); margin:0 auto; }

/* ============================================================
   Программа
   ============================================================ */
.schedule__art{ width:min(440px,82vw); margin:0 auto 40px; }
.timeline{ list-style:none; max-width:640px; margin:0 auto; }
.timeline__item{
  display:grid; grid-template-columns:74px 24px 1fr;
  align-items:flex-start; gap:18px;
  padding:22px 0;
  border-bottom:1px dashed var(--line);
}
.timeline__item:last-child{ border-bottom:none; }
.timeline__time{
  font-family:var(--font-display); font-size:1.5rem; font-weight:500;
  letter-spacing:.02em; padding-top:2px; color:var(--ink);
}
.timeline__dot{
  position:relative; width:24px; height:24px; align-self:start; margin-top:6px;
}
.timeline__dot::before{
  content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:12px; height:12px; border:1.5px solid var(--accent); border-radius:50%;
}
.timeline__title{ font-family:var(--font-display); font-size:1.45rem; line-height:1.2; }
.timeline__sub{ color:var(--ink-soft); font-size:1rem; margin-top:2px; }

/* ============================================================
   Подарки
   ============================================================ */
.gifts__art{ width:min(190px,40vw); margin:0 auto 28px; }
.poem{
  text-align:center; font-family:var(--font-display);
  font-size:clamp(1.25rem,3.4vw,1.7rem); line-height:1.9; color:var(--ink);
}
.poem p{ font-style:italic; }

/* ============================================================
   Дресс-код
   ============================================================ */
.dresscode .container{ text-align:center; }
.dress-swatches{ display:flex; justify-content:center; gap:14px; margin:6px 0 28px; }
.dress-swatches span{
  width:38px; height:38px; border-radius:50%; box-shadow:0 0 0 1px var(--line) inset;
}

/* ============================================================
   Подтверждение
   ============================================================ */
.rsvp .lead{ margin-bottom:36px; }
.rsvp-form{ max-width:480px; margin:0 auto; display:flex; flex-direction:column; gap:22px; }
.field{ display:flex; flex-direction:column; gap:8px; text-align:left; }
.field label,.field__label{
  font-family:var(--font-caps); text-transform:uppercase; letter-spacing:.2em;
  font-size:.68rem; color:var(--ink-faint);
}
.field input,
.field select,
.field textarea{
  font-family:var(--font-body); font-size:1rem; color:var(--ink);
  background:transparent; border:none; border-bottom:1px solid var(--ink-soft);
  padding:10px 2px; transition:border-color .3s;
}
.field textarea{ resize:vertical; }
.field input:focus,
.field select:focus,
.field textarea:focus{ outline:none; border-color:var(--accent); }
.field input::placeholder,.field textarea::placeholder{ color:var(--ink-faint); opacity:.8; }
.field select{ appearance:none; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' fill='none' stroke='%23514a3e' stroke-width='1.4'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 4px center; }

.choice{ display:flex; gap:14px; flex-wrap:wrap; margin-top:2px; }
.choice__opt{ flex:1 1 160px; cursor:pointer; }
.choice__opt input{ position:absolute; opacity:0; pointer-events:none; }
.choice__opt span{
  display:block; text-align:center; padding:13px 12px;
  border:1px solid var(--line); border-radius:40px;
  font-family:var(--font-caps); letter-spacing:.08em; font-size:.86rem;
  color:var(--ink-soft); transition:all .3s var(--ease);
}
.choice__opt input:checked + span{ background:var(--ink); color:var(--paper); border-color:var(--ink); }

.rsvp-form .btn{ align-self:center; margin-top:6px; }
.rsvp-form__hint{ text-align:center; font-size:.82rem; color:var(--ink-faint); margin-top:4px; }

/* ============================================================
   Подвал
   ============================================================ */
.footer{ text-align:center; padding:72px 24px 90px; position:relative; z-index:2; }
.footer__line{ margin-bottom:18px; }
.footer__names{ font-family:var(--font-display); font-size:1.4rem; letter-spacing:.1em; }
.footer__date{
  font-family:var(--font-caps); letter-spacing:.34em; font-size:.8rem;
  color:var(--ink-faint); margin-top:8px;
}
.footer__heart{ color:var(--accent); margin:22px auto 0; }

/* ============================================================
   Анимация появления
   ============================================================ */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity 1s var(--ease) var(--d,0s), transform 1s var(--ease) var(--d,0s); }
.reveal.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero__scroll span{ animation:none; }
}

/* ============================================================
   Адаптив
   ============================================================ */
@media (max-width:760px){
  body{ font-size:17px; }
  .nav__links{
    position:fixed; inset:0 0 0 auto; width:min(78vw,320px);
    background:var(--paper); flex-direction:column; gap:0;
    padding:96px 36px; transform:translateX(100%);
    transition:transform .45s var(--ease); box-shadow:-10px 0 40px rgba(0,0,0,.08);
  }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ font-size:.9rem; padding:16px 0; border-bottom:1px solid var(--line); }
  .nav__burger{ display:flex; z-index:60; }

  .details__grid{ grid-template-columns:1fr; gap:40px; }
  .detail-card--center{ order:-1; }
  .detail-card__art{ width:min(150px,40vw); }

  .timeline__item{ grid-template-columns:64px 18px 1fr; gap:12px; }
  .timeline__time{ font-size:1.25rem; }
  .timeline__title{ font-size:1.2rem; }

  .section{ padding:72px 0; }
}

@media (max-width:420px){
  .countdown__grid{ gap:8px; }
  .cd-cell + .cd-cell::before{ display:none; }
  .cd-cell{ min-width:58px; }
}
