/* ============================================================
   ÍTALA & VINÍCIUS — Site (v2 · direção brandbook warm/light)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400;1,500&family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;1,400&family=Tangerine:wght@400;700&display=swap');

:root{
  /* paleta — clara dominante, vinho só no rodapé */
  --cream:#FBF6EC; --sand:#F2E9D7; --sand-deep:#EADFC8; --edge:#E3D7BF;
  --ink:#43302A; --ink-soft:#7C675B;
  --gold:#A88A55; --gold-soft:#C8B084;
  --wine:#3E2724; --wine-soft:#5A3A34;
  --on-dark:#F8EFDD; --on-dark-soft:#D8C3AE;

  --display:'Playfair Display', Georgia, serif;
  --serif:'Montserrat', system-ui, sans-serif;
  --amp:'Tangerine','Brush Script MT', cursive;   /* só no ampersand & */
  --sans:'Montserrat', system-ui, sans-serif;

  --maxw:1180px; --radius:2px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --photo:grayscale(1) sepia(.07) contrast(1.04) brightness(1.02);
  --shadow:0 30px 70px -40px rgba(67,48,42,.55);
  --shadow-soft:0 18px 44px -30px rgba(67,48,42,.4);
  --nav-w:232px;
  /* recuo lateral que alinha o conteúdo "fora do wrap" com o wrap (considera o menu lateral) */
  --gutter: max(40px, calc((100vw - var(--nav-w) - var(--maxw)) / 2 + 40px));
}

*{ box-sizing:border-box; }
html{ -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility; scroll-behavior:smooth; }
body{ margin:0; font-family:var(--serif); font-size:17px; line-height:1.65; color:var(--ink); background:var(--cream); }
img{ display:block; max-width:100%; }
a{ color:inherit; }
section[id]{ scroll-margin-top:90px; }
a:focus-visible, button:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible{ outline:2px solid var(--gold); outline-offset:3px; }

h1,h2,h3,h4{ font-family:var(--display); font-weight:600; margin:0; line-height:1.1; }
p{ margin:0 0 1em; }

.label{ font-family:var(--sans); font-weight:600; font-size:11px; letter-spacing:.3em; text-transform:uppercase; color:var(--gold); }
.script{ font-family:var(--display); font-style:italic; color:var(--gold); font-weight:500; line-height:1.15; }
.rule{ width:62px; height:1px; background:var(--gold); border:0; margin:22px 0; }
.rule.c{ margin-left:auto; margin-right:auto; }
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 40px; }
.section{ padding:120px 0; }
.bg-sand{ background:var(--sand); }
.bg-sand-deep{ background:var(--sand-deep); }
.muted{ color:var(--ink-soft); }

/* cabeçalho de seção */
.sec-head{ text-align:center; margin-bottom:60px; }
.sec-head .label{ display:block; margin-bottom:16px; }
.sec-head h2{ font-size:clamp(34px,4.4vw,52px); text-transform:uppercase; letter-spacing:.07em; }
.sec-head .script{ display:block; font-size:clamp(22px,3vw,32px); margin-top:10px; }

/* botões */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:.5em; font-family:var(--sans);
  font-weight:500; font-size:11px; letter-spacing:.26em; text-transform:uppercase; padding:16px 32px;
  border-radius:var(--radius); text-decoration:none; cursor:pointer; border:1px solid var(--ink); color:var(--ink);
  background:transparent;
  transition:background .35s var(--ease), color .35s var(--ease), border-color .35s var(--ease), transform .12s ease-out, box-shadow .12s ease-out; }
.btn:hover{ background:var(--ink); color:var(--cream); transform:translateY(-2px); box-shadow:0 10px 22px -12px rgba(67,48,42,.6); }
.btn:active{ transform:translateY(0); box-shadow:none; }
.btn[disabled]{ opacity:.6; pointer-events:none; }
.btn--gold{ background:var(--gold); border-color:var(--gold); color:var(--cream); }
.btn--gold:hover{ background:var(--wine); border-color:var(--wine); color:var(--on-dark); }
.btn--solid{ background:var(--ink); color:var(--cream); }
.btn--solid:hover{ background:var(--wine); }
.btn--light{ border-color:rgba(248,239,221,.6); color:var(--on-dark); }
.btn--light:hover{ background:var(--on-dark); color:var(--ink); border-color:var(--on-dark); }

.chiptag{ display:inline-block; font-family:var(--sans); font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  font-weight:600; color:var(--gold); border:1px solid var(--gold); border-radius:100px; padding:7px 16px; }

/* foto base */
.ph{ overflow:hidden; background:var(--sand-deep); }
.ph img{ width:100%; height:100%; object-fit:cover; filter:var(--photo); }

/* selo girando */
.badge{ width:128px; height:128px; position:relative; display:inline-grid; place-items:center; }
.badge svg{ position:absolute; inset:0; width:100%; height:100%; animation:spin 16s linear infinite; }
.badge text{ font-family:var(--sans); font-size:8.6px; letter-spacing:.18em; text-transform:uppercase; fill:var(--gold); font-weight:600; }
.badge .heart{ font-family:var(--amp); font-weight:700; color:var(--gold); font-size:46px; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ============================ SHELL + RAIL ============================ */
.main{ margin-left:var(--nav-w); }
.rail{ position:fixed; left:0; top:0; bottom:0; width:var(--nav-w); z-index:40;
  background:var(--cream); border-right:1px solid var(--edge);
  display:flex; flex-direction:column; padding:42px 30px;
  transition:background .6s var(--ease), border-color .6s var(--ease); }
.rail__logo{ font-family:var(--sans); font-weight:600; text-transform:uppercase; letter-spacing:.22em; font-size:13px; line-height:1.5; color:var(--ink); text-decoration:none; transition:color .5s var(--ease); }
.rail__logo span{ color:var(--gold); transition:color .5s var(--ease); }
.rail nav{ display:flex; flex-direction:column; margin-top:46px; }
.rail nav a{ position:relative; text-decoration:none; font-family:var(--sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase;
  font-weight:500; color:var(--ink-soft); padding:12px 0; border-bottom:1px solid transparent; transition:color .25s; }
.rail nav a:hover{ color:var(--ink); }
.rail nav a.cta{ color:var(--gold); margin-top:6px; }
.rail nav a.active{ color:var(--ink); font-weight:600; }
.rail nav a.active::before{ content:""; position:absolute; left:-22px; top:50%; width:18px; height:2px; background:var(--gold); transform:translateY(-50%); transition:width .25s var(--ease); }
.rail__foot{ margin-top:auto; font-family:var(--sans); font-size:10px; letter-spacing:.05em; line-height:1.9; color:var(--ink-soft); }

/* tema ESCURO (ativado por scroll, depois do hero) — barra lateral + topbar/hambúrguer mobile */
.rail--dark{ background:var(--wine); border-right-color:var(--wine-soft); }
.rail--dark .rail__logo{ color:var(--on-dark); }
.rail--dark .rail__logo span{ color:var(--gold-soft); }
.rail--dark nav a{ color:rgba(248,239,221,.5); }
.rail--dark nav a:hover{ color:var(--on-dark); }
.rail--dark nav a.cta{ color:var(--gold-soft); }
.rail--dark nav a.active{ color:#fff; }
.rail--dark nav a.active::before{ background:var(--gold-soft); }
.rail--dark .rail__foot{ color:var(--on-dark-soft); }
.topbar.topbar--dark{ background:var(--wine); border-bottom-color:var(--wine-soft); }
.topbar--dark .topbar__logo{ color:var(--on-dark); }
.topbar--dark .topbar__logo span{ color:var(--gold-soft); }
.burger.burger--dark span{ background:var(--on-dark); }

/* topbar + menu mobile (escondidos no desktop) */
.topbar{ display:none; }
.burger{ display:none; }
.mobile-menu{ display:none; }

/* ============================ HERO ============================ */
.hero{ position:relative; height:100vh; min-height:620px; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden; color:var(--on-dark); }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; filter:grayscale(1) sepia(.05) contrast(1.05) brightness(1); }
.hero__scrim{ position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(40,26,22,.4) 0%, rgba(40,26,22,.18) 34%, rgba(40,26,22,.58) 100%),
    radial-gradient(95% 62% at 50% 52%, rgba(40,26,22,.46) 0%, rgba(40,26,22,.12) 46%, rgba(40,26,22,.55) 100%); }
.hero__content{ position:relative; z-index:2; padding:40px; max-width:840px; }
.hero__kicker{ color:var(--on-dark); display:block; margin-bottom:30px; text-shadow:0 1px 16px rgba(40,26,22,.9); }
.hero__names{ font-family:var(--display); font-weight:700; text-transform:uppercase; letter-spacing:.04em;
  font-size:clamp(40px,7vw,84px); line-height:1.02; text-shadow:0 2px 30px rgba(40,26,22,.45); }
.hero__names .n{ display:block; }
.hero__names .amp{ display:block; font-family:var(--amp); font-weight:700; color:var(--gold-soft);
  text-transform:none; letter-spacing:0; font-size:1.15em; line-height:.66; margin:.02em 0; }
.hero__rule{ background:var(--gold-soft); opacity:.9; margin:32px auto; }
.hero__meta{ font-family:var(--sans); font-size:12px; letter-spacing:.3em; text-transform:uppercase; color:var(--on-dark); }
.hero__meta span{ display:block; }
.hero__meta span + span{ margin-top:9px; }
.hero__cta{ margin-top:38px; }
.hero__scroll{ position:absolute; bottom:28px; left:50%; transform:translateX(-50%); z-index:2;
  width:24px; height:40px; border:1px solid rgba(248,239,221,.55); border-radius:14px; display:flex; justify-content:center; padding-top:7px; }
.hero__scroll span{ width:3px; height:8px; border-radius:3px; background:var(--gold-soft); animation:scrollPulse 1.8s var(--ease) infinite; }
@keyframes scrollPulse{ 0%{opacity:0;transform:translateY(-4px)} 40%{opacity:1} 80%,100%{opacity:0;transform:translateY(10px)} }

/* ============================ O CONVITE ============================ */
.convite{ display:grid; grid-template-columns:0.68fr 1.32fr; gap:clamp(28px,4vw,52px); align-items:center; }
.convite__txt .label{ display:block; margin-bottom:18px; }
.convite__txt h2{ font-size:clamp(32px,3.6vw,46px); margin-bottom:28px; }
.convite__accent{ display:block; font-size:54px; margin:2px 0 20px; }
.convite__txt p{ color:var(--ink-soft); }
.convite__sign{ font-size:30px; margin-top:18px; }
.convite__photos{ display:grid; grid-template-columns:repeat(3,1fr); gap:10px; align-items:start; }
.convite__photos .ph{ aspect-ratio:3/4; box-shadow:var(--shadow-soft); }
.convite__photos .ph img{ filter:grayscale(1) sepia(.07) contrast(1.03) brightness(1.08); }
.convite__photos .ph:nth-child(2) img{ filter:grayscale(1) sepia(.07) contrast(.97) brightness(1.5); }

/* ============================ OS DETALHES ============================ */
/* topo fora do .wrap: cabeçalho à esquerda (alinhado ao wrap via --gutter) + foto widescreen colada na margem direita */
.detalhes__top{ display:grid; grid-template-columns:1fr 1.5fr; gap:clamp(28px,4vw,56px); align-items:center; margin-bottom:72px; }
.detalhes__head{ text-align:left; padding-left:var(--gutter); }
.detalhes__head .label{ display:block; margin-bottom:16px; }
.detalhes__head h2{ font-size:clamp(34px,4.4vw,56px); text-transform:uppercase; letter-spacing:.07em; }
.detalhes__head .script{ display:block; font-size:clamp(22px,3vw,32px); margin-top:10px; }
.detalhes__photo{ aspect-ratio:64/25; box-shadow:var(--shadow); }
.detalhes__cols{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(28px,4vw,56px); }
.detalhes__col{ text-align:left; }
.detalhes__col h3{ font-size:26px; text-transform:uppercase; letter-spacing:.08em; }
.detalhes__col .rule{ margin:16px 0; }
.detalhes__col p{ color:var(--ink-soft); font-size:17px; margin:0; }

/* ============================ A CERIMÔNIA ============================ */
.cerimonia__row{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(36px,5vw,72px); align-items:center; }
.cerimonia__media{ aspect-ratio:4/5; box-shadow:var(--shadow); }
.cerimonia__media img{ filter:none; }
.cerimonia__info .label{ display:block; margin-bottom:22px; }
.cerimonia__info h3{ font-size:clamp(30px,3.4vw,44px); text-transform:uppercase; letter-spacing:.05em; margin-bottom:24px; }
.cerimonia__pre{ display:block; font-size:.58em; letter-spacing:.1em; color:var(--ink-soft); margin-bottom:2px; }
.cerimonia__time{ font-family:var(--display); font-weight:500; font-size:clamp(36px,4vw,54px); color:var(--ink); margin:6px 0 14px; }
.cerimonia__info p{ color:var(--ink-soft); max-width:46ch; }
.aviso{ border-left:2px solid var(--gold); padding:10px 0 10px 20px; margin:24px 0; max-width:46ch; color:var(--ink); }
.mapa{ margin-top:64px; border:1px solid var(--edge); border-radius:var(--radius); overflow:hidden; }
.mapa iframe{ width:100%; height:420px; border:0; display:block; filter:grayscale(.3) contrast(1.02); }

/* ============================ DRESS CODE ============================ */
.dress__intro{ text-align:center; max-width:54ch; margin:0 auto 44px; color:var(--ink-soft); }
.dress__rules{ display:flex; justify-content:center; align-items:stretch; flex-wrap:wrap; margin:0 auto 64px; }
.dress__rule{ text-align:center; padding:6px clamp(24px,4vw,52px); }
.dress__rule + .dress__rule{ border-left:1px solid var(--edge); }
.dress__rule .label{ display:block; margin-bottom:12px; }
.dress__rule-val{ font-family:var(--serif); font-size:clamp(20px,2.2vw,26px); color:var(--ink); margin:0; line-height:1.3; }
.dress__boards{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(28px,4vw,48px); align-items:start; }
.board{ text-align:center; }
.board__title{ font-family:var(--display); font-weight:600; text-transform:uppercase; letter-spacing:.08em; font-size:20px; margin-bottom:20px; }
.board__frame{ display:flex; flex-direction:column; align-items:center; gap:18px; }
.board__fallback{ padding:30px 16px; color:var(--ink-soft); font-size:16px; }

/* ============================ GALERIA ============================ */
.galeria__grid{ display:grid; grid-template-columns:repeat(6,1fr); grid-auto-rows:clamp(150px,15vw,210px); gap:14px; }
.galeria__grid .ph{ box-shadow:var(--shadow-soft); }
.galeria__grid .ph img{ transition:transform 1.1s var(--ease); }
.galeria__grid .ph:hover img{ transform:scale(1.05); }
.gg-1{ grid-column:span 2; grid-row:span 2; }
.gg-2{ grid-column:span 2; grid-row:span 2; }
.gg-3{ grid-column:span 2; grid-row:span 2; }
.gg-4{ grid-column:span 3; }
.gg-5{ grid-column:span 3; }

/* ============================ PRESENTES ============================ */
.presentes{ text-align:center; }
.presentes__msg{ max-width:52ch; margin:0 auto 40px; color:var(--ink-soft); font-size:20px; }
.pix{ max-width:520px; margin:0 auto; background:var(--cream); border:1px solid var(--edge); border-radius:var(--radius);
  padding:36px; display:grid; gap:22px; justify-items:center; }
.pix__qr{ width:180px; height:180px; border-radius:var(--radius); display:flex; align-items:center; justify-content:center;
  background:#fff; padding:12px; box-shadow:var(--shadow-soft); }
.pix__qr img{ width:100%; height:100%; object-fit:contain; image-rendering:crisp-edges; }
.pix__key{ display:flex; gap:12px; align-items:center; flex-wrap:wrap; justify-content:center; }
.pix__key code{ font-family:var(--sans); font-size:16px; letter-spacing:.06em; color:var(--ink); background:var(--sand); padding:10px 16px; border-radius:var(--radius); }
.pix small{ font-family:var(--sans); font-size:11px; letter-spacing:.08em; color:var(--ink-soft); }

/* ============================ FAQ ============================ */
.faq{ max-width:760px; margin:0 auto; }
.faq__item{ border-top:1px solid var(--edge); }
.faq__item:last-child{ border-bottom:1px solid var(--edge); }
.faq__q{ width:100%; background:none; border:0; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:24px;
  padding:26px 4px; text-align:left; font-family:var(--display); font-size:24px; font-weight:600; color:var(--ink); }
.faq__sign{ font-family:var(--serif); font-weight:400; color:var(--gold); font-size:28px; flex:none; transition:transform .4s var(--ease); }
.faq__item.open .faq__sign{ transform:rotate(45deg); }
.faq__a{ overflow:hidden; max-height:0; transition:max-height .5s var(--ease); }
.faq__a-inner{ padding:0 4px 26px; color:var(--ink-soft); max-width:64ch; }

/* ===================== FOTO REDONDA + COUNTDOWN ===================== */
.countdown{ position:relative; background:var(--sand); padding:200px 0 120px; margin-top:150px; text-align:center; }
.countdown__circle{ position:absolute; top:0; left:50%; transform:translate(-50%,-50%);
  width:clamp(220px,28vw,320px); height:clamp(220px,28vw,320px); border-radius:50%; overflow:hidden;
  box-shadow:var(--shadow); border:5px solid var(--cream); background:var(--sand-deep); }
.countdown__circle img{ width:100%; height:100%; object-fit:cover; object-position:center; filter:none; }
.countdown .label{ display:block; margin-bottom:30px; }
.countdown__grid{ display:flex; gap:clamp(22px,5vw,68px); justify-content:center; }
.count-unit{ text-align:center; min-width:72px; }
.count-num{ font-family:var(--display); font-weight:500; font-size:clamp(46px,7vw,84px); line-height:1; color:var(--ink); }
.count-label{ font-family:var(--sans); font-size:10px; letter-spacing:.24em; text-transform:uppercase; color:var(--gold); margin-top:12px; }
.countdown__script{ font-size:clamp(20px,2.4vw,27px); margin-top:28px; }

/* ============================ RSVP ============================ */
.rsvp{ text-align:center; }
.rsvp__intro{ max-width:50ch; margin:0 auto 14px; color:var(--ink-soft); font-size:20px; }
.rsvp__deadline{ font-family:var(--sans); font-size:12px; letter-spacing:.18em; text-transform:uppercase; color:var(--gold); margin-bottom:34px; }
.rsvp__cta-wrap{ display:flex; flex-direction:column; align-items:center; gap:30px; }
.rsvp__guia{ margin:44px auto 0; max-width:46ch; font-size:15px; font-style:italic; }

/* modal */
.modal{ position:fixed; inset:0; z-index:90; display:none; align-items:center; justify-content:center; padding:24px; }
.modal.open{ display:flex; }
.modal__overlay{ position:absolute; inset:0; background:rgba(40,26,22,.62); backdrop-filter:blur(3px); animation:overlayIn .15s ease both; }
.modal__panel{ position:relative; z-index:1; width:100%; max-width:580px; max-height:90vh; overflow-y:auto;
  background:var(--cream); border-radius:var(--radius); padding:48px clamp(24px,5vw,52px); box-shadow:var(--shadow);
  transform-origin:center; animation:modalIn .15s var(--ease) both; }
@keyframes overlayIn{ from{ opacity:0 } to{ opacity:1 } }
@keyframes modalIn{ from{ opacity:0; transform:scale(.96) } to{ opacity:1; transform:none } }
.modal__close{ position:absolute; top:16px; right:18px; background:none; border:0; cursor:pointer; font-size:26px; line-height:1; color:var(--ink-soft); }
.modal__close:hover{ color:var(--ink); }
.modal__head{ text-align:center; margin-bottom:28px; }
.modal__head .label{ display:block; margin-bottom:10px; }
.modal__head h3{ font-size:34px; text-transform:uppercase; letter-spacing:.06em; }
.modal__head .script{ display:block; font-size:27px; margin-top:0; }

.form{ display:grid; gap:18px; }
.form[hidden]{ display:none; }
.field{ display:flex; flex-direction:column; gap:8px; text-align:left; }
.field label{ font-family:var(--sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase; font-weight:600; color:var(--ink-soft); }
.field input, .field select, .field textarea{ font-family:var(--serif); font-size:17px; color:var(--ink);
  background:#fff; border:1px solid var(--edge); border-radius:var(--radius); padding:12px 14px; width:100%; transition:border-color .3s var(--ease); }
.field textarea{ resize:vertical; min-height:78px; }
.field input:focus, .field select:focus, .field textarea:focus{ outline:none; border-color:var(--gold); }
.field--row{ display:grid; grid-template-columns:1fr 1fr; gap:18px; }
#acompanhantesWrap{ display:grid; gap:12px; }
.hidden-field{ display:none; }
.form__submit{ margin-top:6px; }
.form__submit .btn{ width:100%; }

.rsvp__success{ text-align:center; animation:successIn .45s var(--ease); }
@keyframes successIn{ from{ opacity:0; transform:translateY(10px) } to{ opacity:1; transform:none } }
.rsvp__check{ width:74px; height:74px; margin:0 auto 14px; }
.rsvp__check svg{ width:100%; height:100%; }
.rsvp__check-c{ fill:none; stroke:var(--gold); stroke-width:2; opacity:.45; stroke-dasharray:151; stroke-dashoffset:151; animation:checkCircle .5s var(--ease) forwards; }
.rsvp__check-m{ fill:none; stroke:var(--gold); stroke-width:3.6; stroke-linecap:round; stroke-linejoin:round; stroke-dasharray:40; stroke-dashoffset:40; animation:checkMark .35s var(--ease) .42s forwards; }
@keyframes checkCircle{ to{ stroke-dashoffset:0 } }
@keyframes checkMark{ to{ stroke-dashoffset:0 } }
.rsvp__success .script{ display:block; font-size:46px; color:var(--gold); margin-bottom:0; line-height:1; }
.rsvp__success h3{ font-size:30px; text-transform:uppercase; letter-spacing:.06em; margin:4px 0 12px; }
.rsvp__success p{ color:var(--ink-soft); margin:0 auto; max-width:40ch; }

/* estados de erro do formulário (inline, próximo ao campo) */
.field__err{ font-family:var(--sans); font-size:10.5px; font-weight:500; letter-spacing:.04em; color:#B3503F; }
.field--error input, .field--error select{ border-color:#B3503F; background:#FCF4F1; }
.shake{ animation:shake .3s cubic-bezier(.36,.07,.19,.97); }
@keyframes shake{ 10%,90%{transform:translateX(-1px)} 20%,80%{transform:translateX(2px)} 30%,50%,70%{transform:translateX(-4px)} 40%,60%{transform:translateX(4px)} }

/* estado de erro do envio (com retry + WhatsApp) */
.rsvp__error{ text-align:center; }
.rsvp__error .script{ display:block; font-size:36px; color:var(--gold); margin-bottom:8px; }
.rsvp__error p{ color:var(--ink-soft); margin:0 auto 22px; max-width:42ch; }
.rsvp__error-actions{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================ RODAPÉ ============================ */
.footer{ background:var(--wine); color:var(--on-dark); text-align:center; padding:96px 0 80px; }
.footer__script{ display:block; font-family:var(--display); font-style:italic; font-weight:500; color:var(--gold-soft); font-size:clamp(28px,3.6vw,40px); line-height:1.2; margin:0 0 16px; }
.footer__sign{ font-family:var(--serif); font-style:italic; font-size:15px; color:var(--on-dark-soft); margin-bottom:8px; }
.footer__names{ font-family:var(--sans); font-size:12px; letter-spacing:.26em; text-transform:uppercase; }
.footer__meta{ font-family:var(--sans); font-size:11px; letter-spacing:.2em; text-transform:uppercase; color:var(--on-dark-soft); margin-top:14px; }

/* ===================== MICROINTERAÇÕES (UI/UX) ===================== */
/* reveal on scroll — só aplicado pelo JS em elementos abaixo da dobra */
.reveal{ opacity:0; transform:translateY(22px); }
.reveal.is-visible{ opacity:1; transform:none; transition:opacity .45s var(--ease), transform .45s var(--ease); }

/* toast (feedback de ação — slide-in 200ms / 3s / slide-out 200ms) */
.toast{ position:fixed; left:50%; bottom:28px; transform:translate(-50%,160%); z-index:120;
  background:var(--ink); color:var(--on-dark); font-family:var(--sans); font-weight:500; font-size:11px;
  letter-spacing:.14em; text-transform:uppercase; padding:14px 26px; border-radius:100px; box-shadow:var(--shadow);
  opacity:0; pointer-events:none; transition:transform .2s var(--ease), opacity .2s var(--ease); }
.toast.show{ transform:translate(-50%,0); opacity:1; }

/* ============================ RESPONSIVO ============================ */
@media (max-width:980px){
  .rail{ display:none; }
  .main{ margin-left:0; }
  .topbar{ display:flex; position:fixed; top:0; left:0; right:0; z-index:40; height:62px; align-items:center; justify-content:center;
    background:var(--cream); border-bottom:1px solid var(--edge);
    transition:background .6s var(--ease), border-color .6s var(--ease); }
  .hero__media img{ object-position:28% center; }
  .field--row{ grid-template-columns:1fr; }
  .presentes .sec-head h2{ font-size:26px; letter-spacing:.02em; }
  .topbar__logo{ font-family:var(--sans); font-weight:600; text-transform:uppercase; letter-spacing:.2em; font-size:12px; color:var(--ink); text-decoration:none; }
  .topbar__logo span{ color:var(--gold); }
  .burger{ display:flex; position:fixed; top:14px; right:18px; z-index:60; width:34px; height:34px; background:none; border:0; cursor:pointer; flex-direction:column; justify-content:center; gap:6px; }
  .burger span{ height:2px; background:var(--ink); transition:.35s var(--ease); }
  .burger.open span:nth-child(1){ transform:translateY(8px) rotate(45deg); }
  .burger.open span:nth-child(2){ opacity:0; }
  .burger.open span:nth-child(3){ transform:translateY(-8px) rotate(-45deg); }
  .mobile-menu{ display:flex; position:fixed; top:0; left:0; right:0; z-index:50; flex-direction:column; gap:2px;
    background:var(--cream); padding:80px 28px 36px; transform:translateY(-100%); transition:transform .5s var(--ease); box-shadow:var(--shadow-soft); }
  .mobile-menu.open{ transform:translateY(0); }
  .mobile-menu a{ font-family:var(--sans); font-weight:600; text-transform:uppercase; letter-spacing:.16em; font-size:13px; color:var(--ink);
    text-decoration:none; padding:15px 4px; border-bottom:1px solid var(--edge); }
  .mobile-menu a:last-child{ border-bottom:0; color:var(--gold); }

  .hero{ height:100svh; }
  .section{ padding:84px 0; }
  .wrap{ padding:0 24px; }
  .convite{ grid-template-columns:1fr; gap:40px; }
  .convite__photos{ max-width:460px; margin:0 auto; }
  .convite__photos .ph:nth-child(1),
  .convite__photos .ph:nth-child(3){ transform:none; }
  .detalhes__top{ grid-template-columns:1fr; gap:22px; }
  .detalhes__head{ padding:0 24px; }
  .detalhes__photo{ aspect-ratio:16/9; }
  .detalhes__cols{ grid-template-columns:1fr; gap:36px; }
  .cerimonia__row{ grid-template-columns:1fr; gap:32px; }
  .cerimonia__media{ order:-1; }
  .mapa iframe{ height:320px; }
  .dress__rule + .dress__rule{ border-left:0; border-top:1px solid var(--edge); margin-top:6px; padding-top:18px; }
  .dress__boards{ grid-template-columns:1fr; gap:34px; }
  .galeria__grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:clamp(150px,42vw,220px); }
  .gg-1,.gg-2,.gg-3{ grid-column:span 1; grid-row:span 1; }
  .gg-4,.gg-5{ grid-column:span 2; }
  .countdown{ margin-top:130px; padding:160px 0 96px; }
}

@media (prefers-reduced-motion:reduce){
  html{ scroll-behavior:auto; }
  .hero__scroll span{ animation:none; }
  .badge svg{ animation:none; }
  .galeria__grid .ph:hover img{ transform:none; }
  .reveal{ opacity:1 !important; transform:none !important; }
  .shake{ animation:none; }
  .modal__panel, .modal__overlay{ animation:none; }
  .btn:hover{ transform:none; box-shadow:none; }
  .rsvp__success{ animation:none; }
  .rsvp__check-c, .rsvp__check-m{ animation:none; stroke-dashoffset:0; }
}
