:root {
  --cream: #faf3ea;
  --cream-deep: #f3e8da;
  --blush: #e8b4b8;
  --rose: #c98a8e;
  --ink: #2a2320;
  --mute: #6b5e57;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: "Inter", system-ui, -apple-system, sans-serif;
  background: var(--cream);
  color: var(--ink);
}
.page { min-height: 100vh; position: relative; overflow: hidden; }
.bg-wash {
  position: absolute; inset: 0; z-index: -2;
  background:
    radial-gradient(1200px 600px at 80% -10%, #f7d9dc 0%, transparent 60%),
    radial-gradient(900px 500px at -10% 100%, #f3e8da 0%, transparent 55%),
    linear-gradient(180deg, #faf3ea 0%, #fbece8 100%);
}
.grain::before {
  content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.05; mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.7'/></svg>");
}
.container { width: min(1120px, 92vw); margin: 0 auto; }
.nav { padding: 1.5rem 0; display: flex; align-items: center; justify-content: space-between; gap: 1rem; }
.brand { display: flex; align-items: center; gap: .65rem; }
.brand-mark { width: 2rem; height: 2rem; border-radius: 999px; border: 1px solid var(--rose); display:grid; place-items:center; font-family:"Cormorant Garamond", serif; font-weight: 600; }
.brand-text { font-family: "Cormorant Garamond", serif; font-size: 1.35rem; }
.brand-text span { color: var(--rose); }
nav { display: flex; gap: 1.2rem; }
nav a { color: var(--mute); text-decoration: none; font-size: .78rem; text-transform: uppercase; letter-spacing: .15em; }
.btn { display: inline-flex; align-items: center; justify-content:center; border-radius: 999px; padding: .75rem 1.2rem; text-decoration: none; border: none; cursor: pointer; }
.btn-dark { background: var(--ink); color: var(--cream); }
.hero { padding: 2rem 0 4rem; display: grid; gap: 2rem; grid-template-columns: 1.2fr .8fr; align-items: center; }
.pill { display: inline-block; font-size: .72rem; text-transform: uppercase; letter-spacing: .2em; border: 1px solid #e9c5c7; color: var(--rose); background: #fff7; border-radius: 999px; padding: .4rem .8rem; }
.hero-copy h1 { font-family: "Cormorant Garamond", serif; font-weight: 400; font-size: clamp(2.4rem, 7vw, 5rem); line-height: 1.02; margin: 1rem 0; }
.shimmer { background: linear-gradient(90deg, #c98a8e, #e8b4b8, #2a2320, #e8b4b8, #c98a8e); background-size: 200% auto; -webkit-background-clip:text; background-clip:text; color: transparent; animation: shimmer 6s linear infinite; }
@keyframes shimmer { from { background-position: -200% 0; } to { background-position: 200% 0; } }
.hero-copy p { color: var(--mute); max-width: 44ch; line-height: 1.7; }
.hero-copy p span { display: block; margin-top: .5rem; color: #53453e; }
.kicker { font-size: .68rem; text-transform: uppercase; letter-spacing: .26em; color: var(--mute); margin: 1.4rem 0 .8rem; }
.countdown { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: .75rem; max-width: 520px; }
.count-item { text-align: center; background: #fff8; backdrop-filter: blur(6px); border: 1px solid #e9c5c7; border-radius: 1rem; padding: .8rem .45rem; }
.count-item strong { display:block; font-family: "Cormorant Garamond", serif; font-size: clamp(1.5rem, 5vw, 2.5rem); }
.count-item small { font-size: .66rem; text-transform: uppercase; letter-spacing: .16em; color: var(--mute); }
.notify { margin-top: 1.4rem; }
#notify-form { display: flex; gap: .6rem; max-width: 560px; }
#email { flex: 1; border: 1px solid #e9c5c7; border-radius: 999px; padding: .8rem 1rem; background: #fff8; }
.error { color: #b0454a; font-size: .85rem; margin: .5rem 0; }
.success { color: #3c5f3a; font-size: .9rem; margin: .5rem 0; }
.meta { color: var(--mute); font-size: .76rem; }
.hero-art { position: relative; min-height: 420px; }
.ring { position: absolute; inset: 8%; border: 1px dashed #c98a8e99; border-radius: 50%; animation: spin 60s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.card { position: absolute; inset: 18%; border-radius: 2rem; border: 1px solid #e9c5c7; background: linear-gradient(135deg, var(--cream), var(--cream-deep)); display:grid; place-items:center; font-family:"Cormorant Garamond", serif; font-size: clamp(3rem, 9vw, 5.5rem); color: var(--rose); box-shadow: 0 24px 60px -30px rgba(201,138,142,.6); }
.badge { position: absolute; background: #ffffffe0; border: 1px solid #e9c5c7; border-radius: 1rem; padding: .6rem .8rem; box-shadow: 0 12px 24px -20px rgba(0,0,0,.25); }
.badge strong { display:block; font-family:"Cormorant Garamond", serif; }
.badge small { font-size: .63rem; text-transform: uppercase; letter-spacing: .12em; color: var(--mute); }
.badge-left { left: -1rem; top: 1.4rem; }
.badge-right { right: -1rem; bottom: 3rem; }
.categories { padding: 2rem 0 4rem; }
.heading { text-align:center; text-transform: uppercase; letter-spacing: .26em; font-size: .66rem; color: var(--mute); margin-bottom: 1rem; }
.grid { display:grid; gap: .9rem; grid-template-columns: repeat(4, minmax(0,1fr)); }
.grid article { background: #fff8; border: 1px solid #e9c5c7; border-radius: 1rem; padding: 1.2rem; text-align:center; }
.grid h3 { margin: 0 0 .35rem; font-family:"Cormorant Garamond", serif; font-size: 1.45rem; }
.grid p { margin: 0; color: var(--mute); text-transform: uppercase; letter-spacing: .15em; font-size: .66rem; }
footer { border-top: 1px solid #e9c5c7; background: #fff7; }
.footer-inner { display: flex; justify-content: space-between; gap: 1rem; align-items:center; padding: 1.1rem 0; color: var(--mute); font-size: .8rem; }
.footer-inner a { color: inherit; }
.leaf { position:absolute; opacity: .4; }
.leaf-top { top:-3rem; left:-3rem; width: 18rem; animation: drift-slow 9s ease-in-out infinite; }
.leaf-bottom { right:-2rem; bottom:0; width: 21rem; animation: drift 7s ease-in-out infinite; }
@keyframes drift { 0%,100%{transform:translateY(0) rotate(0)} 50%{transform:translateY(-10px) rotate(3deg)} }
@keyframes drift-slow { 0%,100%{transform:translateY(0) rotate(0)} 50%{transform:translateY(-7px) rotate(-2deg)} }
@media (max-width: 980px) {
  nav, .nav .btn { display:none; }
  .hero { grid-template-columns: 1fr; }
  .hero-art { min-height: 300px; }
}
@media (max-width: 700px) {
  #notify-form { flex-direction: column; }
  .grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .countdown { gap: .5rem; }
  .footer-inner { flex-direction: column; }
}