/* ══ PATIENTS PAGE ══ */
.page{padding:20px;overflow-y:auto;flex:1}
.page-hdr{display:flex;align-items:center;gap:10px;margin-bottom:16px}
.page-title{font-size:15px;font-weight:600;color:var(--ink)}
.page-count{font-size:13px;color:var(--ink-l)}
.pbtn{height:30px;padding:0 12px;border-radius:3px;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;display:inline-flex;align-items:center;gap:4px}
.pbtn-green{background:#28a745;color:#fff}.pbtn-green:hover{background:#1e7e34}
.pbtn-blue{background:var(--blue);color:#fff}.pbtn-blue:hover{background:var(--blue-h)}
.pbtn-ghost{background:#fff;color:var(--ink-m);border:1px solid var(--gray-d)}.pbtn-ghost:hover{background:var(--gray-l)}
.p-search-bar{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px;background:#fff;padding:12px;border-radius:4px;border:1px solid var(--gray-d)}
.p-search-bar-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:0}
.p-sf{display:flex;flex-direction:column;gap:3px}
.p-sf label{font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em}
.p-sf input,.p-sf select{padding:6px 8px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:12.5px;outline:none}
.p-sf input:focus,.p-sf select:focus{border-color:var(--blue)}
.p-count{font-size:12.5px;color:var(--ink-m);margin-bottom:10px}
/* Patient grid */
.pat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0}
.pat-card{display:flex;align-items:center;gap:10px;padding:9px 14px;border-bottom:1px solid var(--gray-d);border-right:1px solid var(--gray-d);background:#fff;cursor:pointer;transition:background .1s}
.pat-card:hover{background:#f0f7ff}
.pat-avatar{width:38px;height:38px;border-radius:50%;background:#e0e0e0;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:14px;color:#9e9e9e;overflow:hidden}
.pat-avatar img{width:100%;height:100%;object-fit:cover}
.pat-dot{width:10px;height:10px;border-radius:50%;background:var(--gray-m);flex-shrink:0}
.pat-dot.green{background:#28a745}
.pat-dot.red{background:#dc3545}
.pat-name{font-size:12.5px;color:var(--blue);font-weight:500}
.pat-name:hover{text-decoration:underline}
.pat-alert{width:18px;height:18px;background:var(--orange);border-radius:3px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.pat-pagination{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;border-top:1px solid var(--gray-d);background:#fafafa;font-size:12px;color:var(--ink-m)}
.pat-pag-btn{height:26px;padding:0 10px;border:1px solid var(--gray-d);border-radius:3px;background:#fff;font-family:'DM Sans',sans-serif;font-size:11.5px;cursor:pointer;color:var(--ink-m)}
.pat-pag-btn:hover:not(:disabled){background:var(--blue-l);border-color:var(--blue);color:var(--blue)}
.pat-pag-btn:disabled{opacity:.4;cursor:not-allowed}
.pat-loading{text-align:center;padding:32px;color:var(--gray-m);font-size:13px}
.pat-suggest-item{padding:8px 12px;font-size:12.5px;cursor:pointer;border-bottom:1px solid var(--gray-d)}
.pat-suggest-item:last-child{border-bottom:none}
.pat-suggest-item:hover{background:var(--blue-l);color:var(--blue)}
.pat-suggest-item b{color:var(--blue)}

/* ══ PATIENT DETAIL PAGE ══ */
.pat-edit-topbar{background:#fff;border-bottom:1px solid var(--gray-d);padding:8px 16px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.pat-back-btn{width:36px;height:36px;border-radius:4px;background:#fd7e14;color:#fff;border:none;cursor:pointer;font-size:18px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.pat-back-btn:hover{background:#e06010}
.pat-edit-avatar{width:44px;height:44px;border-radius:50%;background:var(--orange);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff;flex-shrink:0}
.pat-edit-name{font-size:15px;font-weight:700;color:var(--ink);line-height:1.1;text-transform:uppercase}
.pat-edit-sub{font-size:12px;color:var(--ink-l)}
.pat-edit-actions{margin-left:auto;display:flex;gap:5px}
.pea-btn{height:34px;padding:0 13px;border-radius:4px;border:none;background:var(--blue);color:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:4px;transition:background .12s}
.pea-btn:hover{background:var(--blue-h)}.pea-btn.red{background:#dc3545}.pea-btn.red:hover{background:#b02a37}.pea-btn.green{background:#28a745}.pea-btn.green:hover{background:#1e7e34}
.pat-edit-sections{display:flex;gap:0;background:#f8f9fa;border-bottom:1px solid var(--gray-d);padding:0 8px;flex-shrink:0;overflow-x:auto}
.pat-sec-btn{padding:9px 14px;border:none;border-bottom:2px solid transparent;background:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink-m);font-weight:500;display:flex;align-items:center;gap:5px;transition:color .1s,border-color .1s;white-space:nowrap}
.pat-sec-btn:hover{color:var(--blue)}.pat-sec-btn.active{color:var(--blue);border-bottom-color:var(--blue);font-weight:600}
.pat-edit-body{padding:16px;overflow-y:auto;flex:1}
.pe-stats{font-size:12px;color:var(--ink-l);text-align:right;margin-bottom:12px}
.pe-section{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.07em;margin:14px 0 8px;border-bottom:1px solid var(--gray-d);padding-bottom:4px}
.pe-g2{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:12px}
.pe-g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px;margin-bottom:12px}
.pe-g4{display:grid;grid-template-columns:2fr 1fr 0.5fr 1fr;gap:14px;margin-bottom:12px}
.pe-g1{margin-bottom:12px}

@media (max-width: 768px) {
  .pe-g2, .pe-g3, .pe-g4 { grid-template-columns: 1fr !important; gap: 10px; }
  .pe-f label { font-size: 10px; }
}

.pe-f label{display:block;font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.pe-f input,.pe-f select,.pe-f textarea{width:100%;padding:7px 9px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;background:#fff;box-sizing:border-box}
.pe-f input:focus,.pe-f select:focus,.pe-f textarea:focus{border-color:var(--blue)}
.pe-f input:disabled,.pe-f select:disabled,.pe-f textarea:disabled{background:#f8f9fa;color:var(--ink-l)}
.pe-tabs{display:flex;gap:0;border-bottom:1px solid var(--gray-d);margin-bottom:14px}
.pe-tab{padding:7px 14px;border:none;border-bottom:2px solid transparent;background:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;color:var(--ink-m);font-weight:500;transition:color .1s}
.pe-tab:hover{color:var(--blue)}.pe-tab.active{color:var(--blue);border-bottom-color:var(--blue)}
.pe-actions{display:flex;gap:8px;margin-top:14px;padding-top:14px;border-top:1px solid var(--gray-d)}
.pe-btn-red{padding:7px 14px;border-radius:3px;background:#dc3545;color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:4px}.pe-btn-red:hover{background:#b02a37}
.pe-btn-green{padding:7px 14px;border-radius:3px;background:#28a745;color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:4px}.pe-btn-green:hover{background:#1e7e34}
.docs-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.docs-panel{background:#fff;border:1px solid var(--gray-d);border-radius:4px;overflow:hidden}
.docs-panel-title{padding:10px 14px;font-size:13px;font-weight:600;color:var(--ink);border-bottom:1px solid var(--gray-d)}
.docs-row{display:flex;align-items:center;padding:8px 14px;border-bottom:1px solid var(--gray-d)}
.docs-row:last-child{border-bottom:none}
.docs-row-name{flex:1;font-size:13px;color:var(--ink)}
.docs-row-btns{display:flex;gap:4px}
.docs-btn{width:28px;height:28px;border:none;border-radius:3px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0}
.docs-btn-edit{background:#5b9bd5;color:#fff}.docs-btn-edit:hover{background:#4a86c0}
.docs-btn-fill{background:#17a2b8;color:#fff}.docs-btn-fill:hover{background:#138496}
.adj-lbl{font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:4px}
.adj-date-wrap{display:flex;align-items:center;gap:6px;margin-bottom:16px}
.adj-date{padding:7px 9px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;width:160px}
.adj-date:focus{border-color:var(--blue)}
.adj-cal-btn{width:30px;height:30px;border-radius:3px;background:#e9f0fb;border:1px solid var(--gray-d);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;color:var(--blue)}
.adj-textarea{width:100%;padding:7px 9px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;resize:vertical;min-height:72px;box-sizing:border-box;margin-bottom:8px}
.adj-textarea:focus{border-color:var(--blue)}
.adj-hint{font-size:12px;color:var(--ink-l);margin-bottom:12px}
.adj-drop{background:#17a2b8;border-radius:4px;padding:32px 20px;text-align:center;color:#fff;font-size:14px;cursor:pointer;transition:background .15s;margin-bottom:16px;border:2px dashed transparent}
.adj-drop:hover,.adj-drop.dragover{background:#138496;border-color:rgba(255,255,255,.4)}
.adj-file-list{margin-bottom:12px}
.adj-file-row{display:flex;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--gray-d);font-size:13px}
.adj-file-row:last-child{border-bottom:none}
.adj-file-name{flex:1;color:var(--ink)}
.adj-file-size{font-size:11px;color:var(--ink-l)}
.adj-file-del{width:22px;height:22px;border-radius:3px;background:#dc3545;color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center}
.adj-actions{text-align:center}
.bonos-wrap{padding:4px 0}
.bonos-hdr{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-top:2px}
.bonos-hdr-title{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.07em;flex:1}
.bonos-add-select{padding:6px 10px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;min-width:200px;cursor:pointer}
.bonos-add-select:focus{border-color:var(--blue)}
.bonos-table{width:100%;border-collapse:collapse;font-size:12.5px}
.bonos-table th{padding:7px 12px;background:var(--gray-l);font-weight:600;color:var(--ink-m);text-align:left;border-bottom:1px solid var(--gray-d);font-size:11px;text-transform:uppercase;letter-spacing:.05em}
.bonos-table td{padding:8px 12px;border-bottom:1px solid var(--gray-d);color:var(--ink)}
.bonos-table tr:last-child td{border-bottom:none}
.bonos-empty{text-align:center;padding:24px;color:var(--ink-l);font-size:13px}
.bonos-del-btn{width:24px;height:24px;border-radius:3px;background:#dc3545;color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center}
.bonos-del-btn:hover{background:#b02a37}
.pe-btn-ghost{padding:7px 14px;border-radius:3px;background:#fff;color:var(--ink-m);border:1px solid var(--gray-d);cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:4px}.pe-btn-ghost:hover{background:var(--gray-l)}
.bonos-confirm-panel{display:block;background:#f0f7ff;border:1px solid #c5d9f7;border-radius:5px;padding:12px 16px;margin-bottom:12px}
.bonos-confirm-row1{display:flex;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid rgba(197,217,247,0.5)}
.bonos-confirm-envio{background:rgba(255,255,255,0.5);border-radius:4px;padding:10px;margin-bottom:12px;border:1px solid rgba(197,217,247,0.3)}
.bonos-envio-hdr{font-size:10px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px;display:flex;align-items:center;gap:5px}
.bonos-envio-grid{display:grid;grid-template-columns:140px 1fr;gap:12px}
.bonos-envio-field{display:flex;flex-direction:column;gap:3px}
.bonos-envio-field label{font-size:10.5px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.04em}
.bonos-envio-select{padding:5px 8px;border:1px solid var(--gray-d);border-radius:3px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;background:#fff}
.bonos-envio-select:focus{border-color:var(--blue)}
.bonos-cad-input{padding:5px 10px;border:1.5px solid var(--gray-d);border-radius:4px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;background:#fff;transition:all .15s;cursor:pointer}
.bonos-cad-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-l)}
.bonos-cad-input:hover{border-color:var(--blue-m)}
.bonos-cad-clear{width:22px;height:22px;border-radius:3px;background:none;border:1px solid var(--gray-d);cursor:pointer;font-size:11px;color:var(--ink-l);display:flex;align-items:center;justify-content:center}
.bonos-cad-clear:hover{background:#f8d7da;color:#dc3545;border-color:#dc3545}
.bonos-confirm-actions{display:flex;gap:6px}
.bonos-send-btn{width:24px;height:24px;border-radius:3px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .12s}
.bonos-send-btn:hover{background:var(--blue-h)}

.fact-panel{background:#fff;border:1px solid var(--gray-d);border-radius:4px;padding:16px;margin-bottom:16px}
.fact-panel-hdr{display:flex;align-items:center;margin-bottom:14px}
.fact-panel-title{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.07em;flex:1}
.fact-pass-btn{padding:7px 14px;border-radius:3px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12.5px;font-weight:500;display:inline-flex;align-items:center;gap:5px}
.fact-pass-btn:hover{background:var(--blue-h)}
.fact-cuenta-row{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.fact-cuenta-input{flex:1;padding:7px 9px;border-radius:3px;border:1px solid var(--gray-d);font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none}
.fact-cuenta-input:focus{border-color:var(--blue)}
.fact-cuenta-actions{display:flex;align-items:center;gap:10px;white-space:nowrap;font-size:12.5px;color:var(--ink-m)}
.fact-cuenta-actions label{display:flex;align-items:center;gap:4px;cursor:pointer}
.fact-radio-row{display:flex;align-items:center;gap:18px;margin-bottom:12px;font-size:13px;color:var(--ink-m)}
.fact-radio-row label{display:flex;align-items:center;gap:5px;cursor:pointer}
.fact-info-box{background:#f8f9fa;border:1px solid var(--gray-d);border-radius:3px;padding:14px 18px;margin-bottom:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px 24px}
.fact-info-lbl{font-size:12px;color:var(--ink-l)}
.fact-info-val{font-size:13px;color:var(--ink);font-weight:500}

/* ══ HISTORIAL DEL PACIENTE ══ */
.hist-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--gray-d)}
.hist-toolbar-title{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.07em;margin-right:4px}
.hist-filter-pill{display:inline-flex;align-items:center;gap:5px;padding:4px 11px;border-radius:20px;border:1.5px solid var(--gray-d);background:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--ink-m);transition:all .15s;white-space:nowrap;user-select:none}
.hist-filter-pill:hover{border-color:var(--blue);color:var(--blue)}
.hist-filter-pill.active{color:#fff;border-color:transparent}
.hist-filter-pill.active.pill-citas{background:#28a745}
.hist-filter-pill.active.pill-canceladas{background:#dc3545}
.hist-filter-pill.active.pill-notas{background:#0d6efd}
.hist-filter-pill.active.pill-bonos{background:#7c3aed}
.hist-filter-pill.active.pill-cobros{background:#0891b2}
.hist-filter-pill.active.pill-docs{background:#6c757d}
.hist-filter-pill .pill-dot{width:8px;height:8px;border-radius:50%;background:currentColor;flex-shrink:0}
.hist-filter-pill .pill-count{background:rgba(0,0,0,.12);border-radius:10px;padding:0 5px;font-size:10.5px;min-width:16px;text-align:center}
.hist-stats-row{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.hist-stat-box{flex:1;min-width:100px;background:#fff;border:1px solid var(--gray-d);border-radius:6px;padding:10px 14px;text-align:center}
.hist-stat-num{font-size:20px;font-weight:700;color:var(--ink);line-height:1}
.hist-stat-lbl{font-size:11px;color:var(--ink-l);margin-top:3px}
.hist-stat-box.accent-green .hist-stat-num{color:#28a745}
.hist-stat-box.accent-red .hist-stat-num{color:#dc3545}
.hist-stat-box.accent-purple .hist-stat-num{color:#7c3aed}
.hist-stat-box.accent-teal .hist-stat-num{color:#0891b2}
.hist-empty{text-align:center;padding:40px 20px;color:var(--ink-l);font-size:13px}
.hist-empty-icon{font-size:32px;margin-bottom:8px}
.hist-timeline{display:flex;flex-direction:column;gap:0}
.hist-group{margin-bottom:20px}
.hist-group-label{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.08em;padding:0 0 6px;border-bottom:1px solid var(--gray-d);margin-bottom:8px;display:flex;align-items:center;gap:6px}
.hist-entry{display:flex;align-items:flex-start;gap:12px;padding:10px 12px;border-radius:6px;border:1px solid var(--gray-d);background:#fff;margin-bottom:6px;transition:box-shadow .15s,border-color .15s}
.hist-entry:hover{border-color:#b0c4e0;box-shadow:0 2px 8px rgba(0,0,0,.07)}
.hist-entry-bar{width:4px;border-radius:4px;flex-shrink:0;align-self:stretch;min-height:36px}
.hist-entry-bar.bar-cita{background:#28a745}
.hist-entry-bar.bar-cancelada{background:#dc3545}
.hist-entry-bar.bar-nota{background:#0d6efd}
.hist-entry-bar.bar-bono{background:#7c3aed}
.hist-entry-bar.bar-cobro{background:#0891b2}
.hist-entry-bar.bar-doc{background:#6c757d}
.hist-entry-icon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}
.hist-entry-icon.ic-cita{background:#e8f5e9}
.hist-entry-icon.ic-cancelada{background:#fce8e8}
.hist-entry-icon.ic-nota{background:#e8f0fe}
.hist-entry-icon.ic-bono{background:#f3e8ff}
.hist-entry-icon.ic-cobro{background:#e0f7fa}
.hist-entry-icon.ic-doc{background:#f1f3f4}
.hist-entry-main{flex:1;min-width:0}
.hist-entry-top{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:3px}
.hist-entry-title{font-size:13px;font-weight:600;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.hist-entry-badge{padding:2px 8px;border-radius:12px;font-size:10.5px;font-weight:600;white-space:nowrap}
.badge-realizada{background:#d4edda;color:#155724}
.badge-confirmada{background:#fff3cd;color:#856404}
.badge-cancelada{background:#f8d7da;color:#721c24}
.badge-pendiente{background:#e2e3e5;color:#383d41}
.badge-pagada{background:#d4edda;color:#155724}
.hist-entry-sub{font-size:12px;color:var(--ink-m);display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.hist-entry-sub span{display:flex;align-items:center;gap:3px}
.hist-entry-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}
.hist-entry-date{font-size:11.5px;font-weight:600;color:var(--ink-m);white-space:nowrap}
.hist-entry-amount{font-size:13px;font-weight:700;color:var(--ink)}
.hist-entry-amount.positive{color:#28a745}
.hist-entry-amount.negative{color:#dc3545}
.hist-entry-notas{margin-top:6px;font-size:12px;color:var(--ink-m);background:#f8f9fa;border-left:3px solid var(--blue-l, #d0e4f7);border-radius:0 4px 4px 0;padding:5px 9px;line-height:1.4}
.hist-nota-standalone{font-size:12.5px;color:var(--ink);line-height:1.5;background:#eef4ff;border:1px solid #c5d9f7;border-left:3px solid #0d6efd;padding:8px 12px;border-radius:0 6px 6px 0}
.hist-no-results{text-align:center;padding:32px;color:var(--ink-l);font-size:13px}
.hist-bono-sessions{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:600;color:#7c3aed;background:#f3e8ff;padding:2px 8px;border-radius:10px}

/* ══ ANOTACIONES DEL PACIENTE ══ */
.anot-layout{display:grid;grid-template-columns:260px 1fr;gap:0;height:100%;min-height:0}
.anot-sidebar{border-right:1px solid var(--gray-d);display:flex;flex-direction:column;overflow:hidden;background:#fafafa}
.anot-sidebar-hdr{padding:10px 12px;border-bottom:1px solid var(--gray-d);display:flex;align-items:center;gap:6px;flex-shrink:0}
.anot-sidebar-title{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.07em;flex:1}
.anot-new-btn{height:28px;padding:0 10px;border-radius:4px;background:var(--blue);color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:3px;transition:background .12s;flex-shrink:0}
.anot-new-btn:hover{background:var(--blue-h)}
.anot-list{flex:1;overflow-y:auto;padding:6px}
.anot-item{padding:9px 11px;border-radius:5px;border:1px solid var(--gray-d);background:#fff;cursor:pointer;margin-bottom:5px;transition:border-color .12s,box-shadow .12s}
.anot-item:hover{border-color:#b0c4e0;box-shadow:0 1px 4px rgba(0,0,0,.07)}
.anot-item.active{border-color:var(--blue);background:#f0f7ff;box-shadow:0 0 0 2px rgba(52,152,219,.12)}
.anot-item-top{display:flex;align-items:center;gap:5px;margin-bottom:3px}
.anot-item-badge{padding:1px 7px;border-radius:10px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;flex-shrink:0}
.badge-valoracion{background:#dbeafe;color:#1d4ed8}
.badge-evolucion{background:#dcfce7;color:#166534}
.badge-corporal{background:#fef3c7;color:#92400e}
.anot-item-date{font-size:11px;color:var(--ink-l);margin-left:auto;flex-shrink:0}
.anot-item-summary{font-size:12px;color:var(--ink-m);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.anot-item-prof{font-size:11px;color:var(--ink-l);margin-top:2px}
.anot-empty-list{text-align:center;padding:32px 12px;color:var(--ink-l);font-size:12.5px}
.anot-editor{display:flex;flex-direction:column;overflow:hidden}
.anot-editor-hdr{padding:10px 16px;border-bottom:1px solid var(--gray-d);display:flex;align-items:center;gap:8px;flex-shrink:0;background:#fff}
.anot-type-tabs{display:flex;gap:0;border:1px solid var(--gray-d);border-radius:5px;overflow:hidden}
.anot-type-tab{padding:5px 12px;border:none;background:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:500;color:var(--ink-m);transition:background .1s,color .1s;white-space:nowrap}
.anot-type-tab:hover{background:#f0f7ff;color:var(--blue)}
.anot-type-tab.active{background:var(--blue);color:#fff}
.anot-editor-fecha{display:flex;align-items:center;gap:6px;margin-left:auto}
.anot-editor-fecha label{font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em}
.bonos-cad-input{padding:5px 10px;border:1.5px solid var(--gray-d);border-radius:4px;font-family:'DM Sans',sans-serif;font-size:12px;color:var(--ink);outline:none;background:#fff;transition:all .15s;cursor:pointer}
.bonos-cad-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-l)}
.bonos-cad-input:hover{border-color:var(--blue-m)}
.anot-editor-actions{display:flex;gap:5px;margin-left:12px}
.anot-save-btn{height:30px;padding:0 12px;border-radius:4px;background:#28a745;color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;display:inline-flex;align-items:center;gap:3px;transition:background .12s}
.anot-save-btn:hover{background:#1e7e34}
.anot-save-btn:disabled{opacity:.6;cursor:not-allowed}
.anot-del-btn{height:30px;padding:0 10px;border-radius:4px;background:#dc3545;color:#fff;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;transition:background .12s}
.anot-del-btn:hover{background:#b02a37}
.anot-editor-body{flex:1;overflow-y:auto;padding:16px}
.anot-form{display:flex;flex-direction:column;gap:0}
.anot-section{font-size:10.5px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.08em;padding:10px 0 5px;border-bottom:1px solid var(--gray-d);margin-bottom:10px;margin-top:6px}
.anot-section:first-child{margin-top:0;padding-top:0}
.anot-field{display:flex;flex-direction:column;gap:3px;margin-bottom:10px}
.anot-field label{font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em;display:flex;align-items:center;gap:5px}
.anot-field label span{font-weight:400;color:var(--ink-l);font-size:10.5px;text-transform:none;letter-spacing:0}
.anot-field input,.anot-field select,.anot-field textarea{width:100%;padding:7px 9px;border:1px solid var(--gray-d);border-radius:3px;font-family:'DM Sans',sans-serif;font-size:13px;color:var(--ink);outline:none;background:#fff;box-sizing:border-box;resize:vertical}
.anot-field input:focus,.anot-field select:focus,.anot-field textarea:focus{border-color:var(--blue)}
.anot-g2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px}
.anot-g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px;margin-bottom:10px}
.anot-dolor-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.anot-dolor-lbl{font-size:11px;font-weight:600;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em}
.anot-dolor-scale{display:flex;gap:3px}
.anot-dolor-btn{width:28px;height:28px;border-radius:4px;border:1.5px solid var(--gray-d);background:#fff;cursor:pointer;font-family:'DM Sans',sans-serif;font-size:12px;font-weight:600;color:var(--ink-m);transition:all .12s;display:flex;align-items:center;justify-content:center}
.anot-dolor-btn:hover{border-color:var(--blue);color:var(--blue)}
.anot-dolor-btn.active{border-color:transparent;color:#fff}
.anot-dolor-btn[data-v="0"].active,.anot-dolor-btn[data-v="1"].active,.anot-dolor-btn[data-v="2"].active{background:#28a745}
.anot-dolor-btn[data-v="3"].active,.anot-dolor-btn[data-v="4"].active{background:#8bc34a}
.anot-dolor-btn[data-v="5"].active,.anot-dolor-btn[data-v="6"].active{background:#ffc107}
.anot-dolor-btn[data-v="7"].active,.anot-dolor-btn[data-v="8"].active{background:#ff7043}
.anot-dolor-btn[data-v="9"].active,.anot-dolor-btn[data-v="10"].active{background:#dc3545}
.anot-dolor-text{font-size:12px;color:var(--ink-m);font-style:italic}
.anot-no-selection{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--ink-l);font-size:13px;gap:10px;padding:40px}
.anot-no-selection-icon{font-size:40px;opacity:.4}
/* Diagrama corporal */
.anot-diagram-wrap{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:12px}
.anot-diagram-panel{display:flex;flex-direction:column;align-items:center;gap:8px}
.anot-diagram-lbl{font-size:11px;font-weight:700;color:var(--ink-l);text-transform:uppercase;letter-spacing:.06em}
.anot-diagram-canvas-wrap{position:relative;border:1.5px solid var(--gray-d);border-radius:6px;overflow:hidden;background:#fff;cursor:crosshair}
.anot-diagram-canvas-wrap svg{display:block}
.anot-diagram-canvas-wrap canvas{position:absolute;top:0;left:0;cursor:crosshair}
.anot-diagram-tools{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.anot-diagram-color{width:22px;height:22px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:border-color .1s,transform .1s}
.anot-diagram-color:hover,.anot-diagram-color.active{border-color:var(--ink);transform:scale(1.15)}
.anot-diagram-tool-btn{height:26px;padding:0 9px;border-radius:3px;border:1px solid var(--gray-d);background:#fff;font-family:'DM Sans',sans-serif;font-size:11.5px;cursor:pointer;color:var(--ink-m);transition:background .1s}
.anot-diagram-tool-btn:hover{background:var(--gray-l)}
.anot-diagram-tool-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}
.anot-diagram-legend{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:11px;color:var(--ink-m);margin-top:4px}
.anot-diagram-legend span{display:flex;align-items:center;gap:3px}
.anot-diagram-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.anot-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;text-align:center;color:var(--ink-l);font-size:13px;gap:8px}

