/* ===========================================================
   RAFAEL & THAIS — Site de casamento
   Paleta: sage / cream / dourado suave
   =========================================================== */
:root{
  --sage:        #2e5b38;   /* verde fechado (tom de apoio) */
  --sage-deep:   #1c4220;   /* Pantone 2411 C */
  --cream:       #f4efe6;
  --cream-soft:  #faf7f1;
  --ink:         #3a3a34;
  --gold:        #b89b6e;
  --invite-bg:   #1c4220;   /* verde fechado do convite */
  --invite-line: #7da57f;

  --serif: "Cormorant Garamond", Georgia, serif;
  --script: "Pinyon Script", cursive;
  --sans: "Jost", system-ui, sans-serif;

  --maxw: 1180px;
}

*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--cream-soft);
  font-weight:300;
  line-height:1.7;
  -webkit-font-smoothing:antialiased;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

/* trava o scroll enquanto o convite está fechado */
body.is-locked{ overflow:hidden; height:100vh; }

/* ---------- elementos tipográficos compartilhados ---------- */
.section{ padding:clamp(4rem,9vw,7.5rem) 1.5rem; }
.section__head{ max-width:680px; margin:0 auto clamp(2.5rem,5vw,4rem); text-align:center; }
.section__sub{ margin-top:1rem; color:#6b6b62; }
.eyebrow{
  font-family:var(--sans); font-size:.78rem; letter-spacing:.32em;
  text-transform:uppercase; color:var(--gold); margin-bottom:1rem;
}
.eyebrow--light{ color:#dcd2bf; }
.title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2rem,4.5vw,3.1rem); line-height:1.15; color:var(--sage-deep);
}

/* ---------- botões ---------- */
.btn{
  display:inline-block; font-family:var(--sans); font-weight:400;
  letter-spacing:.18em; text-transform:uppercase; font-size:.75rem;
  padding:.95rem 2.2rem; border-radius:999px; transition:.35s ease;
  border:1px solid transparent; cursor:pointer;
}
.btn--light{ background:rgba(255,255,255,.92); color:var(--sage-deep); }
.btn--light:hover{ background:#fff; transform:translateY(-2px); }
.btn--dark{ background:var(--sage-deep); color:#fff; }
.btn--dark:hover{ background:var(--sage); transform:translateY(-2px); }
.btn--mini{
  padding:.6rem 1.5rem; font-size:.68rem; border:1px solid var(--sage);
  color:var(--sage-deep);
}
.btn--mini:hover{ background:var(--sage-deep); color:#fff; }

/* ===========================================================
   CONVITE LACRADO (tela de abertura)
   =========================================================== */
.invite{
  position:fixed; inset:0; z-index:1000;
  display:flex; align-items:center; justify-content:center;
  perspective:1800px; overflow:hidden;
}
.invite__panel{
  position:absolute; top:0; bottom:0; width:50.5%;
  background:
    radial-gradient(120% 100% at 50% 0%, #2a5533 0%, var(--invite-bg) 60%, #122c15 100%);
  backface-visibility:hidden;
  transition:transform 1.5s cubic-bezier(.7,0,.2,1);
  box-shadow:0 0 60px rgba(0,0,0,.15);
}
.invite__panel--left{ left:0;  transform-origin:left center;  border-right:1px solid rgba(255,255,255,.25); }
.invite__panel--right{ right:0; transform-origin:right center; border-left:1px solid rgba(255,255,255,.25); }

/* desenhos botânicos */
.invite__deco{ position:absolute; inset:0; opacity:.5; }
.branch{ position:absolute; height:70vh; top:15vh; fill:none; stroke:var(--invite-line); stroke-width:1.4; }
.branch .leaves path{ fill:var(--invite-line); opacity:.55; stroke:none; }
.branch--l{ left:8%; transform:scaleX(-1); }
.branch--r{ right:8%; }

/* conteúdo central */
.invite__center{
  position:relative; z-index:5; text-align:center; color:#e9e2d2;
  transition:opacity .8s ease, transform .8s ease;
}
.invite__kicker{
  font-size:.8rem; letter-spacing:.3em; text-transform:uppercase;
  color:#c8d6c0; margin-bottom:.8rem;
}
.invite__names{
  font-family:var(--script); font-weight:400;
  font-size:clamp(3rem,9vw,5.5rem); line-height:1; color:#f4efe6;
}
.invite__names span{ font-size:.5em; vertical-align:.15em; }
.invite__date{
  font-family:var(--sans); letter-spacing:.45em; font-size:1.05rem;
  margin:.6rem 0 2.4rem; color:#c8d6c0;
}

/* selo de cera */
.seal{
  position:relative; width:120px; height:120px; margin:0 auto;
  border:none; background:transparent; cursor:pointer; display:block;
}
.seal__wax{
  position:absolute; inset:0; border-radius:50%;
  /* selo claro, liso (branco/lilás) */
  background:
    radial-gradient(circle at 38% 30%, #ffffff 0%, #f5f0f8 42%, #e7dcef 78%, #d6c8e2 100%);
  box-shadow:
    0 12px 26px rgba(98,80,120,.30),
    inset 0 2px 7px rgba(255,255,255,.9),
    inset 0 -4px 10px rgba(176,160,198,.45);
  display:flex; align-items:center; justify-content:center;
  transition:transform .5s ease;
}
/* anel fino interno */
.seal__wax::before{
  content:""; position:absolute; inset:9px; border-radius:50%;
  border:1.5px solid rgba(150,132,176,.5);
}
/* anel de pontinhos (efeito rendado) */
.seal__wax::after{
  content:""; position:absolute; inset:15px; border-radius:50%;
  border:2px dotted rgba(150,132,176,.45);
}
.seal__mono{
  position:relative; z-index:2;
  font-family:var(--script); font-weight:400; font-size:2.7rem;
  color:#8273a0; letter-spacing:.01em; line-height:1;
  text-shadow:0 1px 1px rgba(255,255,255,.7);
}
.seal__mono small{ font-size:.42em; vertical-align:.35em; }
/* monograma em imagem (fundo branco some com multiply) */
.seal__img{
  position:relative; z-index:2;
  width:72%; height:72%; object-fit:contain;
  mix-blend-mode:multiply; border-radius:50%;
  pointer-events:none;
}
.seal__pulse{
  position:absolute; inset:-6px; border-radius:50%;
  border:1px solid rgba(150,132,176,.55);
  animation:sealPulse 2.4s ease-out infinite;
}
@keyframes sealPulse{
  0%{ transform:scale(.9); opacity:.7; }
  100%{ transform:scale(1.5); opacity:0; }
}
.seal:hover .seal__wax{ transform:scale(1.06); }
.invite__hint{
  margin-top:1.3rem; font-size:.72rem; letter-spacing:.28em;
  text-transform:uppercase; color:#c8d6c0; animation:fade 2.4s ease-in-out infinite;
}
@keyframes fade{ 0%,100%{opacity:.45;} 50%{opacity:1;} }

/* --- estado aberto --- */
.invite.is-open .invite__panel--left{  transform:rotateY(-115deg); }
.invite.is-open .invite__panel--right{ transform:rotateY(115deg); }
.invite.is-open .invite__center{ opacity:0; transform:scale(.85); }
.invite.is-breaking .seal__wax{ transform:scale(1.18) rotate(8deg); }
.invite.is-breaking .seal{ animation:sealBreak .6s forwards; }
@keyframes sealBreak{
  0%{ opacity:1; }
  60%{ opacity:1; transform:translateY(4px); }
  100%{ opacity:0; transform:translateY(30px) scale(.7); }
}
.invite.is-done{ opacity:0; pointer-events:none; transition:opacity .6s ease .4s; }

/* ===========================================================
   NAV
   =========================================================== */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:1.1rem clamp(1.5rem,4vw,3rem);
  transition:.4s ease;
}
.nav.is-scrolled{
  background:rgba(250,247,241,.92); backdrop-filter:blur(8px);
  box-shadow:0 6px 24px rgba(0,0,0,.06);
}
.nav__brand{
  font-family:var(--serif); font-weight:600; font-size:1.5rem; letter-spacing:.05em;
  color:#fff; transition:color .4s;
}
.nav__brand span{ color:var(--gold); }
.nav.is-scrolled .nav__brand{ color:var(--sage-deep); }
.nav__links{ display:flex; align-items:center; gap:2rem; }
.nav__links a{
  font-size:.8rem; letter-spacing:.14em; text-transform:uppercase; color:#fff;
  transition:color .3s; position:relative;
}
.nav.is-scrolled .nav__links a{ color:var(--ink); }
.nav__links a:not(.nav__cta):hover{ color:var(--gold); }
.nav__cta{
  border:1px solid currentColor; padding:.55rem 1.3rem; border-radius:999px;
}
.nav.is-scrolled .nav__cta{ color:var(--sage-deep); }
.nav__cta:hover{ background:var(--gold); border-color:var(--gold); color:#fff !important; }

.nav__toggle{ display:none; flex-direction:column; gap:5px; background:none; border:none; cursor:pointer; }
.nav__toggle span{ width:26px; height:2px; background:#fff; transition:.3s; }
.nav.is-scrolled .nav__toggle span{ background:var(--sage-deep); }

/* ===========================================================
   HERO
   =========================================================== */
.hero{ position:relative; height:100vh; min-height:600px; display:flex; align-items:center; justify-content:center; text-align:center; overflow:hidden; }
.hero__video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
.hero__overlay{ position:absolute; inset:0; background:linear-gradient(180deg, rgba(20,40,24,.45), rgba(20,40,24,.58)); }
.hero__content{ position:relative; z-index:3; color:#fff; padding:0 1.5rem; }
.hero__kicker{ font-size:.85rem; letter-spacing:.4em; text-transform:uppercase; margin-bottom:1rem; opacity:.9; }
.hero__names{ font-family:var(--script); font-weight:400; font-size:clamp(3.5rem,11vw,7rem); line-height:1; text-shadow:0 4px 30px rgba(0,0,0,.3); }
.hero__names span{ font-size:.5em; vertical-align:.15em; }
.hero__date{ font-family:var(--sans); letter-spacing:.18em; font-size:clamp(1rem,2.5vw,1.3rem); margin:1rem 0 2.2rem; }
.hero__scroll{ position:absolute; bottom:2rem; left:50%; transform:translateX(-50%); z-index:3; width:26px; height:42px; border:1.5px solid rgba(255,255,255,.7); border-radius:14px; }
.hero__scroll span{ position:absolute; top:8px; left:50%; width:4px; height:8px; background:#fff; border-radius:2px; transform:translateX(-50%); animation:scroll 1.6s infinite; }
@keyframes scroll{ 0%{opacity:0; top:8px;} 40%{opacity:1;} 80%{opacity:0; top:22px;} 100%{opacity:0;} }

/* ===========================================================
   SOBRE
   =========================================================== */
.sobre{ background:var(--cream-soft); }
.sobre__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:clamp(2rem,5vw,5rem); align-items:center; }
.sobre__photo{ position:relative; }
.sobre__photo img{ width:100%; aspect-ratio:4/5; object-fit:cover; border-radius:6px; }
.sobre__photo::after{ content:""; position:absolute; inset:14px; border:1px solid rgba(184,155,110,.6); border-radius:6px; pointer-events:none; transform:translate(16px,16px); }
.sobre__text p{ margin-bottom:1.1rem; color:#5b5b52; }
.sobre__text .title{ margin:.6rem 0 1.4rem; }
.sobre__sign{ font-family:var(--script); font-size:1.9rem; color:var(--sage); }

/* variações: fundo alternado, grid invertido e foto sem corte */
.sobre--alt{ background:var(--cream); }
.sobre__grid--flip .sobre__photo{ order:2; }
.sobre__grid--flip .sobre__photo::after{ transform:translate(-16px,16px); }
.sobre__photo--free img{ aspect-ratio:auto; }
.dresscode__tip{
  background:rgba(184,155,110,.12); border-left:3px solid var(--gold);
  padding:.9rem 1.1rem; border-radius:0 6px 6px 0;
}

/* ===========================================================
   FRASE DE ABERTURA
   =========================================================== */
.frase{ background:var(--cream); text-align:center; }
.frase p{
  max-width:780px; margin:0 auto;
  font-family:var(--sans); font-style:italic; font-weight:400;
  font-size:clamp(1.25rem,2.6vw,1.7rem); line-height:1.85; color:var(--sage-deep);
}

/* ===========================================================
   CONTADOR
   =========================================================== */
.contador{ position:relative; background:linear-gradient(135deg,var(--sage) 0%, var(--sage-deep) 100%); text-align:center; color:#fff; }
.contador__inner{ max-width:760px; margin:0 auto; }
.contador__title{
  font-family:var(--serif); font-weight:500; letter-spacing:.05em;
  font-size:clamp(2.4rem,6vw,4rem); line-height:1.1;
}
.contador__texto{
  max-width:620px; margin:1.4rem auto 0;
  font-size:1rem; line-height:1.85; opacity:.92;
}
.contador__frase{
  font-size:.78rem; letter-spacing:.28em; text-transform:uppercase;
  opacity:.9; margin-top:1.6rem;
}
.contador__frase strong{ font-weight:500; }
.countdown{ display:flex; justify-content:center; gap:clamp(1rem,4vw,3rem); margin:1.5rem 0 1.8rem; }
.countdown__box{ display:flex; flex-direction:column; }
.countdown__box span{ font-family:var(--sans); font-weight:500; font-size:clamp(2.6rem,7vw,4.5rem); line-height:1; }
.countdown__box small{ font-size:.72rem; letter-spacing:.25em; text-transform:uppercase; opacity:.8; margin-top:.5rem; }
.contador__date{ font-family:var(--sans); font-size:1.15rem; letter-spacing:.08em; opacity:.95; }

/* ===========================================================
   MEMORY LANE / TIMELINE
   =========================================================== */
.memorias{ background:var(--cream); }
.timeline{ position:relative; max-width:820px; margin:0 auto; }
.timeline::before{ content:""; position:absolute; left:50%; top:0; bottom:0; width:1px; background:rgba(184,155,110,.5); transform:translateX(-50%); }
.tl-item{ position:relative; display:grid; grid-template-columns:1fr 1fr; gap:2.5rem; align-items:center; margin-bottom:clamp(2.5rem,6vw,4.5rem); }
.tl-item::after{ content:""; position:absolute; left:50%; top:50%; width:14px; height:14px; background:var(--gold); border:3px solid var(--cream); border-radius:50%; transform:translate(-50%,-50%); }
.tl-photo img{ width:100%; aspect-ratio:1/1; object-fit:cover; border-radius:4px; box-shadow:0 14px 34px rgba(0,0,0,.12); }
.tl-text .tl-year{ font-family:var(--serif); font-size:2.4rem; color:var(--gold); display:block; line-height:1; }
.tl-text h4{ font-family:var(--serif); font-weight:500; font-size:1.5rem; color:var(--sage-deep); margin:.3rem 0 .5rem; }
.tl-text p{ color:#6b6b62; }
.tl-item:nth-child(even) .tl-photo{ order:2; }
.tl-item:nth-child(even) .tl-text{ order:1; text-align:right; }

/* ===========================================================
   LOCALIZAÇÃO
   =========================================================== */
.local{ background:var(--cream-soft); }
.local__grid{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:1fr 1.1fr; gap:clamp(2rem,5vw,4rem); align-items:center; }
.local__venue{ font-family:var(--sans); font-size:1.7rem; color:var(--sage-deep); margin:.8rem 0 .3rem; }
.local__addr{ color:#6b6b62; margin-bottom:1.5rem; }
.local__meta{ list-style:none; margin-bottom:1.8rem; }
.local__meta li{ padding:.55rem 0; border-bottom:1px solid rgba(0,0,0,.07); font-size:.92rem; display:flex; justify-content:space-between; }
.local__meta strong{ font-weight:500; color:var(--sage-deep); letter-spacing:.05em; }
.local__map iframe{ width:100%; height:400px; border:0; border-radius:6px; box-shadow:0 14px 34px rgba(0,0,0,.1); filter:grayscale(.2); }
.local__art img{ width:100%; border-radius:6px; box-shadow:0 14px 34px rgba(0,0,0,.12); }

/* ===========================================================
   LISTA DE PRESENTES
   =========================================================== */
.presentes{ background:var(--cream); }
.gifts{ max-width:var(--maxw); margin:0 auto; display:grid; grid-template-columns:repeat(4,1fr); gap:1.6rem; }
.gift{ background:#fff; border-radius:8px; overflow:hidden; text-align:center; padding-bottom:1.6rem; box-shadow:0 10px 30px rgba(0,0,0,.05); transition:transform .35s ease, box-shadow .35s ease; }
.gift:hover{ transform:translateY(-6px); box-shadow:0 18px 40px rgba(0,0,0,.1); }
.gift__img img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.gift h4{ font-family:var(--serif); font-weight:500; font-size:1.25rem; color:var(--sage-deep); margin:1.1rem 1rem .3rem; }
.gift__price{ color:var(--gold); font-family:var(--sans); font-size:1.3rem; margin-bottom:1rem; }
/* banner de destaque na home */
.presentes-banner{
  position:relative; overflow:hidden; text-align:center;
  padding:clamp(5rem,11vw,9rem) 1.5rem;
}
.presentes-banner__bg{
  position:absolute; inset:0;
  background:url("../assets/tl-2023.jpg") center 35%/cover no-repeat;
  transform:scale(1.05);
}
.presentes-banner__overlay{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(28,40,28,.74), rgba(20,30,20,.82));
}
.presentes-banner__content{ position:relative; z-index:2; max-width:720px; margin:0 auto; color:#fff; }
.eyebrow--gold{ color:#e6c990; }
.presentes-banner__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2.2rem,5.5vw,3.6rem); line-height:1.12;
  text-shadow:0 4px 24px rgba(0,0,0,.35);
}
.presentes-banner__sub{
  margin:1rem auto 0; max-width:600px; opacity:.95; font-size:.98rem; line-height:1.7;
}
.presentes-banner__sub:last-of-type{ margin-bottom:1.8rem; }
.presentes-banner__sub em{ color:#e6c990; font-style:italic; }
.presentes-banner__chips{
  display:flex; justify-content:center; gap:.8rem; flex-wrap:wrap; margin-bottom:2rem;
}
.chip{
  display:inline-block; padding:.5rem 1.2rem; border-radius:999px;
  border:1px solid rgba(230,201,144,.65); background:rgba(255,255,255,.08);
  backdrop-filter:blur(4px); font-size:.85rem; letter-spacing:.04em;
}
.btn--gold{
  background:linear-gradient(135deg,#d4af6e,#b89b6e); color:#fff;
  font-size:.85rem; padding:1.1rem 2.8rem;
  box-shadow:0 10px 30px rgba(184,155,110,.45);
  animation:goldPulse 2.6s ease-in-out infinite;
}
.btn--gold:hover{ transform:translateY(-3px) scale(1.03); box-shadow:0 16px 40px rgba(184,155,110,.6); }
@keyframes goldPulse{
  0%,100%{ box-shadow:0 10px 30px rgba(184,155,110,.45); }
  50%{ box-shadow:0 10px 42px rgba(212,175,110,.75); }
}

.presentes__pix{ text-align:center; margin-top:3rem; color:#6b6b62; }
.presentes__pix code{ display:inline-block; margin-top:.6rem; background:#fff; border:1px dashed var(--gold); padding:.7rem 1.4rem; border-radius:8px; font-family:var(--sans); color:var(--sage-deep); letter-spacing:.05em; }
.presentes__cta{ margin-top:1.8rem; }

/* cards de cota — 5 por fileira, compactos */
.gifts--cotas{ grid-template-columns:repeat(5,1fr); gap:1.2rem; }
.gift--cota{
  padding:0 0 1.3rem; display:flex; flex-direction:column;
  align-items:center; justify-content:space-between; gap:.85rem;
}
.gift--cota h4{ margin:0; padding:0 1rem; font-size:1.02rem; line-height:1.35; }
.gift--cota .gift__img{ width:100%; }
.gift--cota .gift__img img{ width:100%; aspect-ratio:4/5; height:auto; object-fit:cover; }
.gift--noart{ padding-top:1.6rem; }
/* produtos: foto de loja em fundo branco, sem corte */
.gift--prod .gift__img img{ aspect-ratio:1/1; object-fit:contain; background:#fff; padding:6%; box-sizing:border-box; }
.gift--cota .gift__price{ font-size:1.4rem; }
.gift--cota .btn--mini{ padding:.65rem 1.8rem; font-size:.72rem; }
/* estilo "vitrine": preço grande escuro + botão pill preenchido */
.gift--cota .gift__price{
  margin-bottom:0; font-family:var(--sans); font-weight:500;
  font-size:1.7rem; color:var(--ink); letter-spacing:.01em;
}
.gift--cota .btn--mini{
  background:var(--sage-deep); border:none; color:#fff;
  padding:.8rem 2.4rem; font-size:.8rem; border-radius:999px;
}
.gift--cota .btn--mini:hover{ background:var(--gold); }

/* ===========================================================
   PÁGINA DE PRESENTES — cabeçalho
   =========================================================== */
.page-hero{
  padding:clamp(8rem,16vw,11rem) 1.5rem clamp(3rem,6vw,4.5rem);
  text-align:center; background:var(--cream-soft);
}
.page-hero .section__sub{ max-width:620px; margin-left:auto; margin-right:auto; }
.presentes--casa{ background:var(--cream-soft); }

/* menu de categorias da página de presentes (fica fixo ao rolar) */
.cat-nav{
  position:sticky; top:0; z-index:50;
  display:flex; justify-content:center; gap:.8rem;
  padding:.9rem 1rem; background:rgba(250,247,241,.94);
  backdrop-filter:blur(8px); box-shadow:0 6px 20px rgba(0,0,0,.06);
}
.cat-nav__link{
  padding:.6rem 1.6rem; border-radius:999px; font-size:.85rem;
  letter-spacing:.06em; border:1px solid var(--sage-deep);
  color:var(--sage-deep); transition:.3s ease;
}
.cat-nav__link:hover, .cat-nav__link.is-active{
  background:var(--sage-deep); color:#fff;
}

/* ===========================================================
   MENSAGEM AOS NOIVOS + RSVP
   =========================================================== */
.mensagem{ background:var(--cream-soft); text-align:center; }
.mensagem .btn{ margin-top:1.8rem; }
.rsvp{
  background:linear-gradient(135deg,var(--sage) 0%, var(--sage-deep) 100%);
  text-align:center; color:#fff;
}
.rsvp__title{
  font-family:var(--serif); font-weight:500;
  font-size:clamp(2rem,4.5vw,3.1rem); line-height:1.15; color:#fff;
}
.rsvp__sub{ margin:1rem auto 1.8rem; max-width:520px; opacity:.92; }

/* ===========================================================
   FOOTER
   =========================================================== */
.footer{ background:var(--sage-deep); color:#fff; text-align:center; padding:clamp(3rem,7vw,5rem) 1.5rem; }
.footer__names{ font-family:var(--script); font-size:3rem; }
.footer__names span{ color:var(--gold); font-size:.6em; }
.footer__date{ font-family:var(--sans); letter-spacing:.2em; margin:.3rem 0 1.5rem; opacity:.9; }
.footer__credits{ font-size:.78rem; letter-spacing:.2em; text-transform:uppercase; opacity:.6; }

/* ===========================================================
   FORMULÁRIOS (RSVP + recados)
   =========================================================== */
.form-section{ background:var(--cream-soft); padding-top:0; }
.form-card{
  max-width:560px; margin:0 auto; background:#fff; border-radius:12px;
  padding:clamp(1.8rem,4vw,2.8rem); box-shadow:0 14px 40px rgba(0,0,0,.07);
  display:flex; flex-direction:column; gap:1.3rem; text-align:left;
}
.form-card--narrow{ max-width:420px; margin-top:2rem; }
.field{ display:flex; flex-direction:column; gap:.45rem; }
.field > span{
  font-size:.72rem; letter-spacing:.18em; text-transform:uppercase;
  color:var(--sage-deep); font-weight:500;
}
.field input, .field textarea{
  font-family:var(--sans); font-size:1rem; font-weight:300; color:var(--ink);
  padding:.85rem 1rem; border:1px solid #ddd6c8; border-radius:8px;
  background:var(--cream-soft); transition:border-color .3s;
  resize:vertical;
}
.field input:focus, .field textarea:focus{
  outline:none; border-color:var(--sage); background:#fff;
}
.acomp-list{ display:flex; flex-direction:column; gap:.6rem; }
.acomp-row{ display:flex; gap:.5rem; }
.acomp-row input{
  flex:1; font-family:var(--sans); font-size:1rem; font-weight:300;
  padding:.85rem 1rem; border:1px solid #ddd6c8; border-radius:8px;
  background:var(--cream-soft);
}
.acomp-row input:focus{ outline:none; border-color:var(--sage); background:#fff; }
.acomp-del{
  width:42px; border:1px solid #ddd6c8; border-radius:8px; background:#fff;
  color:#b05a5a; font-size:1.2rem; cursor:pointer;
}
.acomp-del:hover{ background:#fbeeee; }
.btn--add{ align-self:flex-start; margin-top:.6rem; }
.form-submit{ margin-top:.4rem; }
.form-msg{ min-height:1.2em; text-align:center; font-size:.9rem; color:var(--sage-deep); }
.form-success{
  max-width:560px; margin:0 auto; text-align:center; background:#fff;
  border-radius:12px; padding:3rem 2rem; box-shadow:0 14px 40px rgba(0,0,0,.07);
}
.form-success .btn{ margin-top:1.6rem; }
.mensagem .form-card{ margin-top:2.2rem; }

/* ===========================================================
   PAINEL DOS NOIVOS
   =========================================================== */
.dash{ max-width:var(--maxw); margin:0 auto; }
.dash__stats{ display:flex; justify-content:center; gap:clamp(1.5rem,5vw,4rem); margin-bottom:3rem; }
.stat{ text-align:center; }
.stat span{ font-family:var(--sans); font-size:clamp(2.4rem,6vw,3.6rem); color:var(--sage-deep); line-height:1; }
.stat small{ display:block; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:#8b8b80; margin-top:.4rem; }
.dash__block{ margin-bottom:3.5rem; }
.dash__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:1.2rem; flex-wrap:wrap; gap:1rem; }
.table-wrap{ overflow-x:auto; background:#fff; border-radius:10px; box-shadow:0 10px 30px rgba(0,0,0,.05); }
.dash-table{ width:100%; border-collapse:collapse; font-size:.92rem; }
.dash-table th{
  text-align:left; padding:.9rem 1.1rem; background:var(--sage-deep); color:#fff;
  font-weight:400; letter-spacing:.08em; font-size:.75rem; text-transform:uppercase;
}
.dash-table td{ padding:.85rem 1.1rem; border-bottom:1px solid #f0ece2; }
.dash-table tr:last-child td{ border-bottom:none; }
.recados{ display:grid; gap:1rem; }
.recado{ background:#fff; border-radius:10px; padding:1.3rem 1.5rem; box-shadow:0 10px 30px rgba(0,0,0,.05); }
.recado__msg{ font-family:var(--sans); font-size:1.15rem; font-style:italic; color:var(--ink); }
.recado__autor{ margin-top:.5rem; font-size:.82rem; color:#8b8b80; }

/* ===========================================================
   REVEAL (animação ao rolar)
   =========================================================== */
.reveal{ opacity:0; transform:translateY(38px); transition:opacity .9s ease, transform .9s ease; }
.reveal.is-visible{ opacity:1; transform:none; }

/* ===========================================================
   RESPONSIVO
   =========================================================== */
@media (max-width:880px){
  .nav__toggle{ display:flex; }
  .nav__links{
    position:fixed; inset:0 0 0 30%; flex-direction:column; justify-content:center;
    gap:1.8rem; background:rgba(28,66,32,.97); backdrop-filter:blur(6px);
    transform:translateX(100%); transition:transform .4s ease;
  }
  .nav__links.is-open{ transform:none; }
  .nav__links a{ color:#fff !important; font-size:1rem; }
  .nav__cta{ border-color:#fff; }

  .sobre__grid, .local__grid{ grid-template-columns:1fr; }
  .sobre__photo{ max-width:420px; margin:0 auto; }
  .sobre__grid--flip .sobre__photo{ order:0; }
  .local__map, .local__art{ order:-1; }

  .gifts{ grid-template-columns:repeat(2,1fr); }
  .gifts--cotas{ grid-template-columns:repeat(3,1fr); }

  .timeline::before{ left:18px; }
  .tl-item{ grid-template-columns:1fr; gap:1rem; padding-left:48px; }
  .tl-item::after{ left:18px; }
  .tl-item .tl-photo{ order:0 !important; }
  .tl-item .tl-text{ order:1 !important; text-align:left !important; }
  .tl-photo img{ aspect-ratio:16/10; }
}

@media (max-width:520px){
  .gifts, .gifts--cotas{ grid-template-columns:1fr 1fr; gap:1rem; }
  .invite__panel{ width:50.5%; }
  .seal{ width:104px; height:104px; }
}

/* respeita quem prefere menos movimento */
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; transition-duration:.2s !important; }
}
