
:root{
  --bg:#F6F1E8;
  --paper:#fbf8f1;
  --text:#1B1B1B;
  --muted:#5b5b5b;
  --primary:#0f5132;
  --gold:#D8B349;
  --accent:#0F5A45;
  --radius:22px;
  --shadow:0 18px 60px rgba(0,0,0,.12);
  --shadow2:0 10px 30px rgba(0,0,0,.10);
  --serif:"Cormorant Garamond", serif;
  --sans:"Montserrat", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--text);
  background: radial-gradient(1200px 600px at 50% -50%, rgba(216,179,73,.35), transparent 65%),
              radial-gradient(900px 480px at 10% 20%, rgba(35,95,79,.16), transparent 60%),
              var(--bg);
  overflow-x:hidden;
}

a{color:inherit}
.container{width:min(1100px, calc(100% - 40px)); margin:0 auto}
.section{padding:80px 0}
.center{text-align:center}

#particles{position:fixed; inset:0; width:100%; height:100%; pointer-events:none; opacity:.55; z-index:1}

.gate{position:fixed; inset:0; display:grid; place-items:center; background: radial-gradient(1000px 700px at 50% 0%, rgba(216,179,73,.22), transparent 60%), var(--bg); z-index:50}
.gate__wrap{text-align:center; padding:22px; position:relative; z-index:2}
.gate__hint{margin:16px 0 0; font-weight:500; color:rgba(0,0,0,.65)}
.gate__subhint{margin:6px 0 0; font-size:13px; color:rgba(0,0,0,.5)}

.envelope{width:min(440px, 86vw); aspect-ratio: 5/3.2; position:relative; border-radius:26px; cursor:pointer; transform: translateY(0); transition: transform .35s ease}
.envelope:focus{outline:3px solid rgba(216,179,73,.55); outline-offset:6px}
.envelope:hover{transform:translateY(-4px)}
.envelope__back{
  position:absolute; inset:0;
  border-radius:26px;
  background:
    radial-gradient(800px 250px at 30% -30%, rgba(255,255,255,.55), transparent 55%),
    linear-gradient(135deg, rgba(216,179,73,.95), rgba(155,114,33,.95));
  box-shadow: var(--shadow);
}
.envelope__front{
  position:absolute; inset:0;
  border-radius:26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.18), transparent 35%),
    linear-gradient(135deg, rgba(216,179,73,.96), rgba(160,115,33,.96));
  clip-path: polygon(0 0, 100% 0, 100% 78%, 50% 48%, 0 78%);
  opacity:.95;
}
.envelope__shine{position:absolute; inset:-2px; border-radius:28px; background: radial-gradient(600px 260px at 10% 10%, rgba(255,255,255,.55), transparent 60%); mix-blend-mode:screen; opacity:.65}
.wax{position:absolute; left:50%; top:52%; transform:translate(-50%,-50%); width:120px; height:120px; border-radius:999px; background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.32), transparent 45%), linear-gradient(145deg, #8e1f2f, #4b0e18); box-shadow: 0 18px 40px rgba(0,0,0,.25); display:grid; place-items:center}
.wax__ring{width:78%; height:78%; border-radius:999px; border:2px solid rgba(216,179,73,.55); opacity:.9}
.wax__label{position:absolute; font-family:var(--serif); font-size:22px; color:#fff; letter-spacing:.5px; text-shadow:0 10px 22px rgba(0,0,0,.35)}

.app{position:relative; z-index:2}
.hero{position:relative; min-height:100svh; display:grid; align-items:end; padding:70px 0 40px}
.hero__bg{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(1.05) contrast(1.02)}
.hero__overlay{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.12), rgba(0,0,0,.70) 70%, rgba(0,0,0,.85));}
.hero__content{position:relative; z-index:2; padding:0 20px; text-align:center}
.hero__eyebrow{display:inline-block; padding:8px 14px; border-radius:999px; background: rgba(246,241,232,.14); border:1px solid rgba(216,179,73,.45); color:rgba(255,255,255,.88); letter-spacing:.28em; font-size:11px}
.hero__name{margin:18px 0 10px; font-family:var(--serif); color:#fff; font-size:clamp(48px, 7vw, 86px); font-weight:600; letter-spacing:.02em}
.hero__date{color:rgba(255,255,255,.86); font-family:var(--serif); font-size:20px; letter-spacing:.08em}
.hero__scroll{margin:36px auto 0; display:inline-grid; gap:6px; justify-items:center; color:rgba(255,255,255,.85)}
.hero__scrollIcon{font-size:24px; animation:bob 1.2s ease-in-out infinite}
.hero__scrollText{font-size:11px; letter-spacing:.26em}
.hero__controls{position:fixed; right:18px; top:18px; z-index:30}

@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(7px)}}

.btn{display:inline-flex; align-items:center; gap:10px; padding:12px 16px; border-radius:999px; background:var(--primary); color:#fff; border:1px solid rgba(255,255,255,.14); text-decoration:none; font-weight:600; box-shadow: var(--shadow2); transition: transform .2s ease, filter .2s ease}
.btn:hover{transform:translateY(-1px); filter:saturate(1.02)}
.btn--gold{background: linear-gradient(135deg, rgba(216,179,73,.98), rgba(160,115,33,.98)); color:#1b1b1b}
.btn--ghost{background: rgba(246,241,232,.10); backdrop-filter: blur(10px); border:1px solid rgba(216,179,73,.45)}
.btn--small{padding:10px 12px; font-size:13px; white-space:nowrap}
.btn__icon{width:20px; height:20px}

.section--paper{background: linear-gradient(180deg, rgba(255,255,255,.0), rgba(255,255,255,.15) 50%, rgba(255,255,255,.0))}
.card{background: rgba(251,248,241,.92); border:1px solid rgba(0,0,0,.06); border-radius:var(--radius); padding:28px; box-shadow: var(--shadow2)}
.card--soft{background: rgba(255,255,255,.55); backdrop-filter: blur(10px)}
.card--glass{background: rgba(0,0,0,.18); border:1px solid rgba(216,179,73,.35); backdrop-filter: blur(10px)}
.card--frame{border:1px solid rgba(216,179,73,.45); position:relative}
.card--frame:before{content:""; position:absolute; inset:14px; border-radius:calc(var(--radius) - 10px); border:1px solid rgba(216,179,73,.32); pointer-events:none}

.title{font-family:var(--serif); font-weight:600; letter-spacing:.02em; margin:0 0 14px; font-size:34px}
.title--light{color:#fff}
.lead{font-size:16px; color:rgba(0,0,0,.74)}
p{line-height:1.7; margin:10px 0}
strong{font-weight:700}
.muted{color:rgba(0,0,0,.55); font-size:14px}

.signature{margin-top:20px; display:flex; align-items:center; justify-content:center; gap:10px}
.signature__floral{width:34px; height:34px; object-fit:contain; filter: drop-shadow(0 10px 20px rgba(0,0,0,.15))}
.signature__name{font-family:var(--serif); font-size:34px; color:var(--primary)}
.sparkle{position:relative}
.sparkle:after{content:""; position:absolute; left:-10px; top:50%; width:8px; height:8px; background:rgba(216,179,73,.9); border-radius:99px; transform:translateY(-50%) scale(0); animation: sparkleIn 1.2s ease .4s forwards}
@keyframes sparkleIn{0%{transform:translateY(-50%) scale(0); opacity:0}45%{transform:translateY(-50%) scale(1.2); opacity:1}100%{transform:translateY(-50%) scale(1); opacity:.9}}

.section--countdown{position:relative; padding:90px 0}
.countdown__bg{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(1.05) contrast(1.02)}
.countdown__overlay{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.62), rgba(0,0,0,.72));}
.countdown{position:relative; text-align:center}
.flipgrid{display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:14px; margin:20px auto 0; max-width:740px}
.flip{background: rgba(255,255,255,.08); border:1px solid rgba(216,179,73,.35); border-radius:18px; padding:18px 10px; backdrop-filter: blur(10px)}
.flip__num{font-family:var(--serif); font-size:46px; color:#fff; letter-spacing:.05em}
.flip__label{margin-top:6px; font-size:12px; letter-spacing:.26em; color:rgba(255,255,255,.85)}
.countdown__sub{margin-top:18px; font-family:var(--serif); font-size:30px; letter-spacing:.02em}

.grid2{display:grid; grid-template-columns: 1.25fr .95fr; gap:20px; align-items:start}
.rows{margin-top:10px}
.row{display:grid; grid-template-columns: 14px 120px 1fr; gap:10px; padding:12px 0; border-bottom:1px dashed rgba(0,0,0,.12)}
.row:last-child{border-bottom:0}
.row__dot{width:10px; height:10px; background:rgba(35,95,79,.18); border:2px solid rgba(35,95,79,.40); border-radius:99px; margin-top:4px}
.row__k{color:rgba(0,0,0,.55); text-transform:uppercase; letter-spacing:.18em; font-size:11px}
.row__v{color:rgba(0,0,0,.82)}
.actions{display:flex; gap:12px; flex-wrap:wrap; margin-top:18px}

.timeline{margin-top:8px; position:relative; padding-left:8px}
.tl{position:relative; padding-left:34px; margin:18px 0}
.tl:before{content:""; position:absolute; left:13px; top:-18px; bottom:-18px; width:2px; background:linear-gradient(180deg, rgba(91,31,45,.0), rgba(91,31,45,.55), rgba(91,31,45,.0))}
.tl__pin{position:absolute; left:0; top:8px; width:28px; height:28px; border-radius:99px; background:var(--accent); display:grid; place-items:center; box-shadow:0 12px 20px rgba(0,0,0,.12)}
.tl__pin--ghost{background: rgba(91,31,45,.20); border:1px solid rgba(91,31,45,.25)}
.tl__heart{color:#fff; font-size:14px}
.tl__body{background:rgba(255,255,255,.55); border:1px solid rgba(0,0,0,.06); border-radius:18px; padding:16px; backdrop-filter: blur(10px)}
.tl__time{letter-spacing:.22em; font-size:12px; color:rgba(0,0,0,.65)}
.tl__title{font-family:var(--serif); font-size:28px; margin:8px 0 0}
.tl__icon{width:88px; height:88px; object-fit:contain; opacity:.92; margin-top:10px; filter: drop-shadow(0 14px 25px rgba(0,0,0,.10))}

.section--salon{position:relative; padding:90px 0}
.salon__bg{position:absolute; inset:0; background-size:cover; background-position:center; filter:saturate(1.02) contrast(1.02)}
.salon__overlay{position:absolute; inset:0; background: linear-gradient(180deg, rgba(0,0,0,.60), rgba(0,0,0,.72))}

.gallery{display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:12px}
.gitem{border:0; padding:0; border-radius:18px; overflow:hidden; background:#000; cursor:pointer; box-shadow: var(--shadow2)}
.gitem img{width:100%; height:240px; object-fit:cover; display:block; transform:scale(1.02); transition: transform .35s ease}
.gitem:hover img{transform:scale(1.08)}

.contactRow{display:grid; grid-template-columns:40px 1fr auto; gap:12px; align-items:center; padding:14px 0; border-bottom:1px dashed rgba(0,0,0,.12)}
.contactRow:last-child{border-bottom:0}
.avatar{width:40px; height:40px; border-radius:14px; display:grid; place-items:center; background: rgba(35,95,79,.10); border:1px solid rgba(35,95,79,.22)}
.contactRow__k{letter-spacing:.26em; font-size:11px; color:rgba(0,0,0,.55)}
.contactRow__v{font-weight:700}

.note{margin-top:18px; background: rgba(35,95,79,.07); border:1px solid rgba(35,95,79,.18); padding:14px; border-radius:18px}
.note__small{font-size:13px; color:rgba(0,0,0,.65); margin-top:6px}
code{background:rgba(0,0,0,.06); padding:2px 8px; border-radius:999px}

.accounts{display:grid; gap:14px; margin-top:10px}
.acc{background: rgba(251,248,241,.92); border:1px solid rgba(216,179,73,.35); border-radius:18px; padding:16px}
.acc__title{font-weight:800}
.acc__meta{font-size:13px; color:rgba(0,0,0,.55); margin-top:4px}
.acc__line{display:flex; align-items:center; justify-content:space-between; padding:10px 0; border-bottom:1px dashed rgba(0,0,0,.12)}
.acc__line:last-child{border-bottom:0}
.acc__line strong{font-family:var(--serif); font-size:18px}
.acc__line span{color:rgba(0,0,0,.65)}

.footerbar{height:44px; background: linear-gradient(90deg, rgba(91,31,45,1), rgba(91,31,45,.65), rgba(91,31,45,1)); box-shadow: inset 0 10px 24px rgba(0,0,0,.18)}
.footer{padding:26px 0 40px; background: rgba(255,255,255,.20); border-top:1px solid rgba(0,0,0,.06)}
.footer__inner{display:flex; justify-content:space-between; gap:14px; flex-wrap:wrap; color:rgba(0,0,0,.65)}
.footer__links{display:flex; gap:12px}
.footer__links a{text-decoration:none; border-bottom:1px dashed rgba(0,0,0,.25)}
.footer__links a:hover{border-bottom-color:rgba(0,0,0,.55)}

.lightbox{position:fixed; inset:0; background: rgba(0,0,0,.82); display:none; place-items:center; padding:18px; z-index:60}
.lightbox.is-open{display:grid}
.lightbox__img{max-width:min(900px, 92vw); max-height:80vh; border-radius:18px; box-shadow:0 30px 90px rgba(0,0,0,.35)}
.lightbox__close{position:fixed; top:16px; right:16px; width:46px; height:46px; border-radius:999px; border:1px solid rgba(255,255,255,.25); background: rgba(255,255,255,.10); color:#fff; font-size:28px; cursor:pointer}

.reveal{opacity:0; transform:translateY(18px); transition: opacity .8s ease, transform .8s ease}
.reveal.in-view{opacity:1; transform:translateY(0)}

/* responsive */
@media (max-width: 960px){
  .grid2{grid-template-columns:1fr}
  .hero__controls{right:12px; top:12px}
  .gallery{grid-template-columns:repeat(2, minmax(0,1fr))}
  .gitem img{height:220px}
}
@media (max-width: 520px){
  .section{padding:64px 0}
  .card{padding:20px}
  .title{font-size:30px}
  .flipgrid{grid-template-columns:repeat(2, minmax(0,1fr))}
  .hero__name{letter-spacing:.01em}
}
