:root{
  --gold:#c99b2e;
  --gold2:#e7c75b;
  --cream:#fff9ef;
  --brown:#3f351f;
  --green:#25391d;
  --sage:#6e7f58;
  --white:#fff;
  --shadow:0 16px 45px rgba(63,53,31,.16);
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Montserrat',sans-serif;background:var(--cream);color:var(--brown);overflow-x:hidden}
body.lock{overflow:hidden}
.serif{font-family:'Cormorant Garamond',serif}
.intro{position:fixed;inset:0;z-index:999;display:flex;align-items:center;justify-content:center;background:linear-gradient(rgba(255,249,239,.80),rgba(255,249,239,.94)),url('../images/_JAS0789.jpg');background-size:cover;background-position:center 34%;padding:24px;transition:.8s ease;text-align:center}
.intro.hide{opacity:0;pointer-events:none;transform:scale(1.03)}
.intro-card{width:min(92vw,500px);background:rgba(255,255,255,.76);backdrop-filter:blur(8px);border:1px solid rgba(201,155,46,.35);border-radius:34px;padding:36px 26px;box-shadow:var(--shadow)}
.intro-logo{width:min(100%,390px);margin-bottom:10px;opacity:.88;filter:drop-shadow(0 18px 26px rgba(63,53,31,.24)) drop-shadow(0 4px 8px rgba(255,255,255,.70));transform:translateY(-4px)}
.intro-text{text-transform:uppercase;letter-spacing:3px;font-size:13px;margin-bottom:24px}
.intro-countdown{font-size:12px;letter-spacing:1px;color:#705f4f;margin:-16px 0 20px;text-transform:uppercase}
.btn{border:0;background:linear-gradient(135deg,var(--gold),var(--gold2));color:white;padding:14px 28px;border-radius:999px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 8px 22px rgba(201,155,46,.28);transition:.25s}
.btn:hover{transform:translateY(-2px)}
.btn:disabled{opacity:.62;cursor:not-allowed;transform:none;box-shadow:none}
.btn.outline{background:white;color:var(--gold);border:1px solid var(--gold);box-shadow:none}
.music-float{position:fixed;right:18px;bottom:18px;z-index:120;width:54px;height:54px;border-radius:50%;border:0;background:var(--gold);color:white;font-size:20px;box-shadow:var(--shadow);cursor:pointer;animation:pulse 2s infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.08)}}
.hero{min-height:100vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:80px 20px 50px;position:relative;background:url('../images/_JAS0341.jpg');background-size:cover;background-position:center 32%;background-attachment:fixed}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(rgba(255,249,239,.55),rgba(255,249,239,.88))}
.hero-content{position:relative;z-index:2;max-width:760px;animation:fadeUp .9s ease}
.main-logo{width:min(96vw,680px);opacity:.88;filter:drop-shadow(0 22px 30px rgba(63,53,31,.26)) drop-shadow(0 5px 10px rgba(255,255,255,.72));transform:translateY(-6px)}
.date{text-transform:uppercase;letter-spacing:5px;color:var(--green);font-size:14px;margin:18px 0 6px}
.hero h1{font-size:54px;font-weight:500}
.phrase{font-family:'Cormorant Garamond',serif;font-size:26px;font-style:italic;margin:12px 0 28px}
.count-title{text-transform:uppercase;letter-spacing:3px;margin-bottom:14px;font-size:15px}
.countdown{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.time-box{background:rgba(255,255,255,.85);border:1px solid rgba(201,155,46,.20);border-radius:22px;padding:17px 13px;min-width:84px;box-shadow:var(--shadow)}
.time-box span{display:block;font-family:'Cormorant Garamond',serif;font-size:34px;font-weight:700;color:var(--gold)}
.time-box small{text-transform:uppercase;letter-spacing:1px;font-size:11px}
.scroll-link{display:inline-block;margin-top:28px;color:var(--green);text-decoration:none;border-bottom:1px solid var(--green)}
.section{padding:72px 20px;text-align:center;position:relative}
.section h2{font-family:'Cormorant Garamond',serif;font-size:46px;font-weight:500;margin-bottom:12px}
.subtitle{max-width:650px;margin:0 auto 34px;line-height:1.8;color:#705f4f}
.welcome{background:white}
.cards,.actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;max-width:900px;margin:0 auto}
.event-card,.action-card{background:white;border-radius:32px;padding:34px 24px;box-shadow:var(--shadow);border:1px solid rgba(201,155,46,.18);overflow:hidden;position:relative}
.event-card:before,.action-card:before{content:"";position:absolute;width:160px;height:160px;background:radial-gradient(circle,rgba(231,199,91,.22),transparent 70%);right:-55px;top:-55px}
.event-card h3,.action-card h3{font-family:'Cormorant Garamond',serif;font-size:32px;color:var(--gold);margin-bottom:10px}
.month{text-transform:uppercase;letter-spacing:4px;color:var(--sage);font-size:12px}
.day{font-family:'Cormorant Garamond',serif;font-size:84px;line-height:.9;margin:12px 0;color:var(--brown)}
.date-day{display:flex;align-items:baseline;justify-content:center;gap:10px;margin:12px 0;color:var(--brown)}
.date-day .day{margin:0}
.month-inline{letter-spacing:2px;color:var(--brown);font-size:18px;font-weight:600}
.event-time{font-family:'Cormorant Garamond',serif;font-size:30px;font-weight:700;color:var(--gold);margin:8px 0 0}
.place{font-weight:700;margin:18px 0 8px}
.event-card .btn{margin-top:20px}
.gallery-section{background:#f6ecd8}
.slider{position:relative;width:min(92vw,520px);margin:0 auto;overflow:hidden;border-radius:30px;background:#f6ecd8}
.slide-track{display:flex;transition:.45s ease}
.slide-track img{min-width:100%;height:680px;object-fit:cover;object-position:center;cursor:pointer}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:5;width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.82);font-size:34px;color:var(--brown);cursor:pointer}
.prev{left:15px}.next{right:15px}
.icon{font-size:38px;margin-bottom:12px}
.action-card p{line-height:1.7;color:#705f4f;margin-bottom:20px}
.rsvp{background:linear-gradient(rgba(255,249,239,.86),rgba(255,249,239,.90)),url('../images/_JAS0326.jpg');background-size:cover;background-position:center}
.confirmation-card{width:min(92vw,520px);margin:0 auto;background:rgba(255,255,255,.88);border:1px solid rgba(201,155,46,.30);border-radius:32px;padding:34px 24px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.confirmation-card:before{content:"";position:absolute;width:170px;height:170px;background:radial-gradient(circle,rgba(231,199,91,.26),transparent 70%);right:-58px;top:-58px}
.confirmation-card>*{position:relative;z-index:1}
.confirmation-label{text-transform:uppercase;letter-spacing:3px;color:var(--sage);font-size:12px;margin-bottom:8px}
.confirmation-card h3{font-family:'Cormorant Garamond',serif;font-size:34px;color:var(--gold);font-weight:600;margin-bottom:10px}
.confirmation-card p:not(.confirmation-label){line-height:1.7;color:#705f4f;margin-bottom:20px}
.confirmation-status{background:#fff9ef;border:1px solid rgba(201,155,46,.24);border-radius:18px;padding:12px 14px;font-weight:500}
.confirmation-actions{display:flex;justify-content:center;gap:12px;flex-wrap:wrap}
.confirmation-actions .btn{margin-top:0}
.confirmation-closed .confirmation-status{background:#f4e6c7;color:#705f4f}
.terms-section{background:white}
.terms-list{max-width:760px;margin:0 auto;text-align:left;display:grid;gap:12px}
.terms-list p{background:#fff9ef;border:1px solid rgba(201,155,46,.18);border-radius:18px;padding:16px 18px;line-height:1.7;color:#705f4f;box-shadow:0 10px 24px rgba(63,53,31,.08)}
.terms-list strong{color:var(--gold);font-weight:700}
footer{text-align:center;padding:45px 20px;background:#efe1c5}
.footer-logo{width:min(92vw,520px);margin-bottom:6px;opacity:.86;filter:drop-shadow(0 16px 24px rgba(63,53,31,.22)) drop-shadow(0 4px 8px rgba(255,255,255,.68));transform:translateY(-3px)}
.modal{position:fixed;inset:0;z-index:600;background:rgba(30,22,15,.62);display:none;align-items:center;justify-content:center;padding:20px}
.modal.show{display:flex}
.modal-box{width:min(92vw,500px);max-height:88vh;overflow:auto;background:white;border-radius:28px;padding:30px 24px;position:relative;box-shadow:0 20px 60px rgba(0,0,0,.26);animation:pop .25s ease;text-align:left}
.close{position:absolute;top:12px;right:14px;width:34px;height:34px;border-radius:50%;border:0;background:#f4e6c7;color:var(--brown);font-size:20px;cursor:pointer}
.modal h3{font-family:'Cormorant Garamond',serif;color:var(--gold);font-size:34px;margin-bottom:18px;text-align:center}
.modal p{line-height:1.8;margin-bottom:10px;color:#6a5743}
.dress-box{width:min(94vw,760px)}
.dress-gallery{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.dress-gallery a{display:block;border-radius:18px;overflow:hidden;border:1px solid rgba(201,155,46,.22);background:#fff9ef;box-shadow:0 12px 28px rgba(63,53,31,.12);position:relative}
.dress-gallery img{display:block;width:100%;aspect-ratio:3/4;height:auto;object-fit:contain;background:#fff9ef}
.dress-zoom{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.86);color:var(--brown);font-size:32px;line-height:1;box-shadow:0 10px 24px rgba(63,53,31,.22);border:1px solid rgba(201,155,46,.30);pointer-events:none}
input,textarea,select{width:100%;padding:13px 14px;border-radius:15px;border:1px solid #e3d6c5;margin:8px 0;font-family:'Montserrat',sans-serif}
textarea{min-height:95px;resize:vertical}
#uploadStatus{background:#fff9ef;border:1px solid rgba(201,155,46,.22);border-radius:16px;padding:12px 14px;margin:12px 0 18px}
.photo-box{padding:10px;background:transparent;box-shadow:none}
.photo-box img{width:100%;border-radius:22px;display:block}
.petal{position:fixed;top:-20px;width:14px;height:14px;background:#f0cf55;border-radius:80% 0 80% 0;opacity:.75;z-index:20;animation:fall linear forwards;pointer-events:none}
@keyframes fall{to{transform:translateY(105vh) rotate(420deg);opacity:0}}
@keyframes fadeUp{from{opacity:0;transform:translateY(22px)}to{opacity:1;transform:translateY(0)}}
@keyframes pop{from{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}
@media(max-width:700px){
  .main-logo{width:96vw}
  .hero h1{font-size:40px}
  .phrase{font-size:22px}
  .section h2{font-size:38px}
  .slide-track img{height:520px}
  .time-box{min-width:72px;padding:14px 10px}
  .dress-gallery{grid-template-columns:1fr}
}
