/* ============================================================
   ESCRITOS — MODERN STYLES
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{--bg:#f0f2f5;--bg-card:#fff;--border:#e2e8f0;--text:#1e293b;--text-light:#64748b;--text-muted:#94a3b8;--accent:#4f46e5;--accent-light:#eef2ff;--radius:12px;--shadow-sm:0 1px 2px rgba(0,0,0,.05);--shadow-md:0 4px 12px rgba(0,0,0,.08);--shadow-lg:0 12px 32px rgba(0,0,0,.12);--font:'DM Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;--font-display:'Plus Jakarta Sans','DM Sans',sans-serif}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;-webkit-font-smoothing:antialiased;display:flex;flex-direction:column}
.ico{width:18px;height:18px;display:inline-block;vertical-align:middle;fill:none;stroke:currentColor;flex-shrink:0}
.ico--sm{width:14px;height:14px}
.ico--2x{width:28px;height:28px}
.hidden{display:none!important}

/* ---- Header (matches OCR) ---- */
header{background:#fff;border-bottom:1px solid var(--border);padding:10px 32px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;flex-shrink:0}
.title{display:flex;align-items:center;gap:14px}
.title h1{font-size:20px;font-weight:700;color:#0f172a;letter-spacing:-.02em}
.title p{font-size:12px;color:var(--text-muted);margin-top:1px}
.backToSelector{color:var(--text-light);text-decoration:none;display:flex}
.backToSelector:hover{color:var(--accent)}
.headerRight{display:flex;align-items:center;gap:14px}
.headerBtn{background:#f8fafc;border:1px solid var(--border);border-radius:8px;padding:7px 16px;font-size:13px;font-family:inherit;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:#475569;transition:.15s;text-decoration:none}
.headerBtn:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}
.headerBtn .ico{width:14px;height:14px}
.headerBtn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.headerBtn.primary:hover{background:#4338ca}
.headerBtn.primary .ico{stroke:#fff}

/* ---- Main ---- */
main{flex:1;width:100%}
.mainWrap{max-width:860px;margin:0 auto;padding:24px 20px 40px}
.mainWrap.wide{max-width:100%;padding:0}

/* ---- Footer ---- */
footer{text-align:center;padding:8px 20px;font-size:11px;color:var(--text-muted);border-top:1px solid var(--border);background:#fff;flex-shrink:0;letter-spacing:.2px}
footer strong{color:var(--text-light);font-weight:600}

/* ---- Wizard Stepper ---- */
.stepper{display:flex;align-items:center;justify-content:center;gap:0;padding:20px 0 8px}
.step{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-muted);font-weight:500}
.stepDot{width:28px;height:28px;border-radius:50%;background:#e2e8f0;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#94a3b8;transition:.2s}
.step.active .stepDot{background:var(--accent);color:#fff}
.step.done .stepDot{background:#10b981;color:#fff}
.step.active{color:var(--text)}
.stepLine{width:40px;height:2px;background:#e2e8f0;margin:0 4px}

/* ---- Pages ---- */
.wizardPane{padding:16px 0}
.pageTitle{font-family:var(--font-display);font-size:22px;font-weight:700;text-align:center;color:var(--text);margin-bottom:6px}
.pageSubtitle{text-align:center;font-size:14px;color:var(--text-muted);margin-bottom:24px}

/* ---- Category Cards ---- */
.catGrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;max-width:840px;margin:0 auto}
.catCard{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius);padding:24px 20px;cursor:pointer;transition:.2s;display:flex;align-items:center;gap:16px;text-align:left}
.catCard:hover{border-color:var(--accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}
.catIcon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.catIcon .ico{width:24px;height:24px}
.catCard .catLabel{font-size:15px;font-weight:600;color:var(--text)}
.catCard .catDesc{font-size:12px;color:var(--text-muted);margin-top:2px}

/* Category color themes */
.catIcon.cat-aeat{background:#fef3c7;color:#d97706}
.catIcon.cat-aeat .ico{stroke:#d97706}
.catIcon.cat-procesales{background:#ede9fe;color:#7c3aed}
.catIcon.cat-procesales .ico{stroke:#7c3aed}
.catIcon.cat-burofaxes{background:#dbeafe;color:#2563eb}
.catIcon.cat-burofaxes .ico{stroke:#2563eb}
.catIcon.cat-cover_irpf{background:#dcfce7;color:#16a34a}
.catIcon.cat-cover_irpf .ico{stroke:#16a34a}
.catIcon.cat-memorias{background:#fce7f3;color:#db2777}
.catIcon.cat-memorias .ico{stroke:#db2777}
.catIcon.cat-sancionadores{background:#fee2e2;color:#dc2626}
.catIcon.cat-sancionadores .ico{stroke:#dc2626}
/* Subcategory colors */
.catIcon.sub-ampliacion_plazo{background:#fef3c7;color:#d97706}
.catIcon.sub-ampliacion_plazo .ico{stroke:#d97706}
.catIcon.sub-contestacion_requerimiento{background:#e0f2fe;color:#0284c7}
.catIcon.sub-contestacion_requerimiento .ico{stroke:#0284c7}
.catIcon.sub-alegaciones{background:#dbeafe;color:#2563eb}
.catIcon.sub-alegaciones .ico{stroke:#2563eb}
.catIcon.sub-recurso_reposicion{background:#ede9fe;color:#7c3aed}
.catIcon.sub-recurso_reposicion .ico{stroke:#7c3aed}
.catIcon.sub-rec_economico_admin{background:#dcfce7;color:#16a34a}
.catIcon.sub-rec_economico_admin .ico{stroke:#16a34a}
.catIcon.sub-interposicion_rea{background:#e0f2fe;color:#0284c7}
.catIcon.sub-interposicion_rea .ico{stroke:#0284c7}
.catIcon.sub-sanc_alegaciones{background:#fee2e2;color:#dc2626}
.catIcon.sub-sanc_alegaciones .ico{stroke:#dc2626}
.catIcon.sub-sanc_recurso_reposicion{background:#fef3c7;color:#d97706}
.catIcon.sub-sanc_recurso_reposicion .ico{stroke:#d97706}
.catIcon.sub-sanc_interposicion_rea{background:#e0f2fe;color:#0284c7}
.catIcon.sub-sanc_interposicion_rea .ico{stroke:#0284c7}
.catIcon.sub-sanc_rec_economico_admin{background:#fce7f3;color:#db2777}
.catIcon.sub-sanc_rec_economico_admin .ico{stroke:#db2777}
.catIcon.sub-interposicion_rea_abreviado{background:#ccfbf1;color:#0d9488}
.catIcon.sub-interposicion_rea_abreviado .ico{stroke:#0d9488}
.catIcon.sub-sanc_interposicion_rea_abreviado{background:#ffedd5;color:#ea580c}
.catIcon.sub-sanc_interposicion_rea_abreviado .ico{stroke:#ea580c}

/* ---- Client Selector ---- */
.clienteSelector{max-width:640px;margin:0 auto 16px}
.escClienteWrap{position:relative}
.contextInput{display:block;width:100%;border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;font-size:14px;font-family:inherit;color:var(--text);transition:.15s}
.contextInput:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.contextInput.hasSelection{background:#f0fdf4;border-color:#86efac}
.escClienteDropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow-lg);max-height:240px;overflow-y:auto;z-index:50;margin-top:4px}
.escDropItem{padding:10px 14px;cursor:pointer;font-size:13px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #f8fafc}
.escDropItem:hover{background:var(--accent-light)}
.escDropItem.disabled{cursor:default;color:var(--text-muted);justify-content:center}
.escDropItem strong{font-weight:600;color:var(--text)}
.escDropItem span{color:var(--text-muted);font-size:12px}

/* ---- Upload Zone ---- */
.uploadZone{border:2px dashed #cbd5e1;border-radius:var(--radius);padding:40px;text-align:center;cursor:pointer;transition:.2s;background:#fafbfc;max-width:640px;margin:0 auto}
.uploadZone:hover,.uploadZone.dragover{border-color:var(--accent);background:var(--accent-light)}
.uploadIcon{margin-bottom:12px}
.uploadZone p{font-size:14px;color:var(--text-light);margin-top:4px}
.uploadHint{font-size:12px!important;color:var(--text-muted)!important}

/* ---- File List ---- */
.fileList{max-width:640px;margin:16px auto 0;display:flex;flex-direction:column;gap:6px}
.fileItem{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;font-size:13px}
.fileItem .fileIcon{width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.fileItem .fileIcon .ico{width:16px;height:16px}
.fileItem .fileIcon.pdf{background:#fef2f2;color:#dc2626}.fileItem .fileIcon.pdf .ico{stroke:#dc2626}
.fileItem .fileIcon.word{background:#dbeafe;color:#2563eb}.fileItem .fileIcon.word .ico{stroke:#2563eb}
.fileItem .fileIcon.excel{background:#dcfce7;color:#16a34a}.fileItem .fileIcon.excel .ico{stroke:#16a34a}
.fileItem .fileIcon.img{background:#fef3c7;color:#d97706}.fileItem .fileIcon.img .ico{stroke:#d97706}
.fileItem .fileIcon.other{background:#f1f5f9;color:#64748b}.fileItem .fileIcon.other .ico{stroke:#64748b}
.fileItem .fileName{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.fileItem .fileSize{color:var(--text-muted);font-size:11px;flex-shrink:0}
.fileItem .fileRemove{background:none;border:none;cursor:pointer;color:#94a3b8;padding:4px;display:flex;border-radius:4px}
.fileItem .fileRemove:hover{color:#dc2626;background:#fef2f2}
.fileItem .fileRemove .ico{width:14px;height:14px}

/* ---- Context ---- */
.contextLabel{display:block;font-size:13px;font-weight:600;color:var(--text);margin-bottom:6px;max-width:640px;margin-left:auto;margin-right:auto}
.contextArea{display:block;width:100%;max-width:640px;margin:0 auto 8px;border:1.5px solid var(--border);border-radius:10px;padding:14px;font-size:14px;font-family:inherit;resize:vertical;min-height:140px;color:var(--text);transition:.15s;line-height:1.5}
.contextArea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.1)}
.contextHint{font-size:12px;color:var(--text-muted);max-width:640px;margin:0 auto}

/* ---- Action Bar ---- */
.actionBar{display:flex;align-items:center;gap:12px;margin-top:24px;max-width:640px;margin-left:auto;margin-right:auto}
.spacer{flex:1}

/* ---- Generating Screen ---- */
.genScreen{text-align:center;padding:60px 20px}
.genSpinner{width:48px;height:48px;border:4px solid #e2e8f0;border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 20px}
@keyframes spin{to{transform:rotate(360deg)}}
.genTitle{font-family:var(--font-display);font-size:20px;font-weight:700;margin-bottom:10px}
.genStatus{font-size:14px;color:var(--text-muted);max-width:420px;margin:0 auto;line-height:1.5}
.genProgress{font-size:24px;font-weight:600;color:var(--text-light);margin-top:16px;font-variant-numeric:tabular-nums}
.genErrorIcon{margin-bottom:16px}

/* ---- Editor View ---- */
#editorView{max-width:none;margin:0;padding:0;width:100%}
.editorWrap{height:100vh;display:flex;flex-direction:column}
.editorTopBar{display:flex;align-items:center;justify-content:space-between;padding:8px 16px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0;z-index:10}
.editorTopLeft,.editorTopRight{display:flex;align-items:center;gap:10px}
.editorLabel{font-size:13px;color:var(--text-muted);font-weight:500}
.collaboraFrame{flex:1;width:100%;border:none}
.collaboraFallback{flex:1;display:flex;align-items:center;justify-content:center;background:#f8fafc;border-top:1px solid var(--border)}
.fallbackContent{text-align:center;padding:40px 20px;max-width:420px}
.fallbackContent h3{font-size:18px;font-weight:700;color:var(--text);margin:16px 0 8px}
.fallbackContent p{font-size:14px;color:var(--text-muted);line-height:1.6}

/* ---- Chat FAB ---- */
.chatToggle{position:fixed;bottom:24px;right:24px;height:48px;border-radius:24px;background:var(--accent);color:#fff;border:none;cursor:pointer;box-shadow:var(--shadow-lg);display:flex;align-items:center;justify-content:center;gap:8px;z-index:200;transition:.15s;padding:0 18px;font-size:13px;font-weight:600;font-family:inherit}
.chatToggle:hover{transform:scale(1.04);background:#4338ca}
.chatToggle svg{stroke:#fff;flex-shrink:0}
.chatToggle.attention{animation:chatAttention 1s ease 0.8s 2}
@keyframes chatAttention{
  0%,100%{transform:translateY(0) scale(1)}
  20%{transform:translateY(-8px) scale(1.06)}
  40%{transform:translateY(2px) scale(0.98)}
  60%{transform:translateY(-4px) scale(1.03)}
  80%{transform:translateY(1px) scale(0.99)}
}
.badge{position:absolute;top:-2px;right:-2px;width:18px;height:18px;border-radius:50%;background:#dc2626;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center}

/* ---- Chat Overlay ---- */
.chatOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:300;justify-content:flex-end;align-items:stretch}
.chatOverlay.open{display:flex}
.chatPanel{width:520px;max-width:100vw;height:100%;background:#fff;display:flex;flex-direction:column;box-shadow:-4px 0 20px rgba(0,0,0,.1)}
.chatHeader{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border);background:#fafafa}
.chatHeader h3{font-size:16px;font-weight:600;display:flex;align-items:center;gap:8px}
.chatClose{background:none;border:none;font-size:22px;cursor:pointer;color:var(--text-muted);padding:4px;line-height:1}
.chatClose:hover{color:var(--text)}
.chatMessages{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:12px}
.chatMsg{max-width:85%;padding:12px 16px;border-radius:14px;font-size:14px;line-height:1.6;word-wrap:break-word;white-space:pre-wrap}
.chatMsg.user{align-self:flex-end;background:var(--accent);color:#fff;border-bottom-right-radius:4px}
.chatMsg.assistant{align-self:flex-start;background:#f1f5f9;color:var(--text);border-bottom-left-radius:4px}
.chatInputRow{display:flex;gap:8px;padding:14px 16px;border-top:1px solid var(--border)}
.chatInput{flex:1;border:1.5px solid var(--border);border-radius:10px;padding:10px 14px;font-size:14px;font-family:inherit;resize:none;min-height:44px;max-height:120px}
.chatInput:focus{outline:none;border-color:var(--accent)}
.chatSend{background:var(--accent);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-family:inherit;cursor:pointer;font-weight:600}
.chatSend:disabled{opacity:.4;cursor:not-allowed}
.chatTyping{font-size:13px;color:var(--text-muted);padding:8px 16px;font-style:italic}

/* ---- Legal Refs ---- */
.refsToggle{position:fixed;bottom:24px;right:88px;background:#fff;border:1px solid var(--border);border-radius:20px;padding:8px 14px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-light);box-shadow:var(--shadow-sm);z-index:200;font-family:inherit;transition:.15s}
.refsToggle:hover{border-color:var(--accent);color:var(--accent)}
.refsToggle .ico{width:14px;height:14px}
.refsPanel{position:fixed;bottom:68px;right:88px;width:360px;max-height:420px;overflow-y:auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:16px;z-index:200;font-size:13px}
.refItem{display:flex;align-items:flex-start;gap:8px;padding:8px 0;border-bottom:1px solid #f1f5f9}
.refItem:last-child{border-bottom:none}
.refBadge{width:20px;height:20px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.refBadge.ok{background:#dcfce7;color:#16a34a}
.refBadge.fail{background:#fef2f2;color:#dc2626}
.refBadge.unknown{background:#fef3c7;color:#d97706}
.refText{flex:1;min-width:0;font-size:12px;color:var(--text);word-break:break-word}
.refLink{font-size:10px;color:var(--accent);text-decoration:none;white-space:nowrap;flex-shrink:0}
.refLink:hover{text-decoration:underline}
.refPdfBadge{font-size:11px;flex-shrink:0;cursor:default}
.refsLegend{display:flex;gap:12px;flex-wrap:wrap;margin-top:10px;padding-top:10px;border-top:1px solid #f1f5f9;font-size:11px;color:var(--text-muted)}
.refsLegend span{display:flex;align-items:center;gap:4px}

/* ---- Settings Modal ---- */
.settingsOverlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:400;justify-content:center;align-items:center}
.settingsOverlay.open{display:flex}
.settingsBox{background:#fff;border-radius:var(--radius);width:860px;max-width:95vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:var(--shadow-lg)}
.settingsHeader{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.settingsHeader h2{font-size:16px;font-weight:700;display:flex;align-items:center;gap:8px}
.settingsBody{flex:1;overflow-y:auto;padding:20px}
.settingsCatItem{border:1px solid var(--border);border-radius:10px;margin-bottom:14px;overflow:hidden}
.settingsCatItem h4{font-size:14px;font-weight:700;padding:14px 16px 0;color:var(--text);display:flex;align-items:center;gap:8px}
.settingsSubcat{padding:12px 16px;border-top:1px solid #f1f5f9}
.settingsSubcat:first-of-type{border-top:none;padding-top:6px}
.settingsCatName{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px}
.settingsField{margin-bottom:10px}
.settingsField label{display:block;font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}
.settingsField textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:13px;font-family:inherit;min-height:72px;resize:vertical;color:var(--text);line-height:1.5;transition:.15s}
.settingsField textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(79,70,229,.08)}
.settingsField textarea::placeholder{color:#c1c9d4}
.fieldRow{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.templateBadge{font-size:11px;color:#16a34a;font-weight:600;display:inline-flex;align-items:center;gap:4px}
.settingsCatItem .headerBtn{font-size:11px;padding:5px 12px}

/* Settings tabs */
.settingsTabs{display:flex;gap:0;border-bottom:1px solid var(--border);padding:0 20px}
.settingsTab{padding:10px 18px;font-size:13px;font-weight:600;color:var(--text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:.15s}
.settingsTab:hover{color:var(--text)}
.settingsTab.active{color:var(--accent);border-bottom-color:var(--accent)}
.settingsPane{display:none}
.settingsPane.active{display:block}
.settingsHint{font-size:13px;color:#94a3b8;margin-bottom:16px;line-height:1.5}
.settingsHint code{background:#f1f5f9;padding:1px 5px;border-radius:4px;font-size:12px;color:var(--accent)}

/* Memorias templates grid */
.memTplGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.memTplCard{border:1.5px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:6px;transition:.15s}
.memTplCard.uploaded{border-color:#22c55e;background:#f0fdf4}
.memTplCardHeader{display:flex;justify-content:space-between;align-items:flex-start}
.memTplKey{font-size:11px;font-weight:700;color:var(--accent);background:#eef2ff;padding:2px 7px;border-radius:4px;letter-spacing:.3px}
.memTplLabel{font-size:12px;font-weight:600;color:var(--text);line-height:1.3;margin-top:2px}
.memTplStatus{font-size:11px;color:#94a3b8;display:flex;align-items:center;gap:4px}
.memTplStatus.ok{color:#16a34a}
.memTplActions{display:flex;gap:6px;margin-top:4px}
.memTplActions .headerBtn{font-size:10px;padding:3px 8px}

/* Placeholders table */
.phToolbar{display:flex;gap:8px;margin-bottom:12px;align-items:center;flex-wrap:wrap}
.phSearchInput{flex:1;min-width:140px;border:1.5px solid var(--border);border-radius:8px;padding:7px 12px;font-size:13px;font-family:inherit;color:var(--text)}
.phSearchInput:focus{outline:none;border-color:var(--accent)}
.phSelect{border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:12px;font-family:inherit;color:var(--text);background:#fff;cursor:pointer}
.phTableWrap{overflow-x:auto;max-height:420px;overflow-y:auto;border:1px solid var(--border);border-radius:10px}
.phTable{width:100%;border-collapse:collapse;font-size:12px}
.phTable thead{position:sticky;top:0;z-index:1}
.phTable th{background:#f8fafc;padding:8px 10px;text-align:left;font-weight:600;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.4px;border-bottom:1px solid var(--border)}
.phTable td{padding:7px 10px;border-bottom:1px solid #f1f5f9;vertical-align:middle}
.phTable tr:hover td{background:#fafbfe}
.phTable .phKey{font-family:'SF Mono',Consolas,monospace;font-size:11px;color:var(--accent);font-weight:600;cursor:pointer;user-select:all}
.phTable .phSrc{font-size:10px;padding:2px 6px;border-radius:4px;font-weight:600}
.phTable .phSrc.auto{background:#dbeafe;color:#1d4ed8}
.phTable .phSrc.input{background:#fef3c7;color:#92400e}
.phTable .phCat{font-size:10px;color:#64748b;background:#f1f5f9;padding:2px 6px;border-radius:4px}
.phTable .phDesc{font-size:11px;color:#94a3b8;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.phDeleteBtn{background:none;border:none;color:#dc2626;cursor:pointer;padding:2px;opacity:.5;transition:.15s}
.phDeleteBtn:hover{opacity:1}

/* Placeholder add form */
.phAddForm{border:1.5px solid var(--accent);border-radius:10px;padding:16px;margin-top:12px;background:#fafbff}
.phAddForm h4{font-size:13px;font-weight:700;margin-bottom:10px;color:var(--text)}
.phFormRow{display:flex;gap:12px;margin-bottom:10px}
.phFormRow label{flex:1;font-size:11px;font-weight:600;color:var(--text-muted);display:flex;flex-direction:column;gap:4px}
.phFormRow input,.phFormRow select{border:1.5px solid var(--border);border-radius:7px;padding:7px 10px;font-size:13px;font-family:inherit;color:var(--text)}
.phFormRow input:focus,.phFormRow select:focus{outline:none;border-color:var(--accent)}
.phFormActions{display:flex;gap:8px;justify-content:flex-end}

/* Memorias wizard: repr cards */
.memReprCard{border:1px solid var(--border);border-radius:8px;padding:10px 12px;margin-bottom:8px;display:flex;flex-direction:column;gap:6px}
.memReprHeader{display:flex;justify-content:space-between;align-items:center}
.memReprList{max-height:420px;overflow-y:auto;padding-right:4px}
.memNotaField{margin-bottom:8px}
.memUploadGrid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;max-width:700px;margin:20px auto}
.memUploadBox{border:2px dashed var(--border);border-radius:10px;padding:20px 16px;text-align:center;transition:.2s}
.memUploadBox:hover{border-color:var(--accent);background:rgba(79,70,229,.02)}
.memUploadLabel{font-weight:600;font-size:13px;display:block;margin-bottom:4px;color:var(--text)}
.memUploadHint{font-size:11px;color:var(--text-muted);margin:0 0 10px}
.memFileInput{font-size:12px;max-width:100%}
.memFileName{font-size:11px;color:var(--accent);margin-top:6px;min-height:16px;word-break:break-all}
.memNotasStatus{display:flex;align-items:center;gap:10px;justify-content:center;padding:16px;margin:16px auto;max-width:700px;background:var(--accent-light);border-radius:10px;font-size:13px;font-weight:500;color:var(--accent)}

/* Memorias wizard: stepper */
.memStepper{display:flex;align-items:center;justify-content:center;gap:0;padding:16px 12px 12px;margin-bottom:8px;flex-wrap:wrap}
.memStep{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--text-muted);font-weight:500;white-space:nowrap}
.memStepDot{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:2px solid var(--border);font-size:11px;font-weight:700;color:var(--text-muted);background:var(--bg-card);flex-shrink:0;transition:.2s}
.memStepLabel{display:inline;font-size:11px}
.memStepLine{width:16px;height:2px;background:var(--border);flex-shrink:0;margin:0 2px;transition:.2s}
.memStep.active .memStepDot{background:var(--accent);color:#fff;border-color:var(--accent)}
.memStep.active{color:var(--text);font-weight:600}
.memStep.done .memStepDot{background:#10b981;color:#fff;border-color:#10b981}
.memStep.done{color:#10b981}
.memStep.done+.memStepLine{background:#10b981}

/* Memorias wizard: form layout */
.memSocGrid{display:flex;flex-direction:column;gap:8px;max-width:700px;margin:0 auto 16px}
.memSocGrid .ampRow{display:flex;align-items:center;gap:12px}
.memSocGrid .ampRow label{min-width:180px;font-size:13px;font-weight:600;color:var(--text-muted);text-align:right;flex-shrink:0}
.memSocGrid .ampRow .contextInput{flex:1;margin:0}
.memSection{margin-bottom:16px;max-width:640px;margin-left:auto;margin-right:auto}
.memSectionTitle{font-size:13px;font-weight:700;color:var(--accent);margin:16px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border)}

/* Memorias wizard: employees grid */
.memEmplGrid{max-width:620px;margin:0 auto 16px;border:1px solid var(--border);border-radius:10px;overflow:hidden}
.memEmplHeader{display:grid;grid-template-columns:80px repeat(5,1fr);gap:0;background:var(--accent);color:#fff;font-size:11px;font-weight:700;text-align:center;padding:8px 0}
.memEmplHeader span{padding:4px 6px;line-height:1.2}
.memEmplRow{display:grid;grid-template-columns:80px repeat(5,1fr);gap:0;border-top:1px solid var(--border);align-items:center}
.memEmplRow:nth-child(odd){background:var(--bg-card)}
.memEmplLabel{font-size:13px;font-weight:700;color:var(--text);padding:6px 8px;text-align:center;background:rgba(79,70,229,.06)}
.memEmplInput{border:none !important;border-radius:0 !important;text-align:center;padding:8px 4px !important;font-size:13px;background:transparent !important;width:100%;box-sizing:border-box;-moz-appearance:textfield;appearance:textfield}
.memEmplInput::-webkit-inner-spin-button,.memEmplInput::-webkit-outer-spin-button{-webkit-appearance:none;appearance:none;margin:0}
.memEmplInput:focus{background:rgba(79,70,229,.05) !important;outline:2px solid var(--accent) !important;outline-offset:-2px}

/* Memorias wizard: doc selection (phase 7) */
.memDocsSelect{display:flex;flex-direction:column;gap:10px;max-width:500px;margin:0 auto 20px}
.memDocCheck{display:flex;align-items:center;gap:10px;padding:12px 16px;border:1.5px solid var(--border);border-radius:10px;cursor:pointer;font-size:14px;transition:.15s}
.memDocCheck:hover{border-color:var(--accent);background:rgba(79,70,229,.03)}
.memDocCheck input[type="checkbox"]{width:18px;height:18px;accent-color:var(--accent)}
.memDocLabel{font-weight:600;color:var(--text);flex:1}
.memDocKey{font-size:11px;font-weight:700;padding:3px 8px;border-radius:6px;background:var(--accent-light);color:var(--accent);font-family:monospace}

/* Memorias wizard: summary (phase 7) */
.memResumen{border:1px solid var(--border);border-radius:10px;padding:16px;max-width:500px;margin:0 auto;background:var(--bg-card)}
.memResumenTitle{font-size:13px;font-weight:700;color:var(--accent);margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--border)}

/* Memorias wizard: validation */
.memValidation{padding:10px 14px;border-radius:8px;font-size:13px;background:#fef3c7;color:#92400e;border:1px solid #fde68a;margin:10px auto;max-width:500px}
.memSuccessIcon{margin-bottom:16px}

/* Memorias wizard: notas list */
.memNotasList{max-width:700px;margin:0 auto 16px}

/* Custom placeholder fields (regular wizard) */
.phFieldsList{max-width:640px;margin:0 auto 16px}
.phSectionLabel{font-size:12px;font-weight:700;color:var(--accent);text-transform:uppercase;letter-spacing:.5px;margin:12px 0 8px;padding-bottom:4px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.phSectionAuto{color:var(--text-muted)}
.phFieldRequired .contextInput{border-color:#f59e0b;background:#fffbeb}
.phFieldRequired .contextInput:focus{border-color:var(--accent);background:#fff}
.phFieldAuto .contextInput{background:#f0fdf4;border-color:#86efac}
.phFieldAuto .contextInput:focus{border-color:var(--accent);background:#fff}

/* ---- History List ---- */
.historyList{display:flex;flex-direction:column;gap:8px}
.historyItem{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;font-size:13px;transition:.15s}
.historyItem:hover{box-shadow:var(--shadow-sm)}
.historyItem .histIcon{width:36px;height:36px;border-radius:8px;background:var(--accent-light);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.historyItem .histIcon .ico{width:16px;height:16px;stroke:var(--accent)}
.historyItem .histInfo{flex:1;min-width:0}
.historyItem .histTitle{font-weight:600;color:var(--text)}
.historyItem .histDate{font-size:11px;color:var(--text-muted);margin-top:2px}
.historyItem .histBadge{font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600;flex-shrink:0}
.historyItem .histBadge.completed{background:#dcfce7;color:#16a34a}
.historyItem .histBadge.editing{background:#dbeafe;color:#2563eb}
.historyItem .histActions{display:flex;gap:6px;flex-shrink:0}
.histTitleInput{width:100%;border:1.5px solid var(--accent);border-radius:6px;padding:2px 8px;font-size:13px;font-weight:600;font-family:inherit;color:var(--text);outline:none;background:#fafaff}

/* ---- Toast ---- */
.toastContainer{position:fixed;top:70px;right:20px;z-index:500;display:flex;flex-direction:column;gap:8px}
.toast{padding:12px 20px;border-radius:10px;font-size:13px;font-weight:500;box-shadow:var(--shadow-md);animation:toastIn .3s ease;max-width:380px}
.toast.success{background:#dcfce7;color:#15803d;border:1px solid #bbf7d0}
.toast.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}
.toast.info{background:#dbeafe;color:#1d4ed8;border:1px solid #bfdbfe}
@keyframes toastIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}

/* ---- Custom Confirm Dialog ---- */
.confirmOverlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:600;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}
.confirmBox{background:#fff;border-radius:var(--radius);padding:28px 24px 20px;max-width:380px;width:90vw;box-shadow:var(--shadow-lg);text-align:center}
.confirmIcon{margin-bottom:12px}
.confirmMsg{font-size:14px;color:var(--text);line-height:1.5;margin-bottom:20px}
.confirmActions{display:flex;gap:10px;justify-content:center}
.confirmActions .headerBtn{min-width:100px;justify-content:center}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ---- Template Preview Overlay ---- */
.templatePreviewOverlay{position:fixed;inset:0;z-index:500;background:#fff;display:flex;flex-direction:column}
.templatePreviewBar{display:flex;align-items:center;justify-content:space-between;padding:10px 20px;background:#fff;border-bottom:1px solid var(--border);flex-shrink:0}
.templatePreviewTitle{font-size:14px;font-weight:600;color:var(--text)}
.templatePreviewFrame{flex:1;width:100%;border:none}

/* ---- Ampliación de plazo ---- */
.ampSection{margin-bottom:20px;max-width:640px;margin-left:auto;margin-right:auto}
.ampSection .contextInput{display:block}
.ampSection .contextLabel{display:block;margin-bottom:6px;margin-left:0;margin-right:0;max-width:none}
.ampSection .contextHint{margin-top:4px;margin-left:0;margin-right:0;max-width:none}
.uploadZone.compact{padding:20px;min-height:auto}
.uploadZone.compact p{font-size:13px;margin:6px 0 0}
.ampFileName{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#f0fdf4;border:1px solid #86efac;border-radius:8px;font-size:13px;font-weight:600;color:#16a34a;margin-top:8px}
.ampFileName .ampRemove{margin-left:auto;cursor:pointer;color:#94a3b8;font-size:16px}
.ampFileName .ampRemove:hover{color:#dc2626}
.ampExtracted{display:grid;gap:12px;margin-bottom:20px}
.ampRow{display:flex;align-items:center;gap:12px}
.ampRow label{min-width:180px;font-size:13px;font-weight:600;color:var(--text-muted);text-align:right;flex-shrink:0}
.ampRow .contextInput{flex:1;margin:0}
.ampDates{display:flex;align-items:center;gap:8px;justify-content:center;margin:24px 0;flex-wrap:wrap}
.ampDateBox{background:#f8fafc;border:1.5px solid var(--border);border-radius:10px;padding:12px 18px;text-align:center;min-width:140px}
.ampDateBox.highlight{background:#f0fdf4;border-color:#86efac}
.ampDateLabel{display:block;font-size:11px;color:var(--text-muted);margin-bottom:4px}
.ampDateVal{display:block;font-size:14px;font-weight:700;color:var(--text)}
.ampDateBox.highlight .ampDateVal{color:#16a34a}
.ampDateArrow{font-size:20px;color:#94a3b8}
.ampClientMatch{margin:12px 0;padding:10px 14px;border-radius:8px;font-size:12px;display:flex;align-items:center;gap:8px}
.ampClientMatch.found{background:#f0fdf4;border:1px solid #86efac;color:#16a34a}
.ampClientMatch.notfound{background:#fef3c7;border:1px solid #fbbf24;color:#92400e}

/* ---- Responsive ---- */
@media(max-width:640px){
  header{padding:8px 16px}
  .title h1{font-size:17px}
  .headerRight{gap:8px}
  .headerBtn{padding:6px 10px;font-size:12px}
  .mainWrap{padding:16px 12px 32px}
  .catGrid{grid-template-columns:1fr}
  .stepLine{width:20px}
  .step span{display:none}
  .chatPanel{width:100vw}
  .settingsBox{max-width:100vw;border-radius:0}
  .settingsTabs{overflow-x:auto;padding:0 12px}
  .settingsTab{font-size:12px;padding:8px 12px;white-space:nowrap}
  .memTplGrid{grid-template-columns:1fr}
  .phFormRow{flex-direction:column}
  .phToolbar{flex-direction:column}
  .phSearchInput{width:100%}
  .refsPanel{right:16px;left:16px;width:auto}
  .refsToggle{right:80px}
  .ampRow{flex-direction:column;align-items:stretch;gap:4px}
  .ampRow label{min-width:0;text-align:left}
  .ampDates{flex-direction:column}
  .ampDateArrow{transform:rotate(90deg)}
  .memStepper{gap:0;padding:10px 8px}
  .memStepLabel{display:none}
  .memStepLine{width:12px}
  .memSocGrid .ampRow{flex-direction:column;align-items:stretch;gap:4px}
  .memSocGrid .ampRow label{min-width:0;text-align:left}
  .memEmplGrid{overflow-x:auto}
  .memEmplHeader,.memEmplRow{min-width:460px}
  .memDocsSelect{max-width:100%}
}
