:root{
  --bg: #141814;
  --text: rgba(245, 238, 231, .92);
  --muted: rgba(245, 238, 231, .68);

  --olive: #566a3d;
  --stone: #ad9270;

  --line: rgba(245, 238, 231, .14);
  --field: rgba(0,0,0,.18);
  --focus: rgba(86,106,61,.22);

  --radius: 6px;
  --max: 1020px;
}

*{box-sizing:border-box}
body{
  margin:0;
  color: var(--text);
  background:
    radial-gradient(1100px 700px at 25% 0%, rgba(86,106,61,.18), transparent 55%),
    radial-gradient(900px 600px at 85% 30%, rgba(173,146,112,.18), transparent 52%),
    var(--bg);
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}
a{
  color: inherit;
}

.container{
  width:min(var(--max), calc(100% - 44px));
  margin:0 auto;
}

.container.narrow{
  width:min(720px, calc(100% - 44px));
}

.header{
  padding: 44px 0 18px;
  border-bottom: 1px solid var(--line);
}

.header.compact{
  padding: 32px 0 14px;
}

.topline{
  letter-spacing:.12em;
  text-transform:uppercase;
  font-size: 12px;
  color: var(--muted);
}

h1{
  margin: 10px 0 10px;
  font-family: Fraunces, serif;
  font-weight: 650;
  letter-spacing: -0.02em;
  line-height: 1.02;
  font-size: clamp(34px, 4vw, 56px);
}

h2{
  margin: 0 0 10px;
  font-family: Fraunces, serif;
  font-weight: 600;
  letter-spacing: -0.01em;
  font-size: 26px;
}

.details{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  align-items:center;
  color: var(--muted);
  font-size: 14px;
}

.sep{opacity:.6}

.map{
  color: inherit;
  text-decoration:none;
  border-bottom: 1px solid rgba(245,238,231,.25);
}
.map:hover{
  border-bottom-color: rgba(245,238,231,.55);
}

.nav{
  margin-top: 18px;
  display:flex;
  gap: 16px;
  flex-wrap:wrap;
}

.nav-link{
  position: relative;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--muted);
  text-decoration: none;
  padding: 4px 2px;
}

.nav-link::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-2px;
  height:1px;
  background: rgba(245,238,231,.35);
  transform: scaleX(0);
  transform-origin: left;
  transition: transform .2s ease;
}

.nav-link:hover{
  color: var(--text);
}

.nav-link:hover::after{
  transform: scaleX(1);
}

.nav-link.primary{
  color: var(--text);
  font-weight: 700;
  letter-spacing: .08em;
}

.section{
  padding: 26px 0 34px;
}

.lead{
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.55;
  max-width: 62ch;
}

.hero{
  padding: 22px 0 10px;
}

.heroFrame{
  margin:0;
  border-radius: var(--radius);
  overflow:hidden;
  border: 1px solid var(--line);
  background: rgba(0,0,0,.12);
  box-shadow: 0 18px 55px rgba(0,0,0,.35);
}

.heroFrame img{
  display:block;
  width:100%;
  height:auto;
}

.back{
  display:inline-block;
  margin-bottom: 10px;
  color: var(--muted);
  text-decoration:none;
  border-bottom: 1px solid transparent;
}
.back:hover{ border-bottom-color: rgba(245,238,231,.35); }

.form{
  display:flex;
  flex-direction:column;
  gap: 12px;
  margin-top: 8px;
}

.rsvp-inline{
  font-family: Fraunces, serif;
  font-weight: 600;
  text-decoration: none;
  color: var(--text);
  border-bottom: 1px solid rgba(245,238,231,.5);
}

.rsvp-inline:hover{
  border-bottom-color: rgba(245,238,231,.85);
}

label{
  display:flex;
  flex-direction:column;
  gap: 6px;
  font-size: 13px;
  color: var(--muted);
}

input, select{
  padding: 12px 12px;
  border-radius: var(--radius);
  border: 1px solid rgba(245,238,231,.16);
  background: var(--field);
  color: var(--text);
  outline: none;
}

input::placeholder{color: rgba(245,238,231,.45)}
input:focus, select:focus{
  border-color: rgba(86,106,61,.60);
  box-shadow: 0 0 0 4px var(--focus);
}

.grid2{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
@media (max-width: 720px){
  .grid2{grid-template-columns:1fr}
}

.plusone{
  padding: 12px;
  border-radius: 16px;
  border: 1px solid rgba(173,146,112,.22);
  background: rgba(173,146,112,.08);
}

.btn{
  display:inline-block;
  padding: 12px 18px;
  border-radius: var(--radius);
  border: 1px solid rgba(86,106,61,.55);
  background: rgba(86,106,61,.24);
  color: var(--text);
  text-decoration:none;
  cursor:pointer;
  font-weight:600;
  align-self:flex-start;
}

.btn:hover{ background: rgba(86,106,61,.32); }

.btn.ghost{
  border-color: rgba(173,146,112,.55);
  background: rgba(173,146,112,.16);
}
.btn.ghost:hover{ background: rgba(173,146,112,.22); }

.ok{margin: 10px 0 0; color: rgba(170, 220, 170, .95)}
.err{margin: 10px 0 0; color: rgba(255, 170, 170, .95)}

.footer{
  padding: 22px 0 30px;
  border-top: 1px solid var(--line);
  color: rgba(245,238,231,.55);
  font-size: 12px;
}

.hp{position:absolute; left:-10000px; width:1px; height:1px; overflow:hidden;}
.timeline{
  margin-top: 10px;
  border-top: 1px solid var(--line);
}

.timeline .item{
  display:grid;
  grid-template-columns: 90px 1fr;
  gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  align-items: baseline;
}

.timeline .time{
  font-weight: 600;
  letter-spacing: .01em;
  color: rgba(245,238,231,.82);
}

.timeline .desc{
  color: var(--muted);
  line-height: 1.45;
}
@media (max-width: 520px){
  .timeline .item{
    grid-template-columns: 72px 1fr;
  }
}

.cagnotte-link{
  font-family: Fraunces, serif;
  font-size: 16px;
  letter-spacing: .02em;
  text-decoration: none;
  color: var(--text);
  border-bottom: 1px solid rgba(173,146,112,.45);
}

.cagnotte-link:hover{
  border-bottom-color: rgba(173,146,112,.85);
}