/* ===================== Base (tema escuro estilo Spotify) ===================== */
:root{
  --bg:#0d0d12;
  --bg2:#16161e;
  --card:#1b1b24;
  --texto:#ffffff;
  --cinza:#a09cb0;
  --roxo:#f5365c;
  --vermelho:#e11d2a;
  --rosa:#ec4899;
}
*{box-sizing:border-box;margin:0;padding:0}
body{
  font-family:'Poppins',system-ui,sans-serif;
  background:#0b0912;color:var(--texto);
  -webkit-font-smoothing:antialiased;
}
/* esconde a barra de rolagem (continua rolando, só não mostra a barra) */
html{scrollbar-width:none;-ms-overflow-style:none}
html::-webkit-scrollbar,body::-webkit-scrollbar{width:0;height:0;display:none}
/* "celular": a experiência fica centralizada e com largura de app */
.gift{
  max-width:440px;margin:0 auto;min-height:100vh;
  background:linear-gradient(180deg,#1a1626 0%,#120f1c 55%,#0b0912 100%);
  padding-bottom:40px;overflow-x:hidden;
}

/* ===================== Barra de status (iPhone) ===================== */
.statusbar{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 24px 2px;font-size:.82rem;font-weight:700;color:#fff;
}
.sb-time{
  background:#e11d2a;color:#fff;border-radius:999px;
  padding:2px 10px;font-variant-numeric:tabular-nums;
}
.sb-icons{display:flex;align-items:center;gap:6px;color:#fff}
.sb-batt{
  display:inline-block;width:24px;height:12px;border-radius:3px;
  border:1.5px solid rgba(255,255,255,.6);position:relative;padding:1px;
}
.sb-batt::after{content:'';position:absolute;right:-3px;top:3px;width:2px;height:5px;border-radius:0 2px 2px 0;background:rgba(255,255,255,.6)}
.sb-batt i{display:block;width:70%;height:100%;border-radius:1px;background:#fff}

/* ===================== Topnav ===================== */
.topnav{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;font-weight:600;
  background:rgba(13,13,18,.6);backdrop-filter:blur(8px);
}
.topnav-down,.topnav-menu{font-size:1.3rem;color:var(--cinza)}
.topnav-title{font-size:.95rem}

/* ===================== Player ===================== */
.player-card{padding:8px 22px 26px}
.cover{
  width:100%;aspect-ratio:1/1;border-radius:14px;
  background:#2a2740 center/cover no-repeat;
  box-shadow:0 20px 50px rgba(0,0,0,.3);
  display:grid;place-items:center;overflow:hidden;
  transition:opacity .35s ease;
}
.cover-empty{display:flex;flex-direction:column;align-items:center;gap:10px;color:var(--cinza);text-align:center;padding:20px}
.cover-empty[hidden]{display:none}
.cover-empty span{font-size:.95rem}
.track-row{display:flex;align-items:center;justify-content:space-between;margin-top:22px}
.track-info h1{font-size:1.5rem;font-weight:800;line-height:1.1}
.track-info p{color:var(--cinza);font-size:.95rem;margin-top:2px}
.track-check{
  background:#fff;color:#000;width:26px;height:26px;border-radius:50%;
  display:grid;place-items:center;font-size:.85rem;font-weight:700;flex:0 0 auto
}

/* Barra de progresso */
.seek{margin-top:16px}
#seek{
  -webkit-appearance:none;appearance:none;width:100%;height:4px;border-radius:4px;
  background:linear-gradient(90deg,#fff var(--p,0%),#4a4a55 var(--p,0%));
  cursor:pointer;
}
#seek::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;border-radius:50%;background:#fff}
#seek::-moz-range-thumb{width:13px;height:13px;border:0;border-radius:50%;background:#fff}
.seek-times{display:flex;justify-content:space-between;color:var(--cinza);font-size:.75rem;margin-top:6px}

/* Controles */
.controls{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.ctrl{background:none;border:none;color:#fff;cursor:pointer;opacity:.85;display:grid;place-items:center;padding:0}
.ctrl:active{transform:scale(.9)}
.ctrl svg{width:22px;height:22px;display:block}
.ctrl-play{
  background:#fff;color:#0a0a14;width:64px;height:64px;border-radius:50%;
  display:grid;place-items:center;opacity:1;
}
.ctrl-play svg{width:26px;height:26px}
#playIcon{display:grid;place-items:center}

/* ===================== Letra rolando (Sobre o casal) ===================== */
.lyrics-card{
  margin:14px 16px;padding:22px 22px 26px;border-radius:18px;
  background:rgba(20,28,48,.55);backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.1);
}
.lyrics-title{font-size:1.3rem;font-weight:800;margin-bottom:12px}
.lyrics{height:150px;overflow:hidden}
.lyrics p{padding:3px 0;font-size:1rem;color:var(--cinza);opacity:.5;transition:opacity .5s,color .5s,font-weight .5s}
.lyrics p.active{font-weight:700;color:#fff;opacity:1}

/* ===================== Stories ===================== */
.stories-wrap{padding:8px 16px 4px}
.stories{display:flex;gap:12px;overflow-x:auto;scrollbar-width:none}
.stories::-webkit-scrollbar{display:none}
.story{
  position:relative;flex:0 0 96px;height:128px;border-radius:16px;overflow:hidden;
  background:#211d2e center/cover no-repeat;cursor:pointer;
  box-shadow:0 6px 18px rgba(0,0,0,.35);
}
.story::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(0,0,0,.75))}
.story span{position:absolute;left:8px;right:8px;bottom:8px;z-index:1;font-size:.78rem;font-weight:700;line-height:1.1}

/* ===================== Conquistas ===================== */
.achievements{margin:14px 16px;padding:20px;border-radius:18px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1)}
.ach-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ach-head h2{font-size:1.2rem;font-weight:800}
.ach-count{background:#000;color:#fff;font-size:.78rem;font-weight:700;padding:4px 12px;border-radius:999px}
.ach-grid{display:flex;flex-wrap:wrap;gap:10px}
.ach-badge{
  width:62px;height:62px;border-radius:14px;display:grid;place-items:center;
  font-size:1.6rem;color:var(--roxo);
  background:#15131f;border:1px solid var(--roxo);box-shadow:0 0 16px rgba(245,54,92,.25)
}
.ach-badge svg{width:26px;height:26px}

/* ===================== Sua Retrospectiva ===================== */
.wrapped{
  position:relative;overflow:hidden;margin:14px 16px;border-radius:22px;
  background:#08080c;padding:40px 26px;min-height:300px;
  display:flex;align-items:center;
  box-shadow:0 10px 30px rgba(0,0,0,.5);border:1px solid rgba(255,255,255,.06);
}
.wrapped .ribbon{position:absolute;width:200%;height:90px;border-radius:50%;filter:blur(2px);opacity:.95;z-index:0}
.ribbon-1{top:18px;left:-30%;background:linear-gradient(90deg,#ff2d55,#b3001b);transform:rotate(-12deg)}
.ribbon-2{bottom:30px;left:-40%;height:70px;background:linear-gradient(90deg,#e11d2a,#7a0014);transform:rotate(10deg)}
.wrapped-content{position:relative;z-index:1}
.wrapped-content h2{font-size:clamp(1.1rem,6.5vw,1.9rem);font-weight:800;line-height:1.08;overflow-wrap:break-word}
.wrapped-content h2 span{color:#fff}
.wrapped-content p{margin-top:10px;color:var(--cinza);font-size:.95rem}
.wrapped-btn{
  margin-top:22px;background:#4aa3ff;color:#0a0a14;border:none;cursor:pointer;
  font-family:inherit;font-weight:700;font-size:1rem;padding:13px 34px;border-radius:999px;
  box-shadow:0 8px 20px rgba(74,163,255,.35);transition:transform .12s;
}
.wrapped-btn:active{transform:scale(.96)}

/* ===================== Blocos ===================== */
.block{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12);margin:14px 16px;border-radius:18px;padding:24px}
.block-title{font-size:1.4rem;font-weight:800;margin-bottom:16px}
.block-sub{color:var(--cinza);margin-top:-10px;margin-bottom:18px;font-size:.92rem}

/* Sobre o casal */
.block-couple{text-align:left}
.couple-cover{width:100%;height:160px;border-radius:14px;background:linear-gradient(135deg,#3a3550,#241f38) center/cover no-repeat;margin-bottom:16px}
.couple-names{font-size:1.4rem;font-weight:800}
.couple-since{color:#c9c3da;font-size:.9rem;margin-bottom:18px}
.counter{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.cbox{min-width:0;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.06);border-radius:12px;padding:12px 4px;text-align:center}
.cbox span{display:block;font-size:1.3rem;font-weight:800;color:#fff;line-height:1.1}
.cbox small{display:block;color:#c9c3da;font-size:.62rem;white-space:nowrap}

/* Mensagem especial */
.msg-card{background:linear-gradient(135deg,#f0431f,#d11e0a);margin:14px 16px;border-radius:18px;padding:24px}
.msg-label{font-weight:700;font-size:1rem}
.msg-text{
  font-size:1.45rem;font-weight:800;line-height:1.25;margin-top:12px;white-space:pre-line;
  overflow-wrap:anywhere;word-break:break-word;
}
.msg-text.collapsed{
  display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:4;overflow:hidden;
  -webkit-mask-image:linear-gradient(180deg,#000 60%,transparent);
          mask-image:linear-gradient(180deg,#000 60%,transparent);
}
.msg-btn{
  margin-top:16px;background:#fff;color:#111;border:none;border-radius:999px;
  padding:11px 22px;font-family:inherit;font-weight:700;cursor:pointer;font-size:.95rem;
}
.msg-btn:active{transform:scale(.96)}

/* Frases românticas */
.frases{margin:14px 16px;text-align:center;min-height:70px;display:grid;place-items:center}
.frase-atual{
  font-family:'Caveat',cursive;font-size:1.8rem;color:#e7e3f0;line-height:1.2;
  transition:opacity .5s ease;
}

/* Galeria */
.gallery{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.gallery img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:12px;cursor:pointer;transition:transform .2s}
.gallery img:active{transform:scale(.97)}

/* Linha do tempo */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:'';position:absolute;left:6px;top:4px;bottom:4px;width:2px;background:#3a3346}
.tl-item{position:relative;padding-bottom:24px}
.tl-item::before{content:'';position:absolute;left:-22px;top:4px;width:12px;height:12px;border-radius:50%;background:var(--rosa);box-shadow:0 0 0 4px rgba(236,72,153,.2)}
.tl-date{color:var(--rosa);font-weight:700;font-size:.95rem}
.tl-text{color:#e7e3f0;font-size:.92rem;margin-top:2px}
.timeline-end{text-align:center;font-weight:700;margin-top:6px}

/* Footer */
.gift-footer{text-align:center;color:var(--cinza);font-size:.85rem;margin-top:24px}
.gift-footer a{color:var(--roxo)}

/* ===================== Animação ao rolar ===================== */
.reveal{opacity:0;transform:translateY(40px);transition:opacity .7s ease,transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}}

/* Lightbox */
.lightbox{position:fixed;inset:0;background:rgba(20,28,48,.78);backdrop-filter:blur(6px);display:grid;place-items:center;z-index:100;padding:20px}
.lightbox[hidden]{display:none!important}
.lightbox img{max-width:100%;max-height:90vh;border-radius:12px}

/* player do YouTube escondido (toca o áudio da música completa) */
#ytwrap{position:fixed;left:-9999px;top:0;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}

/* ===== Telas bem estreitas (ex.: celular do hero ~230px) ===== */
@media(max-width:340px){
  .player-card{padding:8px 14px 22px}
  .block,.lyrics-card,.wrapped,.msg-card,.stories-wrap{margin-left:10px;margin-right:10px}
  .block{padding:18px}
  .wrapped{padding:30px 18px}
  .counter{gap:6px}
  .cbox{padding:10px 2px}
  .cbox span{font-size:1.1rem}
  .cbox small{font-size:.56rem}
  .wrapped-content h2{font-size:clamp(1rem,7vw,1.6rem)}
}
