
:root{
  --bg:#fbf4ef;
  --card:#ffffffcc;
  --text:#2a2320;
  --muted:#6b625c;
  --brand:#d86a87;
  --brand2:#d6bf96;
  --brand3:#8a5a3a;
  --leaf:#3f6b52;
  --line:rgba(255,255,255,.72);
  --shadow: 0 30px 80px rgba(18, 20, 26, .14);
  --radius: 22px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color:var(--text);
  background:
    radial-gradient(900px 520px at 18% 10%, rgba(216,106,135,.18) 0%, transparent 60%),
    radial-gradient(820px 520px at 85% 20%, rgba(214,191,150,.22) 0%, transparent 58%),
    radial-gradient(900px 800px at 45% 100%, rgba(138,90,58,.12) 0%, transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,.45), rgba(255,255,255,0)),
    var(--bg);
  overflow-x:hidden;
}

body::before{
  content:"";
  position: fixed;
  inset: 0;
  pointer-events:none;
  opacity: .14;
  background:
    radial-gradient(circle at 10px 10px, rgba(216,106,135,.45) 2px, transparent 3px) 0 0/44px 44px,
    radial-gradient(circle at 30px 28px, rgba(214,191,150,.45) 2px, transparent 3px) 0 0/44px 44px;
  mix-blend-mode: multiply;
}

.wrap{
  max-width: 1020px;
  margin: 0 auto;
  padding: 26px 18px 70px;
  position: relative;
  z-index: 1;
}

header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  margin-bottom: 18px;
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius: 999px;
  background: #ffffffb3;
  border: 1px solid var(--line);
  box-shadow: 0 10px 28px rgba(0,0,0,.06);
  backdrop-filter: blur(10px);
}
.dot{
  width:10px;height:10px;border-radius:50%;
  background: linear-gradient(135deg, var(--brand), #f1a0b5);
  box-shadow: 0 0 0 6px rgba(216,106,135,.14);
}
.badge span{font-size:13px;color:var(--muted)}
.ctaTop{display:flex; gap:10px; flex-wrap:wrap}

.btn{
  appearance:none;
  border:0;
  cursor:pointer;
  padding: 11px 14px;
  border-radius: 14px;
  font-weight: 600;
  font-size: 14px;
  transition: transform .12s ease, box-shadow .12s ease, opacity .12s ease;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  text-decoration:none;
  user-select:none;
  white-space:nowrap;
}
.btn:active{transform: translateY(1px)}
.btnPrimary{
  color:#fff;
  background: linear-gradient(135deg, var(--brand), #c24d6e);
  box-shadow: 0 18px 40px rgba(216,106,135,.25);
}
.btnGhost{
  background:#ffffffb8;
  border:1px solid var(--line);
  color:var(--text);
  box-shadow: 0 12px 28px rgba(0,0,0,.06);
  backdrop-filter: blur(10px);
}

.hero{
  border-radius: var(--radius);
  background:
    radial-gradient(760px 420px at 18% 14%, rgba(216,106,135,.22), transparent 60%),
    radial-gradient(640px 380px at 88% 10%, rgba(214,191,150,.22), transparent 58%),
    linear-gradient(180deg, rgba(255,255,255,.86), rgba(255,255,255,.55));
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  overflow:hidden;
  position:relative;
}

.hero::before, .hero::after{
  content:"";
  position:absolute;
  width: 300px;
  height: 300px;
  opacity:.22;
  background:
    radial-gradient(circle at 40% 35%, rgba(63,107,82,.65) 0 16px, transparent 17px),
    radial-gradient(circle at 58% 62%, rgba(63,107,82,.55) 0 14px, transparent 15px),
    radial-gradient(circle at 30% 70%, rgba(214,191,150,.80) 0 12px, transparent 13px),
    radial-gradient(circle at 70% 28%, rgba(216,106,135,.70) 0 10px, transparent 11px);
  border-radius: 999px;
  transform: rotate(18deg);
  filter: blur(.2px);
}
.hero::before{left:-130px; top:-130px}
.hero::after{right:-130px; bottom:-150px; transform: rotate(-18deg)}

.heroInner{
  display:grid;
  grid-template-columns: 1.25fr .95fr;
  gap: 18px;
  padding: 26px;
  align-items: stretch;
}

.title{
  font-family: Fraunces, serif;
  font-size: clamp(34px, 4.4vw, 56px);
  letter-spacing: -0.02em;
  line-height: 1.02;
  margin: 6px 0 12px;
}

.subtitle{
  margin:0 0 16px;
  color: var(--muted);
  font-size: 16px;
  line-height: 1.5;
  max-width: 54ch;
}

.chips{display:flex; gap:10px; flex-wrap:wrap; margin: 14px 0 0}
.chip{
  background:#ffffffc0;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 10px 12px;
  font-size: 13px;
  color: var(--muted);
  display:inline-flex;
  gap:10px;
  align-items:center;
  box-shadow: 0 12px 24px rgba(0,0,0,.05);
  backdrop-filter: blur(10px);
}
.chip b{color:var(--text); font-weight:600}

.cardRight{
  background:#ffffffc7;
  border:1px solid var(--line);
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 18px 40px rgba(0,0,0,.08);
  backdrop-filter: blur(10px);
  display:flex;
  flex-direction:column;
  gap: 14px;
  min-height: 100%;
}

.countdown{display:grid; grid-template-columns: repeat(4,1fr); gap: 10px}
.timeBox{
  border-radius: 14px;
  background: #ffffff;
  border: 1px solid rgba(0,0,0,.06);
  padding: 12px 10px;
  text-align:center;
  box-shadow: 0 12px 28px rgba(0,0,0,.05);
}
.timeBox .n{
  font-family: Fraunces, serif;
  font-size: 28px;
  line-height: 1;
  margin: 0 0 6px;
  color: #b84f6b;
}
.timeBox .l{font-size: 12px; color: var(--muted); margin:0}

.divider{
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(0,0,0,.08), transparent);
  margin: 4px 0;
}

.rsvp{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  margin-top: 18px;
}

.panel{
  border-radius: var(--radius);
  background: #ffffffb9;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
  padding: 18px;
}

h2{
  margin: 0 0 10px;
  font-family: Fraunces, serif;
  letter-spacing: -0.01em;
  font-size: 26px;
}
.muted{color:var(--muted); line-height:1.5; margin:0 0 14px}

form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 8px;
}

.full{grid-column: 1 / -1}
label{font-size: 13px; color: var(--muted); display:block; margin: 0 0 6px}
input, select, textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.08);
  background: rgba(255,255,255,.92);
  padding: 12px 12px;
  font-size: 14px;
  outline:none;
  transition: box-shadow .12s ease, transform .12s ease, border-color .12s ease;
}
textarea{min-height: 92px; resize: vertical}
input:focus, select:focus, textarea:focus{
  border-color: rgba(216,106,135,.55);
  box-shadow: 0 0 0 6px rgba(216,106,135,.12);
}

.actions{display:flex; gap: 10px; flex-wrap:wrap; align-items:center; justify-content:flex-start}
.note{font-size: 12px; color: var(--muted); margin: 8px 0 0}

.wall{display:flex; flex-direction:column; gap: 10px; margin-top: 10px}
.msg{
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(0,0,0,.06);
  box-shadow: 0 14px 34px rgba(0,0,0,.06);
}
.msg b{font-size: 14px}
.msg p{margin:6px 0 0;color:var(--muted);line-height:1.45}

.toast{
  position: fixed;
  right: 18px;
  bottom: 18px;
  max-width: 420px;
  padding: 12px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.9);
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 20px 60px rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  display:none;
  gap: 10px;
  align-items:flex-start;
  z-index: 9999;
}
.toast.show{display:flex; animation: pop .18s ease}
.toast .icon{
  width: 34px; height:34px;
  border-radius: 12px;
  background: linear-gradient(135deg, #34d399, #22c55e);
  display:flex; align-items:center; justify-content:center;
  color:#fff; font-weight:800;
  flex:0 0 auto;
  box-shadow: 0 18px 40px rgba(34,197,94,.25);
}
.toast .t{font-weight:700; margin:0}
.toast .s{margin:4px 0 0; color:var(--muted); font-size: 13px; line-height:1.35}
@keyframes pop{from{transform:translateY(8px); opacity:.6} to{transform:translateY(0); opacity:1}}

.confetti{position: fixed; inset: 0; pointer-events:none; overflow:hidden; z-index: 9998}
.c{
  position:absolute;
  width:10px; height:16px;
  border-radius: 3px;
  opacity: .9;
  animation: fall 1.2s linear forwards;
  transform: translateY(-20px) rotate(0deg);
}
@keyframes fall{to{ transform: translateY(110vh) rotate(540deg); opacity: 1;}}

@media (max-width: 880px){
  .heroInner{grid-template-columns: 1fr; padding: 18px}
  .rsvp{grid-template-columns: 1fr}
  form{grid-template-columns: 1fr}
}