@import url("https://fonts.googleapis.com/css2?family=Inter:wght@200;300;400;500;600&family=Cormorant+Garamond:wght@300;400;500&display=swap");

:root{
  --bg0:#05060a;
  --bg1:#090a12;

  --text: rgba(255,255,255,.90);
  --muted: rgba(255,255,255,.62);
  --muted2: rgba(255,255,255,.48);

  --stroke: rgba(255,255,255,.10);
  --stroke2: rgba(255,255,255,.14);

  --pink:#ff4d7d;
  --hot:#ff2f6d;
  --gold:#ffc566;
  --ice:#77d7ff;

  --shadow: 0 26px 85px rgba(0,0,0,.62);
  --shadow2: 0 18px 55px rgba(0,0,0,.42);

  --r: 28px;
  --ease: cubic-bezier(.2,.9,.2,1);

  --sans: "Inter", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
  --serif: "Cormorant Garamond", ui-serif, Georgia, "Times New Roman", Times, serif;
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  background:
    radial-gradient(1200px 800px at 18% 0%, #12133a 0%, transparent 62%),
    radial-gradient(900px 700px at 88% 12%, #2a1023 0%, transparent 58%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
  color: var(--text);
  font-family: var(--sans);
  overflow-x:hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img{ display:block; max-width:100%; }
.v3{ position:relative; min-height:100vh; }

/* Background */
.bg{ position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }
.blob{
  position:absolute; width:560px; height:560px; border-radius:50%;
  filter: blur(60px); opacity:.55; transform: translate3d(0,0,0);
}
.b1{ left:-220px; top:-180px; background: radial-gradient(circle at 30% 30%, rgba(255,77,125,.95), transparent 58%); }
.b2{ right:-240px; top:40px; background: radial-gradient(circle at 38% 38%, rgba(119,215,255,.85), transparent 62%); }
.b3{ left:12%; bottom:-320px; background: radial-gradient(circle at 35% 35%, rgba(255,197,102,.85), transparent 58%); }

.grain{
  position:absolute; inset:-25%;
  background-image:url("https://grainy-gradients.vercel.app/noise.svg");
  opacity:.12;
  transform: rotate(1.5deg);
}
.vignette{
  position:absolute; inset:-10%;
  background: radial-gradient(circle at 50% 35%, transparent 30%, rgba(0,0,0,.60) 78%);
  opacity:.75;
}

/* Layout */
.wrap{
  position:relative; z-index:2;
  padding: 92px 0 84px;
  display:grid; place-items:center;
}
.hero{ width:min(1060px, 92vw); margin:0 auto; }

.card{
  background: linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.035));
  border: 1px solid var(--stroke);
  border-radius: var(--r);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
  padding: clamp(18px, 3vw, 34px);
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:-60% -35%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,77,125,.14), transparent 55%),
    radial-gradient(circle at 70% 65%, rgba(119,215,255,.09), transparent 58%);
  opacity:.85;
  pointer-events:none;
}
.card::after{
  content:"";
  position:absolute; inset:0;
  border-radius:inherit;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.08);
  pointer-events:none;
}

/* Top typography */
.badge{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,.18);
  border: 1px solid var(--stroke);
  color: rgba(255,255,255,.62);
  font-weight: 400;
  font-size: 12px;
  letter-spacing: .18em;
  text-transform: uppercase;
}
.title{
  margin: 18px 0 10px;
  font-family: var(--serif);
  font-weight: 400;
  font-size: clamp(46px, 5.9vw, 74px);
  line-height: 0.98;
  letter-spacing: -0.03em;
}
.accent{
  background: linear-gradient(135deg, var(--pink), var(--gold));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.sub{
  margin: 0 0 18px;
  max-width: 66ch;
  font-size: 15.5px;
  line-height: 1.65;
  color: var(--muted);
  font-weight: 300;
  letter-spacing: .01em;
}

/* Polaroids */
.polaroids{
  position: relative;
  height: 410px;            /* fixed stage height for overlap layout */
  margin: 14px 0 30px;      /* more space before buttons */
  border-radius: 22px;
  overflow: visible;
}

/* Variable-height polaroids: NO fixed height */
.polaroid{
  position:absolute;
  width: 190px;
  height: auto;             /* ✅ variable height based on caption */
  padding: 12px 12px 22px;  /* extra bottom space for multi-line captions */
  border-radius: 18px;
  background: rgba(255,255,255,.085);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow2);
  backdrop-filter: blur(12px);
  transform-style: preserve-3d;
  cursor: pointer;
  user-select:none;
  overflow:hidden;
  transition: transform 260ms var(--ease), box-shadow 260ms var(--ease), filter 260ms var(--ease), background 260ms var(--ease);
  will-change: transform;
}
.polaroid::before{
  content:"";
  position:absolute; inset:-40% -40%;
  background: radial-gradient(circle at 25% 20%, rgba(255,197,102,.16), transparent 55%),
              radial-gradient(circle at 75% 70%, rgba(255,77,125,.12), transparent 60%);
  opacity:.9;
  pointer-events:none;
  transform: translateZ(8px);
}
.polaroid::after{
  content:"";
  position:absolute; inset:0;
  background: rgba(0,0,0,.18);
  opacity: 0;
  transition: opacity 260ms var(--ease);
  pointer-events:none;
}

.polaroid .frame{
  width:100%;
  height: 168px;            /* keep photo area consistent */
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  transform: translateZ(18px);
}
.polaroid img{
  width:100%;
  height:100%;
  object-fit:cover;
  transform: scale(1.06);
  filter: saturate(1.05) contrast(1.02);
}
.polaroid .cap{
  margin-top: 10px;
  font-family: var(--sans);
  font-size: 12px;
  color: rgba(255,255,255,.72);
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 400;
}
.polaroid .cap strong{
  display:block;
  margin-top: 6px;
  font-family: var(--serif);
  letter-spacing: -0.01em;
  text-transform:none;
  font-weight: 400;
  font-size: 17px;
  color: rgba(255,255,255,.90);
  line-height: 1.22;
}

.polaroid .shine{
  position:absolute; inset:0;
  background: radial-gradient(600px 260px at 20% 10%, rgba(255,197,102,.18), transparent 58%),
              radial-gradient(650px 320px at 85% 85%, rgba(119,215,255,.10), transparent 60%),
              linear-gradient(180deg, transparent, rgba(0,0,0,.18));
  pointer-events:none;
  transform: translateZ(26px);
  opacity:.9;
  transition: opacity 260ms var(--ease);
}

/* Strong hover highlight */
.polaroid:hover{
  transform: translateY(-12px) rotate(0deg) scale(1.09) !important;
  box-shadow: 0 36px 105px rgba(0,0,0,.66);
  filter: saturate(1.08) contrast(1.03);
  background: rgba(255,255,255,.16);
}
.polaroid:hover::after{ opacity: .16; }
.polaroid:hover .shine{ opacity: 1; }
.polaroid:hover .cap{ color: rgba(255,255,255,.86); }
.polaroid:hover .cap strong{ color: rgba(255,255,255,.98); }
.polaroid:active{ transform: translateY(-8px) rotate(0deg) scale(1.06) !important; }

/* Actions */
.actions{
  position:relative;
  display:flex;
  align-items:center;
  gap: 12px;
  flex-wrap:wrap;
  margin-top: 14px;     /* ✅ more space from polaroids */
  min-height: 62px;
  padding: 10px 0 2px;
}

.btn{
  border: 1px solid var(--stroke2);
  background: rgba(255,255,255,.055);
  color: var(--text);
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 500;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: 12px;
  cursor:pointer;
  transition: transform 160ms var(--ease), filter 160ms var(--ease), background 160ms var(--ease);
  box-shadow: 0 12px 28px rgba(0,0,0,.26);
  backdrop-filter: blur(14px);
  user-select:none;
  display:inline-flex;
  gap:10px;
  align-items:center;
  justify-content:center;
  min-width: 190px;
  white-space:nowrap;
}
.btn:hover{ transform: translateY(-1px) scale(1.02); }
.btn:active{ transform: translateY(1px) scale(.99); }

.btn.primary{
  border-color: rgba(255,77,125,.35);
  background: linear-gradient(135deg, rgba(255,77,125,.86), rgba(255,47,109,.62));
}
.btn.ghost{ background: rgba(255,255,255,.03); }

.heart{
  width: 44px;
  height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform 160ms var(--ease), background 160ms var(--ease);
  box-shadow: 0 12px 28px rgba(0,0,0,.26);
}
.heart:hover{ transform: scale(1.07); background: rgba(255,77,125,.14); }
.heart:active{ transform: scale(.96); }

.icon-btn{
  width: 46px;
  height: 46px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.72);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform 160ms var(--ease), background 160ms var(--ease), color 160ms var(--ease);
  box-shadow: 0 12px 28px rgba(0,0,0,.22);
  backdrop-filter: blur(14px);
}
.icon-btn:hover{
  transform: translateY(-1px) scale(1.03);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.90);
}
.icon-btn:active{ transform: translateY(1px) scale(.99); }
.icon-btn .icon{ font-size: 18px; line-height: 1; }

/* Foot */
.foot{ margin-top: 14px; color: var(--muted2); font-size: 12px; letter-spacing:.02em; font-weight: 300; }

/* Modal */
.modal{
  position:fixed; inset:0;
  display:none; place-items:center;
  background: rgba(0,0,0,.58);
  z-index: 999999;
  padding: 18px;
}
.modal.is-open{ display:grid; }
.modal-inner{
  position:relative;
  width: min(900px, 96vw);
  height: min(590px, 86vh);
  border-radius: 28px;
  overflow:hidden;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: var(--shadow);
  backdrop-filter: blur(16px);
  display:grid;
  place-items:center;
}
.confetti{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.close{
  position:absolute; top: 14px; right: 14px;
  width: 42px; height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.92);
  cursor:pointer;
  font-size: 18px;
  display:grid;
  place-items:center;
}

.letter{
  width: min(640px, 92vw);
  border-radius: 26px;
  background: linear-gradient(180deg, rgba(255,255,255,.085), rgba(255,255,255,.045));
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow2);
  backdrop-filter: blur(14px);
  padding: 18px 18px 16px;
  position:relative;
  overflow:hidden;
}
.letter::before{
  content:"";
  position:absolute; inset:-60% -40%;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,77,125,.16), transparent 55%),
    radial-gradient(circle at 70% 65%, rgba(119,215,255,.09), transparent 58%);
  opacity:.85;
  pointer-events:none;
}
.letter-top{ display:flex; align-items:center; justify-content:space-between; position:relative; z-index:2; }
.seal{
  width: 40px; height: 40px; border-radius: 999px;
  display:grid; place-items:center;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  color: rgba(255,255,255,.90);
}
.letter-k{
  color: var(--muted2);
  font-size: 12px;
  letter-spacing:.18em;
  text-transform: uppercase;
  font-weight: 400;
}
.letter-title{
  margin: 14px 0 8px;
  font-family: var(--serif);
  font-weight: 400;
  letter-spacing:-.03em;
  font-size: clamp(26px, 3.3vw, 40px);
  position:relative;
  z-index:2;
}
.letter-text{
  margin: 0 0 14px;
  line-height: 1.65;
  color: var(--muted);
  min-height: 92px;
  white-space: pre-wrap;
  font-weight: 300;
  position:relative;
  z-index:2;
}
.letter-meta{
  display:grid; gap: 6px;
  border-top: 1px solid rgba(255,255,255,.10);
  padding-top: 12px;
  margin-top: 10px;
  position:relative;
  z-index:2;
}
.meta-row{ display:flex; align-items:center; justify-content:space-between; gap:10px; }
.meta-k{
  color: var(--muted2);
  font-size: 12px;
  letter-spacing:.14em;
  text-transform: uppercase;
  font-weight: 400;
}
.meta-v{
  font-weight: 500;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size: 12px;
}
.letter-actions{
  display:flex; gap: 12px; flex-wrap:wrap;
  margin-top: 14px;
  position:relative; z-index:2;
  align-items:center;
}

/* Toast */
.toast{
  position:fixed; left:50%; bottom: 22px;
  transform: translateX(-50%);
  padding: 12px 14px;
  border-radius: 999px;
  background: rgba(0,0,0,.50);
  border: 1px solid rgba(255,255,255,.14);
  color: rgba(255,255,255,.88);
  font-weight: 500;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size: 11px;
  box-shadow: var(--shadow2);
  opacity:0;
  pointer-events:none;
  z-index: 999999;
  backdrop-filter: blur(14px);
}

/* =========================
   RESPONSIVE (Laptop + iPad landscape priority)
   Keep same polaroid DESIGN (no layout mode change)
   ========================= */

/* Laptop / iPad Landscape (<= 1279 covers most laptops + iPad 1024) */
@media (max-width: 1279px){
  .wrap{ padding: 64px 0 60px; }
  .hero{ width:min(980px, 92vw); }
  .card{ padding: 22px; }

  .title{ font-size: clamp(40px, 5.0vw, 62px); }
  .sub{ margin-bottom: 14px; }

  .polaroids{ height: 380px; margin: 12px 0 26px; }
  .polaroid{ width: 182px; }         /* same design, slightly smaller */
  .polaroid .frame{ height: 162px; } /* keep proportion */
}

/* Phone vertical only */
@media (max-width: 520px){
  .wrap{ padding: 72px 0 70px; }
  .polaroids{ height: 520px; }
  .btn{ width: 100%; min-width: 0; }
  .actions{ width: min(420px, 100%); }
}
