/* ============================================================
   Cifras WP — Public CSS v1.0.2
   Mobile-first · Dark mode · Print otimizado
   ============================================================ */

/* ── Tokens ──────────────────────────────────────────────── */
:root {
  --c-primary:       #7c3aed;
  --c-primary-dk:    #5b21b6;
  --c-primary-lt:    #ede9fe;
  --c-accent:        #f59e0b;
  --c-bg:            #ffffff;
  --c-bg-alt:        #f8f7ff;
  --c-card:          #ffffff;
  --c-surface:       #f1f0f7;
  --c-border:        #e2e0f0;
  --c-text:          #1e1b4b;
  --c-muted:         #6b7280;
  --c-light:         #9ca3af;
  --c-chord:         #7c3aed;
  --c-chord-bg:      #ede9fe;
  --c-fs:            16px;
  --c-radius:        12px;
  --c-radius-sm:     8px;
  --c-shadow:        0 1px 3px rgba(0,0,0,.07), 0 4px 16px rgba(124,58,237,.07);
  --c-shadow-lg:     0 8px 32px rgba(124,58,237,.14);
  --c-toolbar-h:     56px;
  --c-ease:          cubic-bezier(.4,0,.2,1);
}

[data-cifra-theme="dark"] {
  --c-bg:         #0f0e1a;
  --c-bg-alt:     #1a1830;
  --c-card:       #1a1830;
  --c-surface:    #252340;
  --c-border:     #2d2b4e;
  --c-text:       #f0eeff;
  --c-muted:      #9b98c0;
  --c-light:      #6b68a0;
  --c-chord-bg:   #2d2060;
  --c-shadow:     0 1px 3px rgba(0,0,0,.3),0 4px 16px rgba(0,0,0,.2);
  --c-shadow-lg:  0 8px 32px rgba(0,0,0,.35);
}

/* ── Reset base ──────────────────────────────────────────── */
.cifras-body-wrap { background: var(--c-bg); color: var(--c-text); transition: background .25s, color .25s; }
.cifras-body-wrap *, .cifras-body-wrap *::before, .cifras-body-wrap *::after { box-sizing: border-box; }

/* ── Print header (só impressão) ─────────────────────────── */
.cifra-print-header { display: none; }

/* ════════════════════════════════════════════════════════════
   TOOLBAR
   ════════════════════════════════════════════════════════════ */
.cifra-toolbar {
  position: sticky;
  top: 0;
  z-index: 500;
  background: var(--c-card);
  border-bottom: 1px solid var(--c-border);
  box-shadow: 0 2px 8px rgba(0,0,0,.06);
  height: var(--c-toolbar-h);
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 0 12px;
  overflow-x: auto;
  scrollbar-width: none;
  flex-wrap: nowrap;
  transition: background .25s, border-color .25s;
}
.cifra-toolbar::-webkit-scrollbar { display: none; }

.cifra-toolbar-group {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

.cifra-toolbar-sep {
  width: 1px;
  height: 24px;
  background: var(--c-border);
  flex-shrink: 0;
  margin: 0 2px;
}

.cifra-toolbar-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--c-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  flex-shrink: 0;
  margin-right: 2px;
}

/* Tom controls — compacto e moderno */
.cifra-tom-controls {
  display: flex;
  align-items: center;
  gap: 0;
  background: var(--c-surface);
  border: 1.5px solid var(--c-border);
  border-radius: 8px;
  overflow: hidden;
}

.cifra-tom-btn {
  width: 32px;
  height: 32px;
  border: none;
  background: transparent;
  color: var(--c-primary);
  font-size: 18px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s var(--c-ease), color .15s;
  line-height: 1;
  padding: 0;
  flex-shrink: 0;
}
.cifra-tom-btn:hover { background: var(--c-primary-lt); }
.cifra-tom-btn:active { background: var(--c-primary); color: #fff; transform: scale(.95); }

.cifra-tom-display {
  min-width: 38px;
  text-align: center;
  font-size: 13px;
  font-weight: 800;
  color: var(--c-primary);
  padding: 0 4px;
  border-left: 1px solid var(--c-border);
  border-right: 1px solid var(--c-border);
  line-height: 32px;
  white-space: nowrap;
}

/* Botões de controle genéricos */
.cifra-ctrl-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  height: 32px;
  padding: 0 10px;
  border: 1.5px solid var(--c-border);
  border-radius: 8px;
  background: var(--c-card);
  color: var(--c-text);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s var(--c-ease), border-color .15s, color .15s, transform .1s;
  white-space: nowrap;
  flex-shrink: 0;
}
.cifra-ctrl-btn:hover { background: var(--c-primary-lt); border-color: var(--c-primary); color: var(--c-primary); }
.cifra-ctrl-btn.active { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.cifra-ctrl-btn:active { transform: scale(.95); }

.cifra-font-btn { font-size: 11px; font-weight: 700; min-width: 34px; justify-content: center; }

.cifra-range {
  width: 64px;
  accent-color: var(--c-primary);
  cursor: pointer;
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════
   LAYOUT
   ════════════════════════════════════════════════════════════ */
.cifra-container {
  max-width: 1040px;
  margin: 0 auto;
  padding: 20px 16px 80px;
}

/* Layout: grid cifra + vídeo lateral */
.cifra-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}
@media (min-width: 900px) {
  .cifra-layout--has-video {
    grid-template-columns: 1fr 240px;
    align-items: start;
  }
}

.cifra-main-col { min-width: 0; }
.cifra-side-col { min-width: 0; }

/* ── Breadcrumb ──────────────────────────────────────────── */
.cifra-breadcrumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  color: var(--c-muted);
  margin-bottom: 16px;
}
.cifra-breadcrumb a { color: var(--c-primary); text-decoration: none; }
.cifra-breadcrumb a:hover { text-decoration: underline; }
.cifra-breadcrumb span { color: var(--c-light); }

/* ── Header da cifra ─────────────────────────────────────── */
.cifra-header { margin-bottom: 20px; }

.cifra-artist-link {
  display: inline-block;
  font-size: 14px;
  font-weight: 700;
  color: var(--c-primary);
  text-decoration: none;
  margin-bottom: 4px;
  letter-spacing: .01em;
}
.cifra-artist-link:hover { text-decoration: underline; }

.cifra-title {
  font-size: clamp(22px, 4.5vw, 34px);
  font-weight: 800;
  line-height: 1.2;
  color: var(--c-text);
  margin: 0 0 12px;
}

.cifra-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

/* Badges */
.cifra-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 99px;
  font-size: 12px;
  font-weight: 600;
  border: 1.5px solid transparent;
  text-decoration: none;
  transition: opacity .15s;
}
.cifra-badge--tom    { background: var(--c-primary-lt); color: var(--c-primary); border-color: var(--c-primary); }
.cifra-badge--capo   { background: #fef3c7; color: #92400e; border-color: #f59e0b; }
.cifra-badge--genero { background: var(--c-surface); color: var(--c-muted); border-color: var(--c-border); }
.cifra-badge--genero:hover { border-color: var(--c-primary); color: var(--c-primary); }

/* ── Corpo da cifra ──────────────────────────────────────── */
.cifra-body {
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--c-radius);
  padding: 24px 20px;
  box-shadow: var(--c-shadow);
  overflow: visible;   /* IMPORTANTE: não clipar tooltips */
  position: relative;
}

.cifra-content {
  font-family: 'Fira Code', 'Courier New', 'Lucida Console', monospace;
  font-size: var(--c-fs);
  line-height: 1.85;
  color: var(--c-text);
  white-space: pre;
  overflow-x: auto;
  position: relative;
}

/* Linhas da cifra */
.cifra-chord-line {
  display: block;
  white-space: pre;
  line-height: 1.8;
  position: relative;
}

.cifra-lyric-line {
  display: block;
  white-space: pre;
  line-height: 1.85;
  color: var(--c-text);
}

.cifra-section-label {
  display: block;
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--c-primary);
  margin: 20px 0 2px;
  opacity: .7;
}

/* Acordes inline */
.cifra-chord {
  display: inline-block;
  color: var(--c-chord);
  font-weight: 800;
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  font-size: .85em;
  cursor: pointer;
  padding: 0 3px;
  border-radius: 4px;
  transition: background .12s var(--c-ease), transform .1s;
  position: relative;
  vertical-align: baseline;
  text-decoration: none;
  letter-spacing: .02em;
}
.cifra-chord:hover {
  background: var(--c-chord-bg);
  transform: translateY(-1px);
}

/* ── Tooltip — renderizado no portal, fora de qualquer overflow ── */
.cifra-tooltip {
  position: fixed;           /* fixed = fora de todo stacking context */
  z-index: 99999;
  background: var(--c-card);
  border: 1.5px solid var(--c-border);
  border-radius: var(--c-radius);
  padding: 10px;
  box-shadow: var(--c-shadow-lg);
  pointer-events: none;
  min-width: 110px;
  text-align: center;
  /* Animação */
  opacity: 0;
  transform: translateY(4px) scale(.97);
  transition: opacity .14s var(--c-ease), transform .14s var(--c-ease);
}
.cifra-tooltip.is-visible {
  opacity: 1;
  transform: translateY(0) scale(1);
  pointer-events: auto;
}
.cifra-tooltip-name {
  font-weight: 800;
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--c-primary);
  font-size: 13px;
  margin-bottom: 6px;
}
.cifra-tooltip-arrow {
  position: absolute;
  width: 10px;
  height: 10px;
  background: var(--c-card);
  border-right: 1.5px solid var(--c-border);
  border-bottom: 1.5px solid var(--c-border);
  transform: rotate(45deg);
  bottom: -6px;
  left: 50%;
  margin-left: -5px;
}
.cifra-diagram-svg { display: block; margin: 0 auto; }

/* ── Diagramas ───────────────────────────────────────────── */
.cifra-diagrams-section {
  margin-top: 28px;
  padding: 20px;
  background: var(--c-bg-alt, var(--c-surface));
  border: 1px solid var(--c-border);
  border-radius: var(--c-radius);
}
.cifra-diagrams-section h3 {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 14px;
  font-weight: 700;
  color: var(--c-text);
  margin: 0 0 16px;
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
}
.cifra-diagrams-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 12px;
}
.cifra-diagram-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 10px 6px;
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--c-radius-sm);
  cursor: pointer;
  transition: box-shadow .15s var(--c-ease), border-color .15s, transform .15s;
}
.cifra-diagram-card:hover {
  box-shadow: var(--c-shadow-lg);
  border-color: var(--c-primary);
  transform: translateY(-2px);
}
.cifra-diagram-card-name {
  font-size: 12px;
  font-weight: 700;
  color: var(--c-primary);
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
}

/* ── Vídeo widget (lateral desktop) ──────────────────────── */
.cifra-video-widget {
  border-radius: var(--c-radius);
  overflow: hidden;
  box-shadow: var(--c-shadow-lg);
  position: sticky;
  top: calc(var(--c-toolbar-h) + 16px);
  border: 1px solid var(--c-border);
}
.cifra-video-thumb-btn {
  display: block;
  width: 100%;
  position: relative;
  cursor: pointer;
  border: none;
  padding: 0;
  background: #000;
  aspect-ratio: 16/9;
  overflow: hidden;
}
.cifra-video-thumb-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s var(--c-ease), opacity .25s;
}
.cifra-video-thumb-btn:hover .cifra-video-thumb-img { transform: scale(1.04); opacity: .85; }
.cifra-video-play-overlay {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cifra-video-play-circle {
  width: 52px;
  height: 52px;
  background: rgba(124,58,237,.88);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 20px rgba(0,0,0,.35);
  transition: transform .2s var(--c-ease), background .2s;
}
.cifra-video-thumb-btn:hover .cifra-video-play-circle { transform: scale(1.1); background: var(--c-primary); }
.cifra-video-widget-label {
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 600;
  color: var(--c-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--c-card);
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
}

/* Mobile: vídeo em largura plena, acima da cifra */
@media (max-width: 899px) {
  .cifra-side-col { order: -1; }
  .cifra-video-widget { position: static; max-width: 480px; margin: 0 auto; }
}

/* ── Modal de vídeo ──────────────────────────────────────── */
.cifra-modal {
  position: fixed;
  inset: 0;
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.cifra-modal[hidden] { display: none; }

.cifra-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(4px);
  cursor: pointer;
}
.cifra-modal-box {
  position: relative;
  width: 100%;
  max-width: 860px;
  border-radius: var(--c-radius);
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(0,0,0,.5);
  animation: cifra-modal-in .2s var(--c-ease);
}
@keyframes cifra-modal-in {
  from { opacity:0; transform: scale(.94) translateY(12px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}
.cifra-modal-ratio {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  background: #000;
}
.cifra-modal-ratio iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.cifra-modal-close {
  position: absolute;
  top: -44px;
  right: 0;
  z-index: 2;
  background: rgba(255,255,255,.15);
  border: 1.5px solid rgba(255,255,255,.3);
  color: #fff;
  border-radius: 8px;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: background .15s;
}
.cifra-modal-close:hover { background: rgba(255,255,255,.3); }

/* ════════════════════════════════════════════════════════════
   TAXONOMY PAGES
   ════════════════════════════════════════════════════════════ */
.cifra-tax-hero {
  background: linear-gradient(135deg, var(--c-primary) 0%, var(--c-primary-dk) 100%);
  padding: 48px 24px 40px;
  color: #fff;
}
.cifra-tax-hero--genero {
  background: linear-gradient(135deg, #1d4ed8 0%, #312e81 100%);
}
.cifra-tax-hero-inner {
  max-width: 1040px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 24px;
}
.cifra-tax-avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  flex-shrink: 0;
  border: 3px solid rgba(255,255,255,.4);
  box-shadow: 0 4px 16px rgba(0,0,0,.25);
}
.cifra-tax-avatar img { width: 100%; height: 100%; object-fit: cover; }
.cifra-tax-eyebrow { font-size: 12px; font-weight: 600; opacity: .75; letter-spacing: .1em; text-transform: uppercase; margin: 0 0 4px; }
.cifra-tax-title { font-size: clamp(26px, 5vw, 42px); font-weight: 800; margin: 0 0 8px; line-height: 1.15; }
.cifra-tax-desc { font-size: 15px; opacity: .85; margin: 0 0 12px; }
.cifra-tax-count {
  display: inline-block;
  background: rgba(255,255,255,.18);
  border: 1px solid rgba(255,255,255,.3);
  padding: 4px 14px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 600;
}

/* ── Cards grid ──────────────────────────────────────────── */
.cifras-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 18px;
}
.cifra-card {
  background: var(--c-card);
  border: 1px solid var(--c-border);
  border-radius: var(--c-radius);
  overflow: hidden;
  transition: box-shadow .2s var(--c-ease), transform .2s var(--c-ease), border-color .2s;
  display: flex;
  flex-direction: column;
}
.cifra-card:hover { box-shadow: var(--c-shadow-lg); transform: translateY(-3px); border-color: var(--c-primary); }
.cifra-card__thumb { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--c-surface); }
.cifra-card__thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.cifra-card:hover .cifra-card__thumb img { transform: scale(1.05); }
.cifra-card__body { padding: 14px; flex: 1; display: flex; flex-direction: column; gap: 5px; }
.cifra-card__title { margin: 0; font-size: 15px; font-weight: 700; line-height: 1.3; font-family: -apple-system, BlinkMacSystemFont, sans-serif; }
.cifra-card__title a { color: var(--c-text); text-decoration: none; }
.cifra-card__title a:hover { color: var(--c-primary); }
.cifra-card__artist { margin: 0; font-size: 13px; font-family: -apple-system, BlinkMacSystemFont, sans-serif; }
.cifra-card__artist a { color: var(--c-primary); text-decoration: none; font-weight: 600; }
.cifra-card__meta { display: flex; flex-wrap: wrap; gap: 5px; margin-top: auto; padding-top: 8px; }

/* ── Paginação ───────────────────────────────────────────── */
.cifras-pagination { display: flex; justify-content: center; gap: 6px; margin-top: 36px; flex-wrap: wrap; }
.cifras-pagination .page-numbers {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 40px; height: 40px; padding: 0 10px;
  border: 1.5px solid var(--c-border); border-radius: var(--c-radius-sm);
  color: var(--c-text); text-decoration: none; font-weight: 600; font-size: 14px;
  font-family: -apple-system, BlinkMacSystemFont, sans-serif;
  transition: background .15s, border-color .15s, color .15s;
}
.cifras-pagination .page-numbers:hover,
.cifras-pagination .page-numbers.current { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }

/* Busca */
.cifras-search-form { width: 100%; max-width: 560px; margin: 0 auto; }
.cifras-search-inner { display: flex; align-items: center; background: var(--c-card); border: 2px solid var(--c-border); border-radius: 99px; overflow: hidden; transition: border-color .15s, box-shadow .15s; }
.cifras-search-inner:focus-within { border-color: var(--c-primary); box-shadow: 0 0 0 4px var(--c-primary-lt); }
.cifras-search-input { flex: 1; border: none; background: transparent; padding: 12px 18px; font-size: 15px; color: var(--c-text); outline: none; }
.cifras-search-btn { padding: 8px 14px; background: var(--c-primary); border: none; color: #fff; cursor: pointer; border-radius: 99px; margin: 4px; display: flex; align-items: center; transition: background .15s; }
.cifras-search-btn:hover { background: var(--c-primary-dk); }

/* Artistas tag list */
.cifras-artistas-list { display: flex; flex-wrap: wrap; gap: 8px; }
.cifras-artista-tag { display: inline-block; padding: 7px 16px; background: var(--c-surface); border: 1.5px solid var(--c-border); border-radius: 99px; color: var(--c-text); text-decoration: none; font-size: 13px; font-weight: 600; transition: background .15s, border-color .15s, color .15s; font-family: -apple-system, BlinkMacSystemFont, sans-serif; }
.cifras-artista-tag:hover { background: var(--c-primary); border-color: var(--c-primary); color: #fff; }
.cifras-artista-tag span { color: var(--c-muted); font-weight: 400; }

.cifra-empty { color: var(--c-muted); text-align: center; padding: 48px 0; font-family: -apple-system, BlinkMacSystemFont, sans-serif; }

/* ════════════════════════════════════════════════════════════
   RESPONSIVIDADE MOBILE
   ════════════════════════════════════════════════════════════ */
@media (max-width: 600px) {
  :root { --c-toolbar-h: auto; }

  .cifra-toolbar {
    height: auto;
    flex-wrap: wrap;
    padding: 8px 10px;
    gap: 6px;
    row-gap: 6px;
  }
  .cifra-toolbar-sep { display: none; }
  .cifra-toolbar-group { flex-wrap: nowrap; }

  /* Esconde rótulos de texto para economizar espaço */
  .cifra-lbl-dark, .cifra-lbl-print { display: none; }

  .cifra-ctrl-btn { padding: 0 8px; }
  .cifra-range { width: 52px; }

  .cifra-container { padding: 14px 10px 60px; }
  .cifra-body { padding: 14px 10px; }
  .cifra-content { font-size: 14px !important; }
  .cifras-grid { grid-template-columns: 1fr; }
  .cifra-diagrams-grid { grid-template-columns: repeat(auto-fill, minmax(76px, 1fr)); gap: 8px; }
  .cifra-tax-hero { padding: 32px 16px 28px; }
}

@media (max-width: 380px) {
  .cifra-tom-display { min-width: 30px; }
  .cifra-range { width: 44px; }
}

/* ════════════════════════════════════════════════════════════
   IMPRESSÃO — layout limpo e profissional
   ════════════════════════════════════════════════════════════ */
@media print {
  /* Ocultar TUDO do site */
  body > *:not(.cifras-body-wrap) { display: none !important; }
  .cifras-body-wrap { display: block !important; }

  /* Ocultar elementos desnecessários */
  .cifra-toolbar,
  .cifra-breadcrumb,
  .cifra-video-widget,
  .cifra-side-col,
  .cifra-modal,
  .cifra-diagrams-section,
  .cifra-artist-link,
  #wpadminbar,
  header, footer, nav, aside,
  .site-header, .site-footer,
  .entry-footer, .comment-respond { display: none !important; }

  /* Mostrar header de impressão */
  .cifra-print-header {
    display: block !important;
    margin-bottom: 20px;
    padding-bottom: 14px;
    border-bottom: 2px solid #1e1b4b;
  }
  .cifra-print-title { font-size: 22pt; font-weight: 800; color: #000; }
  .cifra-print-artist { font-size: 14pt; color: #444; margin-top: 4px; }
  .cifra-print-meta { font-size: 10pt; color: #666; margin-top: 6px; }

  /* Layout limpo */
  .cifra-container { max-width: 100%; padding: 0; margin: 0; }
  .cifra-layout { display: block !important; }
  .cifra-header { display: none !important; } /* já está no print header */
  .cifra-body { border: none !important; box-shadow: none !important; padding: 0 !important; }
  .cifra-content { font-size: 10pt !important; line-height: 1.7 !important; white-space: pre !important; }

  .cifra-chord { color: #000 !important; font-weight: 700 !important; background: none !important; }
  .cifra-section-label { color: #555 !important; border-top: 1px solid #ccc; padding-top: 8px; margin-top: 16px; }

  /* Mostrar diagramas na impressão */
  .cifra-diagrams-section {
    display: block !important;
    background: none !important;
    border: none !important;
    margin-top: 20px;
    padding: 0 !important;
    page-break-inside: avoid;
  }
  .cifra-diagrams-section h3 { font-size: 12pt; border-bottom: 1px solid #ccc; padding-bottom: 6px; }
  .cifra-diagrams-grid { grid-template-columns: repeat(auto-fill, minmax(70px, 1fr)) !important; gap: 8px !important; }
  .cifra-diagram-card { border: 1px solid #ddd !important; padding: 6px !important; box-shadow: none !important; page-break-inside: avoid; }
  .cifra-diagram-svg { width: 70px !important; height: 80px !important; }

  /* Configurações gerais de impressão */
  * { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  @page { margin: 1.5cm; }
}

/* ── Animação de entrada ─────────────────────────────────── */
@keyframes cifraFadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:none; } }
.cifra-container { animation: cifraFadeIn .3s var(--c-ease); }
