:root {
  --bg:        #0a0c0f;
  --bg1:       #101318;
  --bg2:       #161b22;
  --bg3:       #1e252f;
  --border:    rgba(255,255,255,.07);
  --border-md: rgba(255,255,255,.12);
  --text:      #e8edf3;
  --text-dim:  #7a8694;
  --text-faint:#3d4857;
  --gold:      #c8a96e;
  --gold-dim:  rgba(200,169,110,.15);
  --gold-glow: rgba(200,169,110,.08);
  --teal:      #4fc3a1;
  --teal-dim:  rgba(79,195,161,.12);
  --red:       #e05c5c;
  --red-dim:   rgba(224,92,92,.12);
  --blue:      #6eaadc;
  --blue-dim:  rgba(110,170,220,.12);
  --amber:     #f5a623;
  --amber-dim: rgba(245,166,35,.12);
  --green:     #3fb950;
  --r:         8px;
  --r-lg:      14px;
  --shadow:    0 8px 32px rgba(0,0,0,.45);
  --font-serif: 'DM Serif Display', Georgia, serif;
  --font-sans:  'DM Sans', system-ui, sans-serif;
  --font-mono:  'IBM Plex Mono', 'Fira Code', monospace;
  --accent: #1a3a6b;
}
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; overflow: hidden; }
body { background: var(--bg); color: var(--text); font-family: var(--font-sans); font-size: 14px; display: flex; line-height: 1.6; }

/* SIDEBAR */
.sidebar { width: 256px; min-width: 256px; background: var(--bg1); border-right: 1px solid var(--border); display: flex; flex-direction: column; height: 100vh; position: relative; z-index: 10; }
.logo-area { padding: 28px 24px 20px; border-bottom: 1px solid var(--border); }
.logo-wordmark { font-family: var(--font-serif); font-size: 22px; color: var(--gold); line-height: 1; }
.logo-sub { font-size: 10px; color: var(--text-dim); letter-spacing: 2px; text-transform: uppercase; margin-top: 6px; font-family: var(--font-mono); }
.nav { padding: 12px 0; flex: 1; }
.nav-section-label { font-family: var(--font-mono); font-size: 9px; color: var(--text-faint); text-transform: uppercase; letter-spacing: 1.5px; padding: 14px 20px 6px; }
.nav-item { display: flex; align-items: center; gap: 10px; padding: 10px 20px; font-size: 13px; color: var(--text-dim); cursor: pointer; transition: all .15s; border-left: 2px solid transparent; user-select: none; }
.nav-item i { width: 16px; text-align: center; font-size: 13px; }
.nav-item:hover { background: var(--bg2); color: var(--text); }
.nav-item.active { background: var(--gold-glow); color: var(--gold); border-left-color: var(--gold); }
.sidebar-footer { padding: 16px; border-top: 1px solid var(--border); display: flex; flex-direction: column; gap: 8px; }
.status-pill { display: flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 10px; color: var(--teal); padding: 6px 10px; background: var(--teal-dim); border-radius: 20px; border: 1px solid rgba(79,195,161,.15); }
.pulse { width: 6px; height: 6px; background: var(--teal); border-radius: 50%; animation: pulse 2.2s ease-in-out infinite; }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.4;transform:scale(.8)} }
.stats-line { font-family: var(--font-mono); font-size: 9px; color: var(--text-faint); }

/* MAIN */
.main { flex: 1; display: flex; flex-direction: column; overflow: hidden; height: 100vh; }
.topbar { display: flex; align-items: center; justify-content: space-between; padding: 0 28px; height: 56px; border-bottom: 1px solid var(--border); background: var(--bg1); flex-shrink: 0; }
.topbar-title { font-family: var(--font-serif); font-size: 17px; color: var(--text); }
.topbar-meta { font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); }
.view { flex: 1; overflow-y: auto; display: none; }
.view.active { display: block; }
.view-pad { padding: 28px; }

/* INPUT PANEL */
.input-panel { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 22px 24px; margin-bottom: 24px; }
.input-label { font-family: var(--font-mono); font-size: 10px; color: var(--text-dim); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 6px; display: block; }
.input-hint { font-size: 11px; color: var(--text-faint); margin-bottom: 14px; }
.input-row { display: flex; gap: 12px; align-items: flex-end; }
.query-field { flex: 1; background: var(--bg); border: 1px solid var(--border-md); border-radius: var(--r); color: var(--gold); font-family: var(--font-mono); font-size: 12.5px; padding: 11px 14px; height: 48px; outline: none; transition: border-color .2s; }
.query-field:focus { border-color: var(--gold); }
.query-field::placeholder { color: var(--text-faint); }
.btn-run { background: var(--gold); color: #0a0c0f; border: none; border-radius: var(--r); font-family: var(--font-sans); font-weight: 600; font-size: 13px; padding: 0 28px; height: 48px; cursor: pointer; transition: all .15s; }
.btn-run:hover { background: #d9ba82; transform: translateY(-1px); }
.btn-run:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
.tag-row { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 14px; }
.tag { padding: 4px 10px; background: var(--bg3); border: 1px solid var(--border-md); border-radius: 4px; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); cursor: pointer; transition: all .12s; }
.tag:hover { background: var(--gold-dim); border-color: var(--gold); color: var(--gold); }

/* TERMINAL */
.terminal { background: var(--bg); border: 1px solid var(--border); border-radius: var(--r); font-family: var(--font-mono); font-size: 11.5px; padding: 14px 16px; height: 96px; overflow-y: auto; margin-bottom: 24px; color: var(--text-dim); }
.log-line { display: flex; gap: 10px; margin-bottom: 3px; animation: slideIn .15s ease-out; }
.log-ts { color: var(--text-faint); font-size: 10px; }
.log-msg.ok   { color: var(--teal); }
.log-msg.err  { color: var(--red); }
.log-msg.info { color: var(--gold); }
.log-msg.warn { color: var(--amber); }
@keyframes slideIn { from { opacity:0; transform:translateX(-8px);} to {opacity:1;transform:none;} }

/* CARDS */
.dash-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
.span2 { grid-column: span 2; }
.card { background: var(--bg1); border: 1px solid var(--border); border-radius: var(--r-lg); overflow: hidden; margin-bottom: 0; }
.card-head { display: flex; align-items: center; justify-content: space-between; padding: 13px 18px; border-bottom: 1px solid var(--border); background: var(--bg2); }
.card-title { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--text-dim); }
.card-badge { font-family: var(--font-mono); font-size: 10px; padding: 2px 8px; border-radius: 20px; background: var(--gold-dim); color: var(--gold); }
.card-body { padding: 18px; }

/* RISK & INTERACTION */
.risk-box { background: var(--red-dim); border: 1px solid rgba(224,92,92,.2); border-left: 3px solid var(--red); border-radius: var(--r); padding: 14px 18px; margin-bottom: 20px; }
.risk-title { font-family: var(--font-mono); font-size: 9px; color: var(--red); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; }
.risk-item { font-size: 12.5px; color: var(--text-dim); padding: 4px 0 4px 18px; position: relative; }
.risk-item::before { content: "⚠"; position: absolute; left: 0; color: var(--amber); }

/* GENE PILLS */
.genes-wrap { display: flex; flex-wrap: wrap; gap: 6px; }
.gene-pill { padding: 6px 12px; background: var(--bg3); border: 1px solid var(--border-md); border-radius: 4px; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); cursor: pointer; transition: all .12s; display: inline-flex; flex-direction: column; }
.gene-pill:hover { background: var(--gold-dim); border-color: var(--gold); color: var(--gold); }
.gene-sym { font-size: 13px; color: var(--gold); font-weight: 500; }
.gene-loc { font-size: 9px; color: var(--text-faint); margin-top: 2px; }

/* PATHWAY */
.pathway-box { background: var(--bg3); border: 1px solid var(--border-md); border-radius: var(--r); padding: 16px; }
.pathway-id   { font-family: var(--font-mono); font-size: 10px; color: var(--teal); margin-bottom: 4px; }
.pathway-name { font-size: 14px; color: var(--text); font-weight: 500; margin-bottom: 8px; }
.pathway-desc { font-size: 12px; color: var(--text-dim); line-height: 1.6; margin-bottom: 12px; }
.ext-link { display: inline-flex; align-items: center; gap: 5px; font-family: var(--font-mono); font-size: 11px; padding: 6px 12px; border-radius: var(--r); text-decoration: none; transition: all .15s; margin-right: 6px; }
.ext-link.gold { background: var(--gold-dim); border: 1px solid rgba(200,169,110,.25); color: var(--gold); }
.ext-link.teal { background: var(--teal-dim); border: 1px solid rgba(79,195,161,.2); color: var(--teal); }

/* SUPP TABS */
.supp-tabs { display: flex; border-bottom: 1px solid var(--border); margin-bottom: 18px; overflow-x: auto; }
.supp-tab { padding: 8px 16px; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); cursor: pointer; border-bottom: 2px solid transparent; white-space: nowrap; transition: all .15s; }
.supp-tab:hover { color: var(--text); }
.supp-tab.active { color: var(--gold); border-bottom-color: var(--gold); }
.supp-panel { display: none; }
.supp-panel.active { display: block; }
.supp-text { font-size: 12px; color: var(--text-dim); line-height: 1.7; }

/* REFS TABLE */
.sci-table { width: 100%; border-collapse: collapse; color: var(--text); font-size: 12px; }
.sci-table th { text-align: left; padding: 10px; color: var(--text-dim); font-family: var(--font-mono); font-size: 10px; border-bottom: 1px solid var(--border); }
.sci-table td { padding: 12px 10px; border-bottom: 1px solid var(--border); }
.ref-link { color: var(--teal); text-decoration: none; font-family: var(--font-mono); font-size: 10px; }

/* --- PROFESSIONAL MAQUETACIÓN KENRYU STYLE --- */
#report-web-preview {
    background: white; width: 210mm; min-height: 297mm; margin: 0 auto;
    padding: 25mm 20mm; box-shadow: 0 0 20px rgba(0,0,0,0.5);
    color: black; font-family: 'Inter', sans-serif;
    text-align: left; box-sizing: border-box; display: none;
}
#clinical-report-template { width: 100%; max-width: 100%; font-size: 11px; color: black; background: white; }
.header-pdf { color: #1a3a6b; border-bottom: 2px solid #000; padding-bottom: 5px; text-transform: uppercase; font-size: 15px; margin-top: 25px; margin-bottom: 15px; font-weight: 700; }
.tarjeta-pdf { display: inline-block !important; width: 100%; border-left: 5px solid #1a3a6b; padding: 12px 15px; margin-bottom: 20px; box-sizing: border-box; page-break-inside: avoid !important; background: #f8f9fa; border-radius: 0 4px 4px 0; }
#report-web-preview p { text-align: justify; line-height: 1.6; margin-bottom: 12px; font-size: 11.5pt; color: black; }
#report-web-preview ul, #report-web-preview ol { padding-left: 20px; margin-bottom: 15px; color: black; }
#report-web-preview li { margin-bottom: 8px; font-size: 10.5pt; color: black; }
.report-footer { margin-top: 60px; border-top: 1px solid #eee; padding-top: 20px; font-size: 10px; text-align: center; color: #888; }

/* EDITOR UI */
#toolbar { background: var(--bg1); border-bottom: 1px solid var(--border); display: flex; align-items: center; gap: 5px; padding: 8px 20px; flex-shrink: 0; }

/* GENE PANEL */
.gene-panel { position: fixed; right: 0; top: 0; bottom: 0; width: 340px; background: var(--bg1); border-left: 1px solid var(--border-md); box-shadow: -8px 0 40px rgba(0,0,0,.5); z-index: 200; transform: translateX(100%); transition: transform .25s ease; display: flex; flex-direction: column; overflow: hidden; }
.gene-panel.open { transform: none; }
.gene-panel-head { display: flex; align-items: center; justify-content: space-between; padding: 18px 20px; border-bottom: 1px solid var(--border); background: var(--bg2); }
.gene-panel-name { font-family: var(--font-serif); font-size: 22px; color: var(--gold); }
.btn-close { background: none; border: none; color: var(--text-dim); font-size: 20px; cursor: pointer; }
.gene-panel-body { flex: 1; overflow-y: auto; padding: 22px; }
.gp-field { margin-bottom: 16px; }
.gp-label { font-family: var(--font-mono); font-size: 9px; color: var(--text-faint); text-transform: uppercase; letter-spacing: 1px; margin-bottom: 5px; }
.gp-val { font-size: 13px; color: var(--text); line-height: 1.6; }
.gp-mono { font-family: var(--font-mono); font-size: 12px; color: var(--teal); }
.gp-summary { font-size: 12px; color: var(--text-dim); line-height: 1.7; }
.gp-links { display: flex; flex-direction: column; gap: 7px; margin-top: 4px; }

/* LOADING */
.loader-overlay { position: fixed; bottom: 24px; right: 24px; background: rgba(16,19,24,.95); padding: 12px 20px; border-radius: 30px; display: flex; align-items: center; gap: 12px; border: 1px solid var(--gold); box-shadow: 0 0 30px rgba(0,0,0,.6); z-index: 300; transition: .3s; }
.loader-overlay.hidden { opacity: 0; pointer-events: none; transform: translateY(10px); }
.spinner { width: 18px; height: 18px; border: 2px solid rgba(200,169,110,.15); border-top-color: var(--gold); border-radius: 50%; animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.loader-msg { font-family: var(--font-mono); font-size: 11px; color: var(--gold); }

@media print {
    body * { visibility: hidden; }
    #report-web-preview, #report-web-preview * { visibility: visible; }
    #report-web-preview { position: absolute; left: 0; top: 0; width: 100% !important; box-shadow: none; margin: 0; padding: 10mm; }
}

/* ═══ B1: MARKDOWN ═══ */
.md-content p { margin: 0 0 10px 0; font-size: 13px; line-height: 1.7; }
.md-content strong { color: var(--gold); font-weight: 600; }
.md-bullets { padding-left: 22px; margin: 6px 0 14px 0; }
.md-bullets li { font-size: 13px; line-height: 1.7; margin-bottom: 6px; color: var(--text-dim); }

/* ═══ B2: TARJETAS DE SUPLEMENTO ═══ */
.supp-panel { display: none; padding: 8px 0; }
.supp-panel.active { display: block; }
.supp-card { background: var(--bg1); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; }
.supp-card-head { display: flex; align-items: center; justify-content: space-between; padding: 14px 18px; border-bottom: 1px solid var(--border); background: linear-gradient(180deg, var(--bg2) 0%, var(--bg1) 100%); }
.supp-card-title h3 { margin: 0; font-family: var(--font-serif); font-size: 18px; color: var(--gold); }
.supp-sci { display: block; font-size: 11px; font-style: italic; color: var(--text-faint); margin-top: 2px; }
.supp-chip { font-family: var(--font-mono); font-size: 10px; letter-spacing: 1px; padding: 5px 11px; border-radius: 20px; text-transform: uppercase; }
.supp-chip-high { background: rgba(79,195,161,.12); border: 1px solid rgba(79,195,161,.35); color: var(--teal); }
.supp-chip-mid { background: rgba(200,169,110,.1); border: 1px solid rgba(200,169,110,.3); color: var(--gold); }
.supp-chip-low { background: rgba(245,166,35,.08); border: 1px solid rgba(245,166,35,.28); color: var(--amber); }
.supp-card-sec { padding: 14px 18px; border-bottom: 1px solid rgba(255,255,255,.04); }
.supp-card-sec:last-child { border-bottom: none; }
.supp-h { font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.5px; color: var(--teal); text-transform: uppercase; margin: 0 0 10px 0; }
.supp-h-warn { color: var(--amber); }
.supp-count { color: var(--text-faint); font-weight: normal; }
.supp-text { font-size: 13px; line-height: 1.7; color: var(--text-dim); margin: 0; }
.supp-text + .supp-text { margin-top: 8px; }
.supp-list { padding-left: 20px; margin: 4px 0 0 0; }
.supp-list li { font-size: 12.5px; line-height: 1.65; color: var(--text-dim); margin-bottom: 5px; }
.supp-warn { background: rgba(245,166,35,.04); border-left: 3px solid rgba(245,166,35,.3); }
.supp-warn-crit { background: rgba(220,53,69,.05); border-left: 3px solid rgba(220,53,69,.35); }
.supp-ix-list { display: flex; flex-direction: column; gap: 8px; }
.supp-ix-row { display: flex; gap: 10px; padding: 9px 12px; background: var(--bg2); border-radius: 6px; border-left: 2px solid rgba(110,170,220,.4); }
.supp-ix-drug { font-family: var(--font-mono); font-size: 11px; color: var(--blue); font-weight: 600; min-width: 130px; }
.supp-ix-detail { font-size: 12px; color: var(--text-dim); line-height: 1.55; flex: 1; }
.supp-more { margin-top: 8px; }
.supp-more summary { font-size: 11px; color: var(--text-faint); cursor: pointer; padding: 4px 0; font-family: var(--font-mono); }
.supp-more summary:hover { color: var(--gold); }
.supp-more[open] summary { color: var(--gold); margin-bottom: 6px; }
.supp-card-foot { padding: 12px 18px; background: var(--bg2); text-align: right; }
.supp-link { font-family: var(--font-mono); font-size: 11px; color: var(--teal); text-decoration: none; }
.supp-link:hover { color: var(--gold); }

/* ═══ B4: INTERACCIONES ═══ */
.ix-block { background: var(--bg1); border: 1px solid var(--border); border-radius: 10px; overflow: hidden; margin-bottom: 18px; }
.ix-block-head { display: flex; align-items: center; justify-content: space-between; padding: 13px 18px; background: linear-gradient(180deg, var(--bg2) 0%, var(--bg1) 100%); border-bottom: 1px solid var(--border); }
.ix-block-title { margin: 0; font-family: var(--font-serif); font-size: 16px; color: var(--gold); font-weight: 600; }
.ix-block-chips { display: flex; gap: 6px; }
.ix-summary-chip { font-family: var(--font-mono); font-size: 9px; letter-spacing: 1px; padding: 4px 9px; border-radius: 12px; text-transform: uppercase; }
.ix-chip-crit { background: rgba(220,53,69,.15); color: #ff8a95; border: 1px solid rgba(220,53,69,.4); }
.ix-chip-warn { background: rgba(245,166,35,.12); color: var(--amber); border: 1px solid rgba(245,166,35,.35); }
.ix-chip-info { background: rgba(110,170,220,.12); color: var(--blue); border: 1px solid rgba(110,170,220,.35); }
.ix-block-body { padding: 14px 18px; display: flex; flex-direction: column; gap: 11px; }
.ix-card { background: var(--bg2); border-radius: 8px; border-left: 4px solid var(--blue); overflow: hidden; }
.ix-card.ix-crit { border-left-color: #dc3545; background: rgba(220,53,69,.04); }
.ix-card.ix-warn { border-left-color: var(--amber); background: rgba(245,166,35,.04); }
.ix-card.ix-info { border-left-color: var(--blue); }
.ix-card-head { display: flex; align-items: center; justify-content: space-between; padding: 11px 14px; border-bottom: 1px solid rgba(255,255,255,.05); }
.ix-pair { display: flex; align-items: center; gap: 10px; font-size: 13px; }
.ix-left, .ix-right { font-weight: 600; color: var(--text); }
.ix-arrow { color: var(--text-faint); font-size: 13px; }
.ix-sev { font-family: var(--font-mono); font-size: 9px; padding: 4px 9px; border-radius: 4px; letter-spacing: 1px; text-transform: uppercase; }
.ix-sev-crit { background: rgba(220,53,69,.2); color: #ff8a95; }
.ix-sev-warn { background: rgba(245,166,35,.15); color: var(--amber); }
.ix-sev-info { background: rgba(110,170,220,.15); color: var(--blue); }
.ix-card-body { padding: 11px 14px; display: flex; flex-direction: column; gap: 7px; }
.ix-row { display: flex; gap: 12px; font-size: 12px; line-height: 1.6; }
.ix-row-lbl { font-family: var(--font-mono); font-size: 9px; color: var(--text-faint); text-transform: uppercase; letter-spacing: 1px; min-width: 95px; padding-top: 1px; }
.ix-row-val { color: var(--text-dim); flex: 1; }
.ix-row-quote { color: var(--text-dim); font-style: italic; opacity: .85; }
.ix-row-action .ix-row-val { color: var(--text); font-weight: 500; }

/* ═══ B3: EDITOR ESTILO KENRYU ═══ */
#view-report { background: #2a2d33; padding: 0; }
#view-report.view { display: none; }
#view-report.view.active { display: flex; flex-direction: column; height: 100vh; overflow: hidden; }

#report-toolbar { display: flex; align-items: center; gap: 18px; padding: 12px 22px; background: linear-gradient(180deg, var(--bg1) 0%, #14171d 100%); border-bottom: 1px solid var(--border-md); flex-shrink: 0; box-shadow: 0 1px 0 rgba(255,255,255,.02); }
.rt-brand { display: flex; align-items: center; gap: 12px; }
.rt-brand > i { font-size: 22px; color: var(--gold); }
.rt-brand-title { font-family: var(--font-serif); font-size: 16px; color: var(--gold); font-weight: 600; line-height: 1.1; }
.rt-brand-sub { font-family: var(--font-mono); font-size: 9px; letter-spacing: 1.5px; color: var(--text-faint); text-transform: uppercase; margin-top: 2px; }
.rt-meta { flex: 1; text-align: center; font-family: var(--font-mono); font-size: 11px; color: var(--text-dim); letter-spacing: .5px; }
.rt-actions { display: flex; gap: 8px; }
.rt-btn { display: inline-flex; align-items: center; gap: 7px; padding: 9px 16px; border-radius: 6px; font-family: var(--font-mono); font-size: 11px; letter-spacing: .8px; text-transform: uppercase; cursor: pointer; border: 1px solid transparent; transition: all .18s ease; }
.rt-btn:disabled { opacity: .5; cursor: wait; }
.rt-btn-secondary { background: rgba(79,195,161,.08); border-color: rgba(79,195,161,.3); color: var(--teal); }
.rt-btn-secondary:hover:not(:disabled) { background: rgba(79,195,161,.16); border-color: var(--teal); }
.rt-btn-primary { background: linear-gradient(135deg, var(--gold) 0%, #b89656 100%); color: #14171d; font-weight: 600; }
.rt-btn-primary:hover:not(:disabled) { box-shadow: 0 0 18px rgba(200,169,110,.4); transform: translateY(-1px); }

#report-workspace { flex: 1; display: flex; overflow: hidden; }
#report-sidebar { width: 260px; background: var(--bg1); border-right: 1px solid var(--border); padding: 24px 22px; flex-shrink: 0; overflow-y: auto; }
.rep-side-section + .rep-side-section { margin-top: 28px; }
.rep-side-title { font-family: var(--font-mono); font-size: 10px; color: var(--gold); text-transform: uppercase; letter-spacing: 1.5px; margin-bottom: 12px; }
.rep-toc { list-style: none; padding: 0; margin: 0; }
.rep-toc li { font-size: 12px; color: var(--text-dim); padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.04); line-height: 1.5; }
.rep-toc li:last-child { border-bottom: none; }
.rep-toc-rom { display: inline-block; min-width: 24px; font-family: var(--font-mono); font-size: 10px; color: var(--gold); margin-right: 6px; }
.rep-side-note { font-size: 11px; color: var(--text-faint); line-height: 1.6; margin: 0; }

#report-canvas { flex: 1; overflow-y: auto; padding: 32px 0; display: flex; flex-direction: column; align-items: center; background: #2a2d33; }
#editor-empty { color: var(--text-faint); text-align: center; margin-top: 80px; }
#editor-empty i { font-size: 56px; opacity: .25; margin-bottom: 14px; display: block; }
#editor-empty p { font-size: 13px; }

/* ═══ B5: PAGINACIÓN A4 ═══ */
#report-canvas-content { display: flex; flex-direction: column; align-items: center; gap: 22px; width: 100%; }
.a4-page { width: 210mm; min-height: 297mm; background: #ffffff; color: #111; box-shadow: 0 6px 28px rgba(0,0,0,.45); position: relative; display: flex; flex-direction: column; font-family: var(--font-sans); }
.a4-page .page-inner { padding: 22mm 18mm 16mm 18mm; flex: 1; color: #111; font-size: 11pt; line-height: 1.55; }
.a4-page .page-footer { position: absolute; left: 18mm; right: 18mm; bottom: 8mm; display: flex; justify-content: space-between; font-family: var(--font-mono); font-size: 9px; color: #999; border-top: 1px solid #eee; padding-top: 6px; }
.a4-page .page-footer .page-num { font-weight: 600; color: #1a3a6b; }

/* contenido del informe en A4 */
.a4-page .rep-header { display: flex; justify-content: space-between; align-items: baseline; border-bottom: 3px solid #000; padding-bottom: 10px; margin-bottom: 22px; }
.a4-page .rep-h1 { margin: 0; font-size: 26px; font-weight: 800; color: #000; letter-spacing: 1px; }
.a4-page .rep-header-meta { text-align: right; font-size: 10px; color: #333; }
.a4-page section { margin-bottom: 16px; }
.a4-page .header-pdf { font-size: 13pt; color: #1a3a6b; margin: 14px 0 10px 0; padding-bottom: 5px; border-bottom: 1px solid #1a3a6b; font-weight: 700; letter-spacing: .5px; }
.a4-page .tarjeta-pdf { background: #f8fafc; border-left: 4px solid #1a3a6b; padding: 10px 14px; margin: 8px 0; border-radius: 3px; page-break-inside: avoid; break-inside: avoid; color: #111; }
.a4-page p, .a4-page li { color: #111; }
.a4-page a { color: #1a3a6b; text-decoration: none; }
.a4-page .md-content p { font-size: 11pt; color: #111; line-height: 1.55; margin: 0 0 8px 0; }
.a4-page .md-content strong { color: #1a3a6b; }
.a4-page .md-bullets li { font-size: 11pt; color: #111; }
.a4-page ol, .a4-page ul { color: #111; }

/* Force-break helper */
.force-page-break { display: block; height: 0; }

/* Editor TOC active marker */
.rep-toc li.active { color: var(--gold); }

/* Print */
@media print {
  #report-sidebar, #report-toolbar, .sidebar, .topbar, #editor-empty { display: none !important; }
  #report-canvas { padding: 0 !important; background: #fff !important; }
  .a4-page { box-shadow: none !important; page-break-after: always; margin: 0 !important; }
  .a4-page:last-child { page-break-after: auto; }
}

/* ═══ NAVEGADOR ALFABÉTICO DE HIERBAS ═══ */
.herb-browser { background: var(--bg1); border: 1px solid var(--border); border-radius: 10px; margin: 18px 0; overflow: hidden; }
.hb-head { display: flex; align-items: center; gap: 14px; padding: 13px 18px; background: linear-gradient(180deg, var(--bg2) 0%, var(--bg1) 100%); border-bottom: 1px solid var(--border); flex-wrap: wrap; }
.hb-title { font-family: var(--font-serif); font-size: 14px; color: var(--gold); display: inline-flex; align-items: center; gap: 8px; font-weight: 600; }
.hb-title i { color: var(--gold); }
.hb-filter { flex: 1; min-width: 180px; background: var(--bg3); border: 1px solid var(--border); color: var(--text); padding: 8px 12px; border-radius: 6px; font-family: var(--font-sans); font-size: 12px; outline: none; transition: border-color .15s ease; }
.hb-filter:focus { border-color: var(--gold); }
.hb-count { font-family: var(--font-mono); font-size: 10px; color: var(--text-faint); letter-spacing: 1px; text-transform: uppercase; }

.hb-letters { display: flex; flex-wrap: wrap; gap: 4px; padding: 12px 18px; background: var(--bg2); border-bottom: 1px solid var(--border); }
.hb-letter { position: relative; min-width: 32px; height: 32px; padding: 0 6px; background: var(--bg1); color: var(--text-dim); border: 1px solid var(--border); border-radius: 5px; font-family: var(--font-mono); font-size: 12px; font-weight: 600; cursor: pointer; transition: all .15s ease; display: inline-flex; align-items: center; justify-content: center; }
.hb-letter:hover:not(:disabled) { background: rgba(200,169,110,.1); border-color: var(--gold); color: var(--gold); transform: translateY(-1px); }
.hb-letter.active { background: var(--gold); color: #14171d; border-color: var(--gold); }
.hb-letter.active .hb-letter-n { background: rgba(20,23,29,.25); color: #14171d; }
.hb-letter.disabled, .hb-letter:disabled { opacity: .25; cursor: not-allowed; }
.hb-letter-n { position: absolute; top: -5px; right: -5px; min-width: 16px; height: 14px; padding: 0 3px; background: var(--teal); color: var(--bg1); border-radius: 7px; font-size: 8px; font-weight: 700; display: inline-flex; align-items: center; justify-content: center; line-height: 1; }

.hb-list { padding: 14px 18px; display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 8px; max-height: 380px; overflow-y: auto; }
.hb-list::-webkit-scrollbar { width: 8px; }
.hb-list::-webkit-scrollbar-track { background: var(--bg2); }
.hb-list::-webkit-scrollbar-thumb { background: var(--border-md); border-radius: 4px; }
.hb-list::-webkit-scrollbar-thumb:hover { background: var(--gold); }
.hb-item { background: var(--bg2); border: 1px solid var(--border); border-left: 3px solid var(--teal); border-radius: 6px; padding: 10px 12px; cursor: pointer; transition: all .15s ease; text-align: left; display: flex; flex-direction: column; gap: 3px; font-family: var(--font-sans); }
.hb-item:hover { background: var(--bg3); border-left-color: var(--gold); transform: translateX(2px); box-shadow: 0 2px 8px rgba(0,0,0,.2); }
.hb-item-name { font-size: 13px; color: var(--text); font-weight: 500; }
.hb-item:hover .hb-item-name { color: var(--gold); }
.hb-item-sci { font-size: 10.5px; color: var(--text-faint); font-style: italic; }
.hb-empty { grid-column: 1/-1; padding: 40px 20px; text-align: center; color: var(--text-faint); font-size: 13px; font-style: italic; }

/* ═══ TARJETA DE SUPLEMENTO — SECCIONES POR AUDIENCIA (PACIENTE / PROFESIONAL) ═══ */
.supp-common { display: block; font-size: 11px; color: var(--text-faint); margin-top: 3px; }
.supp-common::before { content: ''; }

.supp-audience { border-top: 1px solid var(--border); margin-top: 6px; }
.supp-audience:first-of-type { margin-top: 0; border-top: none; }

.supp-aud-head {
  display: flex; align-items: center; gap: 9px;
  font-family: var(--font-mono); font-size: 10px; letter-spacing: 1.8px; text-transform: uppercase;
  padding: 12px 18px;
  color: #14171d;
  background: linear-gradient(90deg, rgba(200,169,110,.92) 0%, rgba(200,169,110,.55) 100%);
  font-weight: 700;
}
.supp-aud-pro .supp-aud-head {
  background: linear-gradient(90deg, rgba(79,195,161,.85) 0%, rgba(79,195,161,.45) 100%);
}
.supp-aud-head i { font-size: 12px; }

/* Iconos dentro de los headers de subsección */
.supp-h i { margin-right: 6px; font-size: 11px; opacity: .8; }

/* Las secciones dentro de un audience block se ven igual pero con borde izq sutil */
.supp-audience .supp-card-sec { border-left: 2px solid transparent; }
.supp-aud-patient .supp-card-sec { border-left-color: rgba(200,169,110,.12); }
.supp-aud-pro .supp-card-sec     { border-left-color: rgba(79,195,161,.12); }

/* Pestañas ocultas en módulo nutrient (sólo 1 hierba, no necesita tabs) */
#n-supp-tabs[style*="display:none"] + #n-supp-panels .supp-panel { display: block; padding: 0; }
#n-supp-panels .supp-panel { padding: 0 !important; }
#n-herb-body .pathway-box { background: var(--bg1); border: 1px solid var(--border); padding: 14px 18px; border-radius: 10px; }
#n-herb-body .pathway-id { font-family: var(--font-mono); font-size: 10px; color: var(--teal); letter-spacing: 1.5px; text-transform: uppercase; margin-bottom: 4px; }
#n-herb-body .pathway-name { font-family: var(--font-serif); font-size: 16px; color: var(--gold); margin-bottom: 6px; }
#n-herb-body .pathway-desc { font-size: 12.5px; color: var(--text-dim); line-height: 1.6; margin: 8px 0; }

/* ═══ SCROLLBAR VISIBLE EN LAS VISTAS (antes era invisible en algunos navegadores) ═══ */
.view {
  scrollbar-width: thin;
  scrollbar-color: var(--gold) var(--bg2);
}
.view::-webkit-scrollbar {
  width: 12px;
  height: 12px;
}
.view::-webkit-scrollbar-track {
  background: var(--bg2);
  border-left: 1px solid var(--border);
}
.view::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--gold) 0%, #b89656 100%);
  border-radius: 6px;
  border: 2px solid var(--bg2);
  min-height: 40px;
}
.view::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #d4b87a 0%, var(--gold) 100%);
}

/* Indicador "hay más abajo" — sticky hint en la parte inferior */
@keyframes hintPulse {
  0%, 100% { transform: translateY(0); opacity: .85; }
  50% { transform: translateY(-4px); opacity: 1; }
}

/* ═══ DESCRIPCIÓN AMPLIADA DE LA CONDICIÓN CLÍNICA ═══ */
#risk-box-wrap > div:first-child {
  padding: 22px 26px !important;
  margin-bottom: 22px !important;
}
#risk-box-wrap .md-content {
  font-size: 13.5px !important;
  line-height: 1.75 !important;
}
#risk-box-wrap .md-content p {
  margin: 0 0 14px 0;
}
#risk-box-wrap .md-content p:last-child { margin-bottom: 0; }
#risk-box-wrap .md-content strong {
  color: var(--gold);
  font-weight: 600;
}
#risk-box-wrap .md-bullets {
  margin: 10px 0 16px 0;
  padding-left: 22px;
}
#risk-box-wrap .md-bullets li {
  font-size: 13px;
  line-height: 1.7;
  margin-bottom: 8px;
  color: var(--text);
}
#risk-box-wrap .md-bullets li strong {
  color: var(--teal);
}
