/* ============================================================
   K-Vibe Hub — main.css  v2
   Paleta: branco / rosa / bege / cinza-claro
   ============================================================ */
:root {
  --bg: #faf7f5;
  --bg-warm: #f5efe8;
  --surface: #ffffff;
  --beige: #efe6dc;
  --beige-deep: #e5d9cb;
  --pink-soft: #f9e8ee;
  --pink: #e8a8bf;
  --pink-rich: #d97395;
  --accent: #c75b7a;
  --accent-dark: #a0405c;
  --gray-line: #e8e4e0;
  --gray-muted: #9c958c;
  --text: #3a3633;
  --text-soft: #5c5650;
  --shadow: 0 20px 55px rgba(58,54,51,.09);
  --shadow-sm: 0 8px 24px rgba(58,54,51,.06);
  --radius: 18px;
  --radius-sm: 12px;
  --font-display: "Cormorant Infant", Georgia, serif;
  --font-body: "Outfit", system-ui, sans-serif;
  --header-h: 68px;
  --dock-h: 70px;
  --wrap: 940px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
@media(prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{margin:0;font-family:var(--font-body);font-size:1.03rem;line-height:1.65;color:var(--text);background:var(--bg);padding-bottom:calc(var(--dock-h) + 1.5rem)}
.skip-link{position:absolute;left:-999px;top:0;background:var(--accent);color:#fff;padding:.75rem 1rem;z-index:200}
.skip-link:focus{left:0}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Header ── */
.site-header{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);backdrop-filter:blur(14px);border-bottom:1px solid var(--gray-line)}
.header-inner{max-width:var(--wrap);margin:0 auto;padding:0 1.25rem;height:var(--header-h);display:flex;align-items:center;justify-content:space-between;gap:1rem}
.logo{display:flex;align-items:center;gap:.6rem;text-decoration:none;color:var(--text);font-family:var(--font-display);font-weight:700;font-size:1.3rem;letter-spacing:-.02em;white-space:nowrap}
.logo-mark{color:var(--pink-rich);display:flex;flex-shrink:0}
.logo:hover{text-decoration:none}
.site-nav{display:flex;align-items:center;gap:0 .15rem;flex-wrap:nowrap}
.site-nav a{display:inline-flex;align-items:center;gap:.35rem;text-decoration:none;color:var(--text-soft);font-weight:500;font-size:.88rem;padding:.4rem .65rem;border-radius:999px;transition:color .2s,background .2s;white-space:nowrap}
.site-nav a:hover,.site-nav a:focus-visible{color:var(--accent);background:var(--pink-soft);text-decoration:none}
.site-nav a[aria-current="page"]{color:var(--accent);background:var(--pink-soft);font-weight:600}
.nav-icon{display:flex;color:var(--pink-rich)}
.nav-toggle{display:none;flex-direction:column;gap:5px;background:transparent;border:none;padding:.5rem;cursor:pointer;border-radius:var(--radius-sm)}
.nav-toggle span{display:block;width:22px;height:2px;background:var(--text);border-radius:1px;transition:transform .2s,opacity .2s}
.nav-toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav-toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav-toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── Single ad strip ── */
.ad-strip{background:var(--surface);border-bottom:1px solid var(--gray-line);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:.3rem;padding:.5rem 1rem;min-height:100px}
.ad-label{font-size:.6rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gray-muted)}
.ad-placeholder{width:100%;max-width:728px;min-height:90px;background:linear-gradient(145deg,var(--beige),#fff);border:1px dashed var(--beige-deep);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;color:var(--gray-muted);font-size:.8rem;font-weight:500}

/* ── Page wrapper ── */
.page-wrap{max-width:var(--wrap);margin:0 auto;padding:2rem 1.25rem 3.5rem}

/* ── Welcome modal ── */
.welcome-overlay{position:fixed;inset:0;z-index:900;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,rgba(249,232,238,.97) 0%,rgba(239,230,220,.98) 100%);backdrop-filter:blur(4px);padding:1rem}
.welcome-overlay.is-hidden{display:none}
.welcome-card{background:var(--surface);border-radius:28px;padding:clamp(2rem,5vw,3.5rem);max-width:480px;width:100%;text-align:center;box-shadow:0 32px 80px rgba(58,54,51,.14);animation:welcomeIn .45s cubic-bezier(.22,1,.36,1) forwards;position:relative;overflow:hidden}
@keyframes welcomeIn{from{opacity:0;transform:scale(.88) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}
.welcome-card::before{content:'';position:absolute;top:-60px;right:-60px;width:220px;height:220px;border-radius:50%;background:radial-gradient(circle,rgba(232,168,191,.3),transparent 70%);pointer-events:none}
.welcome-logo-wrap{display:flex;flex-direction:column;align-items:center;gap:.5rem;margin-bottom:1.25rem}
.welcome-logo-icon{color:var(--pink-rich)}
.welcome-logo-name{font-family:var(--font-display);font-weight:700;font-size:1.45rem;color:var(--text);letter-spacing:-.02em}
.welcome-heading{font-family:var(--font-display);font-size:clamp(1.85rem,5vw,2.4rem);font-weight:700;line-height:1.15;margin:0 0 .85rem;color:var(--text)}
.welcome-lead{color:var(--text-soft);font-size:1rem;margin:0 0 2rem;max-width:34ch;margin-inline:auto}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.4rem;border-radius:999px;font-family:var(--font-body);font-weight:600;font-size:.95rem;text-decoration:none;border:2px solid transparent;cursor:pointer;transition:transform .15s,box-shadow .15s,background .2s,color .2s}
.btn:hover{text-decoration:none}
.btn-primary{background:linear-gradient(135deg,var(--pink-rich),var(--accent));color:#fff;box-shadow:0 8px 24px rgba(199,91,122,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 12px 30px rgba(199,91,122,.45)}
.btn-xl{padding:1rem 2rem;font-size:1.05rem;width:100%}
.btn-ghost{background:var(--surface);color:var(--accent);border-color:rgba(199,91,122,.35)}
.btn-ghost:hover{background:var(--pink-soft)}
.btn-spotify{background:#1db954;color:#fff;border-color:#1db954;font-size:.85rem;padding:.5rem 1rem}
.btn-spotify:hover{background:#17a349}
.welcome-skip{margin-top:1rem;display:block;background:none;border:none;cursor:pointer;color:var(--gray-muted);font-size:.88rem;font-family:var(--font-body);text-decoration:underline}
.welcome-skip:hover{color:var(--text-soft)}

/* ── Home hero ── */
.hero{position:relative;overflow:hidden;border-radius:var(--radius);background:linear-gradient(135deg,#fff 0%,var(--pink-soft) 50%,var(--beige) 100%);padding:clamp(2rem,5vw,3.25rem);margin-bottom:3rem;box-shadow:var(--shadow-sm);display:grid;grid-template-columns:1fr auto;gap:2rem;align-items:center}
.hero-glow{position:absolute;width:380px;height:380px;right:-100px;top:-100px;pointer-events:none;background:radial-gradient(circle,rgba(232,168,191,.45) 0%,transparent 70%)}
.hero-inner{position:relative;z-index:1}
.hero-eyebrow{font-size:.75rem;text-transform:uppercase;letter-spacing:.22em;color:var(--pink-rich);font-weight:600;margin:0 0 .7rem}
.hero-title{font-family:var(--font-display);font-size:clamp(2rem,4vw,2.8rem);font-weight:700;line-height:1.12;margin:0 0 .9rem;color:var(--text)}
.hero-lead{margin:0 0 1.5rem;max-width:36ch;color:var(--text-soft);font-weight:400}
.hero-cta{display:flex;flex-wrap:wrap;gap:.75rem}
.hero-visual{position:relative;z-index:1}
.vinyl-stack{position:relative;width:170px;height:170px}
.disc{position:absolute;width:150px;height:150px;border-radius:50%;border:3px solid var(--surface);box-shadow:var(--shadow-sm)}
.disc-1{background:conic-gradient(from 40deg,var(--pink),var(--beige-deep),var(--pink-rich),var(--pink));top:0;right:0}
.disc-2{background:conic-gradient(from 120deg,var(--beige),#fff,var(--pink-soft),var(--beige));top:14px;right:26px;transform:rotate(-14deg)}
.disc-3{background:conic-gradient(from 200deg,var(--pink-soft),#fff,var(--gray-line),var(--pink-soft));top:28px;right:50px;transform:rotate(-26deg)}

/* ── Sections ── */
.section{margin-bottom:3.5rem}
.section-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:1.35rem}
.section-head-left{display:flex;align-items:flex-start;gap:.85rem}
.section-icon{flex-shrink:0;width:46px;height:46px;display:flex;align-items:center;justify-content:center;color:var(--pink-rich);background:var(--pink-soft);border-radius:13px}
.section-head h2{font-family:var(--font-display);font-size:clamp(1.65rem,3vw,2.05rem);margin:0;font-weight:700}
.section-sub{margin:.25rem 0 0;color:var(--text-soft);font-size:.93rem}
.see-all{font-size:.88rem;font-weight:600;color:var(--accent);white-space:nowrap;display:inline-flex;align-items:center;gap:.3rem}
.see-all:hover{text-decoration:underline}

/* ── Page hero (inner pages) ── */
.page-hero{padding:clamp(2rem,4vw,3rem) 0 2rem;border-bottom:1px solid var(--gray-line);margin-bottom:2.5rem;display:flex;align-items:flex-start;gap:1.1rem}
.page-hero-icon{width:60px;height:60px;flex-shrink:0;background:var(--pink-soft);border-radius:18px;display:flex;align-items:center;justify-content:center;color:var(--pink-rich)}
.page-hero h1{font-family:var(--font-display);font-size:clamp(2.2rem,5vw,3.2rem);font-weight:700;margin:0 0 .4rem;line-height:1.1}
.page-hero p{color:var(--text-soft);margin:0;max-width:55ch}

/* ── Chart table ── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--gray-line);background:var(--surface);box-shadow:var(--shadow-sm)}
.chart-table{width:100%;border-collapse:collapse;font-size:.93rem}
.chart-table th,.chart-table td{padding:.8rem 1rem;text-align:left;border-bottom:1px solid var(--gray-line)}
.chart-table tr:last-child td{border-bottom:none}
.chart-table th{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-muted);background:var(--bg-warm);white-space:nowrap}
.chart-table tbody tr:hover{background:var(--pink-soft);cursor:default}
.chart-rank{font-weight:700;font-family:var(--font-display);font-size:1.15rem;color:var(--pink-rich);width:2.5rem;text-align:center}
.rank-top{color:var(--accent-dark)}
.movement{font-size:.82rem;font-weight:600}
.movement--up{color:#2a8052}
.movement--down{color:var(--accent)}
.movement--same{color:var(--gray-muted)}

/* ── Chart tabs ── */
.chart-tabs{display:flex;gap:.5rem;margin-bottom:1.25rem;flex-wrap:wrap}
.chart-tab{padding:.5rem 1.1rem;border-radius:999px;border:1.5px solid var(--gray-line);background:var(--surface);font-family:var(--font-body);font-size:.88rem;font-weight:600;cursor:pointer;color:var(--text-soft);transition:all .2s}
.chart-tab.is-active,.chart-tab:hover{background:var(--pink-soft);color:var(--accent);border-color:var(--pink)}
.chart-panel{display:none}.chart-panel.is-active{display:block}

/* ── Playlists ── */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.2rem}
.playlist-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--gray-line);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden;text-decoration:none;color:inherit}
.playlist-card:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.playlist-cover{width:100%;aspect-ratio:1;object-fit:cover;background:var(--beige)}
.playlist-cover-placeholder{width:100%;aspect-ratio:1;background:linear-gradient(135deg,var(--pink-soft),var(--beige));display:flex;align-items:center;justify-content:center;color:var(--pink-rich)}
.playlist-body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.6rem;flex:1}
.playlist-body h3{font-family:var(--font-display);margin:0;font-size:1.2rem;color:var(--text)}
.playlist-meta{display:flex;gap:.4rem;flex-wrap:wrap;font-size:.78rem}
.badge{background:var(--pink-soft);color:var(--accent);padding:.18rem .5rem;border-radius:999px;font-weight:600}
.playlist-body p{margin:0;color:var(--text-soft);font-size:.9rem;flex:1}
.playlist-footer{margin-top:auto;padding-top:.75rem}
.card-action{font-size:.85rem;color:var(--accent);font-weight:600;display:inline-flex;align-items:center;gap:.25rem}

/* ── Track / Letras list ── */
.track-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.track-item{display:grid;grid-template-columns:auto 1fr auto;gap:.85rem;align-items:center;background:var(--surface);border:1px solid var(--gray-line);border-radius:var(--radius-sm);padding:.8rem 1rem;box-shadow:var(--shadow-sm);cursor:pointer;transition:background .15s,transform .1s}
.track-item:hover{background:var(--pink-soft);transform:translateX(2px)}
.track-num{font-variant-numeric:tabular-nums;font-weight:700;color:var(--gray-muted);font-size:.85rem;width:1.5rem;text-align:center}
.track-title{font-weight:600;font-size:.97rem}
.track-artist{display:block;font-size:.85rem;color:var(--text-soft)}
.track-album{font-size:.78rem;color:var(--gray-muted)}
.track-badge{font-size:.75rem;font-weight:600;background:var(--pink-soft);color:var(--accent);padding:.15rem .45rem;border-radius:999px;white-space:nowrap}

/* ── Lyrics modal ── */
.lyrics-modal-overlay{position:fixed;inset:0;z-index:500;background:rgba(58,54,51,.55);backdrop-filter:blur(4px);display:flex;align-items:flex-end;justify-content:center;padding:0 0 var(--dock-h) 0}
.lyrics-modal-overlay.is-hidden{display:none}
.lyrics-modal{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-width:700px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 -20px 60px rgba(58,54,51,.15);animation:slideUp .3s cubic-bezier(.22,1,.36,1)}
@keyframes slideUp{from{transform:translateY(100%)}to{transform:translateY(0)}}
.lyrics-modal-head{padding:1.25rem 1.5rem 1rem;border-bottom:1px solid var(--gray-line);display:flex;align-items:flex-start;gap:1rem}
.lyrics-modal-head-text{flex:1}
.lyrics-modal-title{font-family:var(--font-display);font-size:1.6rem;font-weight:700;margin:0 0 .2rem}
.lyrics-modal-artist{color:var(--pink-rich);font-weight:600;font-size:.95rem}
.lyrics-modal-album{color:var(--gray-muted);font-size:.85rem}
.lyrics-close{background:var(--beige);border:none;border-radius:50%;width:36px;height:36px;flex-shrink:0;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--text-soft);font-size:1.2rem;transition:background .2s}
.lyrics-close:hover{background:var(--pink-soft);color:var(--accent)}
.lyrics-body{overflow-y:auto;padding:1.25rem 1.5rem 2rem;flex:1}
.lyrics-text{white-space:pre-line;font-size:.97rem;line-height:1.85;color:var(--text-soft)}
.lyrics-loading{text-align:center;color:var(--gray-muted);padding:2rem}

/* ── Radio ── */
.radio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(270px,1fr));gap:1.2rem}
.radio-card{background:var(--surface);border-radius:var(--radius);padding:1.5rem;border:1px solid var(--gray-line);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:.85rem;transition:border-color .2s,box-shadow .2s}
.radio-card h3{font-family:var(--font-display);margin:0;font-size:1.25rem}
.radio-card p{margin:0;color:var(--text-soft);font-size:.92rem;flex:1}
.radio-card.is-active{border-color:var(--pink-rich);box-shadow:0 0 0 3px rgba(217,115,149,.18)}
.btn-play-station{background:var(--surface);color:var(--accent);border:2px solid var(--pink);display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.65rem 1rem;border-radius:999px;font-family:var(--font-body);font-weight:600;font-size:.9rem;cursor:pointer;transition:background .2s,color .2s;width:100%}
.btn-play-station:hover{background:var(--pink-soft)}
.btn-play-station.is-playing{background:var(--pink-soft);color:var(--accent-dark)}
.country-section{margin-bottom:2.5rem}
.country-label{font-size:.72rem;text-transform:uppercase;letter-spacing:.12em;color:var(--gray-muted);font-weight:700;margin:0 0 1rem;padding-bottom:.5rem;border-bottom:1px solid var(--gray-line)}
.wave-icon{display:flex;align-items:center;gap:2px;height:16px}
.wave-icon span{display:block;width:3px;background:currentColor;border-radius:2px;animation:wave 1s ease-in-out infinite}
.wave-icon span:nth-child(1){height:6px;animation-delay:0s}
.wave-icon span:nth-child(2){height:12px;animation-delay:.15s}
.wave-icon span:nth-child(3){height:8px;animation-delay:.3s}
.wave-icon span:nth-child(4){height:14px;animation-delay:.1s}
.wave-icon span:nth-child(5){height:5px;animation-delay:.25s}
@keyframes wave{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1.3)}}

/* ── Search bar ── */
.search-bar{position:relative;margin-bottom:1.5rem}
.search-bar input{width:100%;padding:.75rem 1rem .75rem 2.75rem;border:1.5px solid var(--gray-line);border-radius:999px;font-family:var(--font-body);font-size:.95rem;background:var(--surface);color:var(--text);outline:none;transition:border-color .2s}
.search-bar input:focus{border-color:var(--pink)}
.search-bar svg{position:absolute;left:.9rem;top:50%;transform:translateY(-50%);color:var(--gray-muted);pointer-events:none}

/* ── About / prose ── */
.prose p{margin:0 0 1rem;color:var(--text-soft);max-width:70ch}
.prose p:last-child{margin-bottom:0}
.highlight-grid{list-style:none;margin:1.75rem 0 0;padding:0;display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:1rem}
.highlight-grid li{background:var(--surface);border:1px solid var(--gray-line);border-radius:var(--radius-sm);padding:1rem 1.2rem;box-shadow:var(--shadow-sm)}
.highlight-grid strong{display:block;font-family:var(--font-display);font-size:1.1rem;color:var(--accent);margin-bottom:.3rem}
.highlight-grid span{font-size:.9rem;color:var(--text-soft)}

/* ── Footer ── */
.site-footer{border-top:1px solid var(--gray-line);background:var(--surface);padding:2rem 1.25rem}
.footer-inner{max-width:var(--wrap);margin:0 auto;text-align:center}
.footer-brand{font-family:var(--font-display);font-weight:700;font-size:1.2rem;margin:0 0 .4rem}
.footer-note{font-size:.83rem;color:var(--gray-muted);max-width:50ch;margin:0 auto 1rem}
.footer-links{display:flex;justify-content:center;gap:1.25rem;flex-wrap:wrap;list-style:none;padding:0;margin:0}
.footer-links a{color:var(--accent);font-weight:500;font-size:.88rem}

/* ── Audio dock ── */
.audio-dock{position:fixed;left:0;right:0;bottom:0;z-index:110;background:rgba(255,255,255,.96);backdrop-filter:blur(16px);border-top:1px solid var(--gray-line);box-shadow:0 -10px 40px rgba(58,54,51,.08)}
.audio-dock-inner{max-width:var(--wrap);margin:0 auto;padding:0 1.25rem;display:flex;align-items:center;gap:.85rem;min-height:var(--dock-h)}
.dock-play{flex-shrink:0;width:44px;height:44px;border-radius:50%;border:none;background:linear-gradient(135deg,var(--pink-rich),var(--accent));color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .15s,opacity .15s}
.dock-play:disabled{opacity:.4;cursor:not-allowed}
.dock-play:not(:disabled):hover{transform:scale(1.08)}
.icon-play,.icon-pause{display:flex}
.icon-pause[hidden],.icon-play[hidden]{display:none}
.dock-meta{display:flex;flex-direction:column;min-width:0;flex:1}
.dock-station{font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.95rem}
.dock-status{font-size:.82rem;color:var(--gray-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dock-tap-hint{font-size:.78rem;color:var(--accent);font-weight:600;background:var(--pink-soft);padding:.3rem .75rem;border-radius:999px;cursor:pointer;white-space:nowrap;animation:pulseHint 2s ease-in-out infinite;border:none;font-family:var(--font-body)}
.dock-tap-hint.is-hidden{display:none}
@keyframes pulseHint{0%,100%{opacity:1}50%{opacity:.65}}
.section-divider{border:none;border-top:1px solid var(--gray-line);margin:3rem 0}

/* ── Timeline ── */
.timeline{list-style:none;padding:0;margin:0}
.timeline li{position:relative;padding:0 0 1.5rem 2rem;border-left:2px solid var(--gray-line)}
.timeline li:last-child{border-left-color:transparent;padding-bottom:0}
.timeline li::before{content:'';position:absolute;left:-5px;top:6px;width:8px;height:8px;border-radius:50%;background:var(--pink-rich)}
.timeline-year{font-size:.78rem;text-transform:uppercase;letter-spacing:.1em;color:var(--pink-rich);font-weight:700;margin-bottom:.25rem;display:block}
.timeline-text{color:var(--text-soft);font-size:.92rem}

/* ── Responsive ── */
@media(max-width:860px){.hero{grid-template-columns:1fr}.hero-visual{display:none}}
@media(max-width:720px){
  .nav-toggle{display:flex}
  .site-nav{display:none;position:absolute;top:var(--header-h);left:0;right:0;background:var(--surface);flex-direction:column;align-items:stretch;padding:.75rem;border-bottom:1px solid var(--gray-line);box-shadow:var(--shadow-sm);z-index:99}
  .site-nav.is-open{display:flex}
  .site-nav a{border-radius:var(--radius-sm);padding:.65rem .85rem}
}
@media(max-width:540px){
  .track-item{grid-template-columns:auto 1fr}
  .track-badge{display:none}
  .card-grid,.radio-grid{grid-template-columns:1fr}
  .welcome-card{padding:2rem 1.5rem}
}
