/* Theme stylesheet (improves visual polish) */
:root{--bg:#fbf6f2;--card:#fff;--accent:#8b5e3c;--muted:#6b5b4a}
*{box-sizing:border-box}
body{margin:0;font-family:'Open Sans',Arial,Helvetica,sans-serif;background:var(--bg);color:#222;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}
.container{max-width:1100px;margin:0 auto;padding:2rem}
.hero{background:linear-gradient(180deg, rgba(139,94,60,0.06), transparent);padding:4rem 1rem;border-bottom:1px solid rgba(0,0,0,0.03)}
.hero .inner{max-width:900px;margin:0 auto;text-align:center}
h1{font-family:'Playfair Display',serif;font-weight:700;font-size:2.6rem;margin:0;color:var(--accent);letter-spacing:0.5px}
p.lead{font-size:1.05rem;color:var(--muted);margin-top:.6rem}
.card{background:var(--card);padding:1.6rem;border-radius:10px;box-shadow:0 8px 30px rgba(23,18,12,0.06);margin-top:1.4rem}
.countdown{display:flex;gap:1rem;flex-wrap:wrap;align-items:center}
#countdown{font-family:'Playfair Display',serif;font-size:1.15rem;color:var(--accent);background:rgba(139,94,60,0.04);padding:.6rem 1rem;border-radius:8px}
/* timer layout */
#timer{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
#timer .time{background:var(--card);padding:.6rem .9rem;border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,0.04);text-align:center;min-width:72px}
#timer .time div{font-family:'Playfair Display',serif;font-size:1.1rem;color:var(--accent);font-weight:600}
#timer small{display:block;color:var(--muted);font-size:.75rem;margin-top:.25rem}
/* full-bleed cover sections */
.cover{min-height:70vh;background-size:cover;background-position:center center;display:flex;align-items:center;justify-content:center;position:relative}
.cover-inner{background:linear-gradient(180deg, rgba(0,0,0,0.35), rgba(0,0,0,0.15));padding:3rem;border-radius:12px;color:#fff;text-align:center;max-width:900px}
.cover-title{font-family:'Playfair Display',serif;font-size:2.2rem;margin:0 0 .4rem;letter-spacing:0.6px}
.cover-sub{font-size:1.05rem;margin:0 0 1rem}
.cover .cta{display:inline-block;background:rgba(255,255,255,0.92);color:var(--accent);padding:.6rem 1rem;border-radius:40px;text-decoration:none;font-weight:600}
.photos{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem}
.photo{width:100%;height:320px;object-fit:cover;border-radius:8px;box-shadow:0 6px 18px rgba(0,0,0,0.06)}
@media (min-width:900px){.photo{width:calc(50% - .6rem);height:420px}}
.rsvp form{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.rsvp label{display:block;font-size:.95rem;color:var(--muted)}
.rsvp input[type='text'],.rsvp input[type='number'],.rsvp textarea{width:100%;padding:.6rem;border:1px solid rgba(0,0,0,0.08);border-radius:8px;background:#fff}
.rsvp textarea{grid-column:1/-1}
.rsvp .full{grid-column:1/-1}
button{background:var(--accent);color:#fff;border:none;padding:.8rem 1.2rem;border-radius:8px;cursor:pointer;font-weight:600}
#response{margin-top:.8rem;padding:.6rem;border-radius:6px}
.hidden{display:none}
#play-toggle{margin-top:1rem;background:transparent;border:1px solid rgba(0,0,0,0.06);padding:.5rem .8rem;border-radius:6px;color:var(--muted);cursor:pointer}
@media (max-width:720px){.container{padding:1rem}h1{font-size:2rem}.photo{width:calc(50% - .6rem);height:100px}.rsvp form{grid-template-columns:1fr}}