/* =========================================================================
 * flat.css — Theme: Black Chrome / White Reading
 * -------------------------------------------------------------------------
 * Inspirações: Uber, Notion, Linear. Minimalismo confiante.
 *
 * ZONAS:
 *   • CHROME (sidebar, header, dropdowns, modais não-leitura)
 *     → preto puro #0a0a0a — sempre, em todo o app
 *   • CONTEÚDO READING (caderno, leitura, materiais)
 *     → branco puro #ffffff — quando body[data-page-theme="reading"]
 *   • CONTEÚDO DATA (tabelas, gráficos, dashboards)
 *     → cinza-escuro #161616 — modo padrão
 *
 * Acento único: azul #0066ff (CTAs, foco, links).
 * Estados semânticos: verde #00b050, âmbar #ff9500, vermelho #e60023.
 * ========================================================================= */

:root {
  /* === CHROME (escuro, sempre) === */
  --c-chrome:           #0a0a0a;
  --c-chrome-elevated:  #161616;
  --c-chrome-hover:     #1f1f1f;
  --c-chrome-border:    #2a2a2a;
  --c-chrome-border-strong: #3a3a3a;

  /* === DATA SURFACE (modo padrão, dados densos) === */
  --c-data-bg:          #161616;
  --c-data-card:        #1a1a1a;
  --c-data-elevated:    #232323;
  --c-data-border:      #2a2a2a;
  --c-data-border-strong: #3a3a3a;

  /* === READING SURFACE (claro, conteúdo) === */
  --c-read-bg:          #ffffff;
  --c-read-card:        #fafafa;
  --c-read-elevated:    #f5f5f5;
  --c-read-border:      #e5e5e5;
  --c-read-border-strong: #d4d4d4;

  /* === TEXTO === */
  --c-text-on-dark:        #f5f5f5;
  --c-text-on-dark-soft:   #c9c9c9;
  --c-text-on-dark-muted:  #888888;
  --c-text-on-dark-subtle: #555555;
  --c-text-on-light:        #0a0a0a;
  --c-text-on-light-soft:   #2c2c2c;
  --c-text-on-light-muted:  #6e6e6e;
  --c-text-on-light-subtle: #a0a0a0;

  /* === ACENTO ÚNICO === */
  --c-accent:        #0066ff;
  --c-accent-hover:  #0052cc;
  --c-accent-soft:   rgba(0, 102, 255, 0.10);
  --c-accent-ring:   rgba(0, 102, 255, 0.32);

  /* === ESTADOS === */
  --c-success: #00b050;
  --c-warn:    #ff9500;
  --c-danger:  #e60023;
  --c-info:    #0066ff;

  /* === Aliases para o resto do app que ainda usa nomes antigos === */
  --c-bg:          var(--c-data-bg);
  --c-surface:     var(--c-data-card);
  --c-elevated:    var(--c-data-elevated);
  --c-elevated-hi: #2c2c2c;
  --c-border:      var(--c-data-border);
  --c-border-soft: #1f1f1f;
  --c-border-strong: var(--c-data-border-strong);
  --c-text:        var(--c-text-on-dark);
  --c-text-soft:   var(--c-text-on-dark-soft);
  --c-text-muted:  var(--c-text-on-dark-muted);
  --c-text-subtle: var(--c-text-on-dark-subtle);
  --c-overlay:     rgba(0, 0, 0, 0.85);

  /* === Bridge das vars antigas (--ny-*, --gps-*) === */
  --ny-brand-bg:        var(--c-chrome);
  --ny-brand-card:      var(--c-data-card);
  --ny-brand-text:      var(--c-text-on-dark);
  --ny-brand-muted:     var(--c-text-on-dark-muted);
  --ny-brand-green:     var(--c-success);
  --ny-brand-teal:      var(--c-accent);
  --ny-brand-blue:      var(--c-accent);
  --ny-brand-blue-light:var(--c-accent);
  --ny-brand-gradient:  var(--c-accent);

  --gps-bg-primary:    var(--c-chrome);
  --gps-bg-secondary:  var(--c-data-card);
  --gps-bg-tertiary:   var(--c-data-elevated);
  --gps-border:        var(--c-data-border);
  --gps-border-light:  var(--c-chrome-border);
  --gps-text-primary:  var(--c-text-on-dark);
  --gps-text-secondary:var(--c-text-on-dark-soft);
  --gps-text-muted:    var(--c-text-on-dark-muted);
  --gps-accent-primary:  var(--c-accent);
  --gps-accent-secondary:var(--c-accent);
  --gps-accent-tertiary: var(--c-accent);
  --gps-success: var(--c-success);
  --gps-warning: var(--c-warn);
  --gps-danger:  var(--c-danger);

  /* === Geometria === */
  --r-sm: 4px;
  --r:    6px;
  --r-lg: 8px;
  --r-xl: 12px;
  --tr:   120ms ease-out;
}

/* =========================== Base / app shell =========================== */

html, body {
  background: var(--c-data-bg) !important;
  color: var(--c-text-on-dark);
  font-family: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}

/* Mata noise/decorações antigas no body */
body::before,
body::after,
body.nyvvo-app-shell::before,
body.nyvvo-app-shell::after,
body.nyvvo-admin-shell::before,
body.nyvvo-admin-shell::after {
  content: none !important;
  display: none !important;
  background: none !important;
  filter: none !important;
}

body.nyvvo-app-shell,
body.nyvvo-admin-shell {
  background: var(--c-data-bg) !important;
  color: var(--c-text-on-dark) !important;
}

/* === Modo READING: superfície branca onde se lê === */
body[data-page-theme="reading"] #main-content,
body[data-page-theme="reading"] #page-content {
  background: var(--c-read-bg) !important;
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] #page-content h1,
body[data-page-theme="reading"] #page-content h2,
body[data-page-theme="reading"] #page-content h3,
body[data-page-theme="reading"] #page-content h4,
body[data-page-theme="reading"] #page-content h5,
body[data-page-theme="reading"] #page-content h6 {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] #page-content p,
body[data-page-theme="reading"] #page-content li,
body[data-page-theme="reading"] #page-content td {
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] #page-content .widget-card,
body[data-page-theme="reading"] #page-content .kpi-card,
body[data-page-theme="reading"] #page-content [class*="-card"]:not(.gpsn-shell) {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light) !important;
}

/* ============================== SIDEBAR =================================
   Sempre preto puro. Sem glow, sem decoração. Item ativo = cor de fundo
   muda + indicador de borda esquerda.
   ========================================================================= */

#sidebar {
  background: var(--c-chrome) !important;
  border-right: 1px solid var(--c-chrome-border) !important;
  box-shadow: none !important;
}
#sidebar::before, #sidebar::after,
.sidebar-brand-container::before,
.sidebar-brand-container::after {
  content: none !important;
  display: none !important;
  background: none !important;
  filter: none !important;
  animation: none !important;
}
.sidebar-brand-container {
  background: transparent !important;
  border-bottom: 1px solid var(--c-chrome-border) !important;
}
.brand-icon,
.brand-icon svg {
  filter: none !important;
  animation: none !important;
}
.brand-name {
  background: none !important;
  -webkit-text-fill-color: var(--c-text-on-dark) !important;
  color: var(--c-text-on-dark) !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}
.brand-slogan { color: var(--c-text-on-dark-muted) !important; }

#sidebar-nav-list a,
.nav-link {
  color: var(--c-text-on-dark-soft) !important;
  border-left: 3px solid transparent !important;
  background: transparent !important;
  transition: color var(--tr), background-color var(--tr), border-left-color var(--tr) !important;
  filter: none !important;
  font-weight: 500 !important;
}
#sidebar-nav-list a:hover,
.nav-link:hover {
  color: var(--c-text-on-dark) !important;
  background: var(--c-chrome-elevated) !important;
}
#sidebar-nav-list li.active a,
.nav-link.active,
li.active > a {
  color: var(--c-text-on-dark) !important;
  background: var(--c-chrome-elevated) !important;
  border-left-color: var(--c-accent) !important;
  font-weight: 600 !important;
}
#sidebar-nav-list .lucide,
.nav-link .lucide {
  filter: none !important;
}

/* ============================== HEADER ==================================
   Preto puro com texto branco. Sem blur.
   ========================================================================= */

header,
#main-content > header,
body.nyvvo-app-shell header {
  background: var(--c-chrome) !important;
  border-bottom: 1px solid var(--c-chrome-border) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
#page-title {
  color: var(--c-text-on-dark) !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}

/* ============================ Cards / Widgets ==========================
   Em página DATA (default): cards #1a1a1a com borda #2a2a2a
   Em página READING: cards brancos com borda #e5e5e5
   ========================================================================= */

.widget-card,
.kpi-card,
.card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.widget-card::before, .widget-card::after,
.kpi-card::before, .kpi-card::after {
  content: none !important;
  display: none !important;
  background: none !important;
}
.widget-header {
  background: transparent !important;
  border-bottom: 1px solid var(--c-data-border) !important;
  padding: 12px 18px !important;
}
.widget-title {
  color: var(--c-text-on-dark) !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  font-size: 14px !important;
  text-transform: none !important;
}
.widget-body, .widget-footer {
  background: transparent !important;
}
.widget-footer {
  border-top: 1px solid var(--c-data-border) !important;
}

/* =============================== BOTÕES =================================
   2 estilos: primário (preenchido azul OU branco) e secundário (borda)
   ========================================================================= */

.btn-primary, .btn-secondary, button.btn-primary, button.btn-secondary,
.btn, button[type="submit"]:not(.gpsn-tool):not(.gpsn-mode-btn) {
  border-radius: var(--r) !important;
  font-weight: 600 !important;
  font-size: 13px !important;
  letter-spacing: 0 !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
  box-shadow: none !important;
  text-shadow: none !important;
  filter: none !important;
  padding: 8px 14px !important;
}
.btn-primary, button.btn-primary {
  background: var(--c-accent) !important;
  color: #ffffff !important;
  border: 1px solid var(--c-accent) !important;
}
.btn-primary:hover:not(:disabled),
button.btn-primary:hover:not(:disabled) {
  background: var(--c-accent-hover) !important;
  border-color: var(--c-accent-hover) !important;
  transform: none !important;
}
.btn-primary:disabled, button.btn-primary:disabled {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border) !important;
  color: var(--c-text-on-dark-muted) !important;
  cursor: not-allowed !important;
}
.btn-secondary, button.btn-secondary {
  background: transparent !important;
  color: var(--c-text-on-dark) !important;
  border: 1px solid var(--c-chrome-border-strong) !important;
}
.btn-secondary:hover:not(:disabled),
button.btn-secondary:hover:not(:disabled) {
  background: var(--c-chrome-elevated) !important;
  border-color: var(--c-text-on-dark-muted) !important;
  transform: none !important;
}
.btn-sm { padding: 5px 10px !important; font-size: 12px !important; }

/* Botões em página READING: fundo claro inverte os papéis */
body[data-page-theme="reading"] .btn-primary {
  background: var(--c-text-on-light) !important;
  color: var(--c-read-bg) !important;
  border-color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .btn-primary:hover {
  background: #2c2c2c !important;
  border-color: #2c2c2c !important;
}
body[data-page-theme="reading"] .btn-secondary {
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .btn-secondary:hover {
  background: var(--c-read-elevated) !important;
}

/* =============================== INPUTS =================================
   Fundo do contexto, borda 1px, foco azul.
   ========================================================================= */

input[type="text"], input[type="number"], input[type="email"],
input[type="password"], input[type="search"], input[type="url"],
input[type="tel"], input[type="date"], textarea, select,
.input-form, .form-control {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark) !important;
  border-radius: var(--r) !important;
  padding: 8px 12px !important;
  font-family: inherit !important;
  font-size: 13.5px !important;
  transition: border-color var(--tr), box-shadow var(--tr) !important;
  box-shadow: none !important;
  outline: none;
}
input:focus, textarea:focus, select:focus,
.input-form:focus {
  border-color: var(--c-accent) !important;
  box-shadow: 0 0 0 3px var(--c-accent-ring) !important;
  outline: none !important;
}
.form-label, label {
  color: var(--c-text-on-dark-soft) !important;
  font-weight: 500 !important;
  font-size: 12px !important;
  letter-spacing: 0.01em !important;
  text-transform: none !important;
}
::placeholder { color: var(--c-text-on-dark-subtle) !important; opacity: 1; }

body[data-page-theme="reading"] input:not([type="checkbox"]):not([type="radio"]),
body[data-page-theme="reading"] textarea,
body[data-page-theme="reading"] select {
  background: var(--c-read-bg) !important;
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] ::placeholder { color: var(--c-text-on-light-subtle) !important; }
body[data-page-theme="reading"] .form-label,
body[data-page-theme="reading"] label { color: var(--c-text-on-light-muted) !important; }

/* =============================== MODAIS ================================ */

.modal-backdrop,
[id*="modal-backdrop"],
[class*="modal-backdrop"] {
  background: var(--c-overlay) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.modal, .modal-card,
[id*="modal-content"],
[class*="-modal-content"] {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

/* =============================== TABELAS ================================ */

table {
  background: transparent !important;
  border-collapse: collapse;
}
th {
  color: var(--c-text-on-dark-muted) !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  background: var(--c-chrome) !important;
  border-bottom: 1px solid var(--c-data-border) !important;
  padding: 10px 12px !important;
}
td {
  border-bottom: 1px solid var(--c-data-border) !important;
  padding: 10px 12px;
  color: var(--c-text-on-dark);
}
tbody tr:hover td {
  background: var(--c-data-elevated) !important;
}

/* =============================== TEXTO ================================== */

h1, h2, h3, h4, h5, h6 {
  color: var(--c-text-on-dark) !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  line-height: 1.25 !important;
}
p { color: var(--c-text-on-dark); }
a { color: var(--c-accent); text-decoration: none; font-weight: 500; }
a:hover { text-decoration: underline; }

.text-gray-100, .text-gray-200, .text-gray-300, .text-white {
  color: var(--c-text-on-dark) !important;
}
.text-gray-400 { color: var(--c-text-on-dark-soft) !important; }
.text-gray-500 { color: var(--c-text-on-dark-muted) !important; }
.text-gray-600, .text-gray-700 { color: var(--c-text-on-dark-subtle) !important; }

/* Cores de estado (semântica preservada) */
.gps-status-pendente,
.status-pendente,
.text-warning { color: var(--c-warn) !important; }
.gps-status-em-andamento,
.gps-status-em_andamento,
.status-em-andamento,
.text-info { color: var(--c-info) !important; }
.gps-status-concluido,
.status-concluido,
.text-success { color: var(--c-success) !important; }
.gps-status-atrasado,
.status-atrasado,
.text-danger { color: var(--c-danger) !important; }

/* =========================================================================
   KPI cards estilo Uber: número GRANDE, label pequeno em caps
   ========================================================================= */

.kpi-card,
.kpi-card.widget-card {
  padding: 18px 20px !important;
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 120px;
}
.kpi-card-title,
.kpi-card h4,
.kpi-card .label {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin: 0 0 4px !important;
  line-height: 1.2 !important;
}
.kpi-card-value,
.kpi-card .value,
.kpi-card-number {
  color: var(--c-text-on-dark) !important;
  font-size: 32px !important;
  font-weight: 700 !important;
  letter-spacing: -0.03em !important;
  line-height: 1.05 !important;
  margin: 2px 0 !important;
  font-variant-numeric: tabular-nums;
}
.kpi-card-secondary,
.kpi-card .sub {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  margin: 0 !important;
  line-height: 1.4 !important;
}
.kpi-card-icon {
  width: 36px !important;
  height: 36px !important;
  border-radius: 8px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 8px !important;
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark-soft) !important;
  border: 1px solid var(--c-data-border) !important;
}
.kpi-card-icon svg { width: 18px; height: 18px; }

/* KPI em página READING — inverte cores */
body[data-page-theme="reading"] .kpi-card,
body[data-page-theme="reading"] .kpi-card.widget-card {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .kpi-card-title,
body[data-page-theme="reading"] .kpi-card h4 { color: var(--c-text-on-light-muted) !important; }
body[data-page-theme="reading"] .kpi-card-value,
body[data-page-theme="reading"] .kpi-card-number { color: var(--c-text-on-light) !important; }
body[data-page-theme="reading"] .kpi-card-secondary { color: var(--c-text-on-light-muted) !important; }
body[data-page-theme="reading"] .kpi-card-icon {
  background: var(--c-read-elevated) !important;
  color: var(--c-text-on-light-soft) !important;
  border-color: var(--c-read-border) !important;
}

/* Cores temáticas dos ícones de KPI (Tailwind /20 viraram opacas) */
.bg-blue-500\/20    { background: rgba(0, 102, 255, 0.10) !important; }
.bg-green-500\/20   { background: rgba(0, 176, 80, 0.10) !important; }
.bg-amber-500\/20,
.bg-yellow-500\/20  { background: rgba(255, 149, 0, 0.10) !important; }
.bg-red-500\/20     { background: rgba(230, 0, 35, 0.10) !important; }
.bg-purple-500\/20  { background: rgba(124, 58, 237, 0.10) !important; }
.text-blue-400, .text-blue-300 { color: var(--c-accent) !important; }
.text-green-400, .text-green-300 { color: var(--c-success) !important; }
.text-amber-400, .text-yellow-400 { color: var(--c-warn) !important; }
.text-red-400, .text-red-300 { color: var(--c-danger) !important; }

/* =========================== Tailwind compat =========================== */
.bg-gray-800, .bg-gray-900 { background: var(--c-data-card) !important; }
.bg-gray-700 { background: var(--c-data-elevated) !important; }
.bg-gray-600 { background: var(--c-elevated-hi) !important; }
.border-gray-700 { border-color: var(--c-data-border) !important; }
.border-gray-600 { border-color: var(--c-data-border-strong) !important; }

/* =========================== Defensivos globais =========================
   Mata padrões caros (43 backdrop-filter + 4 animações infinitas)
   ========================================================================= */

*, *::before, *::after {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.brand-icon,
.brand-icon svg,
.nav-link .lucide,
#sidebar::before,
#sidebar::after {
  animation: none !important;
  filter: none !important;
}

.lucide,
[data-lucide],
.fas, .far, .fab, i.fa,
svg.lucide,
#sidebar-nav-list .lucide {
  filter: none !important;
  text-shadow: none !important;
}

body, body.nyvvo-app-shell, body.nyvvo-admin-shell {
  background-image: none !important;
}

.btn-primary:hover, .btn-secondary:hover, .btn:hover,
.widget-card:hover, .kpi-card:hover, .card:hover,
.gps-action-button:hover {
  transform: none !important;
}

/* =========================== Scrollbars =========================== */

*::-webkit-scrollbar { width: 10px; height: 10px; }
*::-webkit-scrollbar-track { background: transparent; }
*::-webkit-scrollbar-thumb {
  background: var(--c-data-border);
  border-radius: 5px;
}
*::-webkit-scrollbar-thumb:hover { background: var(--c-data-border-strong); }
body[data-page-theme="reading"] *::-webkit-scrollbar-thumb { background: var(--c-read-border) !important; }
body[data-page-theme="reading"] *::-webkit-scrollbar-thumb:hover { background: var(--c-read-border-strong) !important; }

/* =========================== Animations úteis =========================== */
.animate-pulse { animation: none !important; opacity: 0.6 !important; }
.animate-spin { animation: spin 1s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* =========================================================================
   SRS / HEATMAP / INSIGHTS / PERFORMANCE — harmonização
   --------------------------------------------------------------------------
   Estes módulos compartilham padrões: cards, sub-tabs, listas de itens.
   ========================================================================= */

/* SRS cards */
.srs-card,
.srs-suggestion-card,
.srs-item,
[class*="srs-card"] {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
  box-shadow: none !important;
}
.srs-card:hover,
.srs-suggestion-card:hover {
  border-color: var(--c-data-border-strong) !important;
  background: var(--c-data-elevated) !important;
  transform: none !important;
}
[class*="srs-tag"], [class*="srs-chip"] {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: 999px !important;
  padding: 2px 8px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
}

/* Heatmap */
[class*="heatmap-cell"],
.heatmap-cell {
  border-radius: 2px !important;
  transition: stroke 80ms ease !important;
}
[class*="heatmap"] [class*="-tooltip"] {
  background: #0a0a0a !important;
  color: var(--c-text-on-dark) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 6px 10px !important;
  font-size: 12px !important;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.5);
}

/* Insights cards */
.insights-card,
.insight-card,
.insight-item,
[class*="insight-block"] {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
  box-shadow: none !important;
}
[class*="insight"][class*="-positive"],
[class*="insight"][class*="-success"] {
  border-left: 3px solid var(--c-success) !important;
}
[class*="insight"][class*="-warning"],
[class*="insight"][class*="-attention"] {
  border-left: 3px solid var(--c-warn) !important;
}
[class*="insight"][class*="-critical"],
[class*="insight"][class*="-danger"] {
  border-left: 3px solid var(--c-danger) !important;
}

/* Performance module */
.perf-insights-list,
[id*="performance"] [class*="-list"] {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.perf-insights-list > * {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 12px 14px !important;
}

/* Genéricos: qualquer hero/banner que ainda use gradient */
[class*="-hero"],
[class*="hero-"],
[class*="command-hero"] {
  background: var(--c-data-card) !important;
  background-image: none !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
  box-shadow: none !important;
}
[class*="-hero"]::before, [class*="-hero"]::after,
[class*="hero-"]::before, [class*="hero-"]::after,
[class*="command-hero"]::before, [class*="command-hero"]::after {
  content: none !important;
  display: none !important;
}

/* Genéricos: qualquer h1/h2 com gradient text → cor sólida */
h1[class*="title"], h2[class*="title"], h3[class*="title"],
.page-header,
[class*="-title-gradient"] {
  background: none !important;
  -webkit-text-fill-color: var(--c-text-on-dark) !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: var(--c-text-on-dark) !important;
}

/* Em página READING, o mesmo aplica com cor escura */
body[data-page-theme="reading"] h1[class*="title"],
body[data-page-theme="reading"] h2[class*="title"],
body[data-page-theme="reading"] h3[class*="title"],
body[data-page-theme="reading"] .page-header,
body[data-page-theme="reading"] [class*="-title-gradient"] {
  color: var(--c-text-on-light) !important;
  -webkit-text-fill-color: var(--c-text-on-light) !important;
}

/* Mata sombras de texto residuais */
body * {
  text-shadow: none !important;
}
/* Exceto em tooltip nativo do navegador (não tem como mexer) */

/* =========================================================================
   KANBAN — harmonização
   --------------------------------------------------------------------------
   Command hero, HUD, colunas e cards.
   ========================================================================= */

.kanban-command-hero {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
  padding: 22px 24px !important;
  margin-bottom: 16px;
  box-shadow: none !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.kanban-command-hero::before, .kanban-command-hero::after {
  content: none !important;
  display: none !important;
}
.kanban-command-kicker {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px;
}
.kanban-command-title {
  color: var(--c-text-on-dark) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.022em !important;
  margin: 0 0 6px !important;
  line-height: 1.2 !important;
  background: none !important;
  -webkit-text-fill-color: var(--c-text-on-dark) !important;
}
.kanban-command-subtitle {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 13px !important;
  margin: 0 !important;
  max-width: 580px;
  line-height: 1.5;
}
.kanban-command-tags {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-top: 10px;
}
.kanban-command-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
}

/* HUD do kanban (cards de stats no hero) */
.kanban-command-hud {
  display: grid;
  grid-template-columns: repeat(2, minmax(170px, 1fr));
  gap: 10px;
}
.kanban-hud-card {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 12px 14px !important;
  display: flex;
  align-items: center;
  gap: 10px;
}
.kanban-hud-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--c-data-elevated);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--c-text-on-dark-soft);
}
.kanban-hud-card--cyan    .kanban-hud-icon { background: rgba(0, 102, 255, 0.10); color: var(--c-accent); border: 1px solid rgba(0, 102, 255, 0.25); }
.kanban-hud-card--amber   .kanban-hud-icon { background: rgba(255, 149, 0, 0.10); color: var(--c-warn); border: 1px solid rgba(255, 149, 0, 0.25); }
.kanban-hud-card--emerald .kanban-hud-icon { background: rgba(0, 176, 80, 0.10); color: var(--c-success); border: 1px solid rgba(0, 176, 80, 0.25); }
.kanban-hud-card--violet  .kanban-hud-icon { background: rgba(124, 58, 237, 0.10); color: #a371f7; border: 1px solid rgba(124, 58, 237, 0.25); }
.kanban-hud-label {
  display: block;
  color: var(--c-text-on-dark-muted) !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  margin-bottom: 2px;
}
.kanban-hud-value {
  color: var(--c-text-on-dark) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  font-variant-numeric: tabular-nums;
  display: block;
  line-height: 1;
}
.kanban-hud-meta {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  margin-top: 2px;
  display: block;
}

/* Colunas e cards do kanban */
.kanban-column,
[class*="kanban-col"] {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
}
.kanban-card,
.kanban-card-item {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 10px 12px !important;
  box-shadow: none !important;
  transition: border-color var(--tr) !important;
}
.kanban-card:hover {
  border-color: var(--c-data-border-strong) !important;
  background: var(--c-data-elevated) !important;
}

/* =========================================================================
   PROVAS — harmonização
   --------------------------------------------------------------------------
   Lista de concursos/exames. Tema reading-friendly por padrão (lista pra ler).
   ========================================================================= */

.provas-page-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--c-data-border);
}
.provas-page-heading h1,
.provas-page-heading h2,
#module-title-provas {
  color: var(--c-text-on-dark) !important;
  font-size: 24px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
  background: none !important;
  -webkit-text-fill-color: var(--c-text-on-dark) !important;
}
.provas-page-subtitle {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 13px !important;
  font-weight: 400 !important;
  margin-top: 4px !important;
  max-width: 720px;
  line-height: 1.5;
}
.provas-page-cta {
  flex-shrink: 0;
}

/* HUD (mini KPIs do topo) */
.provas-hud-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.provas-hud-grid > * {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
  box-shadow: none !important;
}

/* Lista de concursos / cards de prova */
.provas-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: 14px;
}
.prova-card,
.concurso-card,
.provas-grid > article,
.provas-grid > .widget-card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 16px 18px !important;
  box-shadow: none !important;
  transition: border-color var(--tr) !important;
}
.prova-card:hover,
.concurso-card:hover,
.provas-grid > article:hover {
  border-color: var(--c-data-border-strong) !important;
  background: var(--c-data-elevated) !important;
}
.prova-card h3, .prova-card h4,
.concurso-card h3, .concurso-card h4 {
  color: var(--c-text-on-dark) !important;
  font-size: 15px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  margin: 0 0 4px !important;
}

/* Section shells (Radar, Sobreposição) */
.provas-section-shell {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
  padding: 22px 24px !important;
  margin-top: 16px !important;
  box-shadow: none !important;
}
.provas-section-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.provas-section-eyebrow {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px;
}
.provas-section-title {
  color: var(--c-text-on-dark) !important;
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  margin: 0 !important;
  line-height: 1.2 !important;
}
.provas-section-copy {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 13px !important;
  margin-top: 6px !important;
  max-width: 640px;
  line-height: 1.5;
}
.provas-section-meta {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 12px !important;
  flex-shrink: 0;
}

/* Radar / overlap cards aninhados */
.provas-radar-grid,
.provas-overlap-layout {
  display: grid;
  gap: 12px;
}
.provas-overlap-card {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
}
.provas-overlap-kicker {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px;
}

/* Note (banner discreto) */
.provas-page-note {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-left: 3px solid var(--c-accent) !important;
  border-radius: var(--r) !important;
  padding: 10px 14px !important;
  color: var(--c-text-on-dark-soft) !important;
  font-size: 12.5px !important;
  margin-top: 12px;
}

/* =========================================================================
   DESEMPENHO (Acompanhamento) — harmonização
   --------------------------------------------------------------------------
   Alvo: hero "Centro de Comando", chips de sinal, tabs de análise (Por
   Disciplina, Matriz, Histórico, Revisões, Insights, Calendário, Missões),
   widgets internos, performance pills.
   ========================================================================= */

.analysis-hero {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
  padding: 24px 28px !important;
  margin-bottom: 16px;
  box-shadow: none !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
.analysis-hero::before, .analysis-hero::after {
  content: none !important;
  display: none !important;
}
.analysis-kicker {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  margin-bottom: 6px;
}
.analysis-page-title,
#module-title-acompanhamento {
  color: var(--c-text-on-dark) !important;
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  margin: 0 !important;
  line-height: 1.15 !important;
  background: none !important;
  -webkit-text-fill-color: var(--c-text-on-dark) !important;
}
.analysis-hero-subtitle {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 14px !important;
  font-weight: 400 !important;
  margin-top: 8px !important;
  max-width: 580px;
  line-height: 1.5;
}

/* Sinais (chips de status no hero) */
.analysis-hero-signals {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.analysis-signal-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark) !important;
  letter-spacing: 0;
  text-transform: none !important;
  cursor: pointer;
  transition: background-color var(--tr) !important;
}
.analysis-signal-chip:hover {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
}
.analysis-signal-chip--cyan {
  color: var(--c-info) !important;
  border-color: rgba(0, 102, 255, 0.30) !important;
  background: rgba(0, 102, 255, 0.08) !important;
}
.analysis-signal-chip--amber {
  color: var(--c-warn) !important;
  border-color: rgba(255, 149, 0, 0.30) !important;
  background: rgba(255, 149, 0, 0.08) !important;
}

/* Tabs de análise (Por Disciplina, Matriz, etc.) */
.analysis-tabs-shell {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  margin-bottom: 16px;
}
.analysis-tabs {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 6px !important;
}
.analysis-tabs > button,
.analysis-tabs > a,
.analysis-tab {
  background: transparent !important;
  border: 0 !important;
  color: var(--c-text-on-dark-soft) !important;
  padding: 7px 14px !important;
  border-radius: var(--r) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  cursor: pointer;
  transition: background-color var(--tr), color var(--tr) !important;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.analysis-tabs > button:hover,
.analysis-tab:hover {
  color: var(--c-text-on-dark) !important;
  background: var(--c-data-elevated) !important;
}
.analysis-tabs > button.is-active,
.analysis-tab.is-active,
.analysis-tab[aria-selected="true"] {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  font-weight: 600 !important;
  box-shadow: inset 0 0 0 1px var(--c-data-border-strong) !important;
}

/* Performance pills usadas em tabelas (performance-none/low/mid/high) */
.performance-none { color: var(--c-text-on-dark-muted) !important; }
.performance-low,
.performance-baixo,
[class*="performance"][class*="low"]    { color: var(--c-danger) !important; }
.performance-mid,
.performance-medio,
[class*="performance"][class*="mid"],
[class*="performance"][class*="medium"]  { color: var(--c-warn) !important; }
.performance-high,
.performance-alto,
[class*="performance"][class*="high"]   { color: var(--c-success) !important; }

/* Widget cards aninhados (KPIs com !mb-0) */
.widget-card.kpi-card .widget-body {
  padding: 12px 14px !important;
  background: transparent !important;
}
.widget-card.kpi-card .widget-body > div:first-child {
  flex-shrink: 0;
}

/* =========================================================================
   PROGRESSO — harmonização
   --------------------------------------------------------------------------
   Reuse da estrutura .pg-kpi-card e widgets.
   ========================================================================= */

.pg-kpi-card,
.pg-kpi-card.widget-card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 16px 18px !important;
  box-shadow: none !important;
}
.pg-kpi-card .kpi-card-icon {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  margin-bottom: 0 !important;
  margin-right: 10px;
  flex-shrink: 0;
}

/* Variantes da paleta (preservadas semanticamente) */
.pg-kpi-card--tempo .kpi-card-icon {
  background: rgba(0, 102, 255, 0.10) !important;
  color: var(--c-accent) !important;
  border: 1px solid rgba(0, 102, 255, 0.25) !important;
}
.pg-kpi-card--desempenho .kpi-card-icon {
  background: rgba(0, 176, 80, 0.10) !important;
  color: var(--c-success) !important;
  border: 1px solid rgba(0, 176, 80, 0.25) !important;
}
.pg-kpi-card--questoes .kpi-card-icon {
  background: rgba(255, 149, 0, 0.10) !important;
  color: var(--c-warn) !important;
  border: 1px solid rgba(255, 149, 0, 0.25) !important;
}
.pg-kpi-card--retencao .kpi-card-icon {
  background: rgba(124, 58, 237, 0.10) !important;
  color: #a371f7 !important;
  border: 1px solid rgba(124, 58, 237, 0.25) !important;
}
.pg-kpi-card--missao .kpi-card-icon {
  background: rgba(230, 0, 35, 0.10) !important;
  color: var(--c-danger) !important;
  border: 1px solid rgba(230, 0, 35, 0.25) !important;
}

/* Card-row do progresso */
.kpi-card-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

/* =========================================================================
   PAINEL (Dashboard) — harmonização
   --------------------------------------------------------------------------
   Alvo: cards (hero/normal), Meta Semanal (Weekly Grind), Primeiros Passos,
   ações rápidas, KPI grid, Visão Rápida, Leitura do Ritmo.
   ========================================================================= */

/* === Cards genéricos do dashboard === */
.dashboard-card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 18px 20px !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}
.dashboard-card::before, .dashboard-card::after {
  content: none !important;
  display: none !important;
}
.dashboard-card-header {
  background: transparent !important;
  border: 0 !important;
  padding: 0 0 12px !important;
  margin-bottom: 12px !important;
  border-bottom: 1px solid var(--c-data-border) !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.dashboard-card-title {
  color: var(--c-text-on-dark) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  margin: 0 !important;
  display: flex;
  align-items: center;
  gap: 8px;
}
.dashboard-card-title svg, .dashboard-card-title i {
  color: var(--c-text-on-dark-soft);
}
.dashboard-card-body {
  background: transparent !important;
  padding: 0 !important;
  color: var(--c-text-on-dark);
}

/* Hero card (Meta Semanal) — visualmente um pouco mais alto, sem decoração */
.dashboard-card--hero {
  padding: 22px 24px !important;
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-xl) !important;
}

/* === Quick actions (botões grandes "Abrir Missão", "Provas", etc.) === */
.dashboard-quick-actions {
  display: flex;
  gap: 10px;
  margin: 12px 0;
  flex-wrap: wrap;
}
.dashboard-action-btn {
  flex: 1 1 200px;
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark) !important;
  padding: 14px 18px !important;
  border-radius: var(--r-lg) !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  cursor: pointer;
  transition: background-color var(--tr), border-color var(--tr) !important;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  box-shadow: none !important;
  filter: none !important;
}
.dashboard-action-btn:hover {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
  transform: none !important;
}
.dashboard-action-btn svg, .dashboard-action-btn i {
  color: var(--c-accent);
  width: 16px !important;
  height: 16px !important;
  filter: none !important;
}
.dashboard-action-btn--qa {
  background: var(--c-accent-soft) !important;
  border-color: rgba(0, 102, 255, 0.30) !important;
  color: var(--c-accent) !important;
}

/* === Quick action icons inline (botões pequenos no header dos cards) === */
.dashboard-quick-action {
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--c-text-on-dark-muted) !important;
  width: 28px;
  height: 28px;
  border-radius: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer;
  transition: background-color var(--tr), color var(--tr) !important;
  padding: 0 !important;
}
.dashboard-quick-action:hover {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border) !important;
}

/* === KPI grid mini dentro de cards === */
.dashboard-kpis-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 12px;
}
.dashboard-kpis-grid > * {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 12px 14px !important;
}

/* === Meta Semanal (Weekly Grind) === */
.grind-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.grind-title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--c-text-on-dark);
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.grind-title-icon {
  font-size: 14px;
  filter: none !important;
}
.grind-title-text {
  letter-spacing: 0.04em;
}
.grind-week-label {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11.5px;
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.grind-settings-btn {
  background: transparent !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  padding: 5px 10px !important;
  border-radius: var(--r) !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.grind-settings-btn:hover {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border-strong) !important;
}

/* Bars (Horas de Estudo / Questões Respondidas) */
.grind-bars-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
.grind-bar-block { display: flex; flex-direction: column; gap: 8px; }
.grind-bar-info {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.grind-bar-label {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.grind-bar-label-icon { font-size: 12px; filter: none !important; }
.grind-bar-value {
  color: var(--c-text-on-dark) !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  font-variant-numeric: tabular-nums;
}
.grind-bar-percent {
  /* Ignora o style="color:#f97316" inline pra cor consistente */
  color: var(--c-text-on-dark-muted) !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  margin-left: 4px;
}
.grind-bar-track {
  height: 6px;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: 3px;
  overflow: hidden;
}
.grind-bar-fill {
  height: 100% !important;
  background: var(--c-accent) !important;
  border-radius: 2px;
  transition: width 320ms ease-out;
}
.grind-bar-fill.hours    { background: var(--c-warn) !important; }
.grind-bar-fill.questions{ background: var(--c-accent) !important; }
.grind-bar-pace {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pace-highlight {
  color: var(--c-text-on-dark-soft) !important;
  font-weight: 600 !important;
}

/* === Onboarding / Primeiros Passos === */
/* Desativado a pedido do usuário. JS continua tentando renderizar nele
   (não dá erro), mas o card fica permanentemente invisível. */
#dashboard-onboarding-zone,
#dashboard-onboarding-card {
  display: none !important;
}

/* =========================================================================
   Revisões Prioritárias (db-srs-stat) — Uber-style: cor só no número
   --------------------------------------------------------------------------
   Antes: cards com fundo vermelho/laranja/amarelo/azul saturados (gritante).
   Agora: card neutro `#1a1a1a`, borda 1px, número usa a cor semântica.
   ========================================================================= */

.db-srs-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
  margin-bottom: 12px;
}

.db-srs-stat {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 12px !important;
  text-align: center !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  box-shadow: none !important;
  position: relative;
  overflow: hidden;
}
.db-srs-stat::before, .db-srs-stat::after {
  content: none !important;
  display: none !important;
}
.db-srs-stat:hover {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
  transform: none !important;
}

.db-srs-stat-number {
  font-size: 28px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  font-variant-numeric: tabular-nums;
  line-height: 1 !important;
  margin-bottom: 6px !important;
  color: var(--c-text-on-dark) !important;
}
.db-srs-stat-label {
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
  color: var(--c-text-on-dark-muted) !important;
}

/* Variantes: cor só no número + dot indicador no canto */
.db-srs-stat--overdue .db-srs-stat-number  { color: var(--c-danger) !important; }
.db-srs-stat--today .db-srs-stat-number    { color: var(--c-warn) !important; }
.db-srs-stat--soon .db-srs-stat-number     { color: #d4a017 !important; }
.db-srs-stat--upcoming .db-srs-stat-number { color: var(--c-accent) !important; }

/* Hover subtil — borda esquerda da cor semântica aparece */
.db-srs-stat--overdue:hover  { border-left-color: var(--c-danger) !important; border-left-width: 2px !important; }
.db-srs-stat--today:hover    { border-left-color: var(--c-warn) !important;   border-left-width: 2px !important; }
.db-srs-stat--soon:hover     { border-left-color: #d4a017 !important;          border-left-width: 2px !important; }
.db-srs-stat--upcoming:hover { border-left-color: var(--c-accent) !important; border-left-width: 2px !important; }

/* Estado "zero" — fica mais discreto ainda */
.db-srs-stat--zero {
  opacity: 0.55;
}
.db-srs-stat--zero .db-srs-stat-number {
  color: var(--c-text-on-dark-muted) !important;
}

/* CTA "Ver todas as revisões" */
.db-srs-cta {
  display: block !important;
  width: 100% !important;
  padding: 9px 14px !important;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: var(--r) !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
  box-shadow: none !important;
}
.db-srs-cta:hover {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
  color: var(--c-text-on-dark) !important;
}

/* =========================================================================
   Leitura do Seu Ritmo (insight-card-*) — Uber-style: borda esquerda fina
   --------------------------------------------------------------------------
   Antes: card com fundo + borda esquerda 4px da cor saturada.
   Agora: card escuro neutro, borda esquerda 3px na cor, ícone tintado sutil.
   ========================================================================= */

.insight-card-compact,
.insight-card-expanded {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-left: 3px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
  margin-bottom: 8px !important;
  display: flex !important;
  gap: 12px !important;
  align-items: flex-start !important;
  box-shadow: none !important;
  transition: border-color var(--tr) !important;
}
.insight-card-compact::before, .insight-card-compact::after,
.insight-card-expanded::before, .insight-card-expanded::after {
  content: none !important;
  display: none !important;
}
.insight-card-compact:hover,
.insight-card-expanded:hover {
  border-color: var(--c-data-border-strong) !important;
}

/* Variantes — só borda esquerda muda de cor */
.insight-card-compact.insight-card-critical,
.insight-card-expanded.insight-card-critical {
  border-left-color: var(--c-danger) !important;
}
.insight-card-compact.insight-card-warning,
.insight-card-expanded.insight-card-warning {
  border-left-color: var(--c-warn) !important;
}
.insight-card-compact.insight-card-info,
.insight-card-expanded.insight-card-info {
  border-left-color: var(--c-accent) !important;
}
.insight-card-compact.insight-card-success,
.insight-card-expanded.insight-card-success {
  border-left-color: var(--c-success) !important;
}

/* Ícone — fundo tintado sutil + cor sólida */
.insight-icon, .insight-icon-large {
  width: 32px !important;
  height: 32px !important;
  border-radius: 8px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark-soft) !important;
  border: 1px solid var(--c-data-border) !important;
}
.insight-card-critical .insight-icon,
.insight-card-critical .insight-icon-large {
  background: rgba(230, 0, 35, 0.10) !important;
  color: var(--c-danger) !important;
  border-color: rgba(230, 0, 35, 0.25) !important;
}
.insight-card-warning .insight-icon,
.insight-card-warning .insight-icon-large {
  background: rgba(255, 149, 0, 0.10) !important;
  color: var(--c-warn) !important;
  border-color: rgba(255, 149, 0, 0.25) !important;
}
.insight-card-info .insight-icon,
.insight-card-info .insight-icon-large {
  background: rgba(0, 102, 255, 0.10) !important;
  color: var(--c-accent) !important;
  border-color: rgba(0, 102, 255, 0.25) !important;
}
.insight-card-success .insight-icon,
.insight-card-success .insight-icon-large {
  background: rgba(0, 176, 80, 0.10) !important;
  color: var(--c-success) !important;
  border-color: rgba(0, 176, 80, 0.25) !important;
}
/* Sobrescreve cores de texto Tailwind nos ícones */
.insight-icon[class*="text-"],
.insight-icon-large[class*="text-"] { color: inherit !important; }

.insight-content {
  flex: 1 1 auto;
  min-width: 0;
}
.insight-title, .insight-title-large {
  color: var(--c-text-on-dark) !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  margin: 0 0 4px !important;
  line-height: 1.35 !important;
}
.insight-title-large { font-size: 15px !important; }
.insight-description, .insight-description-large {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 12.5px !important;
  margin: 0 0 10px !important;
  line-height: 1.5 !important;
}
.insight-description-large { font-size: 13.5px !important; }
.insight-description:last-child,
.insight-description-large:last-child { margin-bottom: 0 !important; }

/* Botão "Começar agora", "Melhorar X", "Estudar agora", etc. */
.insight-action-btn,
.insight-action-btn-large {
  background: var(--c-accent-soft) !important;
  border: 1px solid rgba(0, 102, 255, 0.25) !important;
  color: var(--c-accent) !important;
  border-radius: var(--r) !important;
  padding: 6px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  box-shadow: none !important;
  filter: none !important;
}
.insight-action-btn:hover,
.insight-action-btn-large:hover {
  background: rgba(0, 102, 255, 0.18) !important;
  border-color: rgba(0, 102, 255, 0.45) !important;
  transform: none !important;
}
.insight-action-btn-large {
  font-size: 13px !important;
  padding: 8px 14px !important;
}

.dashboard-card--onboarding .dashboard-card-body {
  padding: 0 !important;
}
.onboarding-progress-bar,
[class*="progress-bar"] {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
}
[class*="progress-fill"] {
  background: var(--c-accent) !important;
}

/* Steps (numerados 01, 02, etc.) */
.onboarding-step,
.dashboard-step,
[class*="step-card"] {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r) !important;
  padding: 12px 14px !important;
  margin-bottom: 8px;
}
.onboarding-step.is-completed,
.dashboard-step.is-completed,
[class*="step"][class*="completed"] {
  border-color: rgba(0, 176, 80, 0.30) !important;
  background: rgba(0, 176, 80, 0.05) !important;
}
.onboarding-step.is-active,
.dashboard-step.is-active,
[class*="step"][class*="active"] {
  border-color: var(--c-accent) !important;
}
[class*="step-number"], [class*="step-num"] {
  color: var(--c-text-on-dark-muted) !important;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
[class*="step-title"], [class*="step-name"] {
  color: var(--c-text-on-dark) !important;
  font-weight: 600 !important;
}
[class*="step-description"], [class*="step-desc"] {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 12.5px !important;
}

/* === Layout grid do dashboard === */
.dashboard-grid {
  display: grid;
  gap: 16px;
}
.dashboard-left-column,
.dashboard-right-column {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

/* === Priority zone (área de "Atenção") === */
.dashboard-priority-zone {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* =========================================================================
   PAINEL em modo READING (fundo branco)
   --------------------------------------------------------------------------
   Sobrescreve todos os componentes do dashboard pra paleta clara, mantendo
   semântica de cor (status preservados).
   ========================================================================= */

body[data-page-theme="reading"] .dashboard-card,
body[data-page-theme="reading"] .dashboard-card--hero {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .dashboard-card-header {
  border-bottom-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .dashboard-card-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .dashboard-card-title svg,
body[data-page-theme="reading"] .dashboard-card-title i {
  color: var(--c-text-on-light-soft) !important;
}

/* Quick actions (cards "Abrir Missão" etc.) */
body[data-page-theme="reading"] .dashboard-action-btn {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .dashboard-action-btn:hover {
  background: var(--c-read-elevated) !important;
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .dashboard-quick-action {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .dashboard-quick-action:hover {
  background: var(--c-read-elevated) !important;
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border) !important;
}

/* KPIs grid interno */
body[data-page-theme="reading"] .dashboard-kpis-grid > * {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light) !important;
}

/* Meta Semanal — Weekly Grind */
body[data-page-theme="reading"] .grind-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .grind-week-label {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .grind-settings-btn {
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .grind-settings-btn:hover {
  background: var(--c-read-elevated) !important;
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .grind-bar-label {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .grind-bar-value {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .grind-bar-percent {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .grind-bar-track {
  background: var(--c-read-elevated) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .grind-bar-pace {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .pace-highlight {
  color: var(--c-text-on-light-soft) !important;
}

/* Revisões Prioritárias (db-srs-*) */
body[data-page-theme="reading"] .db-srs-stat {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .db-srs-stat:hover {
  background: var(--c-read-elevated) !important;
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .db-srs-stat-number {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .db-srs-stat-label {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .db-srs-stat--overdue .db-srs-stat-number  { color: var(--c-danger) !important; }
body[data-page-theme="reading"] .db-srs-stat--today .db-srs-stat-number    { color: var(--c-warn) !important; }
body[data-page-theme="reading"] .db-srs-stat--soon .db-srs-stat-number     { color: #b35900 !important; }
body[data-page-theme="reading"] .db-srs-stat--upcoming .db-srs-stat-number { color: var(--c-accent) !important; }
body[data-page-theme="reading"] .db-srs-stat--zero .db-srs-stat-number {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .db-srs-cta {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .db-srs-cta:hover {
  background: var(--c-read-elevated) !important;
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border-strong) !important;
}

/* Leitura do Seu Ritmo (insight cards) */
body[data-page-theme="reading"] .insight-card-compact,
body[data-page-theme="reading"] .insight-card-expanded {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .insight-card-compact:hover,
body[data-page-theme="reading"] .insight-card-expanded:hover {
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .insight-icon,
body[data-page-theme="reading"] .insight-icon-large {
  background: var(--c-read-elevated) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .insight-card-critical .insight-icon,
body[data-page-theme="reading"] .insight-card-critical .insight-icon-large {
  background: rgba(230, 0, 35, 0.08) !important;
  border-color: rgba(230, 0, 35, 0.22) !important;
  color: var(--c-danger) !important;
}
body[data-page-theme="reading"] .insight-card-warning .insight-icon,
body[data-page-theme="reading"] .insight-card-warning .insight-icon-large {
  background: rgba(255, 149, 0, 0.10) !important;
  border-color: rgba(255, 149, 0, 0.25) !important;
  color: #b35900 !important;
}
body[data-page-theme="reading"] .insight-card-info .insight-icon,
body[data-page-theme="reading"] .insight-card-info .insight-icon-large {
  background: rgba(0, 102, 255, 0.08) !important;
  border-color: rgba(0, 102, 255, 0.22) !important;
  color: var(--c-accent) !important;
}
body[data-page-theme="reading"] .insight-card-success .insight-icon,
body[data-page-theme="reading"] .insight-card-success .insight-icon-large {
  background: rgba(0, 176, 80, 0.08) !important;
  border-color: rgba(0, 176, 80, 0.22) !important;
  color: var(--c-success) !important;
}
body[data-page-theme="reading"] .insight-title,
body[data-page-theme="reading"] .insight-title-large {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .insight-description,
body[data-page-theme="reading"] .insight-description-large {
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .insight-action-btn,
body[data-page-theme="reading"] .insight-action-btn-large {
  background: rgba(0, 102, 255, 0.08) !important;
  border-color: rgba(0, 102, 255, 0.25) !important;
  color: var(--c-accent) !important;
}
body[data-page-theme="reading"] .insight-action-btn:hover,
body[data-page-theme="reading"] .insight-action-btn-large:hover {
  background: rgba(0, 102, 255, 0.14) !important;
  border-color: rgba(0, 102, 255, 0.40) !important;
}

/* Module orientation card (Quando usar este módulo) em reading */
body[data-page-theme="reading"] .module-orientation-card {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .module-orientation-card[open] {
  border-color: var(--c-read-border-strong) !important;
}
body[data-page-theme="reading"] .module-orientation-summary:hover {
  background: var(--c-read-elevated) !important;
}
body[data-page-theme="reading"] .module-orientation-kicker {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .module-orientation-summary-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .module-orientation-summary-action {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .module-orientation-body {
  border-top-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .module-orientation-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .module-orientation-copy {
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .module-orientation-chip {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .module-bridge-card {
  background: var(--c-read-bg) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] .module-bridge-kicker {
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .module-bridge-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .module-bridge-copy {
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .module-bridge-action {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-soft) !important;
}
body[data-page-theme="reading"] .module-bridge-action:hover {
  background: var(--c-read-elevated) !important;
  color: var(--c-text-on-light) !important;
  border-color: var(--c-read-border-strong) !important;
}

/* Headings genéricos em reading */
body[data-page-theme="reading"] h1,
body[data-page-theme="reading"] h2,
body[data-page-theme="reading"] h3,
body[data-page-theme="reading"] h4,
body[data-page-theme="reading"] h5,
body[data-page-theme="reading"] h6 {
  color: var(--c-text-on-light) !important;
}

/* <details> genérico em reading */
body[data-page-theme="reading"] details:not(.module-orientation-card) {
  background: var(--c-read-card) !important;
  border-color: var(--c-read-border) !important;
}
body[data-page-theme="reading"] details:not(.module-orientation-card) > summary {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] details:not(.module-orientation-card) > summary:hover {
  background: var(--c-read-elevated) !important;
}

/* =========================================================================
   GPS — harmonização do módulo "Missão"
   --------------------------------------------------------------------------
   Alvo: KPIs do topo, tabs (Tabela / Revisões), filtros de status, status
   badges das linhas, timer capsule, discipline select, tinting de linha.
   ========================================================================= */

/* === KPIs do topo do GPS (Avanço/Acertos/Tempo/Retenção) === */
#gps-stats .kpi-card,
.gps-stats-row .kpi-card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
  text-align: left !important;
  align-items: flex-start !important;
}
#gps-stats .kpi-title,
.gps-stats-row .kpi-title {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  margin: 0 0 6px !important;
  text-align: left !important;
}
#gps-stats .kpi-value,
.gps-stats-row .kpi-value {
  font-size: 26px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: var(--c-text-on-dark) !important;
  line-height: 1.1 !important;
  font-variant-numeric: tabular-nums;
  text-align: left !important;
}
#gps-stats .kpi-detail,
.gps-stats-row .kpi-detail {
  color: var(--c-text-on-dark-muted) !important;
  font-size: 11.5px !important;
  font-weight: 500 !important;
  margin-top: 4px !important;
  text-align: left !important;
}
/* Override das cores Tailwind inline (text-cyan-400, text-green-400 etc.) */
#gps-stats .text-cyan-400,
#gps-stats .text-cyan-200,
#gps-stats .text-blue-300,
#gps-stats .text-green-400,
#gps-stats .text-green-200,
#gps-stats .text-yellow-400,
#gps-stats .text-yellow-200 {
  color: var(--c-text-on-dark) !important;
}
#gps-stats .kpi-detail.text-cyan-200,
#gps-stats .kpi-detail.text-blue-300,
#gps-stats .kpi-detail.text-green-200,
#gps-stats .kpi-detail.text-yellow-200 {
  color: var(--c-text-on-dark-muted) !important;
}

/* === Section tabs (Tabela / Revisões) === */
.gps-section-tab {
  background: transparent !important;
  border: 0 !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;
  color: var(--c-text-on-dark-muted) !important;
  padding: 8px 12px !important;
  font-size: 13px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: color var(--tr), border-color var(--tr) !important;
  margin-right: 4px !important;
}
.gps-section-tab:hover {
  color: var(--c-text-on-dark) !important;
}
.gps-section-tab.is-active {
  color: var(--c-text-on-dark) !important;
  border-bottom-color: var(--c-accent) !important;
  font-weight: 600 !important;
  background: transparent !important;
}

/* === Filter chips (Todos / Pendentes / Em andamento / Concluídos) === */
.gps-status-filters {
  display: flex !important;
  gap: 6px !important;
  flex-wrap: wrap !important;
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
}
.gps-status-filter-btn {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: 999px !important;
  padding: 5px 12px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
  text-transform: none !important;
  box-shadow: none !important;
}
.gps-status-filter-btn:hover {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border-strong) !important;
}
.gps-status-filter-btn.is-active {
  background: var(--c-accent) !important;
  border-color: var(--c-accent) !important;
  color: #ffffff !important;
}

/* === Status badges nas células (PENDENTE / EM ANDAMENTO / CONCLUÍDO) === */
.status-badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  padding: 3px 9px !important;
  border-radius: 999px !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase !important;
  white-space: nowrap !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  box-shadow: none !important;
  text-shadow: none !important;
}
.status-badge svg, .status-badge i {
  width: 10px !important;
  height: 10px !important;
}
.status-badge-pendente,
.status-pendente {
  background: rgba(255, 149, 0, 0.10) !important;
  color: var(--c-warn) !important;
  border-color: rgba(255, 149, 0, 0.25) !important;
}
.status-badge-em-andamento,
.status-badge-andamento,
.status-em-andamento,
.status-andamento {
  background: rgba(0, 102, 255, 0.10) !important;
  color: var(--c-accent) !important;
  border-color: rgba(0, 102, 255, 0.28) !important;
}
.status-badge-concluido,
.status-concluido {
  background: rgba(0, 176, 80, 0.10) !important;
  color: var(--c-success) !important;
  border-color: rgba(0, 176, 80, 0.25) !important;
}
.status-badge-atrasado,
.status-atrasado {
  background: rgba(230, 0, 35, 0.10) !important;
  color: var(--c-danger) !important;
  border-color: rgba(230, 0, 35, 0.25) !important;
}

/* === Row tinting === */
#gps-tracking-table tbody tr {
  background: transparent !important;
  transition: background-color 80ms ease !important;
}
#gps-tracking-table tbody tr:hover td {
  background: rgba(255, 255, 255, 0.025) !important;
}
#gps-tracking-table tbody tr.task-completed td,
#gps-tracking-table tbody tr.gps-status-concluido td {
  color: var(--c-text-on-dark-muted) !important;
  opacity: 0.7;
}
#gps-tracking-table tbody tr.task-completed:hover td,
#gps-tracking-table tbody tr.gps-status-concluido:hover td {
  opacity: 1;
}
/* Linha "primeira pendente" — sutil indicador esquerdo */
#gps-tracking-table tbody tr.gps-first-pending-row td:first-child {
  border-left: 3px solid var(--c-accent) !important;
  padding-left: 9px !important;
}
/* Flash em conclusão recente */
#gps-tracking-table tbody tr.gps-row-completing td {
  animation: gps-row-flash 950ms ease-out;
}
@keyframes gps-row-flash {
  0%   { background: rgba(0, 176, 80, 0.18); }
  100% { background: transparent; }
}

/* === Discipline select === */
#gps-discipline-select {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border-strong) !important;
  color: var(--c-text-on-dark) !important;
  font-weight: 500 !important;
  font-size: 14px !important;
  padding: 8px 32px 8px 12px !important;
  border-radius: var(--r) !important;
  min-width: 220px;
  box-shadow: none !important;
}
#gps-discipline-select:focus {
  border-color: var(--c-accent) !important;
  box-shadow: 0 0 0 3px var(--c-accent-ring) !important;
}

/* === Timer button (capsule no GPS) === */
.gps-timer-button {
  background: var(--c-data-elevated) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: 999px !important;
  padding: 4px 10px 4px 8px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
  box-shadow: none !important;
  filter: none !important;
}
.gps-timer-button:hover:not(:disabled) {
  background: #2c2c2c !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border-strong) !important;
}
.gps-timer-button.timer-running {
  background: rgba(0, 176, 80, 0.10) !important;
  border-color: rgba(0, 176, 80, 0.35) !important;
  color: var(--c-success) !important;
}
.gps-timer-button.timer-running:hover:not(:disabled) {
  background: rgba(0, 176, 80, 0.15) !important;
}
.gps-timer-button.timer-paused {
  background: rgba(255, 149, 0, 0.10) !important;
  border-color: rgba(255, 149, 0, 0.32) !important;
  color: var(--c-warn) !important;
}
.gps-timer-button .timer-display {
  font-variant-numeric: tabular-nums;
  font-weight: 600;
}
.gps-timer-button svg {
  width: 12px !important;
  height: 12px !important;
  filter: none !important;
}

/* === Tracking table shell === */
.gps-tracking-table-shell {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  overflow-x: auto;
}
#gps-tracking-table {
  background: transparent !important;
  border: 0 !important;
}
#gps-tracking-table thead th {
  background: var(--c-chrome) !important;
  color: var(--c-text-on-dark-muted) !important;
  border-bottom: 1px solid var(--c-data-border) !important;
  position: sticky;
  top: 0;
  z-index: 1;
}
#gps-tracking-table thead th.sortable-header {
  cursor: pointer;
}
#gps-tracking-table thead th.sortable-header:hover {
  color: var(--c-text-on-dark) !important;
  background: var(--c-data-elevated) !important;
}
#gps-tracking-table tbody td {
  border-bottom: 1px solid var(--c-data-border-soft, #1f1f1f) !important;
  font-size: 13px !important;
}

/* === Stars de relevância — usar accent ao invés de amarelo === */
#gps-tracking-table .relevance-stars,
.gps-relevance-stars {
  color: var(--c-text-on-dark-subtle);
}
#gps-tracking-table .relevance-stars .star-filled,
.gps-relevance-stars .star-filled {
  color: var(--c-warn);
}

/* === Coluna "Nº" — força nowrap pra números de 2+ dígitos não quebrarem === */
#gps-tracking-table th:nth-child(2),
#gps-tracking-table td:nth-child(2) {
  white-space: nowrap !important;
  text-align: center !important;
  font-variant-numeric: tabular-nums !important;
  padding-left: 4px !important;
  padding-right: 4px !important;
  min-width: 48px !important;
}
#gps-tracking-table td:nth-child(2) {
  color: var(--c-text-on-dark-muted) !important;
  font-weight: 600;
  font-size: 12.5px;
}

/* Mesmo cuidado pra coluna Tempo e Ex.Prop (também são numéricas) */
#gps-tracking-table th:nth-child(5),
#gps-tracking-table td:nth-child(5),
#gps-tracking-table th:nth-child(8),
#gps-tracking-table td:nth-child(8),
#gps-tracking-table th:nth-child(9),
#gps-tracking-table td:nth-child(9) {
  white-space: nowrap !important;
  font-variant-numeric: tabular-nums !important;
}

/* === Botões de ação na coluna AÇÕES (notebook, menu, delete) === */
#gps-tracking-table .gps-action-button {
  background: transparent !important;
  border: 1px solid transparent !important;
  color: var(--c-text-on-dark-soft) !important;
  width: 28px !important;
  height: 28px !important;
  padding: 0 !important;
  border-radius: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background-color var(--tr), color var(--tr), border-color var(--tr) !important;
  box-shadow: none !important;
  filter: none !important;
}
#gps-tracking-table .gps-action-button:hover:not(:disabled) {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border) !important;
  transform: none !important;
}
#gps-tracking-table .gps-action-button.gps-delete-subtask-btn:hover {
  color: var(--c-danger) !important;
  background: rgba(230, 0, 35, 0.08) !important;
  border-color: rgba(230, 0, 35, 0.25) !important;
}
#gps-tracking-table .gps-action-button.gps-action-notebook-btn.has-note::after {
  background: var(--c-accent) !important;
  box-shadow: 0 0 0 2px var(--c-data-card), 0 0 6px rgba(0, 102, 255, 0.5) !important;
}

/* =========================================================================
   BACKLINKS — rodapé "Mencionado em" (notas + caderno)
   ========================================================================= */

.notas-backlinks,
.gpsn-backlinks {
  margin-top: 32px;
  padding-top: 18px;
  border-top: 1px dashed var(--c-data-border);
}
.gpsn-preview .gpsn-backlinks {
  border-top-color: #e5e5e5;
}

.notas-backlinks-head,
.gpsn-backlinks-head {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--c-text-on-dark-muted);
  margin-bottom: 10px;
}
.gpsn-preview .gpsn-backlinks-head { color: #6e6e6e; }

.notas-backlinks-head svg,
.gpsn-backlinks-head svg {
  width: 13px;
  height: 13px;
  color: var(--c-accent);
}
.notas-backlinks-head strong,
.gpsn-backlinks-head strong { font-weight: 700; }

.notas-backlinks-count,
.gpsn-backlinks-count {
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  color: var(--c-text-on-dark-muted);
  border-radius: 999px;
  padding: 1px 7px;
  font-size: 10.5px;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0;
}
.gpsn-preview .gpsn-backlinks-count {
  background: #fafafa;
  border-color: #e5e5e5;
  color: #6e6e6e;
}

.notas-backlinks-empty {
  color: var(--c-text-on-dark-muted);
  font-size: 12.5px;
  font-style: italic;
  margin: 0;
  line-height: 1.5;
}
.notas-backlinks-empty code {
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: 3px;
  padding: 1px 5px;
  font-family: var(--gpsn-font-mono, 'JetBrains Mono', monospace);
  font-size: 0.9em;
  color: var(--c-accent);
}

.notas-backlinks-list,
.gpsn-backlinks-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.notas-backlinks-item,
.gpsn-backlinks-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r);
  cursor: pointer;
  transition: background-color var(--tr), border-color var(--tr) !important;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-backlinks-item:hover,
.gpsn-backlinks-item:hover {
  background: var(--c-data-elevated);
  border-color: var(--c-data-border-strong);
}
.gpsn-preview .gpsn-backlinks-item {
  background: #fafafa;
  border-color: #e5e5e5;
}
.gpsn-preview .gpsn-backlinks-item:hover {
  background: #f0f0f0;
  border-color: #d4d4d4;
}

.notas-backlinks-icon,
.gpsn-backlinks-icon {
  width: 14px;
  height: 14px;
  color: var(--c-text-on-dark-muted);
  flex-shrink: 0;
}
.gpsn-preview .gpsn-backlinks-icon { color: #6e6e6e; }

.notas-backlinks-title,
.gpsn-backlinks-title {
  flex: 1 1 auto;
  font-size: 13px;
  font-weight: 500;
  color: var(--c-text-on-dark) !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gpsn-preview .gpsn-backlinks-title { color: #0a0a0a !important; }

.notas-backlinks-meta,
.gpsn-backlinks-meta {
  font-size: 11px;
  color: var(--c-text-on-dark-muted);
  flex-shrink: 0;
}
.gpsn-preview .gpsn-backlinks-meta { color: #6e6e6e; }

/* =========================================================================
   Cmd+K: excerpt destacado quando busca casa em body
   ========================================================================= */

.nyvvo-cmdk-item-excerpt {
  font-size: 11.5px;
  line-height: 1.45;
  color: #888888;
  margin-top: 4px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.nyvvo-cmdk-item.is-selected .nyvvo-cmdk-item-excerpt {
  color: #c9c9c9;
}
.nyvvo-cmdk-item-excerpt mark {
  background: rgba(0, 102, 255, 0.18);
  color: #ffffff;
  padding: 1px 2px;
  border-radius: 2px;
}

/* =========================================================================
   WIKILINKS [[...]] e Autocomplete
   ========================================================================= */

/* Wikilink renderizado no preview do caderno e no viewer das Notas */
a.nyvvo-wikilink {
  color: var(--c-accent) !important;
  background: rgba(0, 102, 255, 0.06);
  border-radius: 3px;
  padding: 1px 4px;
  margin: 0 1px;
  text-decoration: none !important;
  border-bottom: 1px solid rgba(0, 102, 255, 0.4) !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  font-weight: 500;
  cursor: pointer;
  white-space: nowrap;
}
a.nyvvo-wikilink:hover {
  background: rgba(0, 102, 255, 0.18) !important;
  border-bottom-color: var(--c-accent) !important;
  border-bottom-style: solid !important;
  text-decoration: none !important;
}
a.nyvvo-wikilink::before {
  content: "🔗";
  font-size: 0.85em;
  margin-right: 3px;
  opacity: 0.5;
}
a.nyvvo-wikilink.is-broken {
  color: var(--c-danger) !important;
  background: rgba(230, 0, 35, 0.08);
  border-bottom: 1px dashed rgba(230, 0, 35, 0.55) !important;
}
a.nyvvo-wikilink.is-broken:hover {
  background: rgba(230, 0, 35, 0.18) !important;
}
a.nyvvo-wikilink.is-broken::before {
  content: "✚";
  color: var(--c-danger);
  opacity: 0.7;
}

/* No caderno: tema claro do preview (fundo branco) */
.gpsn-preview a.nyvvo-wikilink {
  color: #5d6ad2 !important;
  background: rgba(93, 106, 210, 0.08);
  border-bottom-color: rgba(93, 106, 210, 0.45) !important;
}
.gpsn-preview a.nyvvo-wikilink:hover {
  background: rgba(93, 106, 210, 0.18) !important;
  border-bottom-color: #5d6ad2 !important;
}
.gpsn-preview a.nyvvo-wikilink.is-broken {
  color: #c41a3a !important;
  background: rgba(196, 26, 58, 0.08);
  border-bottom-color: rgba(196, 26, 58, 0.55) !important;
}
.gpsn-preview a.nyvvo-wikilink.is-broken:hover {
  background: rgba(196, 26, 58, 0.18) !important;
}

/* Dropdown de autocomplete [[ */
.gpsn-ac-dropdown {
  position: fixed;
  z-index: 100004;
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: var(--r-lg);
  padding: 4px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.6);
  min-width: 280px;
  max-width: 360px;
  max-height: 300px;
  overflow-y: auto;
  font-family: 'Inter', system-ui, sans-serif;
  display: none;
}
.gpsn-ac-dropdown::-webkit-scrollbar { width: 6px; }
.gpsn-ac-dropdown::-webkit-scrollbar-thumb { background: #2a2a2a; border-radius: 3px; }

.gpsn-ac-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: 6px;
  cursor: pointer;
  color: #c9c9c9;
  transition: background-color 80ms ease;
}
.gpsn-ac-item:hover {
  background: #1a1a1a;
}
.gpsn-ac-item.is-selected {
  background: #1f2a3f;
  color: #ffffff;
  border-left: 2px solid var(--c-accent);
  padding-left: 8px;
}
.gpsn-ac-item.gpsn-ac-create {
  color: var(--c-accent);
}
.gpsn-ac-item.gpsn-ac-create.is-selected {
  background: rgba(0, 102, 255, 0.10);
}
.gpsn-ac-icon {
  width: 14px; height: 14px;
  flex-shrink: 0;
  color: var(--c-text-on-dark-muted);
}
.gpsn-ac-item.gpsn-ac-create .gpsn-ac-icon { color: var(--c-accent); }
.gpsn-ac-item.is-selected .gpsn-ac-icon { color: var(--c-accent); }
.gpsn-ac-text { flex: 1 1 auto; min-width: 0; }
.gpsn-ac-title {
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gpsn-ac-folder {
  font-size: 11px;
  color: #888888;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gpsn-ac-empty {
  padding: 12px;
  text-align: center;
  color: #888888;
  font-size: 12px;
  font-style: italic;
}

/* =========================================================================
   MÓDULO NOTAS — Vault estilo Obsidian-lite
   ========================================================================= */

.notas-root {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
}

.notas-topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px 4px 16px 4px;
  border-bottom: 1px solid var(--c-data-border);
  flex-shrink: 0;
}
.notas-topbar-title {
  display: flex;
  align-items: center;
  gap: 12px;
}
.notas-topbar-title svg {
  width: 22px;
  height: 22px;
  color: var(--c-accent);
}
.notas-topbar-title h1 {
  font-size: 22px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: var(--c-text-on-dark) !important;
  margin: 0 !important;
}
.notas-topbar-sub {
  color: var(--c-text-on-dark-muted);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.notas-layout {
  display: grid;
  grid-template-columns: 300px 1fr;
  gap: 16px;
  flex: 1 1 auto;
  min-height: 0;
  height: 100%;
}

/* Vault sidebar */
.notas-vault {
  background: var(--c-data-card);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r-lg);
  overflow-y: auto;
  padding: 4px 4px 8px;
  min-height: 0;
  display: flex;
  flex-direction: column;
}
.notas-vault::-webkit-scrollbar { width: 8px; }
.notas-vault::-webkit-scrollbar-thumb { background: var(--c-data-border); border-radius: 4px; }

/* Vault toolbar (criar pasta/nota, recolher) */
.notas-vault-toolbar {
  display: flex;
  gap: 6px;
  padding: 10px 10px 8px;
  border-bottom: 1px solid var(--c-data-border);
  position: sticky;
  top: 0;
  background: var(--c-data-card);
  z-index: 2;
  flex-shrink: 0;
}
.notas-vault-btn {
  background: var(--c-data-elevated) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark) !important;
  height: 30px !important;
  padding: 0 12px !important;
  border-radius: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  cursor: pointer !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  font-family: 'Inter', system-ui, sans-serif;
  letter-spacing: 0 !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  flex: 1 1 auto;
  box-shadow: none !important;
  white-space: nowrap;
}
.notas-vault-btn svg { width: 13px; height: 13px; flex-shrink: 0; color: currentColor; }
.notas-vault-btn:hover {
  background: #232323 !important;
  border-color: var(--c-data-border-strong) !important;
  transform: none !important;
}
.notas-vault-btn--icon {
  flex: 0 0 32px !important;
  width: 32px;
  padding: 0 !important;
  color: var(--c-text-on-dark-muted) !important;
}
.notas-vault-btn--icon:hover { color: var(--c-text-on-dark) !important; }
.notas-vault-btn--primary {
  background: var(--c-accent) !important;
  border-color: var(--c-accent) !important;
  color: #ffffff !important;
}
.notas-vault-btn--primary:hover {
  background: var(--c-accent-hover) !important;
  border-color: var(--c-accent-hover) !important;
}
.notas-vault-btn-glyph {
  font-size: 14px;
  font-weight: 700;
  line-height: 1;
  margin-right: -2px;
}
.notas-vault-btn-label {
  font-size: 12.5px;
  font-weight: 600;
}

/* Modal customizado (criar pasta / nota) */
.notas-modal-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100005;
  backdrop-filter: blur(2px);
}
.notas-modal {
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: 12px;
  width: min(440px, 92vw);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
  font-family: 'Inter', system-ui, sans-serif;
  color: #f5f5f5;
}
.notas-modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 18px;
  border-bottom: 1px solid #2a2a2a;
}
.notas-modal-header strong {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.notas-modal-close {
  background: transparent;
  border: 0;
  color: #888888;
  font-size: 20px;
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background-color var(--tr), color var(--tr);
}
.notas-modal-close:hover {
  background: #1f1f1f;
  color: #ffffff;
}
.notas-modal-body {
  padding: 16px 18px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.notas-modal-field { display: flex; flex-direction: column; gap: 4px; }
.notas-modal-field label {
  font-size: 11px;
  font-weight: 600;
  color: var(--c-text-on-dark-muted) !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.notas-modal-field input {
  background: #161616 !important;
  border: 1px solid #2a2a2a !important;
  color: #f5f5f5 !important;
  padding: 9px 12px !important;
  border-radius: 6px !important;
  font-size: 13.5px !important;
  font-family: 'Inter', system-ui, sans-serif;
  outline: none !important;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.notas-modal-field input:focus {
  border-color: var(--c-accent) !important;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.20) !important;
}
.notas-modal-field small {
  color: #888888;
  font-size: 11.5px;
  margin-top: 2px;
  line-height: 1.4;
}
.notas-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 14px 18px;
  border-top: 1px solid #2a2a2a;
  background: #0a0a0a;
  border-radius: 0 0 12px 12px;
}
.notas-modal-btn {
  padding: 8px 16px !important;
  border-radius: 6px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer;
  font-family: 'Inter', system-ui, sans-serif;
  border: 1px solid #2a2a2a !important;
  transition: background-color var(--tr), border-color var(--tr);
}
.notas-modal-btn--ghost {
  background: transparent !important;
  color: #c9c9c9 !important;
}
.notas-modal-btn--ghost:hover {
  background: #1f1f1f !important;
  color: #ffffff !important;
}
.notas-modal-btn--primary {
  background: var(--c-accent) !important;
  color: #ffffff !important;
  border-color: var(--c-accent) !important;
}
.notas-modal-btn--primary:hover {
  background: var(--c-accent-hover) !important;
  border-color: var(--c-accent-hover) !important;
}

.notas-folder-children-tree {
  display: flex;
  flex-direction: column;
}
.notas-folder-menu {
  background: transparent;
  border: 0;
  color: var(--c-text-on-dark-muted);
  padding: 0;
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity var(--tr), background-color var(--tr), color var(--tr);
  height: 22px;
  width: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.notas-folder-menu svg { width: 13px; height: 13px; }
.notas-folder-header:hover .notas-folder-menu { opacity: 0.85; }
.notas-folder-menu:hover {
  background: rgba(255, 255, 255, 0.10);
  color: var(--c-text-on-dark) !important;
  opacity: 1 !important;
}

/* Search bar do Vault */
.notas-vault-search {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 8px;
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: 6px;
  margin: 0 6px 8px;
  position: sticky;
  top: 50px; /* abaixo da toolbar */
  z-index: 1;
}
.notas-vault-search-icon {
  font-size: 12px;
  opacity: 0.6;
  flex-shrink: 0;
}
.notas-vault-search-input {
  flex: 1 1 auto;
  background: transparent !important;
  border: 0 !important;
  color: var(--c-text-on-dark) !important;
  font-size: 12.5px !important;
  padding: 4px 0 !important;
  outline: none !important;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-vault-search-input::placeholder { color: var(--c-text-on-dark-muted); }
.notas-vault-search-input:focus {
  border-color: transparent !important;
  box-shadow: none !important;
}
.notas-vault-search-clear {
  background: transparent;
  border: 0;
  color: var(--c-text-on-dark-muted);
  font-size: 16px;
  cursor: pointer;
  padding: 0 6px;
  border-radius: 3px;
  line-height: 1;
}
.notas-vault-search-clear:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--c-text-on-dark);
}

/* Context menu Obsidian-style */
.notas-ctx-menu {
  position: fixed;
  z-index: 100006;
  background: #161616;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
  padding: 4px;
  min-width: 200px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 12.5px;
  color: #f5f5f5;
}
.notas-ctx-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 80ms ease;
  white-space: nowrap;
}
.notas-ctx-item:hover {
  background: var(--c-accent);
  color: #ffffff;
}
.notas-ctx-item.is-danger { color: #f08080; }
.notas-ctx-item.is-danger:hover { background: #c5443c; color: #ffffff; }
.notas-ctx-icon {
  width: 16px;
  text-align: center;
  flex-shrink: 0;
  font-size: 13px;
}
.notas-ctx-label {
  flex: 1 1 auto;
}
.notas-ctx-shortcut {
  font-size: 10.5px;
  color: var(--c-text-on-dark-muted);
  margin-left: 18px;
}
.notas-ctx-item:hover .notas-ctx-shortcut { color: rgba(255,255,255,0.7); }
.notas-ctx-divider {
  height: 1px;
  background: #2a2a2a;
  margin: 4px 0;
}

/* Inline rename input */
.notas-inline-rename {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-accent) !important;
  color: var(--c-text-on-dark) !important;
  padding: 1px 6px !important;
  border-radius: 3px !important;
  font-size: 12.5px !important;
  font-family: inherit !important;
  outline: none !important;
  box-shadow: 0 0 0 2px rgba(0, 102, 255, 0.25) !important;
  flex: 1 1 auto;
  min-width: 80px;
}

/* Drag-drop visual feedback */
.notas-folder-header.is-drop-hover {
  background: var(--c-accent-soft) !important;
  outline: 1px dashed var(--c-accent);
  outline-offset: -2px;
}
.notas-item[draggable="true"] {
  cursor: grab;
}
.notas-item[draggable="true"]:active {
  cursor: grabbing;
  opacity: 0.6;
}

.notas-folder { margin-bottom: 4px; }
.notas-folder-header {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 5px 8px 5px 8px;
  margin: 1px 4px;
  cursor: pointer;
  border-radius: var(--r);
  color: var(--c-text-on-dark-soft);
  user-select: none;
  transition: background-color var(--tr);
}
.notas-folder-header:hover {
  background: var(--c-data-elevated);
  color: var(--c-text-on-dark);
}
.notas-folder-chevron {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--c-text-on-dark-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.notas-folder-chevron svg { width: 12px; height: 12px; }
.notas-folder-icon {
  width: 16px;
  height: 16px;
  color: var(--c-text-on-dark-soft);
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.notas-folder-icon svg { width: 14px; height: 14px; }
.notas-folder-header:hover .notas-folder-icon { color: var(--c-accent); }
.notas-folder-name {
  flex: 1 1 auto;
  font-weight: 600;
  font-size: 12.5px;
  letter-spacing: 0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-folder-count {
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: 999px;
  padding: 1px 8px;
  font-size: 10.5px;
  font-weight: 600;
  color: var(--c-text-on-dark-muted);
  min-width: 22px;
  text-align: center;
  font-variant-numeric: tabular-nums;
}
.notas-folder-children {
  padding-left: 12px;
}
.notas-folder--trash .notas-folder-icon { color: var(--c-text-on-dark-muted); }

.notas-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 4px 8px;
  margin: 1px 4px;
  border-radius: var(--r);
  cursor: pointer;
  color: var(--c-text-on-dark-soft);
  transition: background-color var(--tr), color var(--tr);
  position: relative;
  min-height: 26px;
}
.notas-item:hover {
  background: var(--c-data-elevated);
  color: var(--c-text-on-dark);
}
.notas-item.is-selected {
  background: var(--c-accent-soft);
  color: var(--c-accent);
  font-weight: 500;
}
.notas-item-icon {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  color: var(--c-text-on-dark-muted);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.notas-item-icon svg { width: 13px; height: 13px; }
.notas-item.is-selected .notas-item-icon { color: var(--c-accent); }
.notas-item-title {
  flex: 1 1 auto;
  font-size: 12.5px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-item-meta {
  font-size: 10.5px;
  color: var(--c-text-on-dark-muted);
  margin-right: 4px;
  flex-shrink: 0;
}
.notas-item-menu {
  background: transparent;
  border: 0;
  color: var(--c-text-on-dark-muted);
  padding: 0;
  width: 22px;
  height: 22px;
  border-radius: 4px;
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity var(--tr), background-color var(--tr), color var(--tr);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.notas-item-menu svg { width: 13px; height: 13px; }
.notas-item:hover .notas-item-menu { opacity: 0.85; }
.notas-item-menu:hover {
  background: rgba(255, 255, 255, 0.10);
  color: var(--c-text-on-dark);
  opacity: 1 !important;
}
.notas-item-action {
  background: transparent;
  border: 0;
  color: var(--c-text-on-dark-muted);
  padding: 4px;
  border-radius: 4px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background-color var(--tr), color var(--tr);
}
.notas-item-action svg { width: 13px; height: 13px; }
.notas-item-action:hover { background: var(--c-data-elevated); color: var(--c-text-on-dark); }
.notas-item-action--danger:hover { color: var(--c-danger); background: rgba(230, 0, 35, 0.10); }
.notas-item--trashed .notas-item-title { color: var(--c-text-on-dark-muted); text-decoration: line-through; }

.notas-trash-empty {
  width: calc(100% - 8px);
  margin: 8px 4px 4px;
  padding: 6px 10px;
  background: rgba(230, 0, 35, 0.06);
  border: 1px solid rgba(230, 0, 35, 0.20);
  color: var(--c-danger);
  border-radius: var(--r);
  font-size: 11.5px;
  font-weight: 600;
  cursor: pointer;
  transition: background-color var(--tr);
}
.notas-trash-empty:hover { background: rgba(230, 0, 35, 0.12); }

/* Main content area (legacy padding overridden quando editor inline ativo) */
.notas-content {
  background: var(--c-data-card);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r-lg);
  overflow: hidden;
  min-height: 0;
}

.notas-welcome {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  flex: 1 1 auto;
  height: 100%;
  text-align: center;
  padding: 48px 24px;
  gap: 8px;
  background: var(--c-data-bg);
}
.notas-welcome-icon {
  width: 64px;
  height: 64px;
  border-radius: 50%;
  background: var(--c-accent-soft);
  border: 1px solid rgba(0, 102, 255, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--c-accent);
  margin-bottom: 12px;
}
.notas-welcome-icon svg { width: 28px; height: 28px; }
.notas-welcome h2 {
  font-size: 20px !important;
  font-weight: 700 !important;
  letter-spacing: -0.02em !important;
  color: var(--c-text-on-dark) !important;
  margin: 0 !important;
}
.notas-welcome p {
  color: var(--c-text-on-dark-soft);
  font-size: 13.5px;
  margin: 0 0 20px;
  max-width: 380px;
}
.notas-welcome-tips {
  display: grid;
  gap: 6px;
  max-width: 420px;
  width: 100%;
}
.notas-welcome-tips > div {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  font-size: 12.5px;
  color: var(--c-text-on-dark-soft);
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r);
  padding: 8px 12px;
  text-align: left;
}
.notas-welcome-tips > div span:not([class]) {
  color: var(--c-text-on-dark);
}
.notas-welcome-tips kbd {
  background: var(--c-data-elevated);
  border: 1px solid var(--c-data-border-strong);
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 2px 7px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  color: var(--c-text-on-dark);
  margin-right: 4px;
  display: inline-block;
  min-width: 20px;
  text-align: center;
}

/* =========================================================================
   EDITOR INLINE (estilo Obsidian) — substitui o viewer
   ========================================================================= */
.notas-content {
  padding: 0 !important;
  display: flex;
  flex-direction: column;
}

/* === Editor com TEMA CLARO (estilo Obsidian) === */
.notas-content { background: #ffffff !important; border-color: #e5e5e5 !important; }

/* === TABS BAR === */
.notas-tabs-bar {
  display: flex;
  align-items: center;
  gap: 2px;
  padding: 4px 6px 0;
  background: #f4f3ef;
  border-bottom: 1px solid #e5e5e5;
  overflow-x: auto;
  scrollbar-width: none;
  flex-shrink: 0;
}
.notas-tabs-bar::-webkit-scrollbar { display: none; }

.notas-tab {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px 6px 12px;
  background: #e8e7e2;
  border: 1px solid transparent;
  border-bottom: 0;
  border-top-left-radius: 6px;
  border-top-right-radius: 6px;
  cursor: pointer;
  max-width: 200px;
  min-width: 80px;
  font-size: 12.5px;
  font-weight: 500;
  color: #6e6e6e;
  position: relative;
  bottom: -1px;
  transition: background-color 80ms ease, color 80ms ease;
}
.notas-tab:hover {
  background: #efeeea;
  color: #2c2c2c;
}
.notas-tab.is-active {
  background: #ffffff;
  color: #0a0a0a;
  font-weight: 600;
  border-color: #e5e5e5;
  border-bottom-color: #ffffff;
  z-index: 1;
}
.notas-tab.is-pinned {
  background: linear-gradient(180deg, rgba(255, 176, 0, 0.10), transparent);
}
.notas-tab.is-pinned.is-active {
  background: #ffffff;
}
.notas-tab-pin-icon {
  width: 11px;
  height: 11px;
  color: #ffb000;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
}
.notas-tab-pin-icon svg { width: 11px; height: 11px; }
.notas-tab-title {
  flex: 1 1 auto;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-tab-close {
  background: transparent;
  border: 0;
  color: #888888;
  width: 18px;
  height: 18px;
  border-radius: 3px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  opacity: 0.55;
  margin-left: 2px;
  transition: opacity 80ms ease, background-color 80ms ease, color 80ms ease;
}
.notas-tab-close svg { width: 11px; height: 11px; pointer-events: none; }
.notas-tab.is-active .notas-tab-close { opacity: 0.95; }
.notas-tab:hover .notas-tab-close { opacity: 1; }
.notas-tab-close:hover {
  background: rgba(0, 0, 0, 0.12);
  color: #0a0a0a;
  opacity: 1 !important;
}

/* === EDITOR FRAME (editor + right panel side-by-side) === */
.notas-editor-frame {
  flex: 1 1 auto;
  display: grid;
  min-height: 0;
}
.notas-editor-shell.has-right-panel .notas-editor-frame {
  grid-template-columns: 1fr 240px;
}
.notas-editor-shell:not(.has-right-panel) .notas-editor-frame {
  grid-template-columns: 1fr;
}
.notas-editor-shell.has-right-panel .notas-right-panel {
  display: flex;
}
.notas-editor-shell:not(.has-right-panel) .notas-right-panel { display: none; }

/* === RIGHT PANEL (Outline / Backlinks / Tags) === */
.notas-right-panel {
  background: #fafafa;
  border-left: 1px solid #e5e5e5;
  display: flex;
  flex-direction: column;
  min-height: 0;
  overflow: hidden;
}
.notas-right-tabs {
  display: flex;
  border-bottom: 1px solid #e5e5e5;
  background: #f0f0f0;
  flex-shrink: 0;
}
.notas-right-tab {
  flex: 1 1 auto;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  padding: 8px 6px;
  font-size: 11.5px;
  font-weight: 600;
  color: #6e6e6e;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  transition: color 80ms ease, border-color 80ms ease, background-color 80ms ease;
}
.notas-right-tab svg { width: 12px; height: 12px; }
.notas-right-tab:hover { color: #0a0a0a; }
.notas-right-tab.is-active {
  color: var(--c-accent);
  border-bottom-color: var(--c-accent);
  background: #ffffff;
}
.notas-right-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: 10px 8px;
}
.notas-right-body::-webkit-scrollbar { width: 6px; }
.notas-right-body::-webkit-scrollbar-thumb { background: #d4d4d4; border-radius: 3px; }
.notas-right-empty,
.notas-right-loading {
  padding: 24px 12px;
  text-align: center;
  color: #888888;
  font-size: 12px;
  line-height: 1.5;
}
.notas-right-empty code {
  background: #f4f3ef;
  border: 1px solid #e5e5e5;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 11px;
  color: var(--c-accent);
}

/* Outline list */
.notas-outline {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 12.5px;
}
.notas-outline-item {
  margin: 2px 0;
}
.notas-outline-item a {
  display: block;
  padding: 4px 8px;
  color: #2c2c2c;
  text-decoration: none;
  border-radius: 4px;
  border-left: 2px solid transparent;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  transition: background-color 80ms ease, color 80ms ease;
}
.notas-outline-item a:hover {
  background: #efeeea;
  color: #0a0a0a;
}
.notas-outline-item[data-level="1"] a { font-weight: 600; padding-left: 8px; }
.notas-outline-item[data-level="2"] a { padding-left: 18px; }
.notas-outline-item[data-level="3"] a { padding-left: 28px; font-size: 12px; color: #4a4a4a; }
.notas-outline-item[data-level="4"] a { padding-left: 38px; font-size: 11.5px; color: #6e6e6e; }
.notas-outline-item[data-level="5"] a,
.notas-outline-item[data-level="6"] a { padding-left: 48px; font-size: 11px; color: #888888; }

/* Tags pane */
.notas-tags-pane {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
}
.notas-tag-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 999px;
  font-size: 11.5px;
  color: #4a4a4a;
  cursor: pointer;
  transition: background-color 80ms ease, border-color 80ms ease, color 80ms ease;
}
.notas-tag-pill:hover {
  background: #f0f0f0;
  border-color: #d4d4d4;
  color: #0a0a0a;
}
.notas-tag-pill.is-active {
  background: var(--c-accent-soft);
  border-color: rgba(0, 102, 255, 0.30);
  color: var(--c-accent);
  font-weight: 600;
}
.notas-tag-name { font-weight: 500; }
.notas-tag-count {
  background: #efeeea;
  color: #6e6e6e;
  border-radius: 999px;
  padding: 0 6px;
  font-size: 10.5px;
  font-weight: 600;
}
.notas-tag-pill.is-active .notas-tag-count {
  background: rgba(0, 102, 255, 0.15);
  color: var(--c-accent);
}
.notas-tag-clear {
  width: 100%;
  margin-top: 8px;
  padding: 6px 8px;
  background: #f0f0f0;
  border: 1px solid #e5e5e5;
  border-radius: 4px;
  font-size: 11.5px;
  font-weight: 500;
  color: #6e6e6e;
  cursor: pointer;
  text-align: center;
}
.notas-tag-clear:hover { background: #e5e5e5; color: #0a0a0a; }

/* Tag inline (no preview) */
.notas-tag-inline {
  display: inline-block;
  background: var(--c-accent-soft);
  color: var(--c-accent) !important;
  padding: 0px 6px;
  border-radius: 999px;
  font-size: 0.85em;
  font-weight: 500;
  text-decoration: none !important;
  border: 1px solid rgba(0, 102, 255, 0.20);
  margin: 0 1px;
  cursor: pointer;
  transition: background-color 80ms ease, border-color 80ms ease;
}
.notas-tag-inline:hover {
  background: rgba(0, 102, 255, 0.18);
  border-color: rgba(0, 102, 255, 0.45);
}

/* Indicador de filtro ativo no Vault */
.notas-filter-active {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin: 6px;
  padding: 6px 10px;
  background: rgba(0, 102, 255, 0.08);
  border: 1px solid rgba(0, 102, 255, 0.25);
  border-radius: 5px;
  font-size: 11.5px;
  color: var(--c-accent);
}
.notas-filter-active strong { font-weight: 700; }
.notas-filter-active button {
  background: transparent;
  border: 0;
  color: var(--c-accent);
  font-size: 14px;
  cursor: pointer;
  width: 18px;
  height: 18px;
  border-radius: 3px;
}
.notas-filter-active button:hover { background: rgba(0, 102, 255, 0.20); }

/* Backlinks panel (lateral direita) */
.notas-backlinks-panel {
  list-style: none;
  margin: 0;
  padding: 0;
}
.notas-backlinks-panel-item {
  padding: 8px 10px;
  border-bottom: 1px solid #efeeea;
  cursor: pointer;
  transition: background-color 80ms ease;
}
.notas-backlinks-panel-item:hover { background: #f0f0f0; }
.notas-backlinks-panel-title {
  font-size: 12.5px;
  font-weight: 500;
  color: #0a0a0a;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-backlinks-panel-folder {
  font-size: 10.5px;
  color: #888888;
}

/* === HEADER nav buttons (back/forward) === */
.notas-editor-nav {
  display: inline-flex;
  gap: 2px;
  margin-right: 4px;
}
.notas-editor-nav .notas-editor-icon-btn {
  color: #4a4a4a;
}
.notas-editor-nav .notas-editor-icon-btn[disabled] {
  opacity: 0.35;
  cursor: not-allowed;
}
.notas-editor-pin-flag {
  display: inline-flex;
  align-items: center;
  color: #ffb000;
  margin-left: 4px;
}
.notas-editor-pin-flag svg { width: 12px; height: 12px; }
.notas-editor-icon-btn.is-active {
  background: rgba(255, 176, 0, 0.10);
  color: #ffb000;
  border-color: rgba(255, 176, 0, 0.30);
}

/* === MODO FOCO === */
.notas-editor-shell.is-focus .notas-tabs-bar,
.notas-editor-shell.is-focus .notas-editor-toolbar,
.notas-editor-shell.is-focus .notas-right-panel,
.notas-editor-shell.is-focus .notas-editor-statusbar { display: none !important; }
.notas-editor-shell.is-focus .notas-editor-frame { grid-template-columns: 1fr !important; }
.notas-editor-shell.is-focus .notas-editor-textarea {
  font-size: 17px !important;
  padding: 60px max(80px, 10vw) !important;
  line-height: 1.85 !important;
  border-right: 0 !important;
}
.notas-editor-shell.is-focus .notas-editor-preview {
  padding: 60px max(80px, 10vw) !important;
}

/* === EMBEDS ![[]] === */
.notas-embed {
  background: #fafafa;
  border: 1px solid #e5e5e5;
  border-left: 3px solid var(--c-accent);
  border-radius: 6px;
  margin: 1.2em 0;
  overflow: hidden;
}
.notas-embed.is-broken {
  border-left-color: var(--c-danger);
  background: #fdf3f3;
  padding: 10px 14px;
  color: var(--c-danger);
  font-size: 12.5px;
}
.notas-embed-head {
  padding: 6px 14px;
  background: #f4f3ef;
  border-bottom: 1px solid #e5e5e5;
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 600;
  color: #4a4a4a;
}
.notas-embed-icon { font-size: 13px; opacity: 0.6; }
.notas-embed-title {
  color: var(--c-accent) !important;
  text-decoration: none !important;
}
.notas-embed-title:hover { text-decoration: underline !important; }
.notas-embed-body {
  padding: 14px 18px;
  font-size: 14px;
  line-height: 1.65;
  color: #2c2c2c;
}
.notas-embed-body > *:first-child { margin-top: 0; }
.notas-embed-body > *:last-child { margin-bottom: 0; }
.notas-embed-body h1, .notas-embed-body h2, .notas-embed-body h3 {
  font-size: 1em !important;
  margin: 0.5em 0 !important;
  border-bottom: 0 !important;
  padding-bottom: 0 !important;
}

/* === FRONTMATTER (properties bar) === */
.notas-fm-bar {
  background: #fafafa;
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  padding: 10px 14px;
  margin: 0 0 1.2em;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-size: 12.5px;
}
.notas-fm-field {
  display: flex;
  gap: 12px;
  align-items: baseline;
}
.notas-fm-key {
  flex: 0 0 90px;
  color: #888888;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 10.5px;
  letter-spacing: 0.06em;
}
.notas-fm-value {
  flex: 1 1 auto;
  color: #2c2c2c;
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.notas-fm-tag {
  display: inline-block;
  background: var(--c-accent-soft);
  color: var(--c-accent);
  padding: 1px 8px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 500;
  border: 1px solid rgba(0, 102, 255, 0.20);
}

/* Status bar — botão random + word goal */
.notas-editor-stat-btn {
  background: transparent;
  border: 1px solid #d4d4d4;
  color: #4a4a4a;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: 11px;
  cursor: pointer;
  font-family: inherit;
  transition: background-color 80ms ease, border-color 80ms ease;
}
.notas-editor-stat-btn:hover {
  background: #efeeea;
  border-color: #888888;
}
.notas-editor-stat--goal {
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 3px;
  transition: background-color 80ms ease;
}
.notas-editor-stat--goal:hover {
  background: #efeeea;
}
.notas-editor-stat--goal.is-met {
  color: var(--c-success);
  font-weight: 600;
}

.notas-editor-shell {
  display: flex;
  flex-direction: column;
  height: 100%;
  flex: 1 1 auto;
  min-height: 0;
  background: #ffffff;
}

.notas-editor-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid #e5e5e5 !important;
  background: #fafafa !important;
  flex-shrink: 0;
  min-height: 50px;
}
.notas-editor-actions {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}
.notas-editor-breadcrumb {
  flex: 1 1 auto;
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}
.notas-editor-breadcrumb > span:first-child {
  color: #888888 !important;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
  max-width: 240px;
}
.notas-editor-sep {
  color: #c0c0c0;
  font-size: 12px;
}
.notas-editor-title {
  color: #0a0a0a !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  margin: 0 !important;
  letter-spacing: -0.015em !important;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  cursor: text;
  padding: 2px 6px;
  border-radius: 4px;
  transition: background-color var(--tr);
}
.notas-editor-title:hover {
  background: #efefef;
}

.notas-editor-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.notas-editor-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 500;
  padding: 3px 10px;
  border-radius: 999px;
  background: #ffffff;
  color: #6e6e6e;
  border: 1px solid #e5e5e5;
}
.notas-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #1ea566;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(30, 165, 102, 0.18);
  transition: background var(--tr), box-shadow var(--tr);
}
.notas-editor-status[data-status="saved"] {
  color: #1ea566;
  background: #e6f7ee;
  border-color: #d6f1e3;
}
.notas-editor-status[data-status="saved"] .notas-status-dot {
  background: #1ea566;
  box-shadow: 0 0 0 2px rgba(30, 165, 102, 0.18);
}
.notas-editor-status[data-status="dirty"] {
  color: #c98014;
  background: #fdf6e8;
  border-color: rgba(255, 149, 0, 0.25);
}
.notas-editor-status[data-status="dirty"] .notas-status-dot {
  background: #f39c12;
  box-shadow: 0 0 0 2px rgba(243, 156, 18, 0.22);
  animation: notas-pulse 1.4s ease-in-out infinite;
}
.notas-editor-status[data-status="saving"] {
  color: #5e6cff;
  background: #eff1ff;
  border-color: #d8defb;
}
.notas-editor-status[data-status="saving"] .notas-status-dot {
  background: #5e6cff;
  box-shadow: 0 0 0 2px rgba(94, 108, 255, 0.18);
  animation: notas-pulse 0.9s ease-in-out infinite;
}
.notas-editor-status[data-status="error"] {
  color: #c5443c;
  background: #fdf3f3;
  border-color: rgba(230, 0, 35, 0.25);
}
.notas-editor-status[data-status="error"] .notas-status-dot {
  background: #c5443c;
  box-shadow: 0 0 0 2px rgba(197, 68, 60, 0.18);
}
@keyframes notas-pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.85); }
}
.notas-editor-modes {
  display: inline-flex;
  background: #f0f0f0;
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  padding: 2px;
  margin-left: 4px;
  flex-shrink: 0;
}
.notas-editor-modes[hidden] {
  display: none !important;
}
.notas-editor-mode {
  background: transparent;
  border: 0;
  color: #4a4a4a !important;
  width: 30px;
  height: 26px;
  border-radius: 4px;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  transition: background-color var(--tr), color var(--tr);
  padding: 0;
}
.notas-editor-mode svg { width: 14px !important; height: 14px !important; display: block; flex-shrink: 0; }
.notas-editor-mode:hover { color: #0a0a0a !important; background: rgba(0,0,0,0.06); }
.notas-editor-mode.is-active {
  background: #ffffff;
  color: var(--c-accent) !important;
  box-shadow: 0 0 0 1px #d4d4d4, 0 1px 1px rgba(0,0,0,0.04);
}
.notas-editor-icon-btn {
  background: transparent;
  border: 1px solid transparent;
  color: #4a4a4a !important;
  width: 30px;
  height: 30px;
  border-radius: 6px;
  cursor: pointer;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  transition: background-color var(--tr), color var(--tr), border-color var(--tr);
  padding: 0;
  flex-shrink: 0;
}
.notas-editor-icon-btn svg { width: 14px !important; height: 14px !important; display: block; flex-shrink: 0; }
.notas-editor-icon-btn:hover {
  background: rgba(0, 0, 0, 0.06);
  color: #0a0a0a !important;
  border-color: rgba(0, 0, 0, 0.10);
}
.notas-editor-icon-btn--danger:hover {
  background: rgba(230, 0, 35, 0.10);
  color: var(--c-danger) !important;
  border-color: rgba(230, 0, 35, 0.25);
}
.notas-editor-icon-btn[disabled] {
  opacity: 0.30;
  cursor: not-allowed;
}
.notas-editor-icon-btn[disabled]:hover {
  background: transparent !important;
  color: #4a4a4a !important;
  border-color: transparent !important;
}

/* === Toolbar de formatação === */
.notas-editor-toolbar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  background: #ffffff;
  border-bottom: 1px solid #e5e5e5;
  flex-shrink: 0;
  flex-wrap: wrap;
}
.notas-tb-group { display: inline-flex; gap: 1px; }
.notas-tb-sep {
  width: 1px;
  height: 20px;
  background: #e5e5e5;
  margin: 0 4px;
}
.notas-tb-btn {
  background: transparent;
  border: 1px solid transparent;
  color: #4a4a4a;
  width: 30px;
  height: 28px;
  box-sizing: border-box;
  padding: 0 !important;
  border-radius: 5px;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 30px;
  gap: 0;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  transition: background-color var(--tr), color var(--tr);
}
/* Regra antiga removida (forçava fill: currentColor e stroke-width: 0,
   o que tornava os ícones SVG mono-line invisíveis).
   SVGs agora usam style inline e CSS específica em .notas-editor-toolbar abaixo. */
.notas-tb-btn:hover {
  background: #f0f0f0;
  color: #0a0a0a;
}
.notas-tb-btn:active { background: #e5e5e5; }
.notas-tb-btn.is-active {
  background: #dbeafe !important;
  color: #1e3a8a !important;
  font-weight: 700;
}
.notas-tb-btn.is-active:hover { background: #bfdbfe !important; }

/* Obsidian-style: SVG mono-line + dropdowns
   Sobrescreve regras antigas que zeravam stroke-width e enchiam com fill */
.notas-editor-toolbar .notas-tb-btn svg {
  width: 16px !important;
  height: 16px !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
  display: block;
  color: #4a4a4a;
}
.notas-editor-toolbar .notas-tb-btn:hover svg { color: #0a0a0a; }
.notas-editor-toolbar .notas-tb-btn.is-active svg { color: #1e3a8a; }
.notas-editor-toolbar .notas-tb-btn svg [fill="none"] { fill: none !important; }
.notas-editor-toolbar .notas-tb-btn svg [stroke] { stroke: currentColor !important; }
/* Reseta o "stroke-width: 0" da regra global pra elementos filhos do path */
.notas-editor-toolbar .notas-tb-btn svg path,
.notas-editor-toolbar .notas-tb-btn svg line,
.notas-editor-toolbar .notas-tb-btn svg circle,
.notas-editor-toolbar .notas-tb-btn svg rect,
.notas-editor-toolbar .notas-tb-btn svg polyline,
.notas-editor-toolbar .notas-tb-btn svg polygon {
  stroke-width: inherit !important;
}
.notas-editor-toolbar .notas-tb-btn--dropdown {
  width: auto !important;
  min-width: 36px;
  flex-basis: auto;
  padding: 0 4px 0 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 2px;
}
.notas-editor-toolbar .notas-tb-arrow {
  font-size: 8px;
  opacity: 0.55;
}
.notas-editor-toolbar .notas-tb-btn--dropdown:hover .notas-tb-arrow { opacity: 1; }
.notas-tb-dropdown {
  position: fixed;
  z-index: 100013;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18), 0 2px 8px rgba(0, 0, 0, 0.08);
  padding: 4px;
  min-width: 200px;
  max-width: 260px;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-tb-dd-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 6px 10px;
  border: 0;
  background: transparent;
  color: #1a1a1a;
  font-family: inherit;
  font-size: 13px;
  cursor: pointer;
  border-radius: 4px;
  text-align: left;
}
.notas-tb-dd-item:hover { background: #f4f4f4; }
.notas-tb-dd-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #444;
}
.notas-tb-dd-color-swatch {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 13px;
  border-radius: 4px;
  background: #ffffff;
}
.notas-tb-dd-divider {
  height: 1px;
  background: #ececec;
  margin: 4px 0;
}

.notas-tb-btn--text {
  font-size: 12px;
  letter-spacing: -0.01em;
  color: #4a4a4a;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  font-weight: 600;
  min-width: 30px;
  padding: 0 6px;
  width: auto;
}
.notas-tb-btn--glyph {
  font-size: 15px;
  line-height: 1;
  color: #4a4a4a;
  font-weight: 500;
}
.notas-tb-hl {
  background: #fff2a8;
  color: #0a0a0a;
  padding: 0 3px;
  border-radius: 2px;
  font-size: 10.5px;
  font-weight: 700;
}

/* Body do editor: textarea + preview lado-a-lado */
.notas-editor-body {
  flex: 1 1 auto;
  display: grid;
  min-height: 0;
  background: #ffffff;
  overflow: hidden;
}
.notas-editor-shell[data-mode="split"] .notas-editor-body {
  grid-template-columns: 1fr 1fr;
}
.notas-editor-shell[data-mode="edit"] .notas-editor-body {
  grid-template-columns: 1fr;
}
.notas-editor-shell[data-mode="edit"] .notas-editor-preview { display: none; }
.notas-editor-shell[data-mode="read"] .notas-editor-body {
  grid-template-columns: 1fr;
}
.notas-editor-shell[data-mode="read"] .notas-editor-textarea { display: none; }

.notas-editor-textarea {
  background: #fbfbf8 !important;
  border: 0 !important;
  outline: none !important;
  color: #2c2c2c !important;
  font-family: 'Inter', system-ui, sans-serif !important;
  font-size: 15px !important;
  line-height: 1.7 !important;
  padding: 28px 36px 60px !important;
  resize: none !important;
  width: 100%;
  height: 100%;
  border-right: 1px solid #e5e5e5 !important;
  tab-size: 2;
  -moz-tab-size: 2;
  caret-color: var(--c-accent);
  overflow-y: auto;
}
.notas-editor-shell[data-mode="edit"] .notas-editor-textarea {
  border-right: 0 !important;
}
.notas-editor-textarea::placeholder {
  color: #a0a0a0;
  font-style: italic;
}
.notas-editor-textarea:focus {
  border-right-color: #e5e5e5 !important;
  box-shadow: none !important;
}
.notas-editor-textarea::-webkit-scrollbar { width: 10px; }
.notas-editor-textarea::-webkit-scrollbar-thumb { background: #d4d4d4; border-radius: 5px; }

.notas-editor-preview {
  overflow-y: auto;
  padding: 28px 40px 60px;
  background: #ffffff;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 15.5px;
  line-height: 1.78;
  color: #2c2c2c;
}
.notas-editor-preview::-webkit-scrollbar { width: 10px; }
.notas-editor-preview::-webkit-scrollbar-thumb { background: #d4d4d4; border-radius: 5px; }

.notas-preview-empty {
  color: #a0a0a0;
  font-style: italic;
  font-size: 13.5px;
  margin: 0;
}

/* Markdown rendering dentro do preview do editor (TEMA LIGHT) */
.notas-editor-preview .notas-md h1,
.notas-editor-preview .notas-md h2,
.notas-editor-preview .notas-md h3,
.notas-editor-preview .notas-md h4,
.notas-editor-preview .notas-md h5,
.notas-editor-preview .notas-md h6 {
  color: #0a0a0a !important;
  font-family: 'Inter', system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: -0.022em;
  line-height: 1.3;
  border-bottom: none !important;
}
.notas-editor-preview .notas-md h1 { font-size: 2em; margin: 0.6em 0 0.5em; padding-bottom: 0.28em; border-bottom: 1px solid #e5e5e5 !important; }
.notas-editor-preview .notas-md h2 { font-size: 1.55em; margin: 1.4em 0 0.5em; padding-bottom: 0.22em; border-bottom: 1px solid #e5e5e5 !important; }
.notas-editor-preview .notas-md h3 { font-size: 1.28em; margin: 1.3em 0 0.4em; }
.notas-editor-preview .notas-md p { color: #2c2c2c !important; margin: 0 0 1.05em; }
.notas-editor-preview .notas-md strong { color: #0a0a0a !important; font-weight: 700; }
.notas-editor-preview .notas-md em { color: #2c2c2c !important; font-style: italic; }
.notas-editor-preview .notas-md a { color: #5d6ad2 !important; text-decoration: none; border-bottom: 1px solid rgba(93, 106, 210, 0.30); }
.notas-editor-preview .notas-md a:hover { border-bottom-color: #5d6ad2; }
.notas-editor-preview .notas-md ul, .notas-editor-preview .notas-md ol { margin: 0 0 1em; padding-left: 1.6em; }
.notas-editor-preview .notas-md ul { list-style: disc outside; }
.notas-editor-preview .notas-md ul ul { list-style: circle outside; }
.notas-editor-preview .notas-md ul ul ul { list-style: square outside; }
.notas-editor-preview .notas-md ol { list-style: decimal outside; }
.notas-editor-preview .notas-md ol ol { list-style: lower-alpha outside; }
.notas-editor-preview .notas-md ol ol ol { list-style: lower-roman outside; }
.notas-editor-preview .notas-md li { margin: 0.25em 0; }
.notas-editor-preview .notas-md li::marker { color: #5d6ad2; }
.notas-editor-preview .notas-md code {
  background: #f4f3ef !important;
  color: #b03864 !important;
  padding: 0.15em 0.4em;
  border-radius: 4px;
  border: 1px solid #e5e5e5 !important;
  font-family: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  font-size: 0.88em;
}
.notas-editor-preview .notas-md pre {
  background: #f4f3ef !important;
  border: 1px solid #e5e5e5 !important;
  border-radius: 8px;
  padding: 14px 16px;
  overflow-x: auto;
  margin: 1.2em 0;
}
.notas-editor-preview .notas-md pre code {
  background: transparent !important;
  border: 0 !important;
  padding: 0 !important;
  color: #2c2c2c !important;
}
.notas-editor-preview .notas-md blockquote {
  border-left: 3px solid #d4d4d4;
  padding: 0.4em 0 0.4em 1em;
  color: #6e6e6e !important;
  font-style: italic;
  margin: 1.2em 0;
}
.notas-editor-preview .notas-md hr { border: 0; border-top: 1px solid #e5e5e5; margin: 1.8em 0; }
.notas-editor-preview .notas-md table {
  border-collapse: collapse;
  width: 100%;
  font-size: 0.95em;
  margin: 1.2em 0;
  border: 1px solid #e5e5e5 !important;
  border-radius: 6px;
  overflow: hidden;
  background: #ffffff !important;
}
.notas-editor-preview .notas-md th,
.notas-editor-preview .notas-md td {
  padding: 8px 12px !important;
  border: 1px solid #e5e5e5 !important;
  text-align: left;
  background: #ffffff !important;
  color: #2c2c2c !important;
  vertical-align: top;
}
.notas-editor-preview .notas-md thead th {
  background: #f4f4f4 !important;
  font-weight: 600 !important;
  color: #0a0a0a !important;
  text-transform: none;
  letter-spacing: 0;
  font-size: 0.96em;
}
.notas-editor-preview .notas-md tbody tr:nth-child(even) td { background: #fafafa !important; }
.notas-editor-preview .notas-md tbody tr:hover td,
.notas-editor-preview .notas-md tbody tr:hover th {
  background: #eef4ff !important;
  color: #0a0a0a !important;
}
.notas-editor-preview .notas-md tbody tr td strong,
.notas-editor-preview .notas-md tbody tr td em,
.notas-editor-preview .notas-md tbody tr td span,
.notas-editor-preview .notas-md tbody tr td a,
.notas-editor-preview .notas-md tbody tr td p { color: inherit !important; }
.notas-editor-preview .notas-md mark { background: #fff2a8; color: #0a0a0a; padding: 0.05em 0.25em; border-radius: 3px; }
.notas-editor-preview .notas-md img { max-width: 100%; border-radius: 6px; border: 1px solid #e5e5e5; margin: 1em 0; }

/* Mermaid no preview light */
.notas-mermaid {
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  padding: 18px;
  margin: 1.4em 0;
  text-align: center;
  overflow-x: auto;
}
.notas-mermaid svg {
  max-width: 100%;
  height: auto;
  font-family: 'Inter', system-ui, sans-serif !important;
}
/* Não sobrescrever fill/stroke dos nodes/edges do Mermaid (deixa as cores do tema apareceram) */
.notas-mermaid svg .node rect,
.notas-mermaid svg .node circle,
.notas-mermaid svg .node ellipse,
.notas-mermaid svg .node polygon,
.notas-mermaid svg .node path { stroke-width: 1.5px; }
.notas-mermaid svg .nodeLabel,
.notas-mermaid svg .edgeLabel,
.notas-mermaid svg .label,
.notas-mermaid svg foreignObject div { color: #1a1a1a !important; font-family: inherit !important; }
.notas-mermaid svg .edgeLabel rect,
.notas-mermaid svg .edgeLabel foreignObject { background-color: #ffffff !important; }
.notas-mermaid svg .cluster rect { stroke-dasharray: 4 3; }
.notas-mermaid svg .marker { fill: #5d6ad2 !important; stroke: #5d6ad2 !important; }
.notas-mermaid-error { color: #c5443c; font-family: monospace; font-size: 12.5px; }

/* Callouts */
.notas-callout {
  margin: 1.2em 0;
  padding: 12px 16px;
  border-radius: 6px;
  border-left: 3px solid #5d6ad2;
  background: #f4f5fc;
  color: #2c2c2c;
}
.notas-callout > *:last-child { margin-bottom: 0; }
.notas-callout-title {
  font-weight: 700;
  color: #5d6ad2;
  margin-bottom: 6px;
  font-size: 0.96em;
}
.notas-callout--dica, .notas-callout--tip { border-left-color: #c98014; background: #fdf6e8; }
.notas-callout--dica .notas-callout-title, .notas-callout--tip .notas-callout-title { color: #a96510; }
.notas-callout--atencao, .notas-callout--warning, .notas-callout--aviso { border-left-color: #c5443c; background: #fdf0ee; }
.notas-callout--atencao .notas-callout-title, .notas-callout--warning .notas-callout-title, .notas-callout--aviso .notas-callout-title { color: #a3322a; }
.notas-callout--importante { border-left-color: #b03864; background: #fbeff4; }
.notas-callout--importante .notas-callout-title { color: #93304f; }
.notas-callout--exemplo { border-left-color: #7c3aed; background: #f4f0fc; }
.notas-callout--exemplo .notas-callout-title { color: #6925cc; }
.notas-callout--resumo, .notas-callout--success, .notas-callout--sucesso { border-left-color: #1ea566; background: #e6f7ee; }
.notas-callout--resumo .notas-callout-title, .notas-callout--success .notas-callout-title, .notas-callout--sucesso .notas-callout-title { color: #167a4c; }

/* Status bar */
.notas-editor-statusbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 18px;
  border-top: 1px solid #e5e5e5;
  background: #fafafa;
  flex-shrink: 0;
  font-size: 11.5px;
  color: #6e6e6e;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-editor-stat-sep { color: #d4d4d4; }
.notas-editor-stat-spacer { flex: 1 1 auto; }
.notas-editor-stat[data-stat="updated"] { font-variant-numeric: tabular-nums; }

/* Autocomplete dropdown inline (notas) */
.notas-ac-dropdown {
  position: fixed;
  z-index: 100007;
  background: #ffffff;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.18);
  padding: 4px;
  min-width: 280px;
  max-width: 380px;
  max-height: 280px;
  overflow-y: auto;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-ac-item {
  padding: 8px 10px;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 60ms ease;
}
.notas-ac-item:hover { background: #f0f0f0; }
.notas-ac-item.is-selected {
  background: rgba(0, 102, 255, 0.08);
}
.notas-ac-item.notas-ac-create { color: var(--c-accent); }
.notas-ac-title {
  font-size: 13px;
  color: #0a0a0a;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-ac-folder {
  font-size: 11px;
  color: #888888;
  margin-top: 1px;
}
.notas-ac-empty {
  padding: 12px;
  text-align: center;
  color: #888888;
  font-size: 12px;
  font-style: italic;
}

/* Wikilinks no preview light: ajusta cor */
.notas-editor-preview a.nyvvo-wikilink {
  color: #5d6ad2 !important;
  background: rgba(93, 106, 210, 0.08);
  border-bottom: 1px solid rgba(93, 106, 210, 0.45) !important;
}
.notas-editor-preview a.nyvvo-wikilink.is-broken {
  color: #c41a3a !important;
  background: rgba(196, 26, 58, 0.08);
  border-bottom: 1px dashed rgba(196, 26, 58, 0.55) !important;
}

/* Backlinks no preview light */
.notas-editor-preview .notas-backlinks { border-top-color: #e5e5e5; }
.notas-editor-preview .notas-backlinks-head { color: #6e6e6e; }
.notas-editor-preview .notas-backlinks-count { background: #fafafa; border-color: #e5e5e5; color: #6e6e6e; }
.notas-editor-preview .notas-backlinks-item {
  background: #fafafa !important;
  border-color: #e5e5e5 !important;
}
.notas-editor-preview .notas-backlinks-item:hover {
  background: #f0f0f0 !important;
  border-color: #d4d4d4 !important;
}
.notas-editor-preview .notas-backlinks-title { color: #0a0a0a !important; }
.notas-editor-preview .notas-backlinks-meta { color: #6e6e6e; }
.notas-editor-preview .notas-backlinks-icon { color: #6e6e6e; }
.notas-editor-preview .notas-backlinks-empty { color: #888888; }
.notas-editor-preview .notas-backlinks-empty code {
  background: #fafafa;
  border-color: #e5e5e5;
  color: var(--c-accent);
}

@media (max-width: 900px) {
  .notas-editor-shell[data-mode="split"] .notas-editor-body {
    grid-template-columns: 1fr;
  }
  .notas-editor-shell[data-mode="split"] .notas-editor-preview { display: none; }
}

/* Viewer (preview da nota selecionada) */
.notas-viewer { max-width: 760px; margin: 0 auto; }
.notas-viewer-head {
  border-bottom: 1px solid var(--c-data-border);
  padding-bottom: 16px;
  margin-bottom: 20px;
}
.notas-viewer-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  font-size: 11px;
  color: var(--c-text-on-dark-muted);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.notas-viewer-folder { color: var(--c-accent); font-weight: 600; }
.notas-viewer-sep { opacity: 0.5; }
.notas-viewer-title {
  font-size: 26px !important;
  font-weight: 700 !important;
  letter-spacing: -0.025em !important;
  color: var(--c-text-on-dark) !important;
  margin: 0 0 12px !important;
  line-height: 1.2 !important;
}
.notas-viewer-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.notas-viewer-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 7px !important;
  padding: 7px 12px !important;
  border-radius: 6px !important;
  border: 1px solid var(--c-data-border) !important;
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  font-family: 'Inter', system-ui, sans-serif;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  box-shadow: none !important;
}
.notas-viewer-btn:hover {
  background: #232323 !important;
  border-color: var(--c-data-border-strong) !important;
  transform: none !important;
}
.notas-viewer-btn--primary {
  background: var(--c-accent) !important;
  border-color: var(--c-accent) !important;
  color: #ffffff !important;
}
.notas-viewer-btn--primary:hover {
  background: var(--c-accent-hover) !important;
  border-color: var(--c-accent-hover) !important;
}
.notas-viewer-btn--danger {
  color: var(--c-danger) !important;
  border-color: rgba(230, 0, 35, 0.30) !important;
  background: rgba(230, 0, 35, 0.08) !important;
}
.notas-viewer-btn--danger:hover {
  background: rgba(230, 0, 35, 0.18) !important;
  border-color: rgba(230, 0, 35, 0.50) !important;
}
.notas-viewer-btn svg { width: 13px; height: 13px; }
.notas-viewer-loading {
  color: var(--c-text-on-dark-muted);
  font-size: 13px;
  padding: 24px 0;
}
.notas-empty-content {
  color: var(--c-text-on-dark-muted);
  font-size: 13.5px;
  font-style: italic;
}
.notas-viewer-body { line-height: 1.7; color: var(--c-text-on-dark-soft); }

/* Markdown rendering dentro do viewer (versão compacta — caderno tem o
   estilo principal pra leitura rica) */
.notas-md h1, .notas-md h2, .notas-md h3, .notas-md h4 {
  color: var(--c-text-on-dark) !important;
  letter-spacing: -0.015em;
  margin: 1.4em 0 0.5em;
}
.notas-md h1 { font-size: 1.6em; padding-bottom: 6px; border-bottom: 1px solid var(--c-data-border); }
.notas-md h2 { font-size: 1.32em; padding-bottom: 4px; border-bottom: 1px solid var(--c-data-border); }
.notas-md h3 { font-size: 1.15em; }
.notas-md p { margin: 0 0 0.9em; }
.notas-md a { color: var(--c-accent); }
.notas-md ul, .notas-md ol { margin: 0 0 1em; padding-left: 1.5em; }
.notas-md li { margin: 0.2em 0; }
.notas-md code {
  font-family: var(--gpsn-font-mono, 'JetBrains Mono', monospace);
  font-size: 0.88em;
  background: var(--c-data-bg);
  color: #ff9bb5;
  padding: 0.12em 0.4em;
  border-radius: 4px;
  border: 1px solid var(--c-data-border);
}
.notas-md pre {
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r);
  padding: 12px 14px;
  overflow-x: auto;
  margin: 1em 0;
}
.notas-md pre code { background: transparent; border: 0; padding: 0; }
.notas-md blockquote {
  border-left: 3px solid var(--c-data-border-strong);
  padding-left: 12px;
  color: var(--c-text-on-dark-muted);
  font-style: italic;
  margin: 1em 0;
}
.notas-md table {
  border-collapse: collapse;
  margin: 1em 0;
  width: 100%;
  font-size: 0.95em;
}
.notas-md th, .notas-md td {
  border: 1px solid var(--c-data-border);
  padding: 6px 10px;
  text-align: left;
}
.notas-md thead th { background: var(--c-data-bg); font-weight: 600; }
.notas-md hr { border: 0; border-top: 1px solid var(--c-data-border); margin: 1.5em 0; }

.notas-md-fallback {
  background: var(--c-data-bg);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r);
  padding: 14px;
  font-family: var(--gpsn-font-mono, monospace);
  font-size: 12.5px;
  color: var(--c-text-on-dark-soft);
  white-space: pre-wrap;
}

@media (max-width: 900px) {
  .notas-layout { grid-template-columns: 1fr; }
  .notas-vault { max-height: 280px; }
}

/* =========================================================================
   "Quando usar este módulo" — orientação colapsável (acima do conteúdo)
   --------------------------------------------------------------------------
   Card com kicker discreto + título + ações. Ao expandir mostra: pitch,
   chips de uso e a "ponte" pra próximo passo com botões.
   ========================================================================= */

.module-orientation-card,
details.module-orientation-card {
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  margin: 0 0 16px !important;
  padding: 0 !important;
  overflow: hidden !important;
  transition: border-color var(--tr) !important;
}
.module-orientation-card[open] {
  border-color: var(--c-data-border-strong) !important;
}

.module-orientation-summary {
  cursor: pointer;
  padding: 14px 18px !important;
  list-style: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 16px !important;
  user-select: none;
  transition: background-color var(--tr) !important;
}
.module-orientation-summary::-webkit-details-marker { display: none; }
.module-orientation-summary::marker { display: none; content: ""; }
.module-orientation-summary:hover {
  background: var(--c-data-elevated) !important;
}

.module-orientation-summary-copy { flex: 1 1 auto; min-width: 0; }

.module-orientation-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--c-text-on-dark-muted) !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  margin-bottom: 4px;
}
.module-orientation-kicker svg, .module-orientation-kicker i {
  width: 12px !important; height: 12px !important;
  color: var(--c-accent) !important;
}

.module-orientation-summary-title {
  color: var(--c-text-on-dark) !important;
  font-size: 14px !important;
  font-weight: 600 !important;
  letter-spacing: -0.005em !important;
  margin: 0 !important;
}

/* Ação "Ver guia / Ocultar" — chip pill com chevron */
.module-orientation-summary-action {
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px !important;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
}
.module-orientation-summary:hover .module-orientation-summary-action {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
  color: var(--c-text-on-dark) !important;
}
.module-orientation-summary-action::after {
  content: "▾";
  font-size: 10px;
  color: var(--c-text-on-dark-muted);
  transition: transform var(--tr);
  display: inline-block;
}
.module-orientation-card[open] .module-orientation-summary-action::after {
  transform: rotate(180deg);
}

/* Toggle "Ver guia" / "Ocultar" baseado no estado */
.module-orientation-summary-action-open  { display: inline; }
.module-orientation-summary-action-close { display: none; }
.module-orientation-card[open] .module-orientation-summary-action-open  { display: none; }
.module-orientation-card[open] .module-orientation-summary-action-close { display: inline; }

/* Body */
.module-orientation-body {
  padding: 4px 18px 18px !important;
  border-top: 1px solid var(--c-data-border);
  background: transparent !important;
}
.module-orientation-title {
  color: var(--c-text-on-dark) !important;
  font-size: 14.5px !important;
  font-weight: 600 !important;
  margin: 14px 0 6px !important;
  letter-spacing: -0.005em !important;
  line-height: 1.45 !important;
}
.module-orientation-copy {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  margin: 0 0 14px !important;
}

.module-orientation-signals {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 16px;
}
.module-orientation-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px !important;
  border-radius: 999px !important;
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}
.module-orientation-chip svg, .module-orientation-chip i {
  width: 12px !important; height: 12px !important;
  color: var(--c-accent) !important;
}

/* Bridge ("Próximo passo") */
.module-bridge-card {
  background: var(--c-data-bg) !important;
  border: 1px solid var(--c-data-border) !important;
  border-radius: var(--r-lg) !important;
  padding: 14px 16px !important;
}
.module-bridge-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--c-text-on-dark-muted) !important;
  font-size: 10.5px !important;
  font-weight: 600 !important;
  letter-spacing: 0.10em !important;
  text-transform: uppercase !important;
  margin-bottom: 8px;
}
.module-bridge-kicker svg, .module-bridge-kicker i {
  width: 12px !important; height: 12px !important;
  color: var(--c-accent) !important;
}
.module-bridge-title {
  color: var(--c-text-on-dark) !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
  margin: 0 0 4px !important;
  line-height: 1.4 !important;
}
.module-bridge-copy {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 12.5px !important;
  margin: 0 0 12px !important;
  line-height: 1.5 !important;
}
.module-bridge-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.module-bridge-action {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 12px !important;
  background: var(--c-data-card) !important;
  border: 1px solid var(--c-data-border) !important;
  color: var(--c-text-on-dark-soft) !important;
  border-radius: var(--r) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr) !important;
  box-shadow: none !important;
  filter: none !important;
}
.module-bridge-action:hover {
  background: var(--c-data-elevated) !important;
  border-color: var(--c-data-border-strong) !important;
  color: var(--c-text-on-dark) !important;
  transform: none !important;
}
.module-bridge-action svg, .module-bridge-action i {
  width: 12px !important; height: 12px !important;
  color: var(--c-accent) !important;
}

/* =========================================================================
   <details>/<summary> genéricos — fallback (não pegam o orientation-card)
   ========================================================================= */
details:not(.module-orientation-card) {
  background: var(--c-data-card);
  border: 1px solid var(--c-data-border);
  border-radius: var(--r-lg);
  margin: 8px 0;
  overflow: hidden;
}
details:not(.module-orientation-card) > summary {
  cursor: pointer;
  padding: 12px 16px;
  font-weight: 600;
  color: var(--c-text-on-dark);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 10px;
  user-select: none;
}
details:not(.module-orientation-card) > summary::-webkit-details-marker { display: none; }
details:not(.module-orientation-card) > summary::before {
  content: "▸";
  color: var(--c-text-on-dark-muted);
  font-size: 11px;
  transition: transform var(--tr);
  display: inline-block;
}
details:not(.module-orientation-card)[open] > summary::before {
  transform: rotate(90deg);
}
details:not(.module-orientation-card) > summary:hover {
  background: var(--c-data-elevated);
}

/* =========================================================================
   ESCOPO DO CADERNO (.gps-notebook-overlay) — SEMPRE TEMA CLARO
   --------------------------------------------------------------------------
   O caderno é uma "folha de papel" e cobre tela inteira. Mesmo dentro de
   modo data, ele mantém fundo branco e tipografia escura.
   ========================================================================= */

.gps-notebook-overlay {
  color: #2c2c2c !important;
  padding: 0 !important;
  background: rgba(0, 0, 0, 1) !important;
}
.gps-notebook-overlay .gpsn-shell {
  background: #ffffff !important;
  width: 100vw !important;
  max-width: 100vw !important;
  max-height: 100vh !important;
  height: 100vh !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

.gpsn-header   { background: #0a0a0a !important; border-bottom: 1px solid #2a2a2a !important; }
.gpsn-toolbar  { background: #ffffff !important; border-bottom: 1px solid #e5e5e5 !important; }
.gpsn-body     { background: #ffffff !important; }
.gpsn-editor-pane  { background: #fbfbf8 !important; }
.gpsn-preview-pane { background: #ffffff !important; }
.gpsn-toc-pane     { background: #fafafa !important; border-left: 1px solid #e5e5e5 !important; }
.gpsn-footer       { background: #fafafa !important; border-top: 1px solid #e5e5e5 !important; color: #6e6e6e !important; }

/* Header do caderno (preto: ancora chrome no app) */
.gpsn-header .gpsn-topic-title { color: #ffffff !important; }
.gpsn-header .gpsn-discipline  { color: #999999 !important; }
.gpsn-header .gpsn-sep         { color: #555555 !important; }
.gpsn-header .gpsn-icon-btn    { color: #c9c9c9 !important; }
.gpsn-header .gpsn-icon-btn:hover { color: #ffffff !important; background: #1f1f1f !important; }
.gpsn-header .gpsn-save-status { color: #c9c9c9 !important; background: #161616 !important; border-color: #2a2a2a !important; }
.gpsn-header .gpsn-save-status.is-saved { color: #00b050 !important; background: rgba(0, 176, 80, 0.12) !important; border-color: rgba(0, 176, 80, 0.25) !important; }

/* Tipografia do caderno (preview) */
.gpsn-preview,
.gpsn-preview p,
.gpsn-preview li,
.gpsn-preview td,
.gpsn-preview th { color: #2c2c2c !important; }
.gpsn-preview h1,
.gpsn-preview h2,
.gpsn-preview h3,
.gpsn-preview h4 { color: #0a0a0a !important; border-bottom-color: #e5e5e5 !important; }
.gpsn-preview h5 { color: #6e6e6e !important; }
.gpsn-preview h6 { color: #2c2c2c !important; }
.gpsn-preview strong { color: #0a0a0a !important; }
.gpsn-preview em     { color: #2c2c2c !important; }
.gpsn-preview a      { color: #0066ff !important; border-bottom-color: rgba(0, 102, 255, 0.25) !important; }
.gpsn-preview blockquote { color: #6e6e6e !important; }
.gpsn-preview code   { color: #c41a3a !important; background: #fafafa !important; border-color: #e5e5e5 !important; }
.gpsn-preview pre    { background: #fafafa !important; border-color: #e5e5e5 !important; }
.gpsn-preview pre code { color: #2c2c2c !important; }
.gpsn-preview hr     { background: #e5e5e5 !important; }
.gpsn-preview table  { border-color: #e5e5e5 !important; }
.gpsn-preview th, .gpsn-preview td { border-color: #e5e5e5 !important; }
.gpsn-preview thead th { background: #fafafa !important; color: #0a0a0a !important; }
.gpsn-preview tbody tr:nth-child(even) { background: #fafafa !important; }
.gpsn-preview tbody tr:hover td,
.gpsn-preview tbody tr:hover th { background: #f0f0f0 !important; color: #0a0a0a !important; }
.gpsn-preview mark   { background: #fff2a8 !important; color: #0a0a0a !important; }

/* Editor textarea */
.gpsn-editor {
  color: #2c2c2c !important;
  background: transparent !important;
}
.gpsn-editor::placeholder { color: #a0a0a0 !important; }

/* Toolbar do caderno (claro) */
.gpsn-toolbar .gpsn-tool         { color: #2c2c2c !important; background: transparent !important; }
.gpsn-toolbar .gpsn-tool:hover   { color: #0a0a0a !important; background: #f0f0f0 !important; }
.gpsn-tool-sep     { background: #e5e5e5 !important; }

/* Mode switcher */
.gpsn-mode-switch  { background: #f0f0f0 !important; border-color: #e5e5e5 !important; }
.gpsn-mode-btn     { color: #2c2c2c !important; }
.gpsn-mode-btn:hover { color: #0a0a0a !important; }
.gpsn-mode-btn.active { color: #0066ff !important; background: #ffffff !important; }

/* Sumário */
.gpsn-toc-header { color: #6e6e6e !important; border-bottom-color: #e5e5e5 !important; }
.gpsn-toc-item   { color: #2c2c2c !important; }
.gpsn-toc-item:hover { color: #0a0a0a !important; background: #f0f0f0 !important; }
.gpsn-toc-item.is-active {
  color: #0066ff !important;
  background: rgba(0, 102, 255, 0.08) !important;
  border-left-color: #0066ff !important;
}
.gpsn-toc-item[data-level="1"] { color: #0a0a0a !important; }

/* Callouts */
.gpsn-preview .gpsn-callout                 { color: #2c2c2c !important; }
.gpsn-preview .gpsn-callout-title           { color: #0066ff !important; }
.gpsn-preview .gpsn-callout-question .gpsn-callout-title,
.gpsn-preview .gpsn-callout-quiz .gpsn-callout-title,
.gpsn-preview .gpsn-callout-nota .gpsn-callout-title,
.gpsn-preview .gpsn-callout-info .gpsn-callout-title { color: #0066ff !important; }
.gpsn-preview .gpsn-callout-dica .gpsn-callout-title,
.gpsn-preview .gpsn-callout-tip .gpsn-callout-title  { color: #b35900 !important; }
.gpsn-preview .gpsn-callout-atencao .gpsn-callout-title,
.gpsn-preview .gpsn-callout-warning .gpsn-callout-title { color: #c41a3a !important; }

.gpsn-icon-wrap { color: #ffffff !important; background: var(--c-accent) !important; }

/* Botão Fechar do caderno — destacado */
.gpsn-header .gpsn-close-btn {
  width: auto !important;
  padding: 0 14px !important;
  height: 32px !important;
  background: #ffffff !important;
  color: #0a0a0a !important;
  border: 1px solid #ffffff !important;
  font-weight: 600 !important;
  gap: 6px !important;
  display: inline-flex !important;
  align-items: center !important;
  border-radius: var(--r) !important;
}
.gpsn-header .gpsn-close-btn:hover {
  background: #e5e5e5 !important;
  border-color: #e5e5e5 !important;
}
.gpsn-close-btn .gpsn-close-label { font-size: 12.5px; }
.gpsn-close-btn svg { width: 14px !important; height: 14px !important; }

/* =========================================================================
   TOASTS — sistema de notificação (mensagens flutuantes bottom-right)
   --------------------------------------------------------------------------
   API: window.showToast(msg, type) onde type ∈ info|success|warning|error
   ========================================================================= */

#toast-container {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 100003;
  display: flex;
  flex-direction: column-reverse;
  gap: 8px;
  pointer-events: none;
  max-width: calc(100vw - 40px);
}
/* Quando o FAB Foco está visível, sobe os toasts */
.nyvvo-foco-fab + #toast-container,
body:has(.nyvvo-foco-fab) #toast-container { bottom: 80px; }

.toast {
  pointer-events: auto;
  background: #0f0f0f !important;
  border: 1px solid #2a2a2a !important;
  border-left: 3px solid var(--c-accent) !important;
  border-radius: var(--r-lg) !important;
  padding: 12px 14px !important;
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  min-width: 280px;
  max-width: 420px;
  color: #f5f5f5 !important;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 13px !important;
  line-height: 1.45 !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.5) !important;
  opacity: 0;
  transform: translateX(20px);
  transition: opacity 200ms ease-out, transform 200ms cubic-bezier(0.22, 1, 0.36, 1);
}
.toast.show {
  opacity: 1;
  transform: translateX(0);
}
.toast.toast-info    { border-left-color: var(--c-accent) !important; }
.toast.toast-success { border-left-color: var(--c-success) !important; }
.toast.toast-warning { border-left-color: var(--c-warn) !important; }
.toast.toast-error   { border-left-color: var(--c-danger) !important; }

.toast-icon {
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0;
  margin-top: 1px;
}
.toast.toast-info    .toast-icon { color: var(--c-accent); }
.toast.toast-success .toast-icon { color: var(--c-success); }
.toast.toast-warning .toast-icon { color: var(--c-warn); }
.toast.toast-error   .toast-icon { color: var(--c-danger); }

.toast-content {
  flex: 1 1 auto;
  min-width: 0;
  word-wrap: break-word;
}
.toast-content span {
  color: #f5f5f5 !important;
}

.toast-close-btn {
  background: transparent !important;
  border: 0 !important;
  color: #888888 !important;
  font-size: 18px !important;
  line-height: 1 !important;
  width: 22px !important;
  height: 22px !important;
  cursor: pointer !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 4px !important;
  flex-shrink: 0;
  transition: background-color var(--tr), color var(--tr) !important;
}
.toast-close-btn:hover {
  background: #1f1f1f !important;
  color: #ffffff !important;
}

/* =========================================================================
   LOADING SKELETONS — placeholders cinza pulsantes
   --------------------------------------------------------------------------
   Uso: <div class="nyvvo-skel"></div> no lugar de "Carregando..."
   Variantes: .nyvvo-skel-card, .nyvvo-skel-line, .nyvvo-skel-circle
   ========================================================================= */

.nyvvo-skel,
.nyvvo-skel-line,
.nyvvo-skel-card,
.nyvvo-skel-circle {
  background: linear-gradient(
    90deg,
    var(--c-data-elevated) 0%,
    var(--c-elevated-hi) 50%,
    var(--c-data-elevated) 100%
  );
  background-size: 200% 100%;
  animation: nyvvo-skel-shimmer 1.4s ease-in-out infinite;
  border-radius: var(--r);
}
.nyvvo-skel-line {
  height: 12px;
  margin-bottom: 8px;
}
.nyvvo-skel-line:nth-child(2) { width: 80%; }
.nyvvo-skel-line:nth-child(3) { width: 60%; }
.nyvvo-skel-circle {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  flex-shrink: 0;
}
.nyvvo-skel-card {
  height: 80px;
  border-radius: var(--r-lg);
  margin-bottom: 8px;
}

@keyframes nyvvo-skel-shimmer {
  0%, 100% { background-position: 200% 0; }
  50%      { background-position: -200% 0; }
}

@media (prefers-reduced-motion: reduce) {
  .nyvvo-skel,
  .nyvvo-skel-line,
  .nyvvo-skel-card,
  .nyvvo-skel-circle {
    animation: none;
    background: var(--c-data-elevated);
  }
}

/* Reading mode */
body[data-page-theme="reading"] .nyvvo-skel,
body[data-page-theme="reading"] .nyvvo-skel-line,
body[data-page-theme="reading"] .nyvvo-skel-card,
body[data-page-theme="reading"] .nyvvo-skel-circle {
  background: linear-gradient(
    90deg,
    var(--c-read-elevated) 0%,
    #ebebe8 50%,
    var(--c-read-elevated) 100%
  );
  background-size: 200% 100%;
}

/* =========================================================================
   EMPTY STATES — quando 0 itens, mostra mensagem + CTA centralizada
   --------------------------------------------------------------------------
   Uso:
   <div class="nyvvo-empty">
     <div class="nyvvo-empty-icon"><span data-lucide="..."></span></div>
     <h4 class="nyvvo-empty-title">Título</h4>
     <p class="nyvvo-empty-copy">Texto explicativo</p>
     <button class="nyvvo-empty-cta">Ação</button>
   </div>
   ========================================================================= */

.nyvvo-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 48px 24px;
  gap: 6px;
  min-height: 240px;
}
.nyvvo-empty-icon {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--c-data-elevated);
  border: 1px solid var(--c-data-border);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 12px;
  color: var(--c-text-on-dark-muted);
}
.nyvvo-empty-icon svg {
  width: 24px;
  height: 24px;
}
.nyvvo-empty-title {
  color: var(--c-text-on-dark) !important;
  font-size: 16px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  margin: 0 !important;
}
.nyvvo-empty-copy {
  color: var(--c-text-on-dark-soft) !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  margin: 4px 0 14px !important;
  max-width: 380px;
}
.nyvvo-empty-cta {
  background: var(--c-accent) !important;
  color: #ffffff !important;
  border: 1px solid var(--c-accent) !important;
  border-radius: var(--r) !important;
  padding: 8px 16px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  box-shadow: none !important;
}
.nyvvo-empty-cta:hover {
  background: var(--c-accent-hover) !important;
  border-color: var(--c-accent-hover) !important;
  transform: none !important;
}
.nyvvo-empty-cta-ghost {
  background: transparent !important;
  color: var(--c-text-on-dark-soft) !important;
  border: 1px solid var(--c-data-border-strong) !important;
  margin-top: 6px;
}
.nyvvo-empty-cta-ghost:hover {
  background: var(--c-data-elevated) !important;
  color: var(--c-text-on-dark) !important;
  border-color: var(--c-data-border-strong) !important;
}

body[data-page-theme="reading"] .nyvvo-empty-icon {
  background: var(--c-read-elevated) !important;
  border-color: var(--c-read-border) !important;
  color: var(--c-text-on-light-muted) !important;
}
body[data-page-theme="reading"] .nyvvo-empty-title {
  color: var(--c-text-on-light) !important;
}
body[data-page-theme="reading"] .nyvvo-empty-copy {
  color: var(--c-text-on-light-soft) !important;
}

/* =========================================================================
   Page transition: fade-in sutil quando o conteúdo do módulo é trocado
   ========================================================================= */
@keyframes nyvvo-page-enter {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}
#page-content.nyvvo-page-fresh {
  animation: nyvvo-page-enter 220ms cubic-bezier(0.22, 1, 0.36, 1);
}
/* Sem animação se o usuário pediu menos movimento */
@media (prefers-reduced-motion: reduce) {
  #page-content.nyvvo-page-fresh { animation: none; }
}

/* =========================================================================
   Top loader bar (estilo NProgress) — barra fina azul no topo da viewport
   ========================================================================= */
#nyvvo-top-loader {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--c-accent);
  transform-origin: 0 50%;
  transform: scaleX(0);
  z-index: 100000;
  pointer-events: none;
  opacity: 0;
  box-shadow: 0 0 8px rgba(0, 102, 255, 0.6);
}
#nyvvo-top-loader.is-active {
  opacity: 1;
  /* avança em 3 estágios para dar sensação de progresso enquanto carrega */
  animation: nyvvo-top-loader-progress 1.6s ease-out forwards;
}
#nyvvo-top-loader.is-done {
  transform: scaleX(1);
  opacity: 0;
  transition: opacity 220ms ease 80ms;
}
@keyframes nyvvo-top-loader-progress {
  0%   { transform: scaleX(0); }
  30%  { transform: scaleX(0.3); }
  60%  { transform: scaleX(0.6); }
  90%  { transform: scaleX(0.85); }
  100% { transform: scaleX(0.92); }
}

/* =========================================================================
   FOCO Widget — FAB + painel de sugestões inteligentes
   ========================================================================= */

.nyvvo-foco-fab {
  position: fixed;
  bottom: 20px;
  right: 20px;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: #0a0a0a;
  border: 1px solid #2a2a2a;
  color: #f5f5f5;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 99998;
  transition: background-color var(--tr), border-color var(--tr), transform var(--tr);
  box-shadow: 0 6px 16px rgba(0, 0, 0, 0.45);
}
.nyvvo-foco-fab:hover {
  background: #161616;
  border-color: #3a3a3a;
}
.nyvvo-foco-fab.is-active {
  background: var(--c-accent);
  border-color: var(--c-accent);
  color: #ffffff;
}
.nyvvo-foco-fab svg { width: 20px; height: 20px; }

.nyvvo-foco-panel {
  position: fixed;
  bottom: 80px;
  right: 20px;
  width: 360px;
  max-width: calc(100vw - 40px);
  max-height: calc(100vh - 120px);
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: 12px;
  z-index: 99997;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
  display: none;
  flex-direction: column;
  overflow: hidden;
  font-family: 'Inter', system-ui, sans-serif;
}
.nyvvo-foco-panel.is-open { display: flex; }

.nyvvo-foco-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 14px 16px;
  border-bottom: 1px solid #2a2a2a;
}
.nyvvo-foco-title {
  display: flex;
  align-items: center;
  gap: 10px;
  color: #f5f5f5;
}
.nyvvo-foco-title svg { width: 16px; height: 16px; color: var(--c-accent); }
.nyvvo-foco-title strong {
  font-size: 13.5px;
  font-weight: 700;
  letter-spacing: -0.005em;
}
.nyvvo-foco-close {
  background: transparent;
  border: 0;
  color: #888888;
  font-size: 22px;
  cursor: pointer;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 6px;
  transition: background-color var(--tr), color var(--tr);
}
.nyvvo-foco-close:hover { background: #1f1f1f; color: #ffffff; }

.nyvvo-foco-body {
  padding: 12px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nyvvo-foco-body::-webkit-scrollbar { width: 8px; }
.nyvvo-foco-body::-webkit-scrollbar-thumb { background: #2a2a2a; border-radius: 4px; }

.nyvvo-foco-loading {
  padding: 32px 16px;
  text-align: center;
  color: #888888;
  font-size: 12.5px;
}

/* Cards genéricos */
.nyvvo-foco-card {
  background: #161616;
  border: 1px solid #2a2a2a;
  border-radius: 10px;
  padding: 14px 16px;
}

/* Card de stats (tempo + streak) */
.nyvvo-foco-stat-row {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}
.nyvvo-foco-stat-label {
  color: #888888;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin-bottom: 4px;
}
.nyvvo-foco-stat-value {
  color: #f5f5f5;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}
.nyvvo-foco-stat-suffix {
  color: #888888;
  font-size: 13px;
  font-weight: 500;
}
.nyvvo-foco-stat-flag {
  margin-top: 12px;
  padding: 6px 10px;
  font-size: 11.5px;
  font-weight: 500;
  color: #c9c9c9;
  background: #1f1f1f;
  border-radius: 6px;
  border: 1px solid #2a2a2a;
}
.nyvvo-foco-stat-flag.warn {
  color: var(--c-warn);
  background: rgba(255, 149, 0, 0.08);
  border-color: rgba(255, 149, 0, 0.2);
}

/* Card semanal: total + sparkline + delta */
.nyvvo-foco-week {
  padding: 14px 16px 12px;
}
.nyvvo-foco-week-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
}
.nyvvo-foco-week-total {
  color: #f5f5f5;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  margin-top: 2px;
}
.nyvvo-foco-week-side { text-align: right; }
.nyvvo-foco-week-days {
  color: #f5f5f5;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.nyvvo-foco-week-days span {
  color: #888888;
  font-size: 14px;
  font-weight: 500;
}
.nyvvo-foco-week-days-label {
  color: #888888;
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin-top: 2px;
}

.nyvvo-foco-spark {
  display: block;
  width: 100%;
  height: 44px;
  margin: 6px 0 8px;
}

.nyvvo-foco-week-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid #1f1f1f;
}
.nyvvo-foco-week-delta {
  font-size: 11.5px;
  font-weight: 500;
}
.nyvvo-foco-week-delta.up    { color: var(--c-success); }
.nyvvo-foco-week-delta.down  { color: var(--c-danger); }
.nyvvo-foco-week-delta.neutral { color: #888888; }

.nyvvo-foco-week-foot {
  font-size: 11.5px;
  color: #888888;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid #1f1f1f;
}
.nyvvo-foco-week-foot strong {
  color: #c9c9c9;
  font-weight: 600;
  text-transform: capitalize;
}

/* Distribuição por disciplina (barras horizontais inline) */
.nyvvo-foco-breakdown {
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid #1f1f1f;
}
.nyvvo-foco-breakdown-title {
  color: #888888;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.nyvvo-foco-bar-row {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
  font-size: 11.5px;
}
.nyvvo-foco-bar-row:last-child { margin-bottom: 0; }
.nyvvo-foco-bar-name {
  flex: 0 0 90px;
  color: #c9c9c9;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nyvvo-foco-bar-track {
  flex: 1 1 auto;
  height: 6px;
  background: #1f1f1f;
  border-radius: 3px;
  overflow: hidden;
}
.nyvvo-foco-bar-fill {
  height: 100%;
  background: var(--c-accent);
  border-radius: 3px;
  transition: width 200ms ease-out;
}
.nyvvo-foco-bar-fill.is-muted { background: #555555; }
.nyvvo-foco-bar-pct {
  flex: 0 0 36px;
  text-align: right;
  color: #c9c9c9;
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}
.nyvvo-foco-bar-row.is-muted .nyvvo-foco-bar-name,
.nyvvo-foco-bar-row.is-muted .nyvvo-foco-bar-pct {
  color: #888888;
  font-weight: 500;
}

/* Heatmap calendar (12 semanas) */
.nyvvo-foco-cal {
  padding: 14px 16px 12px;
}
.nyvvo-foco-cal-head {
  margin-bottom: 10px;
}
.nyvvo-foco-cal-summary {
  color: #c9c9c9;
  font-size: 12px;
  font-weight: 500;
  margin-top: 4px;
  display: flex;
  gap: 6px;
  align-items: center;
  flex-wrap: wrap;
}
.nyvvo-foco-cal-summary strong {
  color: #f5f5f5;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.nyvvo-foco-cal-grid {
  display: flex;
  justify-content: center;
  margin: 4px 0;
}
.nyvvo-foco-cal-cell {
  cursor: default;
  transition: stroke 80ms ease;
}
.nyvvo-foco-cal-cell:hover {
  stroke: #f5f5f5;
  stroke-width: 1;
}
.nyvvo-foco-cal-legend {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid #1f1f1f;
  font-size: 10.5px;
  color: #888888;
}
.nyvvo-foco-cal-key {
  width: 11px;
  height: 11px;
  border-radius: 2px;
  display: inline-block;
}
.nyvvo-foco-cal-key[data-lvl="0"] { background: #1f1f1f; }
.nyvvo-foco-cal-key[data-lvl="1"] { background: rgba(0,102,255,0.22); }
.nyvvo-foco-cal-key[data-lvl="2"] { background: rgba(0,102,255,0.45); }
.nyvvo-foco-cal-key[data-lvl="3"] { background: rgba(0,102,255,0.72); }
.nyvvo-foco-cal-key[data-lvl="4"] { background: rgba(0,102,255,1); }

/* Card de ritmo */
.nyvvo-foco-pace {
  padding: 14px 16px;
}
.nyvvo-foco-pace .nyvvo-foco-card-eyebrow {
  margin-bottom: 6px;
}
.nyvvo-foco-pace-main {
  color: #f5f5f5;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.01em;
  font-variant-numeric: tabular-nums;
}
.nyvvo-foco-pace-main.muted {
  color: #888888;
  font-size: 13px;
  font-weight: 500;
}
.nyvvo-foco-pace-main span {
  color: #888888;
  font-size: 13px;
  font-weight: 500;
  margin-left: 4px;
}
.nyvvo-foco-pace-sub {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid #1f1f1f;
  color: #888888;
  font-size: 11.5px;
  line-height: 1.5;
}
.nyvvo-foco-pace-sub strong {
  color: #c9c9c9;
  font-weight: 600;
}

/* Card de ação (clicável) */
.nyvvo-foco-action {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  cursor: pointer;
  transition: background-color 80ms ease, border-color 80ms ease, transform 80ms ease;
}
.nyvvo-foco-action:hover {
  background: #1a1a1a;
  border-color: #3a3a3a;
}
.nyvvo-foco-action:active { transform: scale(0.99); }
.nyvvo-foco-card-icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  background: #1f1f1f;
  border: 1px solid #2a2a2a;
}
.nyvvo-foco-card-icon[data-tone="warn"] {
  background: rgba(255, 149, 0, 0.10);
  border-color: rgba(255, 149, 0, 0.25);
  color: var(--c-warn);
}
.nyvvo-foco-card-icon[data-tone="danger"] {
  background: rgba(230, 0, 35, 0.10);
  border-color: rgba(230, 0, 35, 0.25);
  color: var(--c-danger);
}
.nyvvo-foco-card-icon svg { width: 16px; height: 16px; }
.nyvvo-foco-card-text { flex: 1 1 auto; min-width: 0; }
.nyvvo-foco-card-eyebrow {
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #888888;
  margin-bottom: 3px;
}
.nyvvo-foco-card-title {
  color: #f5f5f5;
  font-size: 13.5px;
  font-weight: 600;
  letter-spacing: -0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nyvvo-foco-card-sub {
  color: #888888;
  font-size: 12px;
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nyvvo-foco-card-arrow {
  color: #555555;
  display: inline-flex;
  align-items: center;
  align-self: center;
}
.nyvvo-foco-action:hover .nyvvo-foco-card-arrow { color: #c9c9c9; }
.nyvvo-foco-card-arrow svg { width: 14px; height: 14px; }

/* Empty state (sem dados) */
.nyvvo-foco-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 24px 12px;
  gap: 8px;
}
.nyvvo-foco-empty-icon {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(0, 102, 255, 0.12);
  border: 1px solid rgba(0, 102, 255, 0.25);
  color: var(--c-accent);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 4px;
}
.nyvvo-foco-empty-icon svg { width: 20px; height: 20px; }
.nyvvo-foco-empty h4 {
  color: #f5f5f5;
  font-size: 14px;
  font-weight: 700;
  margin: 0;
}
.nyvvo-foco-empty p {
  color: #888888;
  font-size: 12.5px;
  margin: 0;
  line-height: 1.5;
}
.nyvvo-foco-cta {
  margin-top: 8px;
  background: var(--c-accent);
  color: #ffffff;
  border: 1px solid var(--c-accent);
  border-radius: 6px;
  padding: 7px 14px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background-color var(--tr);
}
.nyvvo-foco-cta:hover { background: var(--c-accent-hover); }
.nyvvo-foco-cta svg { width: 12px; height: 12px; }

.nyvvo-foco-empty-state {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--c-success);
  font-size: 13px;
  font-weight: 500;
  justify-content: center;
}
.nyvvo-foco-empty-state svg { width: 16px; height: 16px; }

/* Esconde FAB no caderno (não atrapalhar leitura) */
body:has(.gps-notebook-overlay.is-open) .nyvvo-foco-fab,
body:has(.gps-notebook-overlay.is-open) .nyvvo-foco-panel { display: none !important; }

/* =========================================================================
   Command Palette (Ctrl+K)
   ========================================================================= */

.nyvvo-cmdk-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  display: none;
  align-items: flex-start;
  justify-content: center;
  z-index: 100002;
  padding: 88px 24px 24px;
  font-family: 'Inter', system-ui, sans-serif;
}
.nyvvo-cmdk-overlay.is-visible { display: flex; }

.nyvvo-cmdk-card {
  width: 100%;
  max-width: 640px;
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.65);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  max-height: calc(100vh - 120px);
}

/* Input */
.nyvvo-cmdk-input-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  border-bottom: 1px solid #2a2a2a;
}
.nyvvo-cmdk-search-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #888888;
  flex-shrink: 0;
}
.nyvvo-cmdk-search-icon svg { width: 18px; height: 18px; }
.nyvvo-cmdk-input {
  flex: 1;
  background: transparent !important;
  border: 0 !important;
  color: #f5f5f5 !important;
  font-size: 15px !important;
  font-family: inherit !important;
  outline: none !important;
  padding: 0 !important;
  font-weight: 500;
  letter-spacing: -0.01em;
}
.nyvvo-cmdk-input::placeholder { color: #6e6e6e !important; }
.nyvvo-cmdk-input:focus {
  border-color: transparent !important;
  box-shadow: none !important;
}
.nyvvo-cmdk-esc {
  background: #161616;
  border: 1px solid #2a2a2a;
  border-bottom-width: 2px;
  border-radius: 4px;
  font-family: inherit;
  font-size: 11px;
  font-weight: 600;
  color: #999999;
  padding: 2px 7px;
  flex-shrink: 0;
}

/* Results */
.nyvvo-cmdk-results {
  overflow-y: auto;
  padding: 6px 0;
  flex: 1 1 auto;
  min-height: 0;
}
.nyvvo-cmdk-results::-webkit-scrollbar { width: 8px; }
.nyvvo-cmdk-results::-webkit-scrollbar-thumb { background: #2a2a2a; border-radius: 4px; }

.nyvvo-cmdk-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  cursor: pointer;
  transition: background-color 80ms ease;
  border-left: 2px solid transparent;
}
.nyvvo-cmdk-item:hover {
  background: #161616;
}
.nyvvo-cmdk-item.is-selected {
  background: #1a1a1a;
  border-left-color: #0066ff;
}
.nyvvo-cmdk-item-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 6px;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  color: #c9c9c9;
  flex-shrink: 0;
}
.nyvvo-cmdk-item-icon svg { width: 14px; height: 14px; }
.nyvvo-cmdk-item.is-selected .nyvvo-cmdk-item-icon {
  background: #1f1f1f;
  border-color: #3a3a3a;
  color: #f5f5f5;
}
.nyvvo-cmdk-item-text {
  flex: 1 1 auto;
  min-width: 0;
}
.nyvvo-cmdk-item-label {
  color: #f5f5f5;
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nyvvo-cmdk-item-sub {
  color: #888888;
  font-size: 11.5px;
  font-weight: 400;
  margin-top: 1px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.nyvvo-cmdk-item-kind {
  color: #6e6e6e;
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  flex-shrink: 0;
  padding: 2px 8px;
  background: #161616;
  border: 1px solid #2a2a2a;
  border-radius: 999px;
}
.nyvvo-cmdk-item.is-selected .nyvvo-cmdk-item-kind {
  color: #c9c9c9;
  background: #1f1f1f;
  border-color: #3a3a3a;
}
.nyvvo-cmdk-item-kbd {
  background: #161616;
  border: 1px solid #2a2a2a;
  border-bottom-width: 2px;
  border-radius: 4px;
  padding: 2px 6px;
  font-family: inherit;
  font-size: 10.5px;
  font-weight: 600;
  color: #c9c9c9;
  flex-shrink: 0;
  letter-spacing: 0.04em;
}

.nyvvo-cmdk-empty {
  padding: 32px 16px;
  text-align: center;
  color: #6e6e6e;
  font-size: 13px;
}

.nyvvo-cmdk-footer {
  display: flex;
  gap: 16px;
  padding: 8px 16px;
  border-top: 1px solid #2a2a2a;
  background: #0a0a0a;
  font-size: 11px;
  color: #6e6e6e;
}
.nyvvo-cmdk-footer kbd {
  background: #161616;
  border: 1px solid #2a2a2a;
  border-bottom-width: 2px;
  border-radius: 3px;
  padding: 1px 5px;
  font-family: inherit;
  font-size: 10px;
  color: #c9c9c9;
  margin-right: 4px;
}

/* =========================================================================
   Atalhos de teclado: hint flutuante + cheatsheet
   ========================================================================= */

.nyvvo-shortcut-hint {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(8px);
  background: #0a0a0a;
  color: #ffffff;
  padding: 8px 16px;
  border-radius: var(--r);
  font-size: 13px;
  font-weight: 500;
  font-family: 'Inter', system-ui, sans-serif;
  border: 1px solid #2a2a2a;
  z-index: 100000;
  opacity: 0;
  pointer-events: none;
  transition: opacity 160ms ease, transform 160ms ease;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.4);
}
.nyvvo-shortcut-hint.is-visible {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.nyvvo-cheatsheet {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 100001;
  padding: 24px;
}
.nyvvo-cheatsheet.is-visible { display: flex; }
.nyvvo-cheatsheet-card {
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: var(--r-xl);
  padding: 24px 28px;
  max-width: 460px;
  width: 100%;
  color: #f5f5f5;
  font-family: 'Inter', system-ui, sans-serif;
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
}
.nyvvo-cheatsheet-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
  padding-bottom: 12px;
  border-bottom: 1px solid #2a2a2a;
}
.nyvvo-cheatsheet-header strong {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
}
.nyvvo-cheatsheet-close {
  background: transparent;
  border: 0;
  color: #999999;
  font-size: 22px;
  cursor: pointer;
  width: 28px;
  height: 28px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--r);
  transition: background-color var(--tr), color var(--tr);
}
.nyvvo-cheatsheet-close:hover {
  background: #1f1f1f;
  color: #ffffff;
}
.nyvvo-cheatsheet-section { margin-bottom: 18px; }
.nyvvo-cheatsheet-section:last-of-type { margin-bottom: 12px; }
.nyvvo-cheatsheet-section-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #888888;
  margin-bottom: 10px;
}
.nyvvo-cheatsheet-section ul {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.nyvvo-cheatsheet-section li {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: #c9c9c9;
}
.nyvvo-cheatsheet-section li span {
  flex: 1;
  color: #f5f5f5;
}
.nyvvo-cheatsheet-section kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 24px;
  padding: 0 6px;
  background: #161616;
  border: 1px solid #2a2a2a;
  border-bottom-width: 2px;
  border-radius: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 11px;
  font-weight: 600;
  color: #f5f5f5;
}
.nyvvo-cheatsheet-footer {
  font-size: 11.5px;
  color: #888888;
  text-align: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid #2a2a2a;
}

/* Sumário ocultável */
.gpsn-body.gpsn-toc-hidden { grid-template-columns: 1fr 1fr 0 !important; }
.gpsn-body.gpsn-toc-hidden[data-mode="edit"] { grid-template-columns: 1fr 0 0 !important; }
.gpsn-body.gpsn-toc-hidden[data-mode="read"] { grid-template-columns: 0 1fr 0 !important; }
.gpsn-body.gpsn-toc-hidden .gpsn-toc-pane { display: none !important; }
.gpsn-body.gpsn-toc-hidden .gpsn-preview-pane,
.gpsn-body.gpsn-toc-hidden .gpsn-editor-pane { grid-column: span 2 !important; }
.gpsn-body.gpsn-toc-hidden[data-mode="edit"] .gpsn-editor-pane { grid-column: 1 / 4 !important; }
.gpsn-body.gpsn-toc-hidden[data-mode="read"] .gpsn-preview-pane { grid-column: 1 / 4 !important; }

/* =========================================================================
   Botão "Vincular Nota" no header do caderno
   ========================================================================= */
.gpsn-header .gpsn-link-note-btn {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  height: 32px !important;
  padding: 0 12px !important;
  background: #0066ff !important;
  color: #ffffff !important;
  border: 1px solid #0066ff !important;
  border-radius: var(--r) !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  transition: background-color var(--tr), border-color var(--tr) !important;
  margin-right: 6px !important;
  font-family: inherit !important;
}
.gpsn-header .gpsn-link-note-btn:hover {
  background: #0055d4 !important;
  border-color: #0055d4 !important;
}
.gpsn-header .gpsn-link-note-btn svg {
  width: 14px !important;
  height: 14px !important;
  flex-shrink: 0 !important;
}

/* =========================================================================
   Link Picker (modal "Vincular Nota") — busca visual de notas do Vault
   ========================================================================= */
.gpsn-lp-overlay {
  position: fixed !important;
  inset: 0 !important;
  background: rgba(0, 0, 0, 0.62);
  display: none;
  align-items: flex-start;
  justify-content: center;
  /* Acima da notebook overlay (que usa 2147483600 + isolation: isolate) */
  z-index: 2147483646 !important;
  padding: 80px 24px 24px;
  font-family: 'Inter', system-ui, sans-serif;
  backdrop-filter: blur(2px);
}
.gpsn-lp-overlay.is-open { display: flex; }

.gpsn-lp-card {
  width: 100%;
  max-width: 620px;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 12px;
  box-shadow: 0 24px 80px rgba(0, 0, 0, 0.45), 0 4px 12px rgba(0, 0, 0, 0.18);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  max-height: calc(100vh - 120px);
  color: #1a1a1a;
}

.gpsn-lp-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px;
  border-bottom: 1px solid #ececec;
  background: #fafafa;
}
.gpsn-lp-head strong {
  font-size: 13.5px;
  font-weight: 600;
  color: #1a1a1a;
  letter-spacing: -0.01em;
}
.gpsn-lp-close {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: #777;
  cursor: pointer;
  font-size: 20px;
  line-height: 1;
  padding: 0;
  transition: background var(--tr), color var(--tr);
}
.gpsn-lp-close:hover {
  background: #f0f0f0;
  color: #1a1a1a;
}

.gpsn-lp-search {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  border-bottom: 1px solid #ececec;
  background: #ffffff;
}
.gpsn-lp-search svg {
  width: 16px;
  height: 16px;
  color: #888;
  flex-shrink: 0;
}
.gpsn-lp-input {
  flex: 1;
  border: none;
  outline: none;
  font-size: 14px;
  color: #1a1a1a;
  background: transparent;
  font-family: inherit;
  padding: 4px 0;
}
.gpsn-lp-input::placeholder { color: #aaa; }
.gpsn-lp-kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 26px;
  height: 22px;
  padding: 0 6px;
  background: #f4f4f4;
  border: 1px solid #dfdfdf;
  border-bottom-width: 2px;
  border-radius: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  color: #555;
  letter-spacing: 0.02em;
}

.gpsn-lp-results {
  flex: 1;
  overflow-y: auto;
  padding: 6px;
  background: #ffffff;
  min-height: 120px;
  max-height: 50vh;
}

.gpsn-lp-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background var(--tr);
  border: 1px solid transparent;
}
.gpsn-lp-item + .gpsn-lp-item { margin-top: 2px; }
.gpsn-lp-item:hover { background: #f6f6f6; }
.gpsn-lp-item.is-selected {
  background: #eef4ff;
  border-color: #d0e0ff;
}
.gpsn-lp-item.is-selected .gpsn-lp-item-title { color: #0044bb; }

.gpsn-lp-item--create {
  background: #fff8eb;
  border-color: #ffe2a8;
}
.gpsn-lp-item--create:hover { background: #fff1d1; }
.gpsn-lp-item--create.is-selected {
  background: #ffe9b8;
  border-color: #f4c66c;
}
.gpsn-lp-item--create .gpsn-lp-item-title { color: #8a5a00; }
.gpsn-lp-item--create.is-selected .gpsn-lp-item-title { color: #6b4400; }

.gpsn-lp-item-text {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.gpsn-lp-item-title {
  font-size: 13.5px;
  font-weight: 500;
  color: #1a1a1a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gpsn-lp-item-folder {
  font-size: 11.5px;
  color: #888;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gpsn-lp-item-actions {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}
.gpsn-lp-action-btn {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  background: #f4f4f4;
  color: #333;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--tr), border-color var(--tr), color var(--tr);
}
.gpsn-lp-action-btn:hover {
  background: #ececec;
  border-color: #d4d4d4;
}
.gpsn-lp-action-btn--primary {
  background: #0066ff;
  color: #ffffff;
  border-color: #0066ff;
}
.gpsn-lp-action-btn--primary:hover {
  background: #0055d4;
  border-color: #0055d4;
}

.gpsn-lp-empty {
  padding: 28px 16px;
  text-align: center;
  font-size: 13px;
  color: #888;
}

.gpsn-lp-foot {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 10px 16px;
  border-top: 1px solid #ececec;
  background: #fafafa;
  font-size: 11.5px;
  color: #777;
  flex-wrap: wrap;
}
.gpsn-lp-foot kbd {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 22px;
  height: 20px;
  padding: 0 5px;
  margin: 0 3px;
  background: #ffffff;
  border: 1px solid #dfdfdf;
  border-bottom-width: 2px;
  border-radius: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  font-size: 10.5px;
  font-weight: 600;
  color: #555;
  vertical-align: baseline;
}

/* Responsivo: telas pequenas */
@media (max-width: 640px) {
  .gpsn-lp-overlay { padding: 40px 12px 12px; }
  .gpsn-lp-card { max-height: calc(100vh - 64px); }
  .gpsn-lp-item { flex-direction: column; align-items: stretch; }
  .gpsn-lp-item-actions { justify-content: flex-end; }
  .gpsn-lp-foot { font-size: 11px; gap: 10px; }
  .gpsn-header .gpsn-link-note-btn span:not(.gpsn-icon-wrap) { display: none !important; }
  .gpsn-header .gpsn-link-note-btn { padding: 0 8px !important; }
}

/* =========================================================================
   Notas — Slash menu (/ comando)
   ========================================================================= */
.notas-slash-menu {
  position: fixed;
  z-index: 100008;
  display: none;
  width: 280px;
  max-height: 320px;
  overflow-y: auto;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 10px;
  box-shadow: 0 14px 40px rgba(0, 0, 0, 0.14), 0 2px 6px rgba(0, 0, 0, 0.08);
  padding: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  color: #1a1a1a;
}
.notas-slash-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 6px;
  cursor: pointer;
  transition: background var(--tr);
}
.notas-slash-item:hover { background: #f5f5f5; }
.notas-slash-item.is-selected {
  background: #eef4ff;
  outline: 1px solid #d0e0ff;
}
.notas-slash-icon {
  flex-shrink: 0;
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: #f4f4f4;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 700;
  color: #444;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
}
.notas-slash-item.is-selected .notas-slash-icon {
  background: #ffffff;
  color: #0044bb;
}
.notas-slash-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
  flex: 1;
}
.notas-slash-label {
  font-size: 13px;
  font-weight: 500;
  color: #1a1a1a;
  line-height: 1.2;
}
.notas-slash-hint {
  font-size: 11px;
  color: #888;
  margin-top: 2px;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-slash-empty {
  padding: 20px 12px;
  text-align: center;
  color: #888;
  font-size: 12.5px;
}
.notas-slash-empty kbd {
  display: inline-block;
  padding: 1px 5px;
  border: 1px solid #d8d8d8;
  border-bottom-width: 2px;
  border-radius: 3px;
  background: #f6f6f6;
  font-family: inherit;
  font-size: 11px;
}

/* =========================================================================
   Notas — Tab bar polish: + button, dirty dot
   ========================================================================= */
.notas-tab-add {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  margin: 0 6px;
  padding: 0;
  border: 1px dashed #d0d0d0;
  background: transparent;
  border-radius: 6px;
  color: #888;
  font-size: 16px;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--tr), color var(--tr), border-color var(--tr);
  align-self: center;
  font-family: inherit;
  line-height: 1;
}
.notas-tab-add:hover {
  background: #f0f4ff;
  color: #0066ff;
  border-color: #0066ff;
  border-style: solid;
}
.notas-tab-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #f39c12;
  flex-shrink: 0;
  box-shadow: 0 0 0 2px rgba(243, 156, 18, 0.2);
  animation: notas-pulse 1.4s ease-in-out infinite;
}

/* =========================================================================
   Notas — Welcome / empty state
   ========================================================================= */
.notas-welcome-card {
  max-width: 560px;
  margin: 0 auto;
  background: #ffffff;
  border: 1px solid #ececec;
  border-radius: 14px;
  padding: 36px 32px;
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.06);
  text-align: center;
}
/* Texto e ícone do card welcome — cores para fundo CLARO (sobrescreve o tema escuro do .notas-welcome legacy) */
.notas-welcome-card .notas-welcome-icon {
  background: #eef4ff !important;
  border-color: #cfdcff !important;
  color: #0066ff !important;
  margin: 0 auto 16px !important;
}
.notas-welcome-card h2 {
  color: #1a1a1a !important;
  font-size: 22px !important;
  font-weight: 700 !important;
  margin-bottom: 8px !important;
}
.notas-welcome-card p {
  color: #555 !important;
  font-size: 14px !important;
  line-height: 1.55 !important;
  margin: 0 auto 4px !important;
}
.notas-welcome-card p strong { color: #1a1a1a !important; font-weight: 600 !important; }
.notas-welcome-card .notas-welcome-tips {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid #f0f0f0;
}
.notas-welcome-card .notas-welcome-tips > div {
  background: #fafafa !important;
  border-color: #ececec !important;
  color: #555 !important;
  padding: 7px 12px !important;
  grid-template-columns: 96px 1fr !important;
  gap: 10px !important;
}
.notas-welcome-card .notas-welcome-tips > div span:not([class]) {
  color: #1a1a1a !important;
  font-weight: 500;
}
.notas-welcome-card .notas-welcome-tips kbd {
  background: #ffffff !important;
  border: 1px solid #d8d8d8 !important;
  border-bottom-width: 2px !important;
  color: #444 !important;
  font-size: 10.5px !important;
  padding: 2px 6px !important;
  min-width: 22px !important;
}
.notas-welcome-cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 22px 0 18px;
}
.notas-welcome-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: #f6f6f6;
  border: 1px solid #e5e5e5;
  border-radius: 8px;
  color: #1a1a1a;
  font-family: inherit;
  font-size: 13px;
  font-weight: 500;
  cursor: pointer;
  transition: background var(--tr), border-color var(--tr), transform var(--tr);
}
.notas-welcome-btn:hover { background: #ececec; border-color: #d6d6d6; }
.notas-welcome-btn:active { transform: translateY(1px); }
.notas-welcome-btn:disabled { opacity: 0.5; cursor: not-allowed; }
.notas-welcome-btn--primary {
  background: #0066ff;
  color: #ffffff;
  border-color: #0066ff;
}
.notas-welcome-btn--primary:hover { background: #0055d4; border-color: #0055d4; }
.notas-welcome-btn kbd {
  display: inline-block;
  padding: 1px 5px;
  background: rgba(0, 0, 0, 0.08);
  border-radius: 3px;
  font-size: 10.5px;
  font-family: inherit;
  font-weight: 600;
  color: inherit;
}
.notas-welcome-btn--primary kbd { background: rgba(255, 255, 255, 0.18); color: #ffffff; }

.notas-welcome-recent {
  margin: 18px 0 8px;
  padding-top: 18px;
  border-top: 1px solid #f0f0f0;
  text-align: left;
}
.notas-welcome-recent-label {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #999;
  margin-bottom: 8px;
  text-align: center;
}
.notas-welcome-recent-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}
.notas-welcome-recent-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  background: #f6f6f6;
  border: 1px solid #ececec;
  border-radius: 999px;
  color: #444;
  font-family: inherit;
  font-size: 12px;
  cursor: pointer;
  transition: background var(--tr), border-color var(--tr);
  max-width: 220px;
}
.notas-welcome-recent-item span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.notas-welcome-recent-item:hover { background: #ececec; border-color: #d6d6d6; }
.notas-welcome-recent-item svg { width: 12px; height: 12px; flex-shrink: 0; color: #888; }

/* =========================================================================
   Notas — Goal progress bar
   ========================================================================= */
.notas-editor-goal {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 2px 8px;
  border: 1px solid #e5e5e5;
  border-radius: 999px;
  background: #ffffff;
  color: #6e6e6e;
  font-size: 11.5px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--tr), border-color var(--tr), color var(--tr);
}
.notas-editor-goal:hover { background: #f6f6f6; border-color: #d8d8d8; }
.notas-editor-goal-bar {
  position: relative;
  width: 60px;
  height: 5px;
  background: #ececec;
  border-radius: 999px;
  overflow: hidden;
  flex-shrink: 0;
}
.notas-editor-goal-fill {
  display: block;
  height: 100%;
  background: #0066ff;
  border-radius: 999px;
  transition: width 0.3s ease;
}
.notas-editor-goal.is-met {
  color: #1ea566;
  background: #e6f7ee;
  border-color: #d6f1e3;
}
.notas-editor-goal.is-met .notas-editor-goal-fill {
  background: #1ea566;
}
.notas-editor-goal-text {
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

/* =========================================================================
   Notas — Modal de confirmação / prompt visual
   ========================================================================= */
.notas-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.65);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100009;
  backdrop-filter: blur(3px);
  opacity: 0;
  transition: opacity 140ms ease;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-modal-overlay.is-open { opacity: 1; }
.notas-modal-overlay .notas-modal {
  background: #0f0f0f;
  border: 1px solid #2a2a2a;
  border-radius: 12px;
  width: min(440px, 92vw);
  box-shadow: 0 24px 60px rgba(0, 0, 0, 0.6);
  color: #f5f5f5;
  transform: translateY(8px) scale(0.98);
  opacity: 0;
  transition: transform 160ms cubic-bezier(.2,.8,.2,1), opacity 160ms ease;
}
.notas-modal-overlay.is-open .notas-modal {
  transform: translateY(0) scale(1);
  opacity: 1;
}
.notas-modal-head {
  padding: 16px 20px 8px;
}
.notas-modal-title {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: #ffffff;
}
.notas-modal-overlay .notas-modal-body {
  padding: 4px 20px 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  font-size: 13.5px;
  line-height: 1.55;
  color: #c9c9c9;
}
.notas-modal-msg {
  margin: 0 0 4px;
  color: #c9c9c9;
}
.notas-modal-input {
  background: #161616;
  border: 1px solid #2a2a2a;
  color: #f5f5f5;
  padding: 10px 12px;
  border-radius: 6px;
  font-size: 13.5px;
  font-family: inherit;
  outline: none;
  transition: border-color var(--tr), box-shadow var(--tr);
  width: 100%;
}
.notas-modal-input:focus {
  border-color: var(--c-accent);
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.20);
}
.notas-modal-error {
  font-size: 12px;
  color: #ff7466;
  min-height: 14px;
}
.notas-modal-foot {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 20px 16px;
  border-top: 1px solid #1f1f1f;
}
.notas-modal-overlay .notas-modal-btn {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 12.5px;
  font-weight: 600;
  cursor: pointer;
  font-family: inherit;
  border: 1px solid #2a2a2a;
  background: transparent;
  color: #c9c9c9;
  transition: background-color var(--tr), border-color var(--tr), color var(--tr);
}
.notas-modal-overlay .notas-modal-btn:hover {
  background: #1f1f1f;
  color: #ffffff;
}
.notas-modal-overlay .notas-modal-btn--primary {
  background: var(--c-accent);
  color: #ffffff;
  border-color: var(--c-accent);
}
.notas-modal-overlay .notas-modal-btn--primary:hover {
  background: var(--c-accent-hover);
  border-color: var(--c-accent-hover);
}
.notas-modal-overlay .notas-modal-btn--danger {
  background: #c5443c;
  color: #ffffff;
  border-color: #c5443c;
}
.notas-modal-overlay .notas-modal-btn--danger:hover {
  background: #b03830;
  border-color: #b03830;
}
.notas-modal-overlay .notas-modal-btn:focus-visible {
  outline: 2px solid var(--c-accent);
  outline-offset: 2px;
}

/* =========================================================================
   Notas — Find / Replace bar (Ctrl+F / Ctrl+H)
   ========================================================================= */
.notas-find-bar {
  flex-shrink: 0;
  background: #fafafa;
  border-bottom: 1px solid #e5e5e5;
  padding: 8px 12px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  font-family: 'Inter', system-ui, sans-serif;
}
.notas-find-bar[hidden] { display: none; }
.notas-find-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.notas-find-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  flex-shrink: 0;
  opacity: 0.8;
}
.notas-find-input {
  flex: 1 1 auto;
  height: 30px;
  padding: 0 10px;
  border: 1px solid #d8d8d8;
  border-radius: 6px;
  background: #ffffff;
  color: #1a1a1a;
  font-size: 13px;
  font-family: inherit;
  outline: none;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.notas-find-input:focus {
  border-color: #0066ff;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.18);
}
.notas-find-count {
  font-size: 11.5px;
  color: #6e6e6e;
  font-variant-numeric: tabular-nums;
  padding: 0 6px;
  flex-shrink: 0;
  min-width: 56px;
  text-align: center;
}
.notas-find-count.is-empty { color: #b03830; }
.notas-find-nav,
.notas-find-close,
.notas-find-toggle-replace,
.notas-find-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 28px;
  min-width: 28px;
  padding: 0 8px;
  border: 1px solid #d8d8d8;
  background: #ffffff;
  border-radius: 6px;
  color: #444;
  font-family: inherit;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  flex-shrink: 0;
  transition: background var(--tr), color var(--tr), border-color var(--tr);
}
.notas-find-nav:hover,
.notas-find-close:hover,
.notas-find-toggle-replace:hover,
.notas-find-btn:hover {
  background: #f0f0f0;
  color: #0a0a0a;
  border-color: #c4c4c4;
}
.notas-find-btn--primary {
  background: #0066ff;
  color: #ffffff;
  border-color: #0066ff;
}
.notas-find-btn--primary:hover {
  background: #0055d4;
  color: #ffffff;
  border-color: #0055d4;
}
.notas-find-row--replace { padding-left: 24px; }
.notas-find-row--replace[hidden] { display: none; }

/* =========================================================================
   Notas — Sort button no Vault
   ========================================================================= */
.notas-vault-sort-glyph {
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: -0.02em;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
  line-height: 1;
}

/* =========================================================================
   Notas — Ícones customizados (emoji) em pasta e nota
   ========================================================================= */
.notas-item-icon--emoji,
.notas-folder-icon--emoji {
  font-size: 14px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", system-ui, sans-serif;
}
.notas-folder-icon--emoji { font-size: 13.5px; }

/* =========================================================================
   Notas — Emoji picker (escolher ícone)
   ========================================================================= */
.notas-emoji-picker-overlay {
  position: fixed;
  inset: 0;
  background: transparent;
  z-index: 100007;
  font-family: 'Inter', system-ui, sans-serif;
  pointer-events: auto;
}
.notas-emoji-picker {
  position: fixed;
  width: 360px;
  max-height: 480px;
  background: #ffffff;
  border: 1px solid #e2e2e2;
  border-radius: 12px;
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.18), 0 2px 8px rgba(0, 0, 0, 0.10);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  color: #1a1a1a;
}
.notas-emoji-tabs {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 0 6px;
  background: #fafafa;
  border-bottom: 1px solid #ececec;
  overflow-x: auto;
  scrollbar-width: none;
  flex-shrink: 0;
}
.notas-emoji-tabs::-webkit-scrollbar { display: none; }
.notas-emoji-tab {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", system-ui, sans-serif;
  opacity: 0.55;
  transition: opacity var(--tr), background var(--tr), border-color var(--tr);
}
.notas-emoji-tab:hover { opacity: 1; background: rgba(0, 102, 255, 0.06); }
.notas-emoji-tab.is-active {
  opacity: 1;
  border-bottom-color: #0066ff;
  background: #ffffff;
}
.notas-emoji-head {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 10px 8px;
  border-bottom: 1px solid #ececec;
}
.notas-emoji-search {
  flex: 1;
  height: 30px;
  padding: 0 10px;
  border: 1px solid #d8d8d8;
  border-radius: 6px;
  font-family: inherit;
  font-size: 13px;
  outline: none;
  color: #1a1a1a;
  background: #ffffff;
  transition: border-color var(--tr), box-shadow var(--tr);
}
.notas-emoji-search:focus {
  border-color: #0066ff;
  box-shadow: 0 0 0 3px rgba(0, 102, 255, 0.18);
}
.notas-emoji-clear {
  height: 30px;
  padding: 0 10px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  background: #f4f4f4;
  color: #666;
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  font-family: inherit;
  white-space: nowrap;
  transition: background var(--tr), color var(--tr), border-color var(--tr);
}
.notas-emoji-clear:hover {
  background: #fef2f2;
  color: #b91c1c;
  border-color: #fca5a5;
}
.notas-emoji-body {
  flex: 1;
  overflow-y: auto;
  padding: 6px 10px 10px;
}
.notas-emoji-body::-webkit-scrollbar { width: 8px; }
.notas-emoji-body::-webkit-scrollbar-thumb { background: #d4d4d4; border-radius: 4px; }
.notas-emoji-group + .notas-emoji-group { margin-top: 8px; }
.notas-emoji-group-title {
  font-size: 11px;
  font-weight: 600;
  color: #888;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 6px 0 4px;
}
.notas-emoji-grid {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 2px;
}
.notas-emoji-cell {
  width: 100%;
  aspect-ratio: 1;
  border: 1px solid transparent;
  background: transparent;
  border-radius: 6px;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", system-ui, sans-serif;
  transition: background var(--tr), border-color var(--tr), transform 80ms ease;
}
.notas-emoji-cell:hover {
  background: #f0f4ff;
  border-color: #d0e0ff;
  transform: scale(1.08);
}
.notas-emoji-cell.is-current {
  background: #0066ff;
  border-color: #0066ff;
  outline: 2px solid #0066ff;
  outline-offset: -2px;
}
.notas-emoji-empty {
  padding: 24px 8px;
  text-align: center;
  font-size: 12.5px;
  color: #888;
}
.notas-emoji-foot {
  padding: 6px 12px 8px;
  border-top: 1px solid #ececec;
  font-size: 11px;
  color: #777;
  text-align: center;
  background: #fafafa;
}
.notas-emoji-foot kbd {
  display: inline-block;
  padding: 1px 4px;
  margin: 0 2px;
  background: #ffffff;
  border: 1px solid #d8d8d8;
  border-bottom-width: 2px;
  border-radius: 3px;
  font-family: inherit;
  font-size: 10.5px;
  font-weight: 600;
  color: #444;
}

/* =========================================================================
   Floating selection toolbar (estilo Notion/Medium)
   ========================================================================= */
.notas-floating-toolbar {
  position: fixed;
  z-index: 100009;
  display: none;
  align-items: center;
  gap: 1px;
  padding: 4px;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.30);
  font-family: 'Inter', system-ui, sans-serif;
  user-select: none;
  opacity: 0;
  transform: translateY(4px);
  transition: opacity 140ms ease, transform 140ms ease;
}
.notas-floating-toolbar.is-visible {
  display: inline-flex;
  opacity: 1;
  transform: translateY(0);
}
.notas-ft-btn {
  background: transparent;
  border: 0;
  width: 28px;
  height: 28px;
  border-radius: 4px;
  cursor: pointer;
  color: #d4d4d4;
  font-family: inherit;
  font-size: 13px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background var(--tr, 160ms), color var(--tr, 160ms);
}
.notas-ft-btn:hover {
  background: #2a2a2a;
  color: #ffffff;
}
.notas-ft-btn--text {
  font-size: 11px;
  width: auto;
  min-width: 28px;
  padding: 0 6px;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace;
}
.notas-ft-btn .notas-tb-hl {
  background: #fff2a8;
  color: #0a0a0a;
  padding: 0 3px;
  border-radius: 2px;
  font-size: 9.5px;
  font-weight: 700;
}
.notas-ft-sep {
  width: 1px;
  height: 16px;
  background: #2a2a2a;
  margin: 0 3px;
}

/* =========================================================================
   Code syntax highlighting (Prism.js tomorrow theme override)
   ========================================================================= */
.notas-editor-preview .notas-md pre[class*="language-"],
.notas-editor-preview .notas-md pre {
  margin: 14px 0 !important;
  padding: 14px 16px !important;
  background: #1e293b !important;
  border-radius: 8px !important;
  border: 1px solid #2a2a2a !important;
  overflow-x: auto;
  font-size: 12.5px !important;
  line-height: 1.55 !important;
}
.notas-editor-preview .notas-md pre code,
.notas-editor-preview .notas-md pre code[class*="language-"] {
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace !important;
  background: transparent !important;
  color: #e2e8f0 !important;
  padding: 0 !important;
  text-shadow: none !important;
  font-size: 12.5px !important;
  display: block;
  white-space: pre;
}
/* Inline code permanece com seu estilo original */
.notas-editor-preview .notas-md p code,
.notas-editor-preview .notas-md li code,
.notas-editor-preview .notas-md td code {
  background: #f4f4f4 !important;
  color: #be185d !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace !important;
  font-size: 0.92em !important;
}


/* =========================================================================
   Modo Visual (WYSIWYG via contenteditable)
   ========================================================================= */
.notas-editor-engine {
  display: inline-flex;
  align-items: center;
  gap: 0;
  border: 1px solid #e5e5e5;
  border-radius: 6px;
  padding: 2px;
  background: #fafafa;
  margin-right: 4px;
}
.notas-editor-engine-btn {
  background: transparent;
  border: 0;
  padding: 4px 9px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  color: #555;
  cursor: pointer;
  font-family: inherit;
  transition: background var(--tr, 160ms), color var(--tr, 160ms);
  white-space: nowrap;
}
.notas-editor-engine-btn:hover { background: #ececec; color: #1a1a1a; }
.notas-editor-engine-btn.is-active {
  background: #ffffff;
  color: #2563eb;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.06);
}

.notas-editor-frame[data-editor-engine="visual"] .notas-editor-body {
  grid-template-columns: 1fr !important;
}
.notas-editor-wysiwyg {
  flex: 1;
  width: 100%;
  padding: 24px 36px;
  background: #ffffff;
  color: #1a1a1a;
  font-family: 'Inter', -apple-system, system-ui, sans-serif;
  font-size: 16px;
  line-height: 1.65;
  outline: none;
  overflow-y: auto;
  min-height: 100%;
  caret-color: #2563eb;
}
.notas-editor-wysiwyg[data-placeholder]:empty::before {
  content: attr(data-placeholder);
  color: #aaa;
  pointer-events: none;
}
.notas-editor-wysiwyg h1 { font-size: 1.95em !important; font-weight: 700 !important; margin: 0.6em 0 0.4em !important; color: #0a0a0a !important; letter-spacing: -0.01em; }
.notas-editor-wysiwyg h2 { font-size: 1.55em !important; font-weight: 700 !important; margin: 1.2em 0 0.4em !important; color: #0a0a0a !important; }
.notas-editor-wysiwyg h3 { font-size: 1.28em !important; font-weight: 600 !important; margin: 1em 0 0.3em !important; color: #0a0a0a !important; }
.notas-editor-wysiwyg p { margin: 0 0 0.85em !important; color: #1a1a1a !important; }
.notas-editor-wysiwyg ul, .notas-editor-wysiwyg ol { margin: 0 0 0.85em !important; padding-left: 1.6em !important; }
.notas-editor-wysiwyg ul { list-style: disc outside !important; }
.notas-editor-wysiwyg ul ul { list-style: circle outside !important; }
.notas-editor-wysiwyg ul ul ul { list-style: square outside !important; }
.notas-editor-wysiwyg ol { list-style: decimal outside !important; }
.notas-editor-wysiwyg ol ol { list-style: lower-alpha outside !important; }
.notas-editor-wysiwyg ol ol ol { list-style: lower-roman outside !important; }
.notas-editor-wysiwyg li { margin: 0.2em 0; color: #1a1a1a !important; }
.notas-editor-wysiwyg li::marker { color: #5d6ad2; }
.notas-editor-wysiwyg blockquote {
  border-left: 3px solid #2563eb !important;
  margin: 1em 0 !important;
  padding: 0.4em 1em !important;
  color: #555 !important;
  background: #f0f9ff !important;
  border-radius: 0 6px 6px 0;
  font-style: italic;
}
.notas-editor-wysiwyg strong { color: #0a0a0a !important; font-weight: 700 !important; }
.notas-editor-wysiwyg em { font-style: italic !important; color: #2c2c2c !important; }
.notas-editor-wysiwyg code {
  background: #f4f4f4 !important;
  color: #be185d !important;
  padding: 1px 5px !important;
  border-radius: 3px !important;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace !important;
  font-size: 0.92em !important;
}
.notas-editor-wysiwyg pre {
  background: #1e293b !important;
  color: #e2e8f0 !important;
  padding: 14px 16px !important;
  border-radius: 8px !important;
  overflow-x: auto;
  margin: 1em 0 !important;
  font-family: 'JetBrains Mono', 'Fira Code', ui-monospace, monospace !important;
  font-size: 13px !important;
}
.notas-editor-wysiwyg a {
  color: #2563eb !important;
  text-decoration: underline;
}
.notas-editor-wysiwyg img { max-width: 100%; border-radius: 6px; }
.notas-editor-wysiwyg hr { border: 0; border-top: 1px solid #e5e5e5; margin: 1.5em 0; }
.notas-editor-wysiwyg table { border-collapse: collapse; width: 100%; margin: 1em 0; }
.notas-editor-wysiwyg th, .notas-editor-wysiwyg td {
  border: 1px solid #e5e5e5;
  padding: 8px 12px;
  text-align: left;
}
.notas-editor-wysiwyg thead th { background: #fafafa; font-weight: 600; }
.notas-editor-wysiwyg .nyvvo-wikilink {
  color: #2563eb !important;
  text-decoration: none !important;
  border-bottom: 1px dashed #2563eb;
  padding: 0 2px;
  cursor: pointer;
}

/* Frontmatter renderizada como pill bar não-editável no topo */
.notas-vis-fm {
  background: #f0f9ff;
  border: 1px solid #cfdcff;
  border-radius: 6px;
  padding: 8px 12px;
  margin-bottom: 16px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px 16px;
  font-size: 12px;
  color: #1e40af;
}
.notas-vis-fm-field { display: flex; align-items: center; gap: 4px; }
.notas-vis-fm-key { font-weight: 600; }


/* =========================================================================
   Color picker (floating toolbar)
   ========================================================================= */
.notas-color-picker {
  position: fixed;
  z-index: 100012;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.30);
  padding: 6px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4px;
}
.notas-color-swatch {
  width: 26px;
  height: 26px;
  border: 1px solid #2a2a2a;
  border-radius: 4px;
  cursor: pointer;
  transition: transform 80ms ease;
}
.notas-color-swatch:hover {
  transform: scale(1.12);
  border-color: #ffffff;
}

.notas-ft-color-bar {
  display: inline-block;
  width: 14px;
  height: 3px;
  margin-left: 2px;
  border-radius: 1px;
  background: currentColor;
}
.notas-ft-color-btn {
  width: auto;
  padding: 0 6px;
}


/* =========================================================================
   Notion-style right-click context menu
   ========================================================================= */
.notas-notion-menu,
.notas-notion-submenu {
  position: fixed;
  z-index: 100015;
  background: #1a1a1a;
  border: 1px solid #2a2a2a;
  border-radius: 8px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.50), 0 2px 8px rgba(0, 0, 0, 0.30);
  min-width: 240px;
  max-width: 320px;
  padding: 4px;
  font-family: 'Inter', system-ui, sans-serif;
  color: #e5e5e5;
  user-select: none;
  animation: notas-notion-menu-in 120ms ease-out;
}
@keyframes notas-notion-menu-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.notas-notion-submenu--scrollable {
  max-height: 380px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #4a4a4a transparent;
}
.notas-notion-submenu--scrollable::-webkit-scrollbar { width: 8px; }
.notas-notion-submenu--scrollable::-webkit-scrollbar-thumb { background: #4a4a4a; border-radius: 4px; }

.notas-notion-menu-search {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px 8px;
  border-bottom: 1px solid #2a2a2a;
  margin-bottom: 4px;
}
.notas-notion-menu-search-icon {
  font-size: 12px;
  opacity: 0.6;
}
.notas-notion-menu-input {
  flex: 1;
  background: transparent !important;
  border: 0 !important;
  color: #e5e5e5 !important;
  outline: none !important;
  font-family: inherit !important;
  font-size: 12.5px !important;
  padding: 4px 0 !important;
  box-shadow: none !important;
}
.notas-notion-menu-input::placeholder { color: #6a6a6a !important; }

.notas-notion-menu-section-title {
  padding: 8px 10px 4px;
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #888;
}

.notas-notion-menu-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 6px 10px;
  border: 0;
  background: transparent;
  color: #e5e5e5;
  font-family: inherit;
  font-size: 12.5px;
  cursor: pointer;
  border-radius: 4px;
  text-align: left;
  white-space: nowrap;
  transition: background 80ms ease;
}
.notas-notion-menu-item:hover {
  background: #2a2a2a;
}
.notas-notion-menu-item--danger:hover {
  background: #4c1d1d;
  color: #fca5a5;
}

.notas-notion-menu-icon {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 13px;
  font-weight: 600;
  color: #c4c4c4;
  background: transparent;
  border-radius: 3px;
}
.notas-notion-menu-item:hover .notas-notion-menu-icon {
  color: #ffffff;
}
.notas-notion-menu-mark {
  background: #fef3c7;
  color: #92400e;
  padding: 0 3px;
  border-radius: 2px;
  font-size: 9.5px;
  font-weight: 700;
}
.notas-notion-menu-label {
  flex: 1;
  font-weight: 500;
}
.notas-notion-menu-shortcut {
  flex-shrink: 0;
  font-size: 10.5px;
  color: #888;
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  font-weight: 500;
}
.notas-notion-menu-arrow {
  flex-shrink: 0;
  font-size: 14px;
  color: #888;
  font-weight: 600;
  margin-left: 4px;
}
.notas-notion-menu-divider {
  height: 1px;
  background: #2a2a2a;
  margin: 4px 0;
}
.notas-notion-menu-items {
  display: flex;
  flex-direction: column;
}
