/* ===========================
   Two Months of Us — Aidah & Achmed
   Premium editorial anniversary
   =========================== */

:root{
  --cream: #f6f1e7;
  --cream-2: #fbf7ee;
  --ice: #e6eef5;
  --ice-2: #d7e4ee;
  --blue-soft: #b9cfdf;
  --blue-deep: #4a6f8a;
  --blue-ink: #1f3a4d;
  --ink: #1a2530;
  --muted: #6b7a86;
  --gold: #c9a96a;
  --rose: #d9b3b0;
  --white: #ffffff;
  --shadow-soft: 0 30px 60px -30px rgba(31,58,77,0.25);
  --shadow-glass: 0 20px 50px -20px rgba(31,58,77,0.35), inset 0 1px 0 rgba(255,255,255,0.6);
  --radius: 28px;
  --radius-lg: 40px;
  --serif: 'Cormorant Garamond', 'Times New Roman', serif;
  --sans: 'Inter', system-ui, sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{overflow-x:hidden}
html{scroll-behavior:smooth}
body{
  font-family: var(--sans);
  color: var(--ink);
  background:
    radial-gradient(1200px 800px at 10% -10%, #eaf1f7 0%, transparent 60%),
    radial-gradient(1000px 700px at 110% 10%, #fbf3e6 0%, transparent 55%),
    linear-gradient(180deg, var(--cream-2) 0%, #eef3f8 100%);
  min-height:100vh;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

img{max-width:100%;display:block}
button{font:inherit;border:0;background:none;cursor:pointer;color:inherit}
a{color:inherit;text-decoration:none}

.serif{font-family:var(--serif);font-weight:500;letter-spacing:-0.01em}
.italic{font-style:italic}

/* Petals canvas */
#petals{
  position:fixed;inset:0;width:100%;height:100%;
  pointer-events:none;z-index:1;opacity:.55;
}

/* NAV */
.nav{
  position:fixed;top:22px;left:50%;transform:translateX(-50%);
  z-index:50;display:flex;align-items:center;gap:42px;
  padding:14px 26px;
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.7);
  border-radius:999px;
  box-shadow: var(--shadow-glass);
  max-width: calc(100% - 32px);
}
.nav-brand{
  font-family:var(--serif);font-style:italic;font-size:22px;color:var(--blue-ink);
  letter-spacing:.04em;
}
.nav-links{display:flex;gap:26px;list-style:none}
.nav-links a{font-size:13px;color:var(--muted);transition:color .25s}
.nav-links a:hover{color:var(--blue-ink)}
@media (max-width: 720px){
  .nav-links{display:none}
}

/* Music toggle */
.music-toggle{
  position:fixed;right:22px;bottom:22px;z-index:60;
  width:54px;height:54px;border-radius:50%;
  background:rgba(255,255,255,0.7);backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,0.8);
  box-shadow: var(--shadow-glass);
  display:grid;place-items:center;
  color:var(--blue-ink);font-size:20px;
  transition: transform .3s;
}
.music-toggle.playing{animation: spin 6s linear infinite;background:linear-gradient(135deg,#b9cfdf,#fbf3e6)}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============ HERO ============ */
.hero{
  position:relative;
  min-height:100vh;
  padding: 140px 8vw 80px;
  display:flex;align-items:center;justify-content:center;
  overflow:hidden;
}
.hero-bg-text{
  position:absolute;top:46%;left:50%;transform:translate(-50%,-50%);
  font-family:var(--serif);
  font-size: clamp(120px, 22vw, 360px);
  font-weight:400;letter-spacing:-0.04em;
  color:transparent;
  -webkit-text-stroke:1px rgba(74,111,138,0.18);
  white-space:nowrap;pointer-events:none;
  z-index:0;
}
.hero-bg-sub{
  position:absolute;bottom:8%;left:6%;
  font-family:var(--serif);font-style:italic;
  font-size: clamp(60px, 10vw, 160px);
  color:rgba(74,111,138,0.08);
  pointer-events:none;z-index:0;
}

.hero-inner{
  position:relative;z-index:5;text-align:center;max-width:780px;
}
.hero-eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 18px;border-radius:999px;
  background:rgba(255,255,255,0.7);backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,0.8);
  font-size:12px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue-deep);
  box-shadow: var(--shadow-glass);
  margin-bottom:28px;
}
.hero-eyebrow .dot{width:8px;height:8px;border-radius:50%;background:var(--rose);box-shadow:0 0 12px var(--rose)}

.hero-title{
  font-family:var(--serif);
  font-size: clamp(56px, 9vw, 140px);
  line-height:.95;font-weight:400;
  color:var(--blue-ink);
  letter-spacing:-0.03em;
  margin-bottom:22px;
}
.hero-names{
  font-family:var(--serif);font-style:italic;
  font-size: clamp(15px, 1.6vw, 19px);
  color:var(--blue-deep);letter-spacing:.04em;margin-bottom:18px;
}
.hero-sub{
  max-width:560px;margin:0 auto 36px;
  font-size:15px;color:var(--muted);line-height:1.75;
}
.hero-ctas{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

.btn{
  padding:14px 28px;border-radius:999px;
  font-size:13px;letter-spacing:.16em;text-transform:uppercase;
  transition: all .35s cubic-bezier(.2,.8,.2,1);
  display:inline-block;
}
.btn-primary{
  background:linear-gradient(135deg, var(--blue-ink), var(--blue-deep));
  color:#fff;
  box-shadow: 0 14px 30px -10px rgba(31,58,77,.5);
}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 20px 40px -10px rgba(31,58,77,.55)}
.btn-ghost{
  background:rgba(255,255,255,0.6);backdrop-filter:blur(12px);
  border:1px solid rgba(74,111,138,0.2);color:var(--blue-ink);
}
.btn-ghost:hover{background:#fff;transform:translateY(-2px)}

/* Floating elements */
.floating{position:absolute;z-index:3;will-change:transform}

.floating-photo{
  top:18%;left:6%;
}
.photo-frame{
  width:200px;height:260px;border-radius:120px 120px 24px 24px;
  background:linear-gradient(160deg,#fff,#eef3f8);
  border:1px solid rgba(255,255,255,0.9);
  box-shadow: var(--shadow-glass), 0 40px 70px -30px rgba(31,58,77,.4);
  overflow:hidden;display:flex;flex-direction:column;
  backdrop-filter:blur(10px);
}
.photo-placeholder{
  flex:1;position:relative;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.8), transparent 50%),
    linear-gradient(160deg, #cfdfe9 0%, #e8d8c7 100%);
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-size:42px;color:rgba(31,58,77,.45);
  letter-spacing:.04em;overflow:hidden;
}
.photo-placeholder img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.g-photo img,.lb-photo img{width:100%;height:100%;object-fit:cover;border-radius:inherit;display:block}
.photo-caption{
  padding:14px;text-align:center;font-size:11px;letter-spacing:.3em;
  color:var(--blue-deep);background:#fff;
}

.floating-card.card-date{
  top:14%;right:8%;
  width:130px;padding:18px 14px;border-radius:24px;
  background:rgba(255,255,255,0.75);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,0.9);
  box-shadow: var(--shadow-glass);
  text-align:center;display:flex;flex-direction:column;gap:6px;
}
.floating-card.card-date.alt{top:auto;bottom:18%;right:auto;left:10%}
.card-mini{font-size:10px;letter-spacing:.3em;color:var(--muted);text-transform:uppercase}
.card-big{font-family:var(--serif);font-size:46px;color:var(--blue-ink);line-height:1}
.card-big small{font-size:18px;color:var(--blue-deep)}

.glass-heart{
  bottom:14%;right:10%;width:160px;height:160px;
  filter: drop-shadow(0 30px 40px rgba(31,58,77,.25));
}
.glass-heart svg{width:100%;height:100%}

.rings{
  top:30%;right:18%;
  width:120px;height:80px;
}
.ring{
  position:absolute;width:60px;height:60px;border-radius:50%;
  border:3px solid var(--gold);
  box-shadow: 0 8px 20px rgba(201,169,106,.4), inset 0 2px 4px rgba(255,255,255,.6);
  background: radial-gradient(circle at 30% 30%, #f5e0b4, #c9a96a 70%, #8a6f3e);
  background-clip: padding-box;
}
.ring.r1{top:0;left:0}
.ring.r2{top:14px;left:42px;border-color:#e6c98c}

.bouquet{
  bottom:22%;left:4%;width:110px;height:140px;
}
.bouquet .petal{
  position:absolute;width:34px;height:34px;border-radius:50%;
  background:radial-gradient(circle at 30% 30%, #fff, var(--rose) 80%);
  box-shadow:0 4px 10px rgba(217,179,176,.4);
}
.bouquet .p1{top:0;left:38px}
.bouquet .p2{top:18px;left:14px}
.bouquet .p3{top:18px;left:62px}
.bouquet .p4{top:42px;left:30px;background:radial-gradient(circle at 30% 30%, #fff, #e8d8c7 80%)}
.bouquet .p5{top:42px;left:54px;background:radial-gradient(circle at 30% 30%, #fff, var(--blue-soft) 80%)}
.bouquet .stem{position:absolute;top:60px;left:52px;width:4px;height:80px;background:linear-gradient(180deg,#7a8a6a,#4a5a3a);border-radius:4px}

.ribbon{
  top:60%;right:4%;width:140px;height:24px;
  background:linear-gradient(90deg, transparent, var(--rose), transparent);
  border-radius:999px;opacity:.5;filter:blur(2px);
  transform:rotate(-12deg);
}

.hero-scroll{
  position:absolute;bottom:24px;left:50%;transform:translateX(-50%);
  width:1px;height:50px;background:rgba(31,58,77,.2);overflow:hidden;
}
.hero-scroll span{
  display:block;width:100%;height:50%;background:var(--blue-deep);
  animation: scrollHint 2s ease-in-out infinite;
}
@keyframes scrollHint{
  0%{transform:translateY(-100%)}100%{transform:translateY(200%)}
}

/* Float animation */
@keyframes floatY {
  0%,100%{transform:translateY(0)}
  50%{transform:translateY(-14px)}
}
.floating-photo{animation: floatY 7s ease-in-out infinite}
.floating-card.card-date{animation: floatY 6s ease-in-out infinite}
.floating-card.card-date.alt{animation: floatY 8s ease-in-out infinite}
.glass-heart{animation: floatY 9s ease-in-out infinite}
.rings{animation: floatY 7.5s ease-in-out infinite}
.bouquet{animation: floatY 8.5s ease-in-out infinite}

@media (max-width: 900px){
  .floating-photo{top:6%;left:50%;transform:translateX(-50%) scale(.7)}
  .floating-card.card-date{display:none}
  .glass-heart{width:90px;height:90px;bottom:6%;right:6%}
  .rings{display:none}
  .bouquet{display:none}
  .hero{padding-top:180px}
}

/* ============ STATS ============ */
.stats{
  position:relative;z-index:5;
  display:grid;grid-template-columns:repeat(4,1fr);
  gap:0;
  max-width:1200px;margin:0 auto;
  padding:60px 6vw;
  background:rgba(255,255,255,0.5);backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,.6);
  border-bottom:1px solid rgba(255,255,255,.6);
  border-radius: var(--radius-lg);
  margin-top:-40px;margin-left:auto;margin-right:auto;
  width:calc(100% - 32px);
  box-shadow: var(--shadow-soft);
}
.stat{text-align:center;padding:10px;border-right:1px solid rgba(74,111,138,.1)}
.stat:last-child{border-right:0}
.stat-num{
  font-family:var(--serif);font-size: clamp(40px, 5vw, 72px);
  color:var(--blue-ink);line-height:1;letter-spacing:-.02em;
}
.stat-num span{font-size:.45em;color:var(--blue-deep)}
.stat-label{
  margin-top:10px;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted)
}
@media (max-width:720px){
  .stats{grid-template-columns:repeat(2,1fr);gap:30px 0}
  .stat:nth-child(2){border-right:0}
}

/* ============ Generic section heads ============ */
.section-head{text-align:center;max-width:720px;margin:0 auto 60px;position:relative;z-index:3}
.section-head h2{
  font-family:var(--serif);font-size:clamp(36px,5vw,64px);
  color:var(--blue-ink);line-height:1.1;letter-spacing:-.02em;font-weight:400;
}
.eyebrow{
  display:inline-block;font-size:11px;letter-spacing:.3em;text-transform:uppercase;
  color:var(--blue-deep);margin-bottom:16px;
}
.eyebrow.center{display:block}

.bg-text-soft{
  position:absolute;top:30px;left:-20px;
  font-family:var(--serif);font-size:clamp(80px,14vw,200px);
  color:transparent;-webkit-text-stroke:1px rgba(74,111,138,.1);
  letter-spacing:-.04em;pointer-events:none;z-index:0;font-weight:400;
}
.bg-text-soft.right{left:auto;right:-20px}

/* ============ TIMELINE ============ */
.timeline{
  position:relative;padding:140px 8vw 100px;overflow:hidden;
}
.timeline-track{
  position:relative;max-width:1100px;margin:0 auto;
  display:flex;gap:30px;justify-content:space-between;flex-wrap:wrap;
}
.tl-line{
  position:absolute;top:30px;left:5%;right:5%;height:2px;
  background: linear-gradient(90deg, transparent, var(--blue-soft), transparent);
}
.tl-item{flex:1;min-width:260px;position:relative;text-align:center}
.tl-item::before{
  content:"";display:block;width:18px;height:18px;border-radius:50%;
  background:#fff;border:3px solid var(--blue-deep);
  margin:22px auto 30px;
  box-shadow:0 6px 16px rgba(74,111,138,.3);
  position:relative;z-index:2;
}
.tl-date{
  font-family:var(--serif);font-style:italic;font-size:22px;color:var(--blue-deep);
  margin-bottom:16px;
}
.tl-card{
  background:rgba(255,255,255,0.7);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.8);
  border-radius:var(--radius);padding:30px 26px;
  box-shadow: var(--shadow-glass);
  transition: transform .4s, box-shadow .4s;
}
.tl-card:hover{transform:translateY(-6px);box-shadow:0 30px 50px -20px rgba(31,58,77,.35)}
.tl-card h4{font-family:var(--serif);font-size:24px;color:var(--blue-ink);margin-bottom:10px;font-weight:500}
.tl-card p{font-size:14px;color:var(--muted);line-height:1.7}

/* ============ GALLERY ============ */
.gallery{position:relative;padding:120px 0 100px;overflow:hidden}
.gallery-track-wrap{
  position:relative;width:100%;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 10%,#000 90%,transparent);
}
.gallery-track{
  display:flex;gap:24px;padding:20px 24px;
  animation: slide 40s linear infinite;
  width:max-content;
}
.gallery-track:hover{animation-play-state:paused}
@keyframes slide{
  from{transform:translateX(0)}
  to{transform:translateX(-50%)}
}
.g-card{
  flex:0 0 auto;width:280px;height:360px;border-radius:32px;
  background:rgba(255,255,255,.7);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.85);
  box-shadow: var(--shadow-glass);
  padding:14px;display:flex;flex-direction:column;
  cursor:pointer;transition:transform .4s;
}
.g-card:nth-child(odd){transform:translateY(14px)}
.g-card:hover{transform:translateY(-8px) scale(1.02)}
.g-photo{
  flex:1;border-radius:22px;overflow:hidden;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),
    linear-gradient(160deg, var(--ice-2), var(--cream));
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-size:36px;color:rgba(31,58,77,.3);
}
.g-card:nth-child(3n) .g-photo{background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),linear-gradient(160deg, #e6d2cf, #f3e6d4)}
.g-card:nth-child(4n) .g-photo{background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),linear-gradient(160deg, #cfdfe9, #e8e0f0)}
.g-cap{
  text-align:center;padding:14px 10px 6px;
  font-family:var(--serif);font-style:italic;font-size:18px;color:var(--blue-ink);
}

/* ============ WISHES ============ */
.wishes{padding:120px 8vw;position:relative}
.wish-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;max-width:1100px;margin:0 auto;
}
.wish-card{
  position:relative;
  padding:40px 30px 34px;border-radius:var(--radius);
  background:rgba(255,255,255,.65);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.85);
  box-shadow: var(--shadow-glass);
  transition: transform .4s;
  overflow:hidden;
}
.wish-card::before{
  content:"";position:absolute;inset:0;
  background: radial-gradient(circle at 80% 0%, rgba(185,207,223,.4), transparent 50%);
  pointer-events:none;
}
.wish-card:hover{transform:translateY(-6px)}
.wish-num{
  font-family:var(--serif);font-style:italic;font-size:14px;color:var(--blue-deep);
  letter-spacing:.2em;display:block;margin-bottom:18px;
}
.wish-card p{
  font-family:var(--serif);font-size:20px;line-height:1.5;color:var(--blue-ink);
  position:relative;
}

/* ============ CLOSING ============ */
.closing{
  position:relative;padding:160px 8vw 120px;text-align:center;overflow:hidden;
  background: radial-gradient(800px 500px at 50% 0%, rgba(185,207,223,.3), transparent 60%);
}
.closing-inner{max-width:760px;margin:0 auto;position:relative;z-index:3}
.closing-title{
  font-size:clamp(32px,4.5vw,52px);color:var(--blue-ink);
  margin:18px 0 24px;font-style:italic;line-height:1.25;
}
.closing-copy{font-size:16px;color:var(--muted);line-height:1.8;margin-bottom:36px}
.signature{
  margin-top:30px;font-family:var(--serif);font-style:italic;color:var(--blue-deep);
  letter-spacing:.05em;
}

.footer{
  text-align:center;padding:40px 20px;
  font-size:12px;color:var(--muted);letter-spacing:.1em;
  border-top:1px solid rgba(74,111,138,.08);
}

/* ============ Reveal animation ============ */
.reveal{opacity:0;transform:translateY(40px);transition: opacity .9s ease, transform .9s ease}
.reveal.in{opacity:1;transform:translateY(0)}

/* ============ MODAL letter ============ */
.modal{
  position:fixed;inset:0;z-index:100;
  display:none;align-items:center;justify-content:center;
  padding:24px;
}
.modal.open{display:flex}
.modal-backdrop{
  position:absolute;inset:0;
  background: rgba(31,58,77,.5);backdrop-filter:blur(10px);
  animation: fadeIn .4s;
}
.modal-card{
  position:relative;max-width:580px;width:100%;
  background: linear-gradient(180deg, #fdfaf3 0%, #f3ece0 100%);
  border-radius:var(--radius);padding:50px 44px 44px;
  box-shadow: 0 60px 100px -30px rgba(0,0,0,.4), inset 0 1px 0 rgba(255,255,255,.8);
  animation: rise .5s cubic-bezier(.2,.8,.2,1);
  max-height:88vh;overflow-y:auto;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes rise{from{opacity:0;transform:translateY(40px) scale(.96)}to{opacity:1;transform:none}}
.modal-close{
  position:absolute;top:14px;right:18px;font-size:28px;color:var(--blue-deep);
  width:36px;height:36px;border-radius:50%;
}
.modal-close:hover{background:rgba(74,111,138,.1)}
.letter-from{
  font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--blue-deep);margin-bottom:14px;
}
.letter-to{font-size:32px;color:var(--blue-ink);margin-bottom:24px;font-weight:500}
.letter-body{
  font-family:var(--serif);font-size:18px;line-height:1.85;color:var(--ink);
  white-space:pre-wrap;min-height:200px;
}
.letter-body .cursor{
  display:inline-block;width:2px;height:1.1em;background:var(--blue-deep);
  vertical-align:text-bottom;animation: blink 1s steps(1) infinite;
}
@keyframes blink{50%{opacity:0}}

/* ============ LIGHTBOX ============ */
.lightbox{
  position:fixed;inset:0;z-index:90;
  display:none;align-items:center;justify-content:center;
  background:rgba(15,25,35,.85);backdrop-filter:blur(8px);
  padding:24px;
}
.lightbox.open{display:flex;animation:fadeIn .35s}
.lb-content{max-width:520px;width:100%;text-align:center}
.lb-photo{
  aspect-ratio:3/4;border-radius:24px;
  background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.6), transparent 50%),linear-gradient(160deg,#cfdfe9,#e8d8c7);
  display:grid;place-items:center;
  font-family:var(--serif);font-style:italic;font-size:60px;color:rgba(31,58,77,.4);
  box-shadow: 0 40px 80px -20px rgba(0,0,0,.5);
}
.lb-cap{margin-top:18px;color:#fff;font-family:var(--serif);font-style:italic;font-size:22px}
.lb-close{
  position:absolute;top:20px;right:24px;color:#fff;font-size:36px;
  width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.1);
}
.lb-close:hover{background:rgba(255,255,255,.2)}

/* ============ HUG OVERLAY ============ */
.hug-overlay{
  position:fixed;inset:0;z-index:120;display:none;
  align-items:center;justify-content:center;padding:24px;
  background: radial-gradient(circle at 50% 50%, rgba(217,179,176,.4), rgba(31,58,77,.7));
  backdrop-filter:blur(10px);
}
.hug-overlay.open{display:flex;animation:fadeIn .5s}
.hug-card{
  background:rgba(255,255,255,.92);
  border-radius:var(--radius-lg);padding:60px 50px;text-align:center;
  max-width:440px;
  box-shadow: var(--shadow-soft);
  animation: rise .6s cubic-bezier(.2,.8,.2,1);
}
.hug-heart{
  font-size:80px;color:var(--rose);
  animation: beat 1.2s ease-in-out infinite;
  margin-bottom:14px;
}
@keyframes beat{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.hug-card h3{font-size:28px;color:var(--blue-ink);margin-bottom:8px;font-weight:500}
.hug-card p{color:var(--muted)}

/* Magnetic hover utility */
.btn, .wish-card, .tl-card, .g-card, .floating-card{will-change:transform}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001s !important;transition-duration:.001s !important}
}
