 :root{
      --bg1:#0b0b12;
      --bg2:#1a0f1d;
      --pink:#ff4d7d;
      --soft:#ffd1dc;
      --card: rgba(255,255,255,.08);
      --border: rgba(255,255,255,.14);
      --text: rgba(255,255,255,.92);
      --muted: rgba(255,255,255,.7);
    }
    *{box-sizing:border-box}
    body{
      margin:0;
      font-family: system-ui, -apple-system, "Segoe UI", Tahoma, Arial;
      color:var(--text);
      background: radial-gradient(1200px 600px at 80% 20%, #3a1230 0%, transparent 60%),
                  radial-gradient(900px 500px at 20% 80%, #1b3a66 0%, transparent 55%),
                  linear-gradient(180deg, var(--bg1), var(--bg2));
      overflow-x:hidden;
    }
    .wrap{max-width:1000px;margin:auto;padding:28px 18px 60px}
    header{
      display:flex;gap:14px;align-items:center;justify-content:space-between;
      padding:16px 18px;border:1px solid var(--border);border-radius:18px;
      background:rgba(0,0,0,.18);backdrop-filter: blur(10px);
      position:sticky;top:12px;z-index:5;
    }
    .brand{display:flex;align-items:center;gap:10px}
    .dot{width:12px;height:12px;border-radius:50%;background:var(--pink);box-shadow:0 0 18px var(--pink)}
    .brand b{letter-spacing:.2px}
    .pill{
      padding:8px 12px;border-radius:999px;border:1px solid var(--border);
      background:rgba(255,255,255,.06);color:var(--muted);font-size:13px
    }

    .hero{
      margin-top:22px;
      display:grid;grid-template-columns: 1.1fr .9fr;gap:18px;align-items:stretch;
    }
    @media (max-width: 860px){ .hero{grid-template-columns:1fr} }

    .card{
      border:1px solid var(--border);border-radius:22px;
      background:var(--card);backdrop-filter: blur(10px);
      padding:22px;position:relative;overflow:hidden;
    }
    .card::before{
      content:"";position:absolute;inset:-60px;
      background: radial-gradient(400px 240px at 80% 20%, rgba(255,77,125,.22), transparent 60%),
                  radial-gradient(320px 240px at 20% 80%, rgba(255,209,220,.18), transparent 60%);
      filter: blur(10px);
      z-index:0;
    }
    .card > *{position:relative;z-index:1}

    h1{margin:0 0 10px;font-size:40px;line-height:1.15}
    .sub{color:var(--muted);margin:0 0 18px;font-size:16px;line-height:1.8}
    .actions{display:flex;gap:10px;flex-wrap:wrap}
    button, a.btn{
      cursor:pointer;border:none;border-radius:14px;padding:12px 14px;
      font-weight:700;font-size:15px;
      transition: transform .12s ease, opacity .2s ease;
    }
    .primary{
      background: linear-gradient(135deg, var(--pink), #ff7aa2);
      color:#13040a; box-shadow:0 10px 30px rgba(255,77,125,.25);
    }
    .ghost{
      background: rgba(255,255,255,.08);
      border:1px solid var(--border);
      color:var(--text);
    }
    button:hover, a.btn:hover{transform: translateY(-1px)}
    button:active, a.btn:active{transform: translateY(0px);opacity:.9}

    .preview{
      display:flex;flex-direction:column;gap:14px;justify-content:center;
      min-height:220px;
    }
    .stat{
      display:flex;gap:14px;flex-wrap:wrap
    }
    .box{
      flex:1;min-width:160px;
      padding:14px;border-radius:18px;border:1px solid var(--border);
      background: rgba(0,0,0,.16);
    }
    .box small{color:var(--muted)}
    .box b{display:block;font-size:22px;margin-top:6px}

    .section{margin-top:18px;display:grid;grid-template-columns: 1fr 1fr;gap:18px}
    @media (max-width: 860px){ .section{grid-template-columns:1fr} }

    .timeline{display:grid;gap:12px}
    .item{
      display:flex;gap:12px;align-items:flex-start;
      padding:12px 14px;border-radius:18px;border:1px solid var(--border);
      background: rgba(0,0,0,.14);
    }
    .heart{
      width:34px;height:34px;border-radius:12px;
      display:grid;place-items:center;
      background: rgba(255,77,125,.16);
      border:1px solid rgba(255,77,125,.35);
    }
    .item p{margin:0;color:var(--muted);line-height:1.7}
    .item b{display:block;margin-bottom:2px;color:var(--text)}

    .gallery{
      display:grid;grid-template-columns: repeat(3, 1fr);
      gap:10px;
    }
    @media (max-width: 520px){ .gallery{grid-template-columns: repeat(2, 1fr);} }
    .photo{
      aspect-ratio: 1/1;
      border-radius:18px;border:1px solid var(--border);
      overflow:hidden;position:relative;
      background: rgba(255,255,255,.06);
    }
    .photo img{width:100%;height:100%;object-fit:cover;display:block;filter:saturate(1.05)}
    .photo span{
      position:absolute;bottom:8px;right:8px;
      font-size:12px;color:rgba(255,255,255,.85);
      background:rgba(0,0,0,.35);padding:6px 8px;border-radius:999px;
      border:1px solid rgba(255,255,255,.16);
    }

    footer{
      margin-top:18px;text-align:center;color:var(--muted);
      padding:20px 8px
    }

    /* Modal */
    .modal{
      position:fixed;inset:0;display:none;place-items:center;
      background:rgba(0,0,0,.55);z-index:50;
      padding:18px;
    }
    .modal.open{display:grid}
    .modal .inner{
      max-width:680px;width:100%;
      border-radius:22px;border:1px solid var(--border);
      background: rgba(15,10,18,.92);
      backdrop-filter: blur(12px);
      padding:20px;
      box-shadow: 0 20px 70px rgba(0,0,0,.6);
      position:relative;
    }
    .modal h2{margin:0 0 8px}
    .modal p{margin:0;color:var(--muted);line-height:1.9}
    .close{
      position:absolute;left:14px;top:14px;
      width:40px;height:40px;border-radius:14px;
      border:1px solid var(--border);background:rgba(255,255,255,.06);
      color:var(--text);font-size:18px;font-weight:800;
    }

    /* floating hearts */
    .float{
      position:fixed;inset:0;pointer-events:none;z-index:1;overflow:hidden
    }
    .float i{
      position:absolute;bottom:-30px;font-style:normal;
      animation: rise linear forwards;
      opacity:.8;filter: drop-shadow(0 8px 14px rgba(255,77,125,.25));
    }
    @keyframes rise{
      to{transform: translateY(-120vh) rotate(20deg);opacity:0}
    }

    .full-gallery {
  width: 100%;
  padding: 0 40px 40px;
}

.full-gallery .card {
  max-width: 1400px;
  margin: auto;
}

.full-gallery .gallery {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.live-counter {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 10px;
}

.time-box {
  flex: 1;
  min-width: 80px;
  padding: 14px 10px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.18);
  text-align: center;
  backdrop-filter: blur(8px);
  transition: transform .2s ease;
}

.time-box:hover {
  transform: translateY(-3px);
}

.time-box b {
  display: block;
  font-size: 26px;
  font-weight: 800;
  color: var(--soft);
}

.time-box small {
  color: var(--muted);
  font-size: 13px;
}

.preview {
  text-align: center;
  gap: 20px;
}

.top-text small {
  color: var(--muted);
  display: block;
}

.highlight {
  font-size: 22px;
  color: var(--soft);
  display: block;
  margin-top: 4px;
}

.live-counter.horizontal {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  flex-wrap: wrap;
  margin: 10px 0;
}

.time-box {
  flex: 1;
  min-width: 70px;
  padding: 14px 8px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(8px);
  transition: transform .2s ease;
}

.time-box b {
  display: block;
  font-size: 22px;
  font-weight: 800;
  color: var(--soft);
}

.time-box small {
  color: var(--muted);
  font-size: 12px;
}

.bottom-text {
  font-size: 16px;
  font-weight: 600;
  margin-top: 8px;
}

/* Entrance overlay */
#entrance {
  position: fixed;
  inset: 0;
  z-index: 999;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: radial-gradient(ellipse at center, #1a0f1d, var(--bg1));
  transition: opacity .6s ease, visibility .6s ease;
}
#entrance.hide {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.entrance-heart {
  font-size: 72px;
  cursor: pointer;
  animation: pulse 1.2s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.15); }
}
