
:root{
  --beige:#f5f1e8;
  --olive:#7a8450;
  --wood:#8b6f47;
  --accent:#fffaf3;
  --max-width:1100px;
  --container-padding:24px;
  font-family: 'Georgia', serif;
}
*{box-sizing:border-box}
body{margin:0;background:var(--accent);color:#333;line-height:1.5}
.hero{
  height:60vh;
  min-height:420px;
  display:flex;
  align-items:center;
  justify-content:center;
  background-image: url('assets/hero.png');
  background-size:cover;
  background-position:center;
  position:relative;
}
.overlay{
  background: linear-gradient(rgba(245,241,232,0.75), rgba(245,241,232,0.75));
  padding:40px;
  text-align:center;
  border-radius:12px;
  box-shadow:0 6px 18px rgba(0,0,0,0.12);
  width:90%;
  max-width:880px;
}
.names{font-size:44px;margin:0;color:var(--wood);letter-spacing:1px}
.subtitle{margin:12px 0 18px;color:var(--olive);font-size:18px}
.cta-row{display:flex;gap:12px;justify-content:center;margin-top:16px}
.btn{background:var(--olive);color:var(--accent);padding:10px 18px;border-radius:8px;text-decoration:none;font-weight:600}
.btn.alt{background:transparent;color:var(--wood);border:2px solid var(--wood)}

.container{max-width:var(--max-width);margin:32px auto;padding:var(--container-padding)}
.story, .when-where, .audio, .dresscode, .rsvp, .gifts{background:var(--beige);padding:18px;border-radius:10px;margin-bottom:20px;box-shadow:0 4px 12px rgba(0,0,0,0.06)}
h2,h3{color:var(--wood);margin-top:0}

.countdown{display:flex;gap:18px;justify-content:center;margin-bottom:12px}
.countdown>div{text-align:center;padding:8px 12px;border-radius:8px;background:#fff;min-width:72px}
.countdown span{display:block;font-size:22px;font-weight:700;color:var(--olive)}

.rsvp form{display:grid;gap:8px;grid-template-columns:1fr 1fr}
.rsvp label{display:block}
.rsvp input,.rsvp select,.rsvp textarea{width:100%;padding:8px;border-radius:6px;border:1px solid #ddd}
.rsvp textarea{grid-column:1 / -1;height:100px}
.rsvp button{grid-column:1 / -1;justify-self:start}

.gift-buttons{display:flex;gap:10px}
.small{font-size:13px;color:#666}

.site-footer{text-align:center;padding:12px;color:#666;font-size:14px}
@media(max-width:720px){
  .rsvp form{grid-template-columns:1fr}
  .names{font-size:32px}
}
