
:root{
  --gold:#b8862b;
  --gold-soft:#c29a5e;
  --ink:#6f625c;
  --paper:#f6efe7;
  --cream:#fff8ef;
  --brown:#5f4f47;
  --muted:#8d7d75;
  --shadow:0 24px 70px rgba(93,72,61,.14);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Montserrat',sans-serif;
  background:#f6efe7;
  color:var(--ink);
}
button,input,textarea,select{font:inherit}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1140px,calc(100% - 32px));margin:auto}
.nav{
  position:sticky;top:0;z-index:60;
  background:rgba(255,248,241,.88);
  backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(184,134,43,.18);
}
.nav-inner{height:72px;display:flex;align-items:center;justify-content:space-between;gap:18px}
.brand{
  font-family:'Cinzel',serif;
  font-size:18px;
  font-weight:600;
  letter-spacing:.16em;
  color:#9a703a;
  display:flex;align-items:center;gap:12px;
}
.brand span:first-child{
  width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;
  background:#fff;border:1px solid rgba(184,134,43,.35);
}
.nav-links{display:flex;align-items:center;gap:18px;font-size:13px;font-weight:600;color:#74655f}
.btn{
  border:0;border-radius:999px;padding:13px 20px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  cursor:pointer;font-weight:700;transition:.2s;
}
.btn-primary{background:linear-gradient(135deg,#a6763f,#d7b56f 52%,#8e5f30);color:#fff;box-shadow:0 14px 32px rgba(166,118,63,.24)}
.btn-soft{background:#fff;border:1px solid rgba(184,134,43,.24);color:#946d3a}
.btn:hover{transform:translateY(-2px)}
.hero{padding:54px 0 70px}
.hero-grid{display:grid;grid-template-columns:1fr 480px;gap:48px;align-items:center}
.kicker{
  font-family:'Cinzel',serif;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:600;
  font-size:13px;
}
.hero h1,.page-title h1{
  font-family:'Cormorant Garamond',serif;
  color:#6a5044;
  font-size:clamp(3rem,5.6vw,5.8rem);
  font-weight:600;
  line-height:.95;
  margin:14px 0;
}
.hero p,.page-title p,.lead{font-size:17px;line-height:1.82;color:#7e7069}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:26px}
.hero-card{
  border-radius:28px;background:#fff;padding:16px;box-shadow:var(--shadow);
  border:1px solid rgba(184,134,43,.18);
}
.section{padding:60px 0}
.section-head{text-align:center;margin-bottom:32px}
.section-head h2{
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(2.3rem,4vw,4rem);
  color:#6a5044;
  margin:10px 0;
}
.grid{display:grid;gap:22px}
.g3{grid-template-columns:repeat(3,1fr)}
.card{
  background:rgba(255,255,255,.86);
  border:1px solid rgba(184,134,43,.16);
  border-radius:28px;
  box-shadow:0 18px 48px rgba(93,72,61,.09);
  overflow:hidden;
}
.card-pad{padding:26px}
.card h3{font-family:'Cormorant Garamond',serif;font-size:30px;color:#6a5044;margin:0 0 10px}
.card p{line-height:1.75;color:#7e7069}
.template-card .exact-cover{border-radius:28px 28px 0 0}

/* ===== EXACT COVER FROM USER ASSET GUIDE ===== */
.exact-cover-wrap{
  width:min(100%,430px);
  margin:auto;
}
.exact-cover{
  position:relative;
  width:100%;
  aspect-ratio:1080/1536;
  overflow:hidden;
  background:#fff8ef;
  border-radius:0;
  box-shadow:0 24px 70px rgba(93,72,61,.15);
}
.exact-cover.rounded{border-radius:28px}
.cover-layer{
  position:absolute;
  pointer-events:none;
  user-select:none;
  -webkit-user-drag:none;
}
.bg{
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
}
.frame{
  inset:2.2% 2.8%;
  width:94.4%;
  height:95.6%;
  object-fit:contain;
  z-index:2;
}
.floral{z-index:4}
.floral-top-left{width:45%;left:-3%;top:-2%}
.floral-right{width:38%;right:-6%;top:26%}
.floral-bottom-left{width:34%;left:-5%;bottom:5%}
.floral-bottom-right{width:46%;right:-5%;bottom:-2%;z-index:7}
.text-heading{
  position:absolute;
  z-index:6;
  top:12%;
  left:12%;
  right:12%;
  text-align:center;
  color:var(--gold);
}
.eyebrow{
  font-family:'Montserrat',sans-serif;
  font-size:clamp(10px,2.4vw,16px);
  font-weight:600;
  letter-spacing:.42em;
  margin:0 0 .7em;
  text-transform:uppercase;
}
.ornament{
  width:45%;
  height:1px;
  margin:0 auto 1.2em;
  background:var(--gold);
  opacity:.75;
  position:relative;
}
.ornament:before{
  content:"❧";
  position:absolute;
  left:50%;
  top:50%;
  transform:translate(-50%,-54%);
  background:rgba(255,248,239,.96);
  padding:0 .45em;
  font-size:clamp(10px,2vw,15px);
}
.cover-name{
  font-family:'Cinzel',serif;
  font-size:clamp(38px,10vw,72px);
  font-weight:500;
  letter-spacing:.16em;
  line-height:1;
  margin:.12em 0;
}
.amp{
  font-family:'Cinzel',serif;
  font-size:clamp(28px,7vw,46px);
  line-height:1;
  margin:.15em 0;
}
.intro{
  margin-top:1.4em;
  font-size:clamp(8px,2vw,13px);
  line-height:1.75;
  letter-spacing:.26em;
  font-weight:500;
  color:#6f625c;
  text-transform:uppercase;
}
.couple{
  z-index:5;
  width:59%;
  left:21%;
  top:37%;
}
.couple.user-photo{
  width:53%;
  height:38%;
  left:23.5%;
  top:38%;
  object-fit:cover;
  border-radius:38% 38% 16px 16px;
  border:5px solid rgba(255,255,255,.65);
  box-shadow:0 18px 42px rgba(93,72,61,.18);
}
.date-box{
  position:absolute;
  z-index:8;
  left:20%;
  right:20%;
  bottom:7.5%;
  text-align:center;
  color:var(--gold);
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:.8em;
}
.date-side{display:grid;gap:.3em;align-items:center}
.date-side span{height:1px;background:var(--gold);opacity:.75}
.date-side p{
  margin:0;
  font-size:clamp(8px,2vw,13px);
  letter-spacing:.35em;
  color:#6f625c;
  text-transform:uppercase;
}
.date-main{
  font-family:'Cinzel',serif;
  font-size:clamp(42px,10vw,78px);
  line-height:1;
}
.save{
  grid-column:1/4;
  font-size:clamp(8px,2vw,13px);
  letter-spacing:.45em;
  font-weight:600;
  margin:.7em 0 0;
}
.quote{
  grid-column:1/4;
  font-family:'Great Vibes',cursive;
  font-size:clamp(22px,5.8vw,38px);
  color:#6f625c;
  margin:.3em 0 0;
}
.open-btn{
  position:absolute;
  left:50%;
  bottom:2.15%;
  transform:translateX(-50%);
  z-index:20;
  border:0;
  border-radius:999px;
  padding:.75em 1.6em;
  color:white;
  font-family:'Cormorant Garamond',serif;
  font-size:clamp(16px,3.4vw,24px);
  background:linear-gradient(135deg,#a97944,#d5b36d 52%,#8e602f);
  box-shadow:0 14px 32px rgba(126,80,35,.24),inset 0 0 0 1px rgba(255,255,255,.28);
  cursor:pointer;
}
.exact-cover.no-button .open-btn{display:none}

/* ===== PUBLIC INVITATION CONTENT ===== */
.public-bg{
  min-height:100vh;
  background:#f6efe7;
}
.public-shell{
  width:min(100%,480px);
  margin:auto;
  background:#fff8ef;
  box-shadow:0 0 80px rgba(93,72,61,.18);
}
.public-shell .exact-cover{width:100%;height:100svh;min-height:680px;aspect-ratio:auto;box-shadow:none}
.public-shell .text-heading{top:12.5%}
.public-shell .date-box{bottom:8.2%}
.public-shell .open-btn{bottom:3.8%}
.inv-content{display:none}
.inv-content.opened{display:block;animation:fadeIn .75s ease both}
@keyframes fadeIn{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.inv-section{
  position:relative;
  padding:68px 26px;
  text-align:center;
  border-bottom:1px solid rgba(184,134,43,.14);
  overflow:hidden;
}
.inv-section:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(circle at 0% 10%,rgba(239,186,174,.18),transparent 34%),
    radial-gradient(circle at 100% 80%,rgba(196,154,94,.12),transparent 36%);
}
.inv-section>*{position:relative;z-index:1}
.inv-section h2{
  font-family:'Cormorant Garamond',serif;
  font-size:42px;
  font-weight:600;
  color:#8f6b3e;
  margin:0 0 18px;
}
.inv-section p{line-height:1.9;color:#756862}
.bismillah{font-family:'Cormorant Garamond',serif;font-size:32px;color:#b8862b;margin-bottom:18px}
.inv-quote{font-family:'Cormorant Garamond',serif;font-size:23px;line-height:1.75;margin:24px auto;color:#6c5f59}
.couple-grid{display:grid;grid-template-columns:1fr auto 1fr;gap:16px;align-items:center}
.avatar{width:126px;height:126px;border-radius:50%;object-fit:cover;border:5px solid #fff;margin:auto;box-shadow:0 16px 34px rgba(93,72,61,.16)}
.couple-grid h3{font-family:'Cormorant Garamond',serif;font-size:30px;color:#8f6b3e;margin:12px 0 6px}
.big-amp{font-family:'Great Vibes',cursive;font-size:56px;color:#b8862b}
.info-grid,.event-grid,.gift-grid{display:grid;gap:14px;margin-top:22px}
.event-grid{grid-template-columns:1fr 1fr}
.info-card,.event-card,.gift-card{
  background:#fff;
  border:1px solid rgba(184,134,43,.18);
  border-radius:22px;
  padding:20px;
  box-shadow:0 14px 34px rgba(93,72,61,.08);
}
.info-card b,.event-card h3,.gift-card b{display:block;font-family:'Cinzel',serif;color:#8f6b3e;letter-spacing:.08em}
.countdown{display:grid;grid-template-columns:repeat(4,1fr);gap:9px;margin:24px 0}
.countdown div{background:#fff;border:1px solid rgba(184,134,43,.16);border-radius:18px;padding:13px 8px}
.countdown b{display:block;font-family:'Cinzel',serif;font-size:25px;color:#8f6b3e}
.countdown span{font-size:11px;color:#877870}
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:18px}
.gallery img{height:130px;width:100%;object-fit:cover;border-radius:18px;border:3px solid #fff;box-shadow:0 10px 24px rgba(93,72,61,.10)}
.timeline{text-align:left;display:grid;gap:14px;margin-top:18px}
.timeline article{background:#fff;border:1px solid rgba(184,134,43,.16);border-radius:22px;padding:18px}
.timeline b{font-family:'Cinzel',serif;color:#8f6b3e}
.form-grid{display:grid;gap:12px;margin-top:18px}
.field{text-align:left}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px;color:#806f67}
.field input,.field textarea,.field select{
  width:100%;
  border:1px solid rgba(184,134,43,.22);
  border-radius:16px;
  padding:13px 14px;
  background:#fff;
  color:#5f544f;
}
.field textarea{min-height:92px;resize:vertical}
.wish-list{display:grid;gap:10px;text-align:left;margin-top:20px}
.wish{background:#fff;border:1px solid rgba(184,134,43,.14);border-radius:18px;padding:14px}
.wish b{color:#8f6b3e}
.music-fab{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:100;
  width:54px;height:54px;
  border-radius:50%;
  border:0;
  background:linear-gradient(135deg,#a97944,#d5b36d);
  color:#fff;
  box-shadow:0 14px 34px rgba(93,72,61,.25);
  cursor:pointer;
}
.music-fab.playing{animation:pulse 1.5s infinite}
@keyframes pulse{50%{transform:scale(1.08)}}

/* ===== EDITOR ===== */
.editor-layout{display:grid;grid-template-columns:430px 1fr;gap:24px;align-items:start}
.editor-panel{position:sticky;top:92px;max-height:calc(100vh - 110px);overflow:auto}
.form-section{background:#fff;border:1px solid rgba(184,134,43,.16);border-radius:24px;padding:22px;margin-bottom:16px;box-shadow:0 12px 34px rgba(93,72,61,.08)}
.form-section h3{font-family:'Cormorant Garamond',serif;color:#8f6b3e;font-size:28px;margin:0 0 12px}
.editor-preview{background:#fff;border-radius:28px;padding:16px;box-shadow:var(--shadow)}
.editor-preview .exact-cover-wrap{width:430px;max-width:100%}
.table{width:100%;border-collapse:separate;border-spacing:0 10px}
.table td{background:#fff;padding:12px;border-top:1px solid rgba(184,134,43,.13);border-bottom:1px solid rgba(184,134,43,.13)}
.table td:first-child{border-left:1px solid rgba(184,134,43,.13);border-radius:14px 0 0 14px}
.table td:last-child{border-right:1px solid rgba(184,134,43,.13);border-radius:0 14px 14px 0}
.toast{
  position:fixed;
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:999;
  padding:12px 18px;
  border-radius:999px;
  background:#3e3430;
  color:#fff;
  box-shadow:0 14px 34px rgba(0,0,0,.2);
  opacity:0;
  pointer-events:none;
  transition:.2s;
}
.toast.show{opacity:1;bottom:28px}

@media(max-width:980px){
  .hero-grid,.editor-layout{grid-template-columns:1fr}
  .editor-panel{position:static;max-height:none}
  .g3{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .nav-links{display:none}
  .hero{padding-top:30px}
  .g3,.event-grid,.couple-grid{grid-template-columns:1fr}
  .hero-card{padding:0;background:transparent;box-shadow:none;border:0}
  .exact-cover-wrap{width:min(100%,430px)}
  .public-shell .exact-cover{min-height:720px}
  .inv-section{padding:54px 20px}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery img{height:120px}
  .countdown{grid-template-columns:repeat(2,1fr)}
}


/* starter-exact cover based on supplied asset package */
.starter-cover-wrap{width:min(100%,430px);margin:auto}
.starter-cover{position:relative;width:100%;aspect-ratio:1080/1536;overflow:hidden;background:#fff8ef}
.starter-cover.rounded{border-radius:28px;box-shadow:0 24px 70px rgba(93,72,61,.15)}
.starter-cover .layer{position:absolute;pointer-events:none;user-select:none;display:block}
.starter-cover .bg{inset:0;width:100%;height:100%;object-fit:cover}
.starter-cover .frame{inset:2.2% 2.8%;width:94.4%;height:95.6%;object-fit:contain;z-index:2}
.starter-cover .floral{z-index:4}
.starter-cover .floral-top-left{width:45%;left:-3%;top:-2%}
.starter-cover .floral-right{width:38%;right:-6%;top:26%}
.starter-cover .floral-bottom-left{width:34%;left:-5%;bottom:5%}
.starter-cover .floral-bottom-right{width:46%;right:-5%;bottom:-2%}
.starter-cover .text-heading{position:absolute;z-index:6;top:12%;left:12%;right:12%;text-align:center;color:#b8862b}
.starter-cover .eyebrow{font-family:'Montserrat',sans-serif;font-size:clamp(10px,2.4vw,16px);font-weight:600;letter-spacing:.42em;margin:0 0 .7em;text-transform:uppercase}
.starter-cover .ornament{width:45%;height:1px;margin:0 auto 1.2em;background:#b8862b;opacity:.75;position:relative}
.starter-cover .ornament:before{content:'❧';position:absolute;left:50%;top:50%;transform:translate(-50%,-54%);background:rgba(255,248,239,.98);padding:0 .45em;font-size:clamp(10px,2vw,15px)}
.starter-cover .cover-name{font-family:'Cinzel',serif;font-size:clamp(38px,10vw,72px);font-weight:500;letter-spacing:.16em;line-height:1;margin:.12em 0}
.starter-cover .amp{font-family:'Cinzel',serif;font-size:clamp(28px,7vw,46px);line-height:1;margin:.15em 0}
.starter-cover .intro{margin-top:1.4em;font-size:clamp(8px,2vw,13px);line-height:1.75;letter-spacing:.26em;font-weight:500;color:#6f625c;text-transform:uppercase}
.starter-cover .couple{z-index:5;width:59%;left:21%;top:37%}
.starter-cover .date-box{position:absolute;z-index:7;left:20%;right:20%;bottom:7.5%;text-align:center;color:#b8862b;display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:.8em}
.starter-cover .date-side{display:grid;gap:.3em;align-items:center}
.starter-cover .date-side span{height:1px;background:#b8862b;opacity:.75}
.starter-cover .date-side p{margin:0;font-size:clamp(8px,2vw,13px);letter-spacing:.35em;color:#6f625c;text-transform:uppercase}
.starter-cover .date-main{font-family:'Cinzel',serif;font-size:clamp(42px,10vw,78px);line-height:1}
.starter-cover .save{grid-column:1/4;font-size:clamp(8px,2vw,13px);letter-spacing:.45em;font-weight:600;margin:.7em 0 0;text-transform:uppercase}
.starter-cover .quote{grid-column:1/4;font-family:'Great Vibes',cursive;font-size:clamp(22px,5.8vw,38px);color:#6f625c;margin:.3em 0 0}
.cover-cta-wrap{display:flex;justify-content:center;padding:18px 16px 22px;background:#fff8ef}
.cover-cta-wrap .btn{min-width:240px;font-family:'Cormorant Garamond',serif;font-size:28px;padding:14px 26px}


/* V8 editable couple photo placement.
   Default cover remains same as requested; uploaded photo becomes transparent PNG and placed in same subject area. */
.starter-cover .couple.uploaded-png{
  z-index:5;
  width:60%;
  left:20%;
  top:37%;
  height:auto;
  object-fit:contain;
  filter:drop-shadow(0 18px 30px rgba(84,62,52,.16));
}
.editor-panel .form-section .field small{
  display:block;
  margin-top:6px;
  color:#8d7d75;
  font-size:12px;
}
