/* MANIA DE MUSICA — Design System v1
   Minimalismo acolhedor, tipografia expressiva, respiro generoso.
   Inspirado em Medium, Lenny's Newsletter, The Marginalian. */
:root {
  --bg: #FAF7F2; --bg-alt: #F3EFE7;
  --ink: #1A1A1A; --ink-soft: #3C3A36; --muted: #6B6B6B;
  --border: #E8E4DC; --accent: #6B2E2B; --accent-hover: #4A1F1D;
  --wood: #8B5A2B; --highlight: #F5E6D3; --dark: #1A1612;
  --font-serif: 'Fraunces', 'Playfair Display', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --container: 1180px; --container-read: 720px;
  --radius: 4px; --radius-lg: 12px;
  --shadow-md: 0 4px 16px rgba(26,22,18,0.08);
  --shadow-lg: 0 12px 32px rgba(26,22,18,0.12);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-sans);font-size:17px;line-height:1.65;color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color .18s ease}
a:hover{color:var(--accent)}
h1,h2,h3,h4{font-family:var(--font-serif);font-weight:500;line-height:1.15;letter-spacing:-.015em;color:var(--ink)}
h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:600}
h2{font-size:clamp(1.5rem,3vw,2.1rem);margin-top:2.6em;margin-bottom:.8em}
h3{font-size:1.35rem;margin-top:2em;margin-bottom:.6em}
p{margin-bottom:1.3em}
strong{font-weight:600;color:var(--ink)}
blockquote{border-left:3px solid var(--accent);padding:.4em 0 .4em 1.4em;font-style:italic;color:var(--ink-soft);font-size:1.1em;margin:1.8em 0}
ul,ol{margin:1em 0 1.5em 1.4em}
li{margin-bottom:.5em}
.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.container-read{max-width:var(--container-read);margin:0 auto;padding:0 24px}
/* HEADER */
.site-header{position:sticky;top:0;z-index:50;background:rgba(250,247,242,.92);backdrop-filter:saturate(180%) blur(10px);-webkit-backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--border)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 24px;max-width:var(--container);margin:0 auto}
.brand{display:flex;align-items:center;text-decoration:none}
.brand img{display:block;height:42px;width:auto;max-width:100%}
.nav{display:flex;align-items:center;gap:28px}
.nav a{font-size:.95rem;color:var(--ink-soft);font-weight:500}
.nav a:hover{color:var(--accent)}
/* SEARCH */
.search-wrap{position:relative;flex:1;max-width:420px}
.search-box{display:flex;align-items:center;gap:10px;background:var(--bg-alt);border:1px solid var(--border);border-radius:999px;padding:8px 16px;transition:all .18s}
.search-box:focus-within{border-color:var(--accent);background:#fff;box-shadow:0 0 0 3px rgba(107,46,43,.08)}
.search-box svg{width:16px;height:16px;color:var(--muted);flex-shrink:0}
.search-box input{border:0;background:transparent;outline:none;font-family:inherit;font-size:.95rem;color:var(--ink);width:100%}
.search-box input::placeholder{color:var(--muted)}
.search-box kbd{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.72rem;color:var(--muted);background:#fff;border:1px solid var(--border);padding:2px 6px;border-radius:3px}
.search-results{position:absolute;top:calc(100% + 10px);left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);max-height:480px;overflow-y:auto;padding:8px;display:none}
.search-results.active{display:block}
.search-filters{display:flex;gap:6px;padding:8px;border-bottom:1px solid var(--border);margin-bottom:8px;flex-wrap:wrap}
.filter-chip{font-size:.78rem;color:var(--ink-soft);background:var(--bg-alt);border:1px solid transparent;padding:4px 10px;border-radius:999px;cursor:pointer;transition:all .15s;font-weight:500}
.filter-chip:hover{background:var(--border)}
.filter-chip.active{background:var(--accent);color:#fff}
.search-result{display:block;padding:12px 14px;border-radius:var(--radius);transition:background .15s;border-bottom:1px solid var(--bg-alt)}
.search-result:last-child{border-bottom:0}
.search-result:hover{background:var(--bg-alt)}
.search-result-kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700;margin-bottom:3px}
.search-result-title{font-weight:500;font-size:.96rem;color:var(--ink);margin-bottom:2px;line-height:1.3}
.search-result-meta{font-size:.8rem;color:var(--muted)}
.search-empty{padding:24px;text-align:center;color:var(--muted);font-size:.9rem}
/* HERO */
.hero{padding:80px 0 56px;text-align:center;border-bottom:1px solid var(--border)}
.hero h1{font-size:clamp(2.6rem,6vw,4.5rem);font-weight:400;line-height:1.05;margin-bottom:.4em}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero-lead{font-size:1.15rem;color:var(--ink-soft);max-width:560px;margin:0 auto 36px;line-height:1.5}
.chips{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-top:22px}
.chip{font-size:.85rem;color:var(--ink-soft);background:#fff;border:1px solid var(--border);padding:8px 16px;border-radius:999px;transition:all .2s;font-weight:500}
.chip:hover{border-color:var(--accent);color:var(--accent)}
/* GRID */
.section{padding:72px 0}
.section-header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:36px;gap:20px;flex-wrap:wrap}
.section-title{font-family:var(--font-serif);font-size:1.8rem;font-weight:500;letter-spacing:-.015em;margin:0}
.section-link{font-size:.9rem;font-weight:500;color:var(--accent)}
.section-link::after{content:' →'}
.post-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:40px 32px}
.post-card{display:block}
.post-card-media{aspect-ratio:16/9;background:#1A1612;border-radius:var(--radius-lg);overflow:hidden;position:relative;margin-bottom:18px}
.post-card-media img{width:100%;height:100%;object-fit:cover;object-position:center;transition:transform .5s ease}
.post-card:hover .post-card-media img{transform:scale(1.03)}
.post-card-media .play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:linear-gradient(180deg,transparent 40%,rgba(0,0,0,.35));opacity:0;transition:opacity .3s}
.post-card:hover .play{opacity:1}
.post-card-kicker{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:600;margin-bottom:8px}
.post-card-title{font-family:var(--font-serif);font-size:1.35rem;font-weight:500;line-height:1.25;color:var(--ink);margin-bottom:8px;letter-spacing:-.012em}
.post-card:hover .post-card-title{color:var(--accent)}
.post-card-excerpt{font-size:.95rem;color:var(--ink-soft);line-height:1.5}
.post-card-meta{display:flex;gap:12px;align-items:center;margin-top:12px;font-size:.82rem;color:var(--muted)}
.post-card-meta span::before{content:'•';margin-right:12px;color:var(--border)}
.post-card-meta span:first-child::before{display:none}
.featured-post{display:grid;grid-template-columns:1.35fr 1fr;gap:48px;align-items:center;padding-bottom:56px;margin-bottom:56px;border-bottom:1px solid var(--border)}
.featured-post .post-card-media{aspect-ratio:16/9;margin-bottom:0}
.featured-post .post-card-title{font-size:2.4rem;line-height:1.1}
.featured-post .post-card-excerpt{font-size:1.1rem;line-height:1.55;max-width:42ch}
@media(max-width:820px){.featured-post{grid-template-columns:1fr;gap:24px}.featured-post .post-card-title{font-size:1.9rem}}
/* ARTICLE */
.article{padding:56px 0 48px}
.article-kicker{font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-weight:700;margin-bottom:16px;text-align:center}
.article-title{font-size:clamp(2rem,5vw,3.2rem);font-weight:500;line-height:1.1;letter-spacing:-.02em;margin-bottom:20px;text-align:center}
.article-lead{font-size:1.25rem;color:var(--ink-soft);line-height:1.5;text-align:center;max-width:640px;margin:0 auto 36px}
.article-meta{display:flex;align-items:center;justify-content:center;gap:14px;font-size:.88rem;color:var(--muted);padding:16px 0 40px;border-bottom:1px solid var(--border);margin-bottom:48px;flex-wrap:wrap}
.article-meta .avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--wood),var(--accent));display:inline-flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.9rem}
.article-meta strong{color:var(--ink);font-weight:500}
.article-body{font-size:1.08rem;line-height:1.75;color:var(--ink-soft)}
.article-body p{margin-bottom:1.5em}
.article-body h2{font-size:1.75rem;font-weight:500;margin-top:2.6em;margin-bottom:.7em;color:var(--ink)}
.article-body h3{font-size:1.3rem;font-weight:600;margin-top:2em;margin-bottom:.5em;color:var(--ink)}
.article-body ul,.article-body ol{margin-bottom:1.8em}
.article-body li{margin-bottom:.7em}
.article-body li::marker{color:var(--accent)}
.article-body a{color:var(--accent);border-bottom:1px solid currentColor}
.article-body a:hover{color:var(--accent-hover)}
.video-embed{aspect-ratio:16/9;margin:40px 0;border-radius:var(--radius-lg);overflow:hidden;background:var(--dark);box-shadow:var(--shadow-md)}
.video-embed iframe{width:100%;height:100%;border:0}
.callout{background:var(--highlight);border-left:4px solid var(--wood);padding:24px 28px;border-radius:0 var(--radius-lg) var(--radius-lg) 0;margin:36px 0;font-size:1rem}
.callout strong{color:var(--accent)}
.pull-quote{font-family:var(--font-serif);font-size:1.6rem;line-height:1.3;color:var(--ink);font-style:italic;text-align:center;padding:40px 20px;margin:48px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.tags{margin-top:48px;padding-top:32px;border-top:1px solid var(--border);display:flex;flex-wrap:wrap;gap:8px}
.tag{font-size:.8rem;color:var(--muted);background:var(--bg-alt);padding:6px 12px;border-radius:999px;font-weight:500}
/* CLUBE CTA */
/* CLUBE BANNER — specificity forte p/ vencer .article-body h3 */
.clube-banner{background:linear-gradient(135deg,#1A1612 0%,#2A1F15 50%,#3B2614 100%);color:#fff;padding:44px 44px;border-radius:var(--radius-lg);margin:64px 0;position:relative;overflow:hidden}
.clube-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(circle at 85% 30%,rgba(139,90,43,.15),transparent 55%),radial-gradient(circle at 15% 85%,rgba(107,46,43,.2),transparent 50%);pointer-events:none}
.clube-banner .clube-banner-inner{position:relative;z-index:1;display:grid;grid-template-columns:1.15fr .85fr;gap:44px;align-items:center}
.clube-banner .clube-kicker{display:inline-block;font-size:.72rem;text-transform:uppercase;letter-spacing:.14em;color:#D4A574;font-weight:700;margin-bottom:18px;padding:4px 12px;border:1px solid rgba(212,165,116,.35);border-radius:999px;background:transparent}
.clube-banner .clube-headline,.clube-banner h3.clube-headline,.article-body .clube-banner .clube-headline{font-family:var(--font-serif);font-size:clamp(1.4rem,2.6vw,1.9rem);line-height:1.2;font-weight:500;letter-spacing:-.015em;color:#fff !important;margin:0 0 14px 0;display:block}
.clube-banner .clube-headline em{color:#E8B87A;font-style:normal;font-weight:600}
.clube-banner .clube-sub{font-size:.96rem;line-height:1.55;color:rgba(255,255,255,.82);max-width:46ch;margin:0 0 22px 0}
.clube-banner .clube-cta{display:inline-flex;align-items:center;gap:10px;background:#fff;color:var(--dark);padding:14px 26px;border-radius:999px;font-weight:600;font-size:.98rem;white-space:nowrap;transition:all .2s;box-shadow:0 4px 16px rgba(0,0,0,.2);border-bottom:0}
.clube-banner .clube-cta:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.3);color:var(--dark);background:#fff}
.clube-banner .clube-cta svg{width:16px;height:16px}
.clube-banner-visual{position:relative;border-radius:10px;overflow:hidden;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);height:240px;max-width:100%;display:block}
.clube-banner-visual img{width:100%;height:100%;object-fit:cover;display:block;max-height:240px}
@media(max-width:760px){.clube-banner{padding:32px 28px}.clube-banner .clube-banner-inner{grid-template-columns:1fr;gap:24px}.clube-banner-visual{height:200px;max-width:480px;margin:0 auto}.clube-banner-visual img{max-height:200px}}
.clube-banner.compact{padding:32px 32px;margin:48px 0}
.clube-banner.compact .clube-headline{font-size:clamp(1.15rem,2vw,1.4rem)}
.clube-banner.compact .clube-sub{font-size:.9rem}
.clube-banner.compact .clube-cta{padding:12px 22px;font-size:.9rem}
/* FOOTER */
.site-footer{border-top:1px solid var(--border);padding:56px 0 40px;margin-top:80px;background:var(--bg-alt)}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:40px}
@media(max-width:720px){.footer-grid{grid-template-columns:1fr 1fr}}
.footer-col h4{font-family:var(--font-sans);font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink);margin-bottom:16px}
.footer-col a{display:block;font-size:.92rem;color:var(--muted);padding:4px 0}
.footer-col a:hover{color:var(--accent)}
.footer-about p{font-size:.92rem;color:var(--muted);line-height:1.6}
.footer-bottom{margin-top:48px;padding-top:24px;border-top:1px solid var(--border);font-size:.82rem;color:var(--muted);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
/* SEARCH PAGE */
.search-page{padding:56px 0}
.search-page-title{font-family:var(--font-serif);font-size:2rem;font-weight:500;margin-bottom:8px}
.advanced-filters{display:flex;gap:12px;flex-wrap:wrap;padding:20px 0 32px;border-bottom:1px solid var(--border);margin-bottom:32px}
.filter-group{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.filter-group-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-right:8px}
/* UTILS */
.hidden{display:none !important}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
@media(max-width:760px){
  /* Mobile-first redesign do header: logo no topo, busca grande abaixo */
  .header-inner{
    display:grid;
    grid-template-columns:1fr auto;
    grid-template-areas:"brand nav" "search search";
    gap:12px;
    padding:14px 16px;
    align-items:center;
  }
  .brand{grid-area:brand;flex-shrink:0;align-items:center}
  .brand img{height:34px}
  .nav{grid-area:nav;display:flex;gap:14px;font-size:.85rem}
  .nav a{font-weight:500}
  .search-wrap{grid-area:search;max-width:none;width:100%}
  .search-box{
    padding:14px 16px;
    border:1.5px solid var(--accent);
    background:#fff;
    box-shadow:0 2px 10px rgba(107,46,43,.08);
    border-radius:14px;
  }
  .search-box svg{width:20px;height:20px;color:var(--accent)}
  .search-box input{font-size:16px;font-weight:500} /* 16px evita zoom auto no iOS */
  .search-box kbd{display:none}

  /* Hero compacto: headline + chips, sem lead longo */
  .hero{padding:24px 0 18px;border-bottom:0}
  .hero h1{font-size:1.85rem;line-height:1.1;margin-bottom:8px}
  .hero-lead{display:none}
  .chips{gap:6px;justify-content:center}
  .chip{font-size:.78rem;padding:6px 12px}
}


/* ============================================================
   ARTICLE LAYOUT — coluna principal + sidebar sticky direita
   ============================================================ */
.article-layout{
  display:grid;
  grid-template-columns:minmax(0,720px) 300px;
  gap:56px;
  max-width:1140px;
  margin:0 auto;
  padding:0 24px;
  align-items:start;
}
.article-main{min-width:0}
.article-sidebar{
  position:sticky;
  top:100px;
  align-self:start;
  width:100%;
}
/* Em viewports < 1140px, stacka o sidebar embaixo — mas com limite de largura pra não ficar gigante */
@media(max-width:1140px){
  .article-layout{grid-template-columns:1fr;gap:32px;max-width:720px}
  .article-sidebar{
    position:static;
    max-width:380px;
    margin:32px auto 0;
  }
}

/* VERTICAL BANNER (sticky sidebar) */
.clube-vertical{
  background:linear-gradient(160deg,#1A1612 0%,#2A1F15 55%,#3B2614 100%);
  color:#fff;
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  box-shadow:var(--shadow-md);
  display:flex;
  flex-direction:column;
}
.clube-vertical::before{
  content:'';position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(circle at 80% 15%,rgba(139,90,43,.18),transparent 55%),radial-gradient(circle at 20% 90%,rgba(107,46,43,.22),transparent 55%);
}
.clube-vertical-visual{
  position:relative;z-index:1;
  height:170px;
  background:rgba(255,255,255,.04);
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
}
.clube-vertical-visual img{width:100%;height:100%;object-fit:cover;display:block;max-height:170px}
.clube-vertical-body{position:relative;z-index:1;padding:22px 22px 24px}
.clube-vertical .clube-kicker-v{
  display:inline-block;
  font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;
  color:#D4A574;font-weight:700;
  padding:3px 10px;border:1px solid rgba(212,165,116,.35);border-radius:999px;
  background:transparent;
  margin-bottom:14px;
}
.article-body .clube-vertical .clube-headline-v,
.clube-vertical .clube-headline-v{
  font-family:var(--font-serif);
  font-size:1.2rem;line-height:1.2;
  font-weight:500;letter-spacing:-.015em;
  color:#fff !important;
  margin:0 0 10px 0;
  display:block;
}
.clube-vertical .clube-headline-v em{color:#E8B87A;font-style:normal;font-weight:600}
.clube-vertical .clube-sub-v{
  font-size:.88rem;line-height:1.5;
  color:rgba(255,255,255,.8);
  margin:0 0 18px 0;
}
.clube-vertical .clube-cta-v{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:#fff;color:var(--dark);
  padding:12px 18px;border-radius:999px;
  font-weight:600;font-size:.92rem;
  text-decoration:none;border-bottom:0;
  width:100%;
  transition:transform .2s ease,box-shadow .2s ease;
  box-shadow:0 3px 10px rgba(0,0,0,.2);
}
.clube-vertical .clube-cta-v:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.28);color:var(--dark);background:#fff}
.clube-vertical .clube-cta-v svg{width:14px;height:14px}

/* Selo discreto opcional no final do banner */
.clube-vertical-foot{
  position:relative;z-index:1;
  border-top:1px solid rgba(255,255,255,.08);
  padding:12px 22px;
  font-size:.74rem;color:rgba(255,255,255,.55);
  display:flex;align-items:center;gap:8px;
}
.clube-vertical-foot .dot{width:6px;height:6px;border-radius:50%;background:#22c55e;box-shadow:0 0 0 4px rgba(34,197,94,.18)}

/* ============================================================
   SHORTS POPUP + FEED MODAL
   ============================================================ */
/* Popup flutuante — canto direito inferior */
.shorts-pop{
  position:fixed;bottom:24px;right:24px;z-index:100;
  width:84px;height:84px;border-radius:50%;
  overflow:hidden;cursor:pointer;
  box-shadow:0 10px 30px rgba(26,22,18,.35),0 0 0 3px #fff;
  animation:mmPulse 2.4s ease-in-out infinite;
  background:#1A1612;
}
@keyframes mmPulse{
  0%,100%{transform:scale(1);box-shadow:0 10px 30px rgba(26,22,18,.35),0 0 0 3px #fff,0 0 0 8px rgba(107,46,43,0)}
  50%{transform:scale(1.04);box-shadow:0 12px 36px rgba(26,22,18,.4),0 0 0 3px #fff,0 0 0 14px rgba(107,46,43,.18)}
}
.shorts-pop img{width:100%;height:100%;object-fit:cover;display:block;opacity:.85}
.shorts-pop::after{
  content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.65) 100%);
  pointer-events:none;
}
.shorts-pop-label{
  position:absolute;left:0;right:0;bottom:0;
  padding:6px 4px 8px;text-align:center;z-index:1;
  font-size:.68rem;font-weight:600;color:#fff;
  text-transform:uppercase;letter-spacing:.08em;
  pointer-events:none;
}
.shorts-pop-play{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-55%);
  width:24px;height:24px;z-index:1;color:#fff;opacity:.95;
}
.shorts-pop-close{
  position:absolute;top:-6px;right:-6px;z-index:2;
  width:22px;height:22px;border-radius:50%;
  background:#fff;color:#1A1612;border:0;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:12px;line-height:1;font-weight:700;
  box-shadow:0 2px 6px rgba(0,0,0,.2);
}
@media(max-width:520px){
  .shorts-pop{width:72px;height:72px;bottom:18px;right:18px}
}

/* Modal fullscreen */
.shorts-modal{
  position:fixed;inset:0;z-index:200;
  background:#000;
  display:none;
  overflow:hidden;
}
.shorts-modal.active{display:block}
body.shorts-open{overflow:hidden}

.shorts-modal-close{
  position:absolute;top:16px;right:16px;z-index:20;
  width:40px;height:40px;border-radius:50%;
  background:rgba(255,255,255,.12);backdrop-filter:blur(10px);
  border:0;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;line-height:1;
}
.shorts-modal-close:hover{background:rgba(255,255,255,.2)}

.shorts-modal-cta{
  position:absolute;top:16px;left:16px;z-index:20;
  display:flex;align-items:center;gap:10px;
  background:rgba(0,0,0,.55);backdrop-filter:blur(10px);
  padding:8px 16px 8px 10px;border-radius:999px;
  color:#fff;text-decoration:none;font-size:.82rem;font-weight:500;
}
.shorts-modal-cta img{width:22px;height:22px;border-radius:50%;border:1px solid rgba(255,255,255,.3)}
.shorts-modal-cta:hover{background:rgba(0,0,0,.75);color:#fff}

.shorts-scroll{
  height:100vh;height:100dvh;
  overflow-y:scroll;
  scroll-snap-type:y mandatory;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
}
.shorts-scroll::-webkit-scrollbar{display:none}
.short-slide{
  height:100vh;height:100dvh;
  scroll-snap-align:start;scroll-snap-stop:always;
  position:relative;
  display:flex;align-items:center;justify-content:center;
  background:#000;
}
.short-slide-frame{
  width:100%;max-width:420px;height:100%;max-height:90vh;
  aspect-ratio:9/16;
  position:relative;
}
.short-slide iframe{
  width:100%;height:100%;border:0;
  border-radius:12px;
  background:#000;
}
.short-slide-overlay{
  position:absolute;left:0;right:0;bottom:0;
  padding:20px 20px 24px;
  background:linear-gradient(180deg,transparent,rgba(0,0,0,.72));
  border-radius:0 0 12px 12px;
  color:#fff;pointer-events:none;
  display:flex;flex-direction:column;gap:6px;
}
.short-slide-kind{
  display:inline-block;align-self:flex-start;
  font-size:.64rem;text-transform:uppercase;letter-spacing:.14em;
  font-weight:700;padding:3px 10px;border-radius:999px;
  background:rgba(255,255,255,.15);backdrop-filter:blur(6px);
  color:#fff;
}
.short-slide-kind.kind-dica{background:rgba(232,184,122,.22);color:#F3D4A4}
.short-slide-kind.kind-entretenimento{background:rgba(107,46,43,.5);color:#fff}
.short-slide-title{font-family:var(--font-serif);font-size:1.05rem;font-weight:500;line-height:1.3;color:#fff;margin:0;letter-spacing:-.01em}
.short-slide-hint{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:.86rem;color:rgba(255,255,255,.6);
  pointer-events:none;opacity:0;transition:opacity .3s;
}
.short-slide.pending .short-slide-hint{opacity:1}
.short-nav-hint{
  position:absolute;left:50%;bottom:20px;transform:translateX(-50%);
  color:rgba(255,255,255,.55);font-size:.75rem;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  z-index:10;pointer-events:none;
  animation:mmSwipe 1.8s ease-in-out infinite;
}
@keyframes mmSwipe{
  0%,100%{transform:translate(-50%,0);opacity:.55}
  50%{transform:translate(-50%,-6px);opacity:.9}
}
.shorts-loading{
  position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.9rem;
}

/* CTA "Ver curso completo" dentro do short */
.short-slide-cta{
  display:inline-flex;align-items:center;gap:8px;
  align-self:flex-start;
  background:rgba(255,255,255,.95);color:#1A1612 !important;
  padding:9px 14px 9px 12px;border-radius:999px;
  font-weight:600;font-size:.82rem;
  text-decoration:none;border-bottom:0;
  pointer-events:auto;
  box-shadow:0 6px 18px rgba(0,0,0,.25);
  transition:transform .2s ease,box-shadow .2s ease;
  margin-bottom:10px;
}
.short-slide-cta:hover{transform:translateY(-1px);box-shadow:0 8px 22px rgba(0,0,0,.32);color:#1A1612 !important;background:#fff}
.short-slide-cta svg{width:14px;height:14px;flex-shrink:0}
.short-slide-cta .cta-arrow{width:12px;height:12px;opacity:.7}
.short-slide-overlay{pointer-events:none}
.short-slide-overlay .short-slide-cta{pointer-events:auto}

/* ============================================================
   COMMENTS SECTION
   ============================================================ */
.comments{
  margin-top:56px;padding-top:40px;
  border-top:1px solid var(--border);
}
.comments-header{
  display:flex;align-items:baseline;gap:12px;margin-bottom:22px;
}
.comments-title{
  font-family:var(--font-serif);font-size:1.35rem;font-weight:500;
  letter-spacing:-.012em;margin:0;
}
.comments-count{
  font-size:.85rem;color:var(--muted);
}
.comment-form{
  display:flex;flex-direction:column;gap:10px;
  background:var(--bg-alt);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:18px;
  margin-bottom:28px;
}
.comment-form .row{display:flex;gap:10px;align-items:center}
.comment-form input[type="text"], .comment-form textarea{
  font-family:inherit;font-size:.96rem;
  color:var(--ink);background:#fff;
  border:1px solid var(--border);border-radius:var(--radius);
  padding:10px 12px;outline:none;width:100%;
  transition:border-color .18s,box-shadow .18s;
  resize:vertical;
}
.comment-form input:focus, .comment-form textarea:focus{
  border-color:var(--accent);box-shadow:0 0 0 3px rgba(107,46,43,.08);
}
.comment-form textarea{min-height:88px;line-height:1.5}
.comment-form .actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}
.comment-form .hint{font-size:.78rem;color:var(--muted)}
.comment-form .btn-send{
  background:var(--accent);color:#fff;
  border:0;padding:10px 22px;border-radius:999px;
  font-weight:600;font-size:.9rem;cursor:pointer;
  transition:background .18s,transform .2s;
}
.comment-form .btn-send:hover{background:var(--accent-hover);transform:translateY(-1px)}
.comment-form .btn-send:disabled{background:var(--border);color:var(--muted);cursor:not-allowed;transform:none}

.comment{
  display:grid;grid-template-columns:40px 1fr;gap:14px;
  padding:16px 0;border-bottom:1px solid var(--border);
}
.comment:last-child{border-bottom:0}
.comment-avatar{
  width:40px;height:40px;border-radius:50%;
  background:linear-gradient(135deg,var(--wood),var(--accent));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:600;font-size:.92rem;
  flex-shrink:0;
}
.comment-body{min-width:0}
.comment-head{
  display:flex;align-items:baseline;gap:10px;margin-bottom:4px;flex-wrap:wrap;
}
.comment-author{font-weight:600;font-size:.95rem;color:var(--ink)}
.comment-time{font-size:.78rem;color:var(--muted)}
.comment-text{
  font-size:.98rem;line-height:1.55;color:var(--ink-soft);
  white-space:pre-wrap;word-wrap:break-word;
}
.comment-actions{margin-top:8px;display:flex;gap:14px;align-items:center}
.btn-like{
  background:transparent;border:1px solid var(--border);
  color:var(--muted);font-size:.82rem;font-weight:500;
  padding:5px 12px;border-radius:999px;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  transition:all .18s;
  font-family:inherit;
}
.btn-like:hover{border-color:var(--accent);color:var(--accent)}
.btn-like.liked{background:var(--accent);border-color:var(--accent);color:#fff}
.btn-like svg{width:14px;height:14px}
.btn-like .count{font-variant-numeric:tabular-nums}

.comments-empty{
  text-align:center;padding:32px 16px;
  color:var(--muted);font-size:.92rem;
  background:var(--bg-alt);border-radius:var(--radius-lg);
}
.comments-empty strong{color:var(--ink)}


/* Vertical banner stackado — limites já definidos via height fixo (170px) */


/* Home banner horizontal — entre 760 e 1100 ficam lado a lado mas image menor */
@media(min-width:761px) and (max-width:1100px){
  .clube-banner .clube-banner-inner{grid-template-columns:1fr 300px;gap:24px}
  .clube-banner-visual{height:180px}
  .clube-banner-visual img{max-height:180px}
  .clube-banner{padding:36px 28px}
}

/* ============================================================
   SEO + A11Y — skip link, breadcrumbs, related, author bio, TOC
   ============================================================ */
/* Skip to content — invisível até foco via teclado */
.skip-link{
  position:absolute;top:-40px;left:8px;z-index:200;
  background:var(--accent);color:#fff;
  padding:10px 18px;border-radius:6px;
  font-weight:500;font-size:.88rem;
  text-decoration:none;
  transition:top .2s ease;
}
.skip-link:focus{top:8px;color:#fff}

/* Breadcrumbs */
.breadcrumbs{
  padding:16px 0 0;
  font-size:.85rem;
  color:var(--muted);
}
.breadcrumbs ol{
  list-style:none;margin:0;padding:0;
  display:flex;flex-wrap:wrap;gap:6px;align-items:center;
}
.breadcrumbs li{margin:0;display:flex;align-items:center;gap:6px}
.breadcrumbs li+li::before{content:'›';color:var(--border);margin-right:2px}
.breadcrumbs a{color:var(--muted);text-decoration:none}
.breadcrumbs a:hover{color:var(--accent);text-decoration:underline}
.breadcrumbs [aria-current="page"]{color:var(--ink);font-weight:500}

/* TOC (Tabela de conteúdo) */
.toc{
  background:var(--bg-alt);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:20px 24px;
  margin:32px 0;
  font-size:.95rem;
}
.toc-title{
  font-family:var(--font-sans);
  font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;
  font-weight:600;color:var(--muted);margin-bottom:10px;
}
.toc ol{margin:0;padding-left:18px;color:var(--ink-soft)}
.toc li{margin-bottom:6px;line-height:1.4}
.toc li::marker{color:var(--accent);font-weight:600}
.toc a{color:var(--ink-soft);text-decoration:none}
.toc a:hover{color:var(--accent)}

/* Related Posts */
.related-posts{
  margin-top:56px;padding-top:40px;
  border-top:1px solid var(--border);
}
.related-title{
  font-family:var(--font-serif);
  font-size:1.35rem;font-weight:500;
  letter-spacing:-.012em;margin:0 0 20px 0;
}
.related-grid{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.related-card{
  display:block;
  background:var(--bg-alt);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:16px;
  text-decoration:none;color:inherit;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.related-card:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--accent);
}
.related-card-kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700;margin-bottom:6px}
.related-card-title{font-family:var(--font-serif);font-size:1.02rem;font-weight:500;line-height:1.25;margin:0 0 6px 0;color:var(--ink)}
.related-card-meta{font-size:.78rem;color:var(--muted)}

/* Author Bio */
.author-bio{
  display:grid;grid-template-columns:auto 1fr;gap:20px;
  margin-top:48px;padding:24px;
  background:linear-gradient(135deg,var(--bg-alt) 0%,var(--highlight) 100%);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  align-items:start;
}
.author-avatar{
  width:72px;height:72px;border-radius:50%;
  background:linear-gradient(135deg,var(--wood),var(--accent));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-weight:600;font-size:1.6rem;
  font-family:var(--font-serif);
  flex-shrink:0;
}
.author-name{font-family:var(--font-serif);font-size:1.2rem;font-weight:500;margin:0 0 4px 0;color:var(--ink)}
.author-role{font-size:.82rem;color:var(--muted);margin-bottom:10px}
.author-desc{font-size:.94rem;color:var(--ink-soft);line-height:1.55;margin-bottom:12px}
.author-links{display:flex;gap:14px;font-size:.85rem}
.author-links a{color:var(--accent);font-weight:500;text-decoration:none}
.author-links a:hover{text-decoration:underline}
@media(max-width:520px){
  .author-bio{grid-template-columns:1fr;text-align:center}
  .author-avatar{margin:0 auto}
  .author-links{justify-content:center}
}

/* Anchor offset for TOC links */
.article-body h2, .article-body h3{scroll-margin-top:100px}

/* ============================================================
   LISTING PAGES (/aulas, /musicas, /cifras)
   ============================================================ */
.listing{padding:40px 0 80px}
.listing-hero{text-align:center;padding:56px 24px 48px;border-bottom:1px solid var(--border);margin-bottom:56px}
.listing-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:400;margin-bottom:14px}
.listing-hero h1 em{font-style:italic;color:var(--accent)}
.listing-hero p{font-size:1.1rem;color:var(--ink-soft);max-width:560px;margin:0 auto}
.listing-count{display:block;margin-top:16px;font-size:.84rem;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.listing-filters{
  display:flex;gap:8px;flex-wrap:wrap;justify-content:center;
  margin-bottom:48px;
}
.listing-filter{
  font-size:.86rem;font-weight:500;
  padding:8px 18px;border-radius:999px;
  background:#fff;border:1px solid var(--border);color:var(--ink-soft);
  cursor:pointer;transition:all .18s;
  font-family:inherit;
}
.listing-filter:hover{border-color:var(--accent);color:var(--accent)}
.listing-filter.active{background:var(--accent);border-color:var(--accent);color:#fff}
.listing-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));
  gap:40px 32px;
}
.listing-empty{text-align:center;padding:48px 24px;color:var(--muted);font-size:.95rem}

/* ============================================================
   E-COMMERCE VIOLÕES
   ============================================================ */
.violoes-hero{text-align:center;padding:56px 24px 40px;border-bottom:1px solid var(--border)}
.violoes-hero h1{font-size:clamp(2.2rem,5vw,3.4rem);font-weight:400;margin-bottom:12px}
.violoes-hero h1 em{font-style:italic;color:var(--accent)}
.violoes-hero p{font-size:1.1rem;color:var(--ink-soft);max-width:620px;margin:0 auto}

.violoes-filters{
  background:var(--bg-alt);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:24px 28px;
  margin:40px auto 32px;
  max-width:1080px;
}
.vf-row{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px;align-items:end}
@media(max-width:760px){.vf-row{grid-template-columns:1fr;gap:18px}}
.vf-label{font-size:.78rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;margin-bottom:10px;display:block}
.vf-range{display:grid;grid-template-columns:1fr 1fr;gap:12px;align-items:center}
.vf-range .vals{font-family:var(--font-serif);font-size:1.15rem;color:var(--ink);font-weight:500}
.vf-range input[type=range]{width:100%;accent-color:var(--accent)}
.vf-chips{display:flex;gap:6px;flex-wrap:wrap}
.vf-chip{font-size:.82rem;background:#fff;border:1px solid var(--border);padding:6px 14px;border-radius:999px;cursor:pointer;font-family:inherit;color:var(--ink-soft);transition:all .15s}
.vf-chip:hover{border-color:var(--accent);color:var(--accent)}
.vf-chip.active{background:var(--accent);border-color:var(--accent);color:#fff}
.vf-result{font-size:.9rem;color:var(--muted);margin-top:16px;text-align:center}

.violoes-grid{
  display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));
  gap:24px;
  max-width:1180px;margin:0 auto;padding:0 24px;
}
.violao-card{
  background:#fff;
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.violao-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md);border-color:var(--accent)}
.violao-img{aspect-ratio:4/3;background:var(--bg-alt);position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden}
.violao-img img{width:100%;height:100%;object-fit:cover}
.violao-level{position:absolute;top:10px;left:10px;font-size:.68rem;text-transform:uppercase;letter-spacing:.08em;font-weight:700;padding:4px 9px;border-radius:999px;color:#fff;background:rgba(0,0,0,.75);backdrop-filter:blur(6px)}
.violao-level.iniciante{background:rgba(34,139,34,.9)}
.violao-level.intermediario{background:rgba(212,165,116,.95)}
.violao-level.avancado{background:rgba(107,46,43,.95)}
.violao-level.profissional{background:rgba(26,22,18,.95)}
.violao-body{padding:18px 20px 20px;display:flex;flex-direction:column;flex:1}
.violao-brand{font-size:.76rem;text-transform:uppercase;letter-spacing:.08em;color:var(--accent);font-weight:700;margin-bottom:4px}
.violao-name{font-family:var(--font-serif);font-size:1.1rem;font-weight:500;line-height:1.25;color:var(--ink);margin:0 0 8px 0}
.violao-rating{display:flex;align-items:center;gap:6px;margin-bottom:10px;font-size:.82rem;color:var(--muted)}
.violao-rating .stars{color:#F5A623;letter-spacing:-1px}
.violao-note{font-size:.88rem;line-height:1.5;color:var(--ink-soft);margin:8px 0 14px;flex:1}
.violao-price{font-family:var(--font-serif);font-size:1.5rem;font-weight:500;color:var(--ink);margin-bottom:12px}
.violao-price .cents{font-size:.9rem;color:var(--muted)}
.violao-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:#FFE600;color:#1A1612;
  padding:12px 16px;border-radius:var(--radius);
  font-weight:700;font-size:.92rem;text-decoration:none;border-bottom:0;
  transition:background .15s;
}
.violao-cta:hover{background:#FDC300;color:#1A1612}
.violao-cta svg{width:16px;height:16px}

.violoes-empty{text-align:center;padding:48px 20px;color:var(--muted);font-size:.95rem}

.affiliate-disclosure{
  max-width:920px;margin:56px auto 0;padding:20px 24px;
  background:var(--bg-alt);border:1px dashed var(--border);border-radius:var(--radius);
  font-size:.84rem;color:var(--muted);line-height:1.55;text-align:center;
}

/* ============================================================
   VIOLÕES v2 — dual slider + tabs + busca local
   ============================================================ */
.cat-tabs{display:flex;gap:8px;justify-content:center;margin:24px auto 32px;max-width:600px;padding:4px;background:var(--bg-alt);border-radius:999px;border:1px solid var(--border)}
.cat-tab{flex:1;padding:10px 24px;border-radius:999px;font-size:.92rem;font-weight:600;cursor:pointer;background:transparent;border:0;color:var(--ink-soft);font-family:inherit;transition:all .2s}
.cat-tab:hover{color:var(--accent)}
.cat-tab.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px rgba(0,0,0,.08)}

/* Busca local dentro da página */
.local-search{
  position:relative;max-width:680px;margin:0 auto 16px;
}
.local-search-input{
  width:100%;
  font-family:inherit;font-size:1rem;
  padding:14px 20px 14px 48px;
  border:1px solid var(--border);
  border-radius:999px;
  background:#fff;
  color:var(--ink);
  transition:border-color .18s, box-shadow .18s;
  outline:none;
}
.local-search-input:focus{border-color:var(--accent);box-shadow:0 0 0 4px rgba(107,46,43,.1)}
.local-search-icon{position:absolute;left:20px;top:50%;transform:translateY(-50%);color:var(--muted);pointer-events:none}
.local-search-icon svg{width:18px;height:18px}
.local-search-clear{
  position:absolute;right:14px;top:50%;transform:translateY(-50%);
  background:var(--bg-alt);border:0;width:26px;height:26px;border-radius:50%;
  cursor:pointer;color:var(--muted);font-size:14px;line-height:1;
  display:none;align-items:center;justify-content:center;
}
.local-search-clear.show{display:flex}

/* Dual-range slider — 1 barra com 2 handles */
.dual-range{
  position:relative;height:44px;margin-top:6px;
}
.dual-range-track{
  position:absolute;left:0;right:0;top:50%;transform:translateY(-50%);
  height:6px;background:var(--border);border-radius:999px;overflow:hidden;
}
.dual-range-fill{
  position:absolute;top:0;bottom:0;background:var(--accent);border-radius:999px;
}
.dual-range input[type=range]{
  position:absolute;left:0;right:0;
  top:50%;transform:translateY(-50%);
  width:100%;height:22px;background:transparent;
  pointer-events:none;
  -webkit-appearance:none;appearance:none;
  margin:0;
}
.dual-range input[type=range]::-webkit-slider-runnable-track{background:transparent;height:6px;border:0}
.dual-range input[type=range]::-moz-range-track{background:transparent;height:6px;border:0}
.dual-range input[type=range]::-webkit-slider-thumb{
  -webkit-appearance:none;appearance:none;
  pointer-events:auto;
  width:22px;height:22px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);
  cursor:pointer;box-shadow:0 2px 6px rgba(0,0,0,.15);
  transition:transform .15s;
  margin-top:-8px; /* centraliza thumb (22px) na track (6px): (22-6)/2 = 8 */
}
.dual-range input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1)}
.dual-range input[type=range]::-moz-range-thumb{
  pointer-events:auto;
  width:22px;height:22px;border-radius:50%;
  background:#fff;border:2px solid var(--accent);cursor:pointer;
  box-shadow:0 2px 6px rgba(0,0,0,.15);
}
.dual-range-vals{
  display:flex;justify-content:space-between;align-items:baseline;
  margin-bottom:6px;font-family:var(--font-serif);font-size:1.15rem;color:var(--ink);font-weight:500;
}
.dual-range-vals small{font-size:.72rem;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600;font-family:var(--font-sans)}

/* Sub-chips (para acessórios) */
.sub-chips{display:flex;gap:6px;flex-wrap:wrap;justify-content:center;margin-bottom:24px}

/* ============================================================
   PAGINAÇÃO
   ============================================================ */
.pagination{
  display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap;
  margin:48px auto 24px;padding:0 24px;
}
.pagination button, .pagination .pg-info{
  font-family:inherit;font-size:.9rem;font-weight:500;
  background:#fff;border:1px solid var(--border);color:var(--ink-soft);
  padding:9px 16px;border-radius:999px;cursor:pointer;
  transition:all .15s;
  min-width:40px;
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
}
.pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.pagination button.active{background:var(--accent);border-color:var(--accent);color:#fff;cursor:default}
.pagination button:disabled{opacity:.4;cursor:not-allowed}
.pagination .pg-info{
  background:transparent;border:0;padding:9px 6px;color:var(--muted);font-size:.85rem;
}
.pagination .pg-jump{display:flex;gap:6px;align-items:center;font-size:.85rem;color:var(--muted)}
.pagination .pg-jump input{width:54px;text-align:center;padding:6px 8px;border:1px solid var(--border);border-radius:6px;font-family:inherit;font-size:.85rem;color:var(--ink)}
@media(max-width:560px){
  .pagination button{padding:8px 12px;min-width:36px;font-size:.85rem}
  .pagination .pg-jump{display:none}
}

/* ============================================================
   CROSS-PROMO — uma página divulga as outras
   ============================================================ */
.cross-promo{
  display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));
  gap:18px;max-width:1140px;margin:64px auto;padding:0 24px;
}
.cross-promo-card{
  display:flex;flex-direction:column;justify-content:space-between;
  padding:28px 28px 26px;border-radius:14px;
  background:linear-gradient(160deg, var(--bg-alt) 0%, var(--highlight) 100%);
  border:1px solid var(--border);
  text-decoration:none;color:inherit;
  transition:all .22s ease;
  position:relative;overflow:hidden;
  min-height:200px;
}
.cross-promo-card:hover{transform:translateY(-3px);border-color:var(--accent);box-shadow:var(--shadow-md)}
.cross-promo-card-kicker{font-size:.7rem;text-transform:uppercase;letter-spacing:.14em;color:var(--accent);font-weight:700;margin-bottom:10px}
.cross-promo-card-title{font-family:var(--font-serif);font-size:1.3rem;font-weight:500;line-height:1.25;color:var(--ink);margin:0 0 8px 0;letter-spacing:-.01em}
.cross-promo-card-sub{font-size:.92rem;line-height:1.5;color:var(--ink-soft);margin:0 0 16px 0}
.cross-promo-card-cta{align-self:flex-start;font-size:.86rem;font-weight:600;color:var(--accent);display:inline-flex;align-items:center;gap:6px}
.cross-promo-card-cta::after{content:'→';transition:transform .2s}
.cross-promo-card:hover .cross-promo-card-cta::after{transform:translateX(4px)}

/* Variações de cor por tipo */
.cross-promo-card.to-aulas{background:linear-gradient(160deg, #FAF7F2 0%, #F3EFE7 100%)}
.cross-promo-card.to-cifras{background:linear-gradient(160deg, #FAF7F2 0%, #F5E6D3 100%)}
.cross-promo-card.to-violoes{background:linear-gradient(160deg, #2A1F15 0%, #3B2614 100%);color:#fff;border-color:#3B2614}
.cross-promo-card.to-violoes .cross-promo-card-title{color:#fff}
.cross-promo-card.to-violoes .cross-promo-card-sub{color:rgba(255,255,255,.78)}
.cross-promo-card.to-violoes .cross-promo-card-kicker{color:#E8B87A}
.cross-promo-card.to-violoes .cross-promo-card-cta{color:#E8B87A}
.cross-promo-card.to-violoes:hover{border-color:#E8B87A}

/* Variante mais compacta (single card, banner) */
.cross-promo-single{
  display:flex;align-items:center;justify-content:space-between;gap:24px;
  max-width:1100px;margin:48px auto;padding:22px 28px;
  background:var(--bg-alt);border:1px solid var(--border);border-radius:12px;
  text-decoration:none;color:inherit;transition:all .2s;
}
.cross-promo-single:hover{border-color:var(--accent);box-shadow:var(--shadow-md);color:inherit}
.cross-promo-single .left strong{font-family:var(--font-serif);font-size:1.15rem;font-weight:500;color:var(--ink);display:block;margin-bottom:2px}
.cross-promo-single .left span{font-size:.92rem;color:var(--ink-soft)}
.cross-promo-single .arrow{flex-shrink:0;font-size:1.5rem;color:var(--accent);font-weight:300}
@media(max-width:560px){.cross-promo-single{flex-direction:column;align-items:flex-start}.cross-promo-single .arrow{display:none}}

/* ============================================================
   TOP BANNER — animado, rotativo, com SVG ilustrado
   ============================================================ */
.top-banner{
  position:relative;
  overflow:hidden;
  border-bottom:1px solid var(--border);
  isolation:isolate;
}
.top-banner-slide{
  display:none;
  align-items:center;justify-content:space-between;
  gap:24px;padding:14px 28px 18px;
  max-width:1280px;margin:0 auto;
  position:relative;
  min-height:74px;
}
.top-banner-slide.active{display:flex;animation:bannerFadeIn .6s ease}
@keyframes bannerFadeIn{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}

/* Variação Violões — dark wood */
.top-banner-slide.violoes{
  background:
    radial-gradient(ellipse at 80% 50%, rgba(232,184,122,.18) 0%, transparent 60%),
    radial-gradient(ellipse at 0% 100%, rgba(107,46,43,.25) 0%, transparent 60%),
    linear-gradient(95deg, #1A1612 0%, #2A1F15 60%, #3B2614 100%);
  color:#fff;
  border-bottom:1px solid #3B2614;
}
.top-banner-slide.violoes::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200' viewBox='0 0 200 200'%3E%3Cpath d='M30 100 Q 100 30, 170 100 T 30 100' stroke='%23E8B87A' stroke-width='.4' fill='none' opacity='.15'/%3E%3C/svg%3E");
  opacity:.5;
  animation:bannerWavePan 18s linear infinite;
}
@keyframes bannerWavePan{from{background-position:0 0}to{background-position:200px 0}}

/* Variação Cifras — bege quente */
.top-banner-slide.cifras{
  background:
    radial-gradient(ellipse at 90% 50%, rgba(232,184,122,.35) 0%, transparent 50%),
    linear-gradient(95deg, #F5E6D3 0%, #FAF7F2 60%, #F3EFE7 100%);
  color:var(--ink);
}
.top-banner-slide.cifras::before{
  content:'';position:absolute;inset:0;z-index:-1;
  background:url("data:image/svg+xml;utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240' viewBox='0 0 240 240'%3E%3Ctext x='10' y='40' fill='%236B2E2B' opacity='.06' font-family='serif' font-size='32' font-weight='600'%3EC%3C/text%3E%3Ctext x='80' y='90' fill='%236B2E2B' opacity='.05' font-family='serif' font-size='28' font-weight='600'%3EAm%3C/text%3E%3Ctext x='160' y='150' fill='%236B2E2B' opacity='.06' font-family='serif' font-size='34' font-weight='600'%3EG%3C/text%3E%3Ctext x='40' y='200' fill='%236B2E2B' opacity='.05' font-family='serif' font-size='30' font-weight='600'%3EEm%3C/text%3E%3C/svg%3E");
  opacity:.7;
  animation:bannerWavePan 26s linear infinite reverse;
}

/* Variação Aulas — cor neutra com toques bordô */
.top-banner-slide.aulas{
  background:
    radial-gradient(ellipse at 0% 50%, rgba(107,46,43,.12) 0%, transparent 50%),
    linear-gradient(95deg, #FAF7F2 0%, #F3EFE7 100%);
  color:var(--ink);
}

.top-banner-art{
  flex-shrink:0;width:80px;height:80px;
  display:flex;align-items:center;justify-content:center;
  position:relative;
}
.top-banner-art svg{width:100%;height:100%;display:block}

.top-banner-text{flex:1;min-width:0}
.top-banner-kicker{
  display:inline-block;font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;font-weight:700;
  padding:3px 10px;border-radius:999px;margin-bottom:6px;
}
.top-banner-slide.violoes .top-banner-kicker{background:rgba(232,184,122,.18);color:#E8B87A;border:1px solid rgba(232,184,122,.3)}
.top-banner-slide.cifras .top-banner-kicker{background:rgba(107,46,43,.1);color:var(--accent);border:1px solid rgba(107,46,43,.18)}
.top-banner-slide.aulas .top-banner-kicker{background:rgba(107,46,43,.08);color:var(--accent)}
.top-banner-headline{
  font-family:var(--font-serif);font-size:1.05rem;font-weight:500;line-height:1.35;
  margin:0;letter-spacing:-.01em;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.top-banner-headline em{font-style:italic}
.top-banner-slide.violoes .top-banner-headline em{color:#E8B87A;font-style:normal;font-weight:600}
.top-banner-slide.cifras .top-banner-headline em{color:var(--accent);font-style:normal;font-weight:600}
.top-banner-slide.violoes .top-banner-headline{color:#fff}
.top-banner-slide.cifras .top-banner-headline{color:var(--ink)}
.top-banner-slide.aulas .top-banner-headline{color:var(--ink)}

.top-banner-cta{
  flex-shrink:0;
  display:inline-flex;align-items:center;gap:8px;
  padding:11px 22px;border-radius:999px;
  font-weight:600;font-size:.88rem;
  text-decoration:none;border:0;
  transition:transform .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.top-banner-slide.violoes .top-banner-cta{background:#fff;color:#1A1612}
.top-banner-slide.cifras .top-banner-cta{background:var(--accent);color:#fff}
.top-banner-slide.aulas .top-banner-cta{background:var(--accent);color:#fff}
.top-banner-cta:hover{transform:translateY(-1px);box-shadow:0 4px 12px rgba(0,0,0,.18)}
.top-banner-cta svg{width:14px;height:14px;transition:transform .2s}
.top-banner-cta:hover svg{transform:translateX(3px)}

/* Indicadores de slide */
.top-banner-dots{
  position:absolute;bottom:4px;left:50%;transform:translateX(-50%);
  display:flex;gap:5px;z-index:5;
}
.top-banner-dots button{
  width:6px;height:6px;border-radius:50%;border:0;padding:0;cursor:pointer;
  background:rgba(0,0,0,.25);transition:all .2s;
}
.top-banner-slide.violoes ~ .top-banner-dots button,
.top-banner-slide.violoes + .top-banner-dots button{background:rgba(255,255,255,.3)}
.top-banner-dots button.active{width:18px;border-radius:3px;background:var(--accent)}
.top-banner-slide.violoes.active ~ .top-banner-dots button.active{background:#E8B87A}

/* Animações dos elementos SVG (notas, ondas) */
@keyframes floatNote{0%,100%{transform:translateY(0) rotate(0)}50%{transform:translateY(-6px) rotate(8deg)}}
@keyframes pulseString{0%,100%{opacity:.4}50%{opacity:.95}}
@keyframes drawLine{from{stroke-dashoffset:200}to{stroke-dashoffset:0}}
.svg-note{animation:floatNote 3.4s ease-in-out infinite}
.svg-note-2{animation:floatNote 4.2s ease-in-out infinite .3s}
.svg-note-3{animation:floatNote 3.8s ease-in-out infinite .8s}
.svg-string{animation:pulseString 2.2s ease-in-out infinite}
.svg-line{stroke-dasharray:200;animation:drawLine 4s ease-out infinite alternate}

@media(max-width:760px){
  .top-banner-slide{padding:14px 18px;gap:14px;min-height:auto}
  .top-banner-art{width:54px;height:54px}
  .top-banner-headline{font-size:.92rem}
  .top-banner-cta{padding:9px 16px;font-size:.82rem}
  .top-banner-cta span{display:none}
  .top-banner-cta svg{display:block}
}
@media(max-width:520px){
  .top-banner-art{display:none}
}

/* Botão close (opcional) */
.top-banner-close{
  position:absolute;top:8px;right:10px;
  background:transparent;border:0;color:currentColor;opacity:.4;
  cursor:pointer;font-size:18px;line-height:1;padding:4px 6px;
  transition:opacity .15s;z-index:3;
}
.top-banner-close:hover{opacity:.9}
