/* ============================================================
   Portal Cotizaciones ANIDA — tema "enterprise SOC" (replica del panel SOC)
   ============================================================ */
/* Modo CLARO (base) */
:root{
  --bg:#f5f6fa; --bg-sidebar:#fff; --bg-card:#fff; --bg-header:#fff;
  --bg-input:#f7f9fc; --bg-nav-act:#eef3fb; --bg-elev:#f7f9fc;
  --border:#e4e9f0; --border-2:#f0f3f8; --border-3:#d8dfe9;
  --text:#1f2937; --text-2:#5b6473; --text-3:#9ba3b1;
  --accent:#4f7cc4; --accent-h:#3a67ad; --accent-light:#eef3fb;
  --success:#16a34a; --warning:#d97706; --critical:#dc2626;
  --shadow:0 2px 14px rgba(0,0,0,.06); --shadow-lg:0 6px 28px rgba(0,0,0,.10);
  /* Identidad del documento (se mantiene en la vista previa = .docx real) */
  --doc-navy:#0E1A2B; --doc-blue:#0573AE;
}
/* Modo OSCURO "enterprise" (default del portal) */
body[data-theme="dark"]{
  --bg:#0a0e1a; --bg-sidebar:#11162a; --bg-card:#151a2e; --bg-header:#11162a;
  --bg-input:#1c2240; --bg-nav-act:#1e2647; --bg-elev:#1a1f38;
  --border:#232a47; --border-2:#1a2038; --border-3:#2c3457;
  --text:#e6ecf5; --text-2:#8a96b3; --text-3:#5a6485;
  --accent:#0064FA; --accent-h:#2563eb; --accent-light:#1e3a8a;
  --success:#22c55e; --warning:#fbbf24; --critical:#ef4444;
  --shadow:0 4px 16px rgba(0,0,0,.40); --shadow-lg:0 8px 32px rgba(0,0,0,.55);
  color-scheme:dark;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
body{margin:0;font-family:'Inter',sans-serif;background:var(--bg);color:var(--text);
  color-scheme:light;transition:background .25s,color .25s}

.topbar{display:flex;align-items:center;justify-content:space-between;
  background:var(--bg-header);color:var(--text);padding:14px 28px;border-bottom:1px solid var(--border)}
.brand{display:flex;align-items:center}
.brand-sub{margin-left:22px;font-size:13px;color:var(--text-2)}

/* Logo: se muestra tal cual, ajustado al alto de la barra conservando su proporción */
.logo-wrapper{position:relative;display:inline-flex;align-items:center}
.brand-logo{height:auto;max-height:48px;width:auto;display:block;background:none;border:0;padding:0}
.logo-edit-btn,.logo-del-btn{position:absolute;width:24px;height:24px;border-radius:50%;
  border:2px solid var(--bg-header);cursor:pointer;font-size:11px;line-height:1;padding:0;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .15s;z-index:5}
.logo-edit-btn{bottom:-8px;right:-8px;background:var(--accent);color:#fff}
.logo-del-btn{bottom:-8px;right:20px;background:var(--critical);color:#fff}
.logo-wrapper:hover .logo-edit-btn,.logo-wrapper:hover .logo-del-btn{opacity:1}
.logo-edit-btn:hover{background:var(--accent-h)}
.logo-del-btn:hover{background:#b91c1c}

/* Campo de carga (cuando no hay logo) */
.logo-upload-label{font-size:13px;font-weight:600;color:var(--text-2);background:var(--bg-input);
  border:1px dashed var(--border-3);border-radius:8px;padding:9px 16px;cursor:pointer;white-space:nowrap}
.logo-upload-label:hover{background:var(--bg-nav-act);color:var(--text)}

.ia-badge{font-size:12px;padding:5px 12px;border-radius:20px;background:var(--bg-input);
  color:var(--text-2);border:1px solid var(--border)}
.ia-badge.on{background:rgba(34,197,94,.12);color:var(--success);border-color:rgba(34,197,94,.35)}

.topbar-right{display:flex;align-items:center;gap:12px}
.btn-theme-toggle{width:38px;height:38px;border-radius:50%;border:1px solid var(--border);
  background:var(--bg-card);color:var(--text-2);cursor:pointer;display:flex;align-items:center;
  justify-content:center;transition:all .2s;flex-shrink:0;padding:0}
.btn-theme-toggle:hover{background:var(--accent-light);border-color:var(--accent);color:var(--accent);transform:rotate(20deg)}

.tabs{display:flex;gap:4px;background:var(--bg-header);padding:0 28px;border-bottom:1px solid var(--border)}
.tab{border:0;background:none;padding:14px 18px;font-family:inherit;font-size:14px;font-weight:500;
  color:var(--text-2);cursor:pointer;border-bottom:3px solid transparent}
.tab:hover{color:var(--text)}
.tab.active{color:var(--text);border-bottom-color:var(--accent)}

main{max-width:920px;margin:24px auto;padding:0 20px}
.view{display:none}.view.active{display:block}

.card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;
  padding:22px 24px;margin-bottom:20px;box-shadow:var(--shadow)}
.card h2{margin:0 0 16px;font-size:15px;font-weight:600;color:var(--text)}

.grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;margin-bottom:16px}
label{display:flex;flex-direction:column;font-size:12px;font-weight:600;color:var(--text-2);gap:5px}
input,select,textarea{font-family:inherit;font-size:14px;color:var(--text);
  border:1px solid var(--border);border-radius:8px;padding:9px 11px;background:var(--bg-input)}
input::placeholder,textarea::placeholder{color:var(--text-3)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px rgba(0,100,250,.25)}
label.file{margin-bottom:16px}

.btn{display:inline-block;border:0;border-radius:8px;padding:11px 20px;font-family:inherit;
  font-size:14px;font-weight:600;cursor:pointer;text-decoration:none;text-align:center}
.btn.primary{background:var(--accent);color:#fff}
.btn.primary:hover{background:var(--accent-h)}
.btn.ghost{background:var(--bg-input);color:var(--text);border:1px solid var(--border)}
.row{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}
.hint{font-size:12.5px;color:var(--text-3);margin:10px 0 0}
.error{color:var(--critical);font-size:13px;margin:10px 0 0;white-space:pre-wrap}

.resultado{border-color:var(--accent);background:var(--bg-elev)}
.resultado h2{color:var(--success)}

/* ---------- Tabla de historial ---------- */
.tabla{width:100%;border-collapse:collapse;font-size:13px}
.tabla th{text-align:left;background:var(--bg-input);color:var(--text-2);padding:10px 12px;
  font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border)}
.tabla td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.tabla tr:nth-child(even) td{background:var(--bg-elev)}
.pill{font-size:11px;padding:3px 9px;border-radius:12px;font-weight:600}
.pill.generado{background:rgba(34,197,94,.14);color:#4ade80}
.pill.error{background:rgba(239,68,68,.14);color:#f87171}
.pill.warn{background:rgba(251,191,36,.14);color:#fbbf24}
.link{color:var(--accent);text-decoration:none;font-weight:600;cursor:pointer}
.link:hover{color:var(--accent-h)}
.link.del{color:var(--critical);margin-left:10px}

.overlay{position:fixed;inset:0;background:rgba(5,8,16,.72);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:16px;color:#fff;font-size:14px;z-index:50}
.spinner{width:42px;height:42px;border:4px solid rgba(255,255,255,.2);border-top-color:var(--accent);
  border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

@media(max-width:640px){.grid{grid-template-columns:1fr}}

/* ---------- Login ---------- */
.login-wrap{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px}
.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:14px;
  box-shadow:var(--shadow-lg);padding:34px 30px;width:100%;max-width:360px;display:flex;flex-direction:column;gap:12px}
.login-logo{height:54px;width:auto;align-self:center;margin-bottom:4px}
.login-card h1{font-size:18px;font-weight:600;text-align:center;margin:0;color:var(--text)}
.login-sub{font-size:13px;color:var(--text-2);text-align:center;margin:0 0 8px}
.login-card label{font-size:12px;font-weight:600;color:var(--text-2);display:flex;flex-direction:column;gap:5px}
.login-card .btn{margin-top:8px;width:100%}
.login-foot{font-size:11px;color:var(--text-3)}

/* ---------- Menú de usuario en el header ---------- */
.user-menu{display:flex;align-items:center;gap:10px}
.user-chip{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-2)}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;flex-shrink:0}
.user-name{font-weight:600;color:var(--text)}
.user-rol{font-size:10px;color:var(--text-3);text-transform:uppercase;letter-spacing:.04em}
.btn-logout{background:var(--bg-input);border:1px solid var(--border);color:var(--text-2);
  border-radius:8px;padding:6px 12px;font-family:inherit;font-size:12px;font-weight:600;cursor:pointer}
.btn-logout:hover{background:var(--bg-nav-act);color:var(--text)}

/* ---------- Panel de usuarios (admin) ---------- */
.usr-form{display:grid;grid-template-columns:1fr 1fr 140px 1fr auto;gap:10px;align-items:end;margin-bottom:18px}
.usr-form .btn{padding:9px 16px}
@media(max-width:760px){.usr-form{grid-template-columns:1fr 1fr}}

/* ============================================================
   Vista previa editable = representación del .docx real.
   Mantiene la identidad ANIDA del documento (hoja blanca + banner navy).
   ============================================================ */
.doc-preview{border:1px solid var(--border);border-radius:10px;overflow:hidden;background:#fff;
  box-shadow:var(--shadow)}
.ed,.dp-desc-line,.dp-intro{outline:none;border-radius:4px;transition:background .12s}
.ed:focus,.dp-desc-line:focus,.dp-intro:focus,.dp-item-tit:focus,.dp-item-sub:focus{
  background:#eef6fc;box-shadow:0 0 0 2px rgba(5,115,174,.25)}
.doc-preview [contenteditable="true"]:hover{background:#f5f9fd}

.dp-banner{background:var(--doc-navy);color:#fff;padding:16px 22px}
.dp-anida{color:var(--doc-blue);font-weight:700;letter-spacing:2px;font-size:13px}
.dp-titulo{font-size:18px;font-weight:600;margin-top:2px}
.dp-subtitulo{font-size:12px;color:#BFD4E6;margin-top:2px}

.dp-dest{display:flex;flex-wrap:wrap;gap:2px 18px;padding:14px 22px;background:#F2F6FA;
  border-bottom:1px solid #D5DEE7;font-size:13px;color:#1F2937}
.dp-dest>div{min-width:120px}
.dp-fecha{margin-left:auto;color:var(--doc-blue);font-weight:600}

.dp-h2{font-size:14px;font-weight:700;color:var(--doc-navy);padding:14px 22px 4px;
  border-bottom:2px solid var(--doc-blue);margin:6px 22px 0}
.dp-intro{font-size:13px;line-height:1.55;padding:10px 22px;text-align:justify;color:#1F2937}

.dp-table{width:calc(100% - 44px);margin:8px 22px 4px;border-collapse:collapse;font-size:12.5px}
.dp-table th{background:var(--doc-navy);color:#fff;padding:7px 10px;text-align:left;font-size:11px;letter-spacing:.5px}
.dp-table th:last-child{text-align:center}
.dp-table td{border:1px solid #D5DEE7;padding:8px 10px;vertical-align:top;color:#1F2937}
.dp-table tr:nth-child(even) td{background:#fafcfe}
.dp-itemcol{width:23%}
.dp-item-tit{font-weight:700;color:var(--doc-navy)}
.dp-item-sub{color:var(--doc-blue);font-weight:600;font-size:11px;margin-top:2px}
.dp-desccol{width:57%}
.dp-desc-line{font-size:12px;line-height:1.5;color:#1F2937;padding:1px 2px;margin-bottom:2px}
.dp-preciocol{width:20%}
.dp-precio{text-align:center}
.dp-uf{display:flex;align-items:center;justify-content:center;gap:4px;font-weight:700;color:var(--doc-navy);font-size:15px}
.dp-precio-input{width:64px;text-align:center;padding:3px 4px;border:1px solid var(--doc-blue);border-radius:6px;font-size:13px;background:#fff;color:#1F2937}
.dp-usd{font-weight:700;color:var(--doc-navy);font-size:15px}
.dp-iva{color:#6B7280;font-size:11px;margin-top:2px}
.dp-tipopago{color:var(--doc-blue);font-weight:600;font-style:italic;font-size:10px;margin-top:3px}
.dp-nota-kam{color:#6B7280;font-size:9px;margin-top:3px}

.dp-cond,.dp-oc,.dp-firma{font-size:12.5px;padding:8px 22px;color:#1F2937;line-height:1.6}
.dp-firma{padding-bottom:16px}
.dp-oc{background:#F2F6FA;margin:0 22px;border-radius:8px;border-left:4px solid var(--doc-blue);padding:10px 16px}
