/* ================================================================
   Procoex CRM v4 - Estilos globales
================================================================ */


:root{
  --sb:#1c2333; --sb2:#242d40; --sb3:#2e3a50; --sbt:#9aa8c0; --sbta:#e8ecf4; --sba:rgba(99,148,255,.15);
  --ac:#c0392b; --ac2:#e74c3c; --blue:#3b6fd4; --green:#2d8a4e; --orange:#c97c1a; --warn:#d4a017;
  --bg:#f0f2f7; --surf:#fff; --surf2:#f5f7fb; --bdr:#dde1ea; --bdr2:#c5cad8;
  --tx:#1a1f2e; --tx2:#5a6275; --tx3:#9ca3b8;
  --rad:6px; --shd:0 1px 4px rgba(0,0,0,.09),0 4px 16px rgba(0,0,0,.06);
  --sb-w:220px;
}
*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;overflow:hidden;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--tx);font-size:13px;line-height:1.5;}
input,select,textarea,button{font-family:inherit;font-size:13px;}
::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-thumb{background:var(--bdr2);border-radius:3px;}

/* ── LOGIN · branding petriOS (indigo / obsidian / lavanda) ─── */
#login-wrap{position:fixed;inset:0;background:radial-gradient(1100px 560px at 50% -8%, #1A1F2E 0%, #0A0F1C 62%);display:flex;align-items:center;justify-content:center;z-index:9999;font-family:'Inter',-apple-system,sans-serif;}
.lbox{width:360px;}
.llogo{text-align:center;margin-bottom:28px;}
.lbrand{font-family:'Inter',sans-serif;font-size:22px;font-weight:500;color:#fff;letter-spacing:.5px;}
.lbrand b{color:#9B91F0;font-weight:400;}
.lsub{font-size:10px;color:rgba(255,255,255,.5);letter-spacing:1.6px;margin-top:4px;text-transform:uppercase;}
.lcard{background:rgba(255,255,255,.035);border:0.5px solid rgba(123,111,232,.20);border-radius:14px;padding:28px;box-shadow:0 24px 60px rgba(0,0,0,.45);}
.lcard h2{font-size:16px;font-weight:600;color:#fff;margin-bottom:20px;letter-spacing:.2px;}
.ldemo{background:rgba(123,111,232,.10);border:0.5px solid rgba(123,111,232,.28);border-radius:8px;padding:9px 12px;font-size:12px;color:#C9C3F5;margin-bottom:16px;line-height:1.9;}
.ldemo a,.ldemo b{color:#9B91F0;}
.lfg{margin-bottom:14px;}
.lfg label{display:block;font-size:10px;font-weight:600;color:rgba(255,255,255,.55);margin-bottom:4px;letter-spacing:.8px;text-transform:uppercase;}
.lfg input{width:100%;background:rgba(255,255,255,.06);border:0.5px solid rgba(255,255,255,.12);border-radius:8px;padding:10px 12px;color:#fff;outline:none;transition:border .15s,box-shadow .15s;box-sizing:border-box;}
.lfg input:focus{border-color:#7B6FE8;box-shadow:0 0 0 3px rgba(123,111,232,.18);}
.lfg input::placeholder{color:rgba(255,255,255,.35);}
/* Ojo mostrar/ocultar contraseña */
.lpass-eye{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:6px;display:flex;align-items:center;line-height:0;color:#9B91F0;opacity:.85;transition:opacity .15s,color .15s;}
.lpass-eye:hover{opacity:1;color:#B9B1F7;}
.lbtn{width:100%;background:linear-gradient(135deg,#4A3FB8 0%,#2D2580 100%);color:#fff;border:none;border-radius:9px;padding:11px;font-weight:600;font-size:14px;cursor:pointer;transition:filter .15s,transform .05s;}
.lbtn:hover{filter:brightness(1.12);}
.lbtn:active{transform:translateY(1px);}
#lerr{color:#f87171;font-size:12px;margin-top:8px;min-height:16px;}

/* ── LAYOUT ────────────────────────────────── */
#app{display:flex;height:100vh;overflow:hidden;}

/* ── SIDEBAR ───────────────────────────────── */
#sidebar{
  width:var(--sb-w);min-width:var(--sb-w);
  background:var(--sb);display:flex;flex-direction:column;overflow:hidden;
  border-right:1px solid rgba(0,0,0,.2);
  transition:width .2s ease, min-width .2s ease;
}
/* Plegado del menú en escritorio (botón hamburguesa de la topbar) → más
   espacio para el área de trabajo. En móvil el menú es off-canvas (.open). */
@media (min-width:769px){
  body.sb-collapsed #sidebar{ display:none !important; }
}
.topbar-burger{
  background:transparent;border:0;font-size:19px;line-height:1;color:var(--tx2);
  cursor:pointer;padding:6px 12px 6px 0;margin-right:2px;border-radius:8px;
}
.topbar-burger:hover{ color:var(--tx); }
.sb-logo{padding:16px 16px 12px;border-bottom:1px solid rgba(255,255,255,.06);}
.sb-brand{font-family:'Space Mono',monospace;font-size:15px;font-weight:700;color:#fff;}
.sb-brand b{color:var(--ac2);}
.sb-ver{font-size:9px;color:var(--sbt);margin-top:1px;letter-spacing:.5px;}

/* ── SELECTOR SUCURSAL (bloque destacado) ── */
.sb-suc-block{
  margin:10px 10px 0;
  background:var(--sb3);
  border:1px solid rgba(255,255,255,.08);
  border-radius:8px;
  overflow:hidden;
}
.sb-suc-label{
  font-size:9px;font-weight:700;color:var(--sbt);letter-spacing:1.2px;text-transform:uppercase;
  padding:8px 12px 4px;
}
.sb-suc-current{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px 10px;cursor:pointer;
  color:#fff;font-size:12.5px;font-weight:500;
}
.sb-suc-current .suc-ico{font-size:14px;flex-shrink:0;}
.sb-suc-current .suc-arrow{margin-left:auto;font-size:10px;color:var(--sbt);transition:transform .2s;}
.sb-suc-current.open .suc-arrow{transform:rotate(180deg);}
.sb-suc-list{
  display:none;border-top:1px solid rgba(255,255,255,.06);
  max-height:180px;overflow-y:auto;
}
.sb-suc-list.open{display:block;}
.suc-opt{
  display:flex;align-items:center;gap:8px;
  padding:8px 12px;cursor:pointer;color:var(--sbt);font-size:12px;
  transition:background .12s,color .12s;
}
.suc-opt:hover{background:rgba(255,255,255,.06);color:#fff;}
.suc-opt.active{color:#fff;background:rgba(99,148,255,.12);}
.suc-opt .suc-check{margin-left:auto;color:var(--blue);font-size:12px;}
.suc-opt-all{border-bottom:1px solid rgba(255,255,255,.06);}

/* ── USER ─────────────────────────────────── */
.sb-user{display:flex;align-items:center;gap:9px;padding:10px 12px;border-bottom:1px solid rgba(255,255,255,.06);margin-top:8px;}
.sb-av{width:30px;height:30px;border-radius:50%;background:var(--ac);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;}
.sb-uname{font-size:12px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sb-urole{font-size:10px;color:var(--sbt);}

/* ── NAV ──────────────────────────────────── */
nav{flex:1;overflow-y:auto;padding:6px 0 10px;}
.nav-sec{padding:10px 14px 2px;font-size:9px;font-weight:700;color:rgba(154,168,192,.45);letter-spacing:1.5px;text-transform:uppercase;}
.ni{
  display:flex;align-items:center;gap:8px;padding:6px 14px;
  cursor:pointer;color:var(--sbt);font-size:12.5px;
  border-left:3px solid transparent;transition:all .1s;white-space:nowrap;
}
.ni:hover{background:rgba(255,255,255,.04);color:var(--sbta);}
.ni.active{background:var(--sba);color:#fff;border-left-color:var(--ac2);}
.ni .ico{font-size:14px;width:18px;text-align:center;flex-shrink:0;}
.ni-sub{padding-left:10px;}
.ni-sub .ni{font-size:12px;padding:5px 14px 5px 32px;border-left:none;}
.ni-sub .ni::before{content:'›';margin-right:4px;color:var(--sbt);}
.ni-sub .ni.active{color:var(--ac2);background:rgba(192,57,43,.08);}

.sb-foot{padding:10px 12px;border-top:1px solid rgba(255,255,255,.06);}
.sb-out{display:flex;align-items:center;gap:7px;cursor:pointer;color:var(--sbt);font-size:12px;padding:5px 2px;border-radius:4px;transition:color .15s;}
.sb-out:hover{color:var(--ac2);}

/* ── MAIN ─────────────────────────────────── */
#main{flex:1;display:flex;flex-direction:column;overflow:hidden;}
.topbar{
  height:46px;background:var(--surf);border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 20px;flex-shrink:0;box-shadow:0 1px 3px rgba(0,0,0,.05);
}
.topbar-bc{font-size:13px;color:var(--tx2);}
.topbar-bc b{color:var(--tx);font-weight:600;}
.topbar-bc .sep{margin:0 6px;color:var(--tx3);}
.topbar-suc{display:flex;align-items:center;gap:6px;background:var(--surf2);border:1px solid var(--bdr);border-radius:20px;padding:4px 12px;font-size:12px;color:var(--tx2);}
.topbar-suc .suc-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;}
.topbar-suc.todas .suc-dot{background:var(--orange);}
.topbar-right{display:flex;align-items:center;gap:8px;}

.content{flex:1;overflow-y:auto;padding:20px;}
.page{display:none;animation:fadeIn .18s ease;}
.page.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(3px)}to{opacity:1;transform:none}}

/* ── BOTONES ──────────────────────────────────────────────────
 * Estilos uniformes y prominentes: cada botón debe verse claramente
 * como una acción posible (peso visual, sombra suave, hover-lift).
 * ───────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:6px;
  padding:7px 14px; border-radius:var(--rad);
  font-size:12.5px; font-weight:600; line-height:1.2;
  cursor:pointer; border:none; white-space:nowrap;
  transition:transform .12s ease, box-shadow .12s ease, background .12s, filter .12s, border-color .12s;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.btn:hover { transform:translateY(-1px); }
.btn:active { transform:translateY(0); box-shadow:0 1px 2px rgba(15,23,42,.08) inset; }
.btn:disabled, .btn.is-disabled { opacity:.55; cursor:not-allowed; transform:none; box-shadow:none; }

/* Primario petriOS — ÍNDIGO (CTA · máxima jerarquía visual).
   Brand book §2: los CTAs son índigo (#4A3FB8), hover lavanda (#7B6FE8).
   El rojo legacy (--ac, marca Procoex retirada) ya NO se usa para CTAs; queda
   solo para acentos puntuales. `.btn-dg` (peligro) mantiene su propio rojo.
   Las variantes .shdr .btn-pr (blanco sobre banner) y .modal .mft .btn-pr
   (degradado índigo) ganan por especificidad y siguen aplicando. */
.btn-pr{ background:var(--petri-indigo); color:#fff; box-shadow:0 2px 6px rgba(74,63,184,.28); }
.btn-pr:hover{ background:var(--petri-lavender); box-shadow:0 4px 12px rgba(74,63,184,.35); }

/* Azul informativo */
.btn-bl{ background:var(--blue); color:#fff; box-shadow:0 2px 6px rgba(37,99,235,.28); }
.btn-bl:hover{ filter:brightness(1.08); box-shadow:0 4px 12px rgba(37,99,235,.35); }

/* Secundario — ahora con peso visible (no se pierde sobre fondo blanco) */
.btn-sc{
  background:#fff; color:var(--tx);
  border:1.5px solid #cbd5e1;
}
.btn-sc:hover{ background:#f8fafc; border-color:#64748b; }

/* Peligro */
.btn-dg{ background:#dc2626; color:#fff; box-shadow:0 2px 6px rgba(220,38,38,.28); }
.btn-dg:hover{ background:#b91c1c; box-shadow:0 4px 12px rgba(220,38,38,.35); }

/* Tamaños */
.btn-sm{ padding:5px 11px; font-size:12px; }
.btn-xs{ padding:4px 10px; font-size:11px; }
.btn-ic{ padding:6px 8px; border-radius:6px; }

/* Botones de exportación — más visibles, tipo "chip activo" */
.btn-ex{
  background:#fff; border:1.5px solid #cbd5e1;
  color:var(--tx); padding:6px 11px; font-size:12px; font-weight:600;
  box-shadow:0 1px 2px rgba(15,23,42,.06);
}
.btn-ex:hover{ background:#f1f5f9; border-color:#475569; transform:translateY(-1px); }

/* ── BADGES ───────────────────────────────── */
.badge{display:inline-block;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;white-space:nowrap;}
.bg{background:#eef0f5;color:#6b7280;}
.bb{background:#dbeafe;color:#1d4ed8;}
.bgn{background:#dcfce7;color:#15803d;}
.br{background:#fee2e2;color:#b91c1c;}
.bo{background:#ffedd5;color:#c2410c;}
.by{background:#fef9c3;color:#854d0e;}
.bp{background:#f3e8ff;color:#7e22ce;}
.bc{background:#cffafe;color:#0e7490;}

/* Estado expediente */
.est-lead{background:#f1f5f9;color:#64748b;}
.est-presupuestado{background:#e0e7ff;color:#3730a3;}
.est-aceptado{background:#dcfce7;color:#166534;}
.est-planificado{background:#dbeafe;color:#1e40af;}
.est-en_curso{background:#fef9c3;color:#854d0e;font-weight:700;}
.est-finalizado{background:#f0fdf4;color:#14532d;border:1px solid #bbf7d0;}
.est-cancelado{background:#fee2e2;color:#991b1b;}

/* ── COMPONENTES ──────────────────────────── */
.krow{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px;}
.kcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:14px 16px;box-shadow:var(--shd);position:relative;overflow:hidden;}
.kcard-ico{position:absolute;right:12px;top:10px;font-size:24px;opacity:.12;}
.kcard-lbl{font-size:10px;font-weight:600;color:var(--tx2);letter-spacing:.4px;text-transform:uppercase;}
.kcard-val{font-family:'Space Mono',monospace;font-size:26px;font-weight:700;margin:4px 0 2px;color:var(--tx);}
.kcard-sub{font-size:11px;color:var(--tx3);}

/* ── Cabecera de página · banner slim marca Petri (global) ─────
   Look & feel del brand book petriOS aplicado a TODOS los módulos:
   banner oscuro slim (indigo/obsidiana), título Fraunces, acento
   lavanda. Markup: .shdr > div(título) + opcional .sacts(acciones).
   Eyebrow opcional vía atributo data-eyebrow en .shdr. */
.shdr{
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  background:linear-gradient(120deg,#0A0F1C 0%,#241D63 70%,#4A3FB8 150%);
  border-radius:12px;padding:10px 20px;margin-bottom:14px;color:#fff;
  position:relative;overflow:hidden;
}
.shdr::after{content:"";position:absolute;right:-30px;top:-46px;width:160px;height:160px;
  background:radial-gradient(circle,rgba(123,111,232,.40),transparent 70%);pointer-events:none;}
.shdr > div{position:relative;z-index:1;min-width:0;}
.stitle{font-family:var(--petri-font-display);font-weight:300;font-size:21px;color:#fff;
  letter-spacing:-.02em;line-height:1.15;}
.ssub{font-size:12px;color:rgba(255,255,255,.6);margin-top:2px;}
/* Eyebrow opcional: <div class="shdr" data-eyebrow="PETRI · …"> */
.shdr[data-eyebrow] .stitle::before{content:attr(data-eyebrow);display:block;
  font-family:var(--petri-font-ui);font-size:9px;font-weight:600;letter-spacing:1.4px;
  color:var(--petri-lavender-soft);margin-bottom:1px;line-height:1;}
/* Acciones legibles sobre el banner oscuro */
.sacts{display:flex;gap:6px;align-items:center;position:relative;z-index:1;flex-wrap:wrap;}
.shdr .btn-pr{background:#fff;color:var(--petri-indigo-deep);border-color:transparent;}
.shdr .btn-pr:hover{background:var(--petri-lavender-bg);}
.shdr .btn-sc{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25);}
.shdr .btn-sc:hover{background:rgba(255,255,255,.20);}
.shdr .fi,.shdr select.fi{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.25);}
/* Las <option> de un <select> heredan color del padre y se renderizan en
   un popup blanco fuera del DOM normal. Si el <select> está en .shdr (fondo
   oscuro), su `color:#fff` hace invisibles las opciones sobre el dropdown.
   Forzamos color oscuro y fondo claro a las options en cualquier estado.
   (Bug 49cb.70 — antes solo se veían al hover por el azul de selección). */
.shdr select.fi option,
.shdr .fi option { color:#0A0F1C; background:#fff; }

.tbar{display:flex;gap:8px;margin-bottom:12px;align-items:center;flex-wrap:wrap;}
.srch{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:7px 11px;color:var(--tx);outline:none;transition:border .15s;min-width:180px;}
.srch:focus{border-color:var(--blue);}
.fsl{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:6px 9px;color:var(--tx);outline:none;cursor:pointer;}
.date-in{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:6px 9px;color:var(--tx);outline:none;width:128px;}
.exp-btns{margin-left:auto;display:flex;gap:4px;}

.twrap{border:1px solid var(--bdr);border-radius:var(--rad);overflow:auto;background:var(--surf);box-shadow:var(--shd);-webkit-overflow-scrolling:touch;}
table{width:100%;border-collapse:collapse;}
thead{background:var(--surf2);}
th{padding:8px 11px;text-align:left;font-size:11px;font-weight:600;color:var(--tx2);letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid var(--bdr);white-space:nowrap;}
td{padding:8px 11px;font-size:12.5px;border-bottom:1px solid var(--bdr);color:var(--tx2);vertical-align:middle;}
td b{color:var(--tx);}
tbody tr:hover{background:#f8f9fc;}
tbody tr:last-child td{border-bottom:none;}
.tact{display:flex;gap:4px;opacity:0;transition:opacity .12s;}
tr:hover .tact{opacity:1;}
.tfr td{background:var(--surf2);font-weight:600;color:var(--tx);border-top:2px solid var(--bdr2);}

.panel{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:16px;box-shadow:var(--shd);}
.ptitle{font-size:10px;font-weight:700;color:var(--tx2);letter-spacing:.6px;text-transform:uppercase;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;}

/* ── MODAL ────────────────────────────────── */
.ov{position:fixed;inset:0;background:rgba(10,15,30,.55);z-index:500;display:none;align-items:center;justify-content:center;backdrop-filter:blur(2px);}
#m-confirm{z-index:600;}
#m-inventario{z-index:550;}
#m-inv-destino,#m-inv-estancia,#m-inv-enser,#m-inv-foto,#m-inv-dia,#m-inv-item{z-index:580;}
#m-rrhh-editor{z-index:520;}
#m-rrhh-disp,#m-rrhh-anexo,#m-rrhh-inc{z-index:560;}
#m-flota-editor{z-index:520;}
#m-flota-mant,#m-flota-anexo,#m-flota-inc{z-index:560;}
/* ── Contenido de modales con pestañas (Flota, RRHH) ── */
#m-flota-editor .mbody .fg,
#m-flota-editor .mbody [style*="grid"] > div,
#m-rrhh-editor .mbody .fg,
#m-rrhh-editor .mbody [style*="grid"] > div{margin-bottom:6px;}
#m-flota-editor .mbody .fi,
#m-rrhh-editor .mbody .fi{padding:8px 10px;font-size:13px;}

/* ── Pestañas dentro de modales (Flota, RRHH) ── */
.modal-tabs{display:flex;background:var(--surf2);overflow-x:auto;overflow-y:visible;flex-shrink:0;}
.mt{padding:18px 20px 16px;font-size:13px;font-weight:500;cursor:pointer;color:var(--tx2);border:none;border-bottom:3px solid var(--bdr);background:none;white-space:nowrap;transition:all .15s;}
.mt:hover{color:var(--tx);}
.mt.active{color:var(--ac);font-weight:600;border-bottom-color:var(--ac);}
.ov.open{display:flex;}
.modal{background:var(--surf);border:1px solid var(--bdr);border-radius:10px;width:680px;max-width:96vw;max-height:93vh;overflow-y:auto;box-shadow:0 20px 60px rgba(0,0,0,.18);}
.modal-sm{width:460px;} .modal-lg{width:900px;}
.mhd{padding:16px 20px 12px;border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:center;}
.mhd h3{font-size:15px;font-weight:700;}
.mhd .mcod{font-family:'Space Mono',monospace;font-size:11px;color:var(--tx3);margin-left:8px;}
.mx{background:none;border:none;color:var(--tx2);cursor:pointer;font-size:18px;padding:2px 6px;border-radius:4px;line-height:1;}
.mx:hover{background:var(--surf2);}
.mbody{padding:20px;}
.mft{padding:12px 20px;border-top:1px solid var(--bdr);display:flex;justify-content:flex-end;gap:8px;}

/* ── FORM ─────────────────────────────────── */
.fg{margin-bottom:11px;}
.fg2{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:11px;}
.fg3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px;margin-bottom:11px;}
.fg4{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:11px;}
label.fl{display:block;font-size:11px;font-weight:600;color:var(--tx2);margin-bottom:3px;letter-spacing:.3px;}
label.fl.req::after{content:' *';color:#dc2626;}
.fi{width:100%;background:var(--surf2);border:1px solid var(--bdr);border-radius:5px;padding:7px 10px;color:var(--tx);outline:none;transition:border .15s;}
.fi:focus{border-color:var(--blue);background:#fff;}
textarea.fi{resize:vertical;min-height:60px;}
.fsep{font-size:10px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.6px;padding:10px 0 6px;border-bottom:1px solid var(--bdr);margin-bottom:10px;}
.fck{display:flex;align-items:center;gap:7px;padding:6px 0;cursor:pointer;font-size:13px;}
.fck input[type=checkbox]{width:15px;height:15px;cursor:pointer;accent-color:var(--ac);}

/* ── MODAL — secciones tipo "card" para formularios largos ──────
   Agrupan visualmente bloques de campos relacionados. Mismo lenguaje
   visual que `.insp-sec` (los demás modales profesionales del CRM):
   fondo blanco, borde gris, sombra suave, título uppercase con icono
   en rojo CRM y separador inferior. Reutilizables por cualquier modal
   grande (proveedor, cliente, expediente, etc.). */
.msec{background:#fff;border:1px solid var(--bdr);border-radius:10px;padding:14px 16px;margin-bottom:12px;box-shadow:0 1px 2px rgba(15,23,42,.04);}
.msec-hd{display:flex;align-items:center;gap:8px;font-size:11px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.06em;margin:0 0 10px;padding-bottom:8px;border-bottom:1px solid var(--bdr);}
.msec-hd .ico{font-size:16px;line-height:1;color:var(--ac);}
.msec .fg, .msec .fg2, .msec .fg3, .msec .fg4{margin-bottom:10px;}
.msec .fg:last-child, .msec .fg2:last-child, .msec .fg3:last-child, .msec .fg4:last-child{margin-bottom:0;}

/* Header del modal con subtítulo (CIF, fecha alta, badge…) */
.mhd-stack{display:flex;flex-direction:column;gap:2px;min-width:0;}
.mhd-stack h3{margin:0;}
.mhd-sub{font-size:11px;color:var(--tx2);font-weight:400;display:flex;gap:10px;align-items:center;flex-wrap:wrap;}
.mhd-sub b{color:var(--tx);font-weight:600;}
.mhd-sub .sep{color:var(--tx3);}

/* ── MODAL · branding Petri GLOBAL ──────────────────────────────
   Mismo precedente que el rebrand global de .shdr (cabeceras de página):
   TODOS los modales del CRM llevan cabecera índigo, cuerpo claro con
   inputs blancos (contraste sin/ con secciones), foco y acentos índigo y
   botón primario con degradado. Las secciones .msec (tarjetas blancas)
   destacan sobre el cuerpo gris. Per-modal sólo se ajusta el ancho. */
.modal .mhd{
  background:linear-gradient(120deg,#0A0F1C 0%,#241D63 72%,#4A3FB8 140%);
  border-bottom:0;color:#fff;
}
.modal .mhd h3{color:#fff;}
.modal .mhd .mcod{color:rgba(255,255,255,.62);}
.modal .mhd-sub,.modal .mhd-sub b{color:rgba(255,255,255,.74);}
.modal .mhd-sub .sep{color:rgba(255,255,255,.4);}
.modal .mx{color:rgba(255,255,255,.85);}
.modal .mx:hover{color:#fff;background:rgba(255,255,255,.14);}
.modal .mbody{background:var(--surf2);}
.modal .mbody .fi{background:#fff;}
.modal .msec-hd .ico{color:var(--petri-indigo);}
.modal .fi:focus{border-color:var(--petri-indigo);background:#fff;}
.modal .mft .btn-pr{background:linear-gradient(135deg,var(--petri-indigo),var(--petri-indigo-deep));box-shadow:none;border-color:transparent;}

/* Tabla compacta para contactos / líneas dentro de un modal */
.msec-tbl{width:100%;border-collapse:collapse;font-size:12px;background:#fff;border:1px solid #E8E3DA;border-radius:6px;overflow:hidden;}
.msec-tbl thead th{background:#EEE9DE;color:var(--tx2);font-size:10px;text-transform:uppercase;letter-spacing:.5px;font-weight:700;padding:7px 10px;text-align:left;}
.msec-tbl tbody td{padding:6px 10px;border-top:1px solid #F0EBE0;}
.msec-tbl tbody tr:hover{background:#FAF8F2;}
.msec-tbl tbody tr.empty td{text-align:center;color:var(--tx3);padding:14px;font-style:italic;}

/* ── PESTAÑAS EXPEDIENTE ──────────────────── */
.tabs-wrap{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);box-shadow:var(--shd);}
.tabs-nav{display:flex;border-bottom:1px solid var(--bdr);background:var(--surf2);border-radius:var(--rad) var(--rad) 0 0;overflow-x:auto;}
.tn{padding:9px 16px;font-size:12.5px;font-weight:500;cursor:pointer;color:var(--tx2);border-bottom:2px solid transparent;white-space:nowrap;transition:all .15s;border:none;background:none;}
.tn:hover{color:var(--tx);}
.tn.active{color:var(--ac);border-bottom-color:var(--ac);font-weight:600;}
.tb{display:none;padding:20px;}
.tb.active{display:block;}

/* ── RUTA / PARADAS ─────────────────────────── */
.ruta-timeline{position:relative;padding:0 0 8px 0;}
.ruta-header{margin-bottom:14px;}
.ruta-resumen{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--tx);}
.ruta-km{font-size:12px;font-weight:500;color:var(--ac);background:var(--ac)12;padding:2px 10px;border-radius:20px;}
.ruta-punto{display:flex;align-items:flex-start;gap:12px;position:relative;padding:0 0 0 0;}
.ruta-linea{position:absolute;left:8px;top:22px;bottom:-20px;width:2px;background:var(--bdr);z-index:0;}
.ruta-punto:last-of-type .ruta-linea{display:none;}
.ruta-icono{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;position:relative;z-index:1;background:var(--surf);padding:1px;}
.ruta-contenido{flex:1;border:1px solid var(--bdr);border-radius:var(--rad);padding:10px 14px;background:var(--surf);margin-bottom:0;transition:box-shadow .15s;}
.ruta-contenido:hover{box-shadow:0 2px 8px rgba(0,0,0,.06);}
.ruta-punto-hdr{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:4px;}
.ruta-badge{font-size:10px;font-weight:600;padding:1px 8px;border-radius:10px;border:1px solid;}
.ruta-label{font-size:12px;font-weight:700;letter-spacing:.3px;}
.ruta-fecha{font-size:11px;color:var(--tx2);margin-left:auto;}
.ruta-dir{font-size:13px;font-weight:500;color:var(--tx);}
.ruta-detalle{font-size:11px;color:var(--tx2);margin-top:2px;}
.ruta-notas{font-size:11px;color:var(--tx3);margin-top:3px;font-style:italic;}
.ruta-acciones{display:flex;gap:3px;margin-left:auto;}
.ruta-add-wrap{display:flex;justify-content:center;padding:6px 0 6px 20px;}
.ruta-add-btn{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:500;color:var(--tx3);background:none;border:1px dashed var(--bdr);border-radius:var(--rad);padding:4px 14px;cursor:pointer;transition:all .15s;}
.ruta-add-btn:hover{color:var(--ac);border-color:var(--ac);background:var(--ac)08;}
.ruta-footer{display:flex;align-items:center;gap:8px;margin-top:14px;padding:10px 14px;background:var(--surf2);border-radius:var(--rad);border:1px solid var(--bdr);}
.ruta-dist-label{font-size:12px;color:var(--tx2);}
.ruta-dist-val{font-size:14px;font-weight:700;color:var(--tx);}
.ruta-form-inline{border:1px solid var(--ac);border-radius:var(--rad);padding:14px;margin:6px 0 6px 20px;background:var(--surf);box-shadow:0 2px 12px rgba(0,0,0,.08);}
.ruta-form-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;}

/* ── DOCUMENTOS CANVAS ───────────────────────── */
.docs-canvas{display:flex;flex-wrap:wrap;gap:16px;padding:4px 0;}
.doc-card{border:1px solid var(--bdr);border-radius:var(--rad);padding:16px;text-align:center;width:180px;display:flex;flex-direction:column;align-items:center;gap:4px;background:var(--surf);transition:box-shadow .15s;}
.doc-card:hover{box-shadow:0 2px 12px rgba(0,0,0,.07);}
.doc-card-add{cursor:pointer;border-style:dashed;justify-content:center;min-height:200px;}
.doc-card-add:hover{border-color:var(--ac);background:var(--ac)06;}
.doc-card-icon{margin-bottom:6px;}
.doc-card-title{font-size:12px;font-weight:700;letter-spacing:.3px;}
.doc-card-sub{font-size:11px;color:var(--tx2);}
.doc-card-badge{margin:4px 0;}
.doc-card-form{width:100%;margin:6px 0 2px;}
.doc-card-actions{display:flex;gap:6px;margin-top:8px;justify-content:center;}
.doc-act-btn{display:flex;align-items:center;gap:3px;background:var(--surf2);border:0.5px solid var(--bdr);border-radius:var(--rad);padding:4px 8px;cursor:pointer;color:var(--tx2);transition:all .12s;}
.doc-act-btn:hover{color:var(--ac);border-color:var(--ac);background:var(--ac)08;}

/* ── PLANIFICACIÓN CALENDARIO · aspecto PETRI ──────────────────
   Reestilado a la marca Petri (indigo #4A3FB8 / obsidiana #0A0F1C,
   Fraunces+Inter, neutros piedra). Consume las variables --petri-*
   de includes/petri-brand.css (cargado globalmente). Scoping bajo
   #page-planificacion para no afectar a otros módulos. */

/* Header cover SLIM: una sola fila (eyebrow + título + subtítulo) */
#page-planificacion .shdr{
  background:linear-gradient(120deg,#0A0F1C 0%,#241D63 70%,#4A3FB8 150%);
  border-radius:12px;padding:9px 20px;margin-bottom:12px;color:#fff;position:relative;overflow:hidden;
  display:flex;align-items:baseline;gap:14px;flex-wrap:wrap;
}
#page-planificacion .shdr::after{content:"";position:absolute;right:-30px;top:-46px;width:160px;height:160px;
  background:radial-gradient(circle,rgba(123,111,232,.40),transparent 70%);pointer-events:none;}
#page-planificacion .shdr > div{display:contents;}  /* stitle y ssub pasan a ser hijos flex del header */
#page-planificacion .shdr .stitle{font-family:var(--petri-font-display);font-weight:300;font-size:21px;color:#fff;
  letter-spacing:-.02em;line-height:1.1;margin:0;position:relative;z-index:1;}
#page-planificacion .shdr .stitle::before{content:"PETRI · OPERATIVA";display:block;font-family:var(--petri-font-ui);
  font-size:9px;font-weight:600;letter-spacing:1.4px;color:var(--petri-lavender-soft);margin-bottom:1px;line-height:1;}
#page-planificacion .shdr .ssub{color:rgba(255,255,255,.6);font-size:12px;margin:0;position:relative;z-index:1;}

/* Botones de modo / vista / navegación */
#page-planificacion .btn-sc{background:#fff;color:var(--petri-indigo-deep);border:0.5px solid var(--petri-limestone);
  border-radius:9px;font-family:var(--petri-font-ui);font-weight:600;transition:.12s;}
#page-planificacion .btn-sc:hover{background:var(--petri-lavender-bg);border-color:var(--petri-lavender-soft);}
#page-planificacion .plan-modo-btn.active,
#page-planificacion .plan-vista-btn.active{
  background:linear-gradient(135deg,#4A3FB8,#2D2580);color:#fff;border-color:transparent;
  box-shadow:0 2px 8px rgba(74,63,184,.30);outline:none;
}
#page-planificacion #plan-mes-label{font-family:var(--petri-font-ui);color:var(--petri-text-primary);font-weight:600;}

/* Rejilla y celdas de día */
.plan-grid-clasica,.plan-grid-det{display:grid;grid-template-columns:repeat(7,1fr);gap:6px;}
.plan-dia{border:0.5px solid var(--petri-border);border-radius:12px;min-height:104px;background:#fff;overflow:hidden;box-shadow:var(--petri-shadow-sm);}
.plan-dia-hoy{border-color:var(--petri-indigo);box-shadow:inset 0 0 0 1.5px var(--petri-indigo);}
.plan-dia-dom{background:var(--petri-marble);}
.plan-dia-hdr{display:flex;justify-content:space-between;align-items:center;padding:5px 9px;background:var(--petri-stone-light);font-size:11px;}
.plan-dia-num{font-weight:700;font-size:13px;color:var(--petri-text-primary);}
.plan-dia-sem{color:var(--petri-granite);text-transform:uppercase;font-size:9px;font-weight:600;letter-spacing:.5px;}
.plan-dia-count{background:var(--petri-indigo);color:#fff;font-size:9px;font-weight:700;padding:1px 7px;border-radius:99px;}
.plan-dia-body{padding:5px;}

/* Tarjeta compacta (vista Clásica/Semana/Día) */
.plan-card{padding:6px 8px;margin-bottom:4px;border-radius:8px;background:var(--petri-marble);border:0.5px solid var(--petri-border);
  font-size:10px;cursor:pointer;transition:box-shadow .12s,transform .12s;}
.plan-card:hover{box-shadow:var(--petri-shadow-md);transform:translateY(-1px);}
.plan-card-cli{font-weight:700;font-size:11px;color:var(--petri-text-primary);line-height:1.2;}
.plan-card-exp{color:var(--petri-granite);font-family:var(--petri-font-mono);font-size:9px;}
.plan-card-dir{color:var(--petri-text-secondary);font-size:9px;}
.plan-card-vol{color:var(--petri-indigo);font-size:9px;font-weight:700;}

/* Vista DETALLE (K.1): celdas más altas, tarjeta con toda la info */
.plan-dia-det{min-height:150px;}
.plan-dia-body-det{padding:6px;max-height:360px;overflow:auto;}
.plan-det-vacio{color:var(--petri-limestone);font-size:11px;text-align:center;padding:10px 0;}
.plan-card-det{background:#fff;border:0.5px solid var(--petri-border);border-radius:10px;padding:8px 9px;margin-bottom:7px;
  cursor:pointer;font-size:11px;box-shadow:var(--petri-shadow-sm);transition:box-shadow .12s,transform .12s;}
.plan-card-det:hover{box-shadow:var(--petri-shadow-md);transform:translateY(-1px);}
.pcd-head{display:flex;justify-content:space-between;align-items:center;gap:6px;margin-bottom:4px;}
.pcd-hora{color:#fff;font-weight:700;font-size:10px;padding:2px 8px;border-radius:99px;white-space:nowrap;}
.pcd-vol{background:var(--petri-lavender-bg);color:var(--petri-indigo-deep);font-weight:700;font-size:10px;padding:2px 8px;border-radius:99px;white-space:nowrap;}
.pcd-cli{font-weight:700;font-size:12px;color:var(--petri-text-primary);line-height:1.2;}
.pcd-exp{font-family:var(--petri-font-mono);font-size:9.5px;color:var(--petri-granite);margin-bottom:2px;}
.pcd-fase{display:inline-block;background:var(--petri-lavender-bg);color:var(--petri-indigo);font-size:9px;font-weight:600;
  padding:1px 8px;border-radius:99px;margin:2px 0 3px;}
.pcd-row{display:flex;gap:6px;align-items:flex-start;font-size:10.5px;color:var(--petri-text-secondary);margin-top:3px;line-height:1.35;}
.pcd-ic{flex-shrink:0;width:14px;text-align:center;}
.pcd-na{color:var(--petri-text-tertiary);}
.pcd-tareas{margin-top:5px;padding-top:5px;border-top:1px dashed var(--petri-border);font-style:italic;}

/* Grilla recurso × días (Camión / Operario) */
.plan-grilla-wrap{overflow-x:auto;border:0.5px solid var(--petri-border);border-radius:12px;}
.plan-grilla{width:100%;border-collapse:collapse;font-size:11px;font-family:var(--petri-font-ui);}
.plan-grilla th,.plan-grilla td{border:0.5px solid var(--petri-border);padding:5px;}
.plan-grilla-recurso{white-space:nowrap;font-weight:600;min-width:120px;position:sticky;left:0;background:var(--petri-marble);color:var(--petri-text-primary);z-index:1;}
.plan-grilla-dia{min-width:140px;text-align:center;font-size:10px;background:var(--petri-stone-light);color:var(--petri-text-secondary);}
.plan-grilla-celda{vertical-align:top;cursor:pointer;}
.plan-celda-ocupada{background:var(--petri-lavender-bg);}
.plan-celda-nodisponible{background:var(--petri-stone-light);color:var(--petri-granite);font-size:10px;font-style:italic;text-align:center;vertical-align:middle;}
.plan-card-mini{padding:5px 7px;margin-bottom:3px;border-radius:7px;color:#fff;font-size:10px;line-height:1.3;}

/* ── K · Conflictos en grilla Camión/Operario ─────────────────
   Sobreasignación (2+ servicios mismo día) y operario asignado en
   día No Disponible. Resaltado para que salte a la vista. */
.plan-celda-conflicto{background:rgba(163,45,45,.10);box-shadow:inset 0 0 0 1.5px #A32D2D;}
.plan-celda-choque{background:repeating-linear-gradient(45deg,rgba(163,45,45,.10),rgba(163,45,45,.10) 7px,rgba(163,45,45,.20) 7px,rgba(163,45,45,.20) 14px);box-shadow:inset 0 0 0 1.5px #A32D2D;}
.plan-celda-flag{display:inline-block;background:#A32D2D;color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:6px;margin-bottom:3px;letter-spacing:.3px;}

/* ── K · Barra de KPIs del rango ──────────────────────────────*/
#plan-kpis{margin:2px 0 12px;}
#plan-kpis:empty{display:none;}
.plan-kpis-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;}
@media(max-width:760px){.plan-kpis-grid{grid-template-columns:repeat(2,1fr);}}

/* ── K · Avisos de jornada (sin asignar / capacidad) ──────────*/
.plan-avisos{display:flex;flex-wrap:wrap;gap:3px;margin:3px 0 4px;}
.plan-aviso{font-size:9px;font-weight:600;padding:1px 6px;border-radius:6px;line-height:1.4;}
.plan-aviso-warn{background:rgba(186,117,23,.14);color:#8a560f;}
.plan-aviso-cap{background:rgba(163,45,45,.12);color:#A32D2D;}
/* Tarjeta compacta: marcador ⚠ en esquina + borde de aviso */
.plan-card{position:relative;}
.plan-card-haswarn{box-shadow:inset 0 0 0 1px rgba(186,117,23,.45);}
.plan-card-warn{position:absolute;top:3px;right:4px;font-size:10px;line-height:1;color:#BA7517;}

/* ── K · Filtro "Sin asignar" activo ──────────────────────────*/
#page-planificacion #plan-filtro-sinasignar.active{
  background:linear-gradient(135deg,#A32D2D,#7a1f1f);color:#fff;border-color:transparent;
  box-shadow:0 2px 8px rgba(163,45,45,.30);
}

/* ── K · Drag-to-reschedule ───────────────────────────────────*/
#page-planificacion [data-jornada][draggable="true"]{cursor:grab;}
#page-planificacion .plan-drag{opacity:.45;}
.plan-dia-over{outline:2px dashed var(--petri-indigo);outline-offset:-2px;background:var(--petri-lavender-bg);}

/* ── EXPEDIENTE HEADER (legacy — mantenido por si lo usa otro módulo) ── */
.exp-hdr{
  background:linear-gradient(135deg,var(--sb) 0%,var(--sb3) 100%);
  border-radius:var(--rad);padding:16px 20px;margin-bottom:14px;
  display:flex;align-items:center;justify-content:space-between;
  border:1px solid rgba(255,255,255,.05);
}
.exp-cod{font-family:'Space Mono',monospace;font-size:20px;font-weight:700;color:#fff;}
.exp-sub{font-size:12px;color:rgba(255,255,255,.6);margin-top:3px;}
.exp-chips{display:flex;gap:8px;align-items:center;flex-wrap:wrap;}
.chip{background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);padding:4px 12px;border-radius:20px;font-size:12px;}

/* ── EXPEDIENTE EDITOR · NUEVO ASPECTO PROFESIONAL (sesión 34c) ─────────
 * Cero cambios de operativa: IDs de campos, tabs y handlers son los
 * mismos. Solo cambia la presentación visual del header, las tabs y
 * la organización del formulario en cards. */

/* Hero card blanca con mini-KPIs */
.exp-hero{
  background:var(--surf);border:1px solid var(--bdr);border-radius:10px;
  padding:14px 18px;margin-bottom:12px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.exp-hero-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.exp-hero-left{flex:1;min-width:340px;}
.exp-hero-code{
  font-family:'Space Mono',Consolas,monospace;font-size:18px;font-weight:700;color:var(--tx);
  display:inline-block;background:var(--surf2);padding:3px 10px;border-radius:5px;letter-spacing:.5px;
}
.exp-hero-state{
  display:inline-block;margin-left:8px;padding:3px 10px;border-radius:99px;
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
}
.exp-hero-sub{
  margin-top:6px;display:flex;gap:14px;align-items:center;flex-wrap:wrap;
  font-size:13px;color:var(--tx2);
}
.exp-hero-sub b{color:var(--tx);}
.exp-hero-route{display:inline-flex;align-items:center;gap:6px;font-size:12px;}
.exp-hero-route .arr{color:var(--tx3);}
.exp-hero-meta{font-size:11px;color:var(--tx3);}
.exp-hero-kpis{display:flex;gap:8px;flex-wrap:wrap;}
.exp-mk{
  background:var(--surf2);border:1px solid var(--bdr);border-radius:7px;
  padding:8px 14px;min-width:120px;line-height:1.2;
}
.exp-mk .lbl{font-size:10px;color:var(--tx2);text-transform:uppercase;letter-spacing:.06em;font-weight:600;}
.exp-mk .val{font-size:16px;font-weight:700;margin-top:2px;}
.exp-mk .sub{font-size:10px;color:var(--tx3);margin-top:2px;}
.exp-mk.vol  .val{color:var(--blue);}
.exp-mk.pres .val{color:#8b5cf6;}
.exp-mk.fac  .val{color:var(--green);}
.exp-mk.marg .val{color:#0891b2;}

/* Badges de estado (paleta semántica) */
.expst-lead         {background:#dbeafe;color:#1e40af;}
.expst-presupuestado{background:#ede9fe;color:#6b21a8;}
.expst-aceptado     {background:#dcfce7;color:#166534;}
.expst-planificado  {background:#fef3c7;color:#92400e;}
.expst-en_curso     {background:#fed7aa;color:#9a3412;}
.expst-finalizado   {background:#e2e8f0;color:#334155;}
.expst-cancelado    {background:#fee2e2;color:#991b1b;}

/* Tabs estilo flat con underline rojo CRM (sin tocar .tn legacy) */
.exp-tabs{
  display:flex;gap:2px;background:var(--surf);border:1px solid var(--bdr);border-radius:10px 10px 0 0;
  padding:0 8px;border-bottom:2px solid var(--bdr);margin-bottom:0;overflow-x:auto;
  position:sticky;top:0;z-index:5;
}
.exp-tabs .tn{
  padding:11px 16px;font-size:13px;font-weight:500;color:var(--tx2);cursor:pointer;
  border:0;background:transparent;position:relative;transition:color .15s;
  display:inline-flex;align-items:center;gap:6px;white-space:nowrap;
}
.exp-tabs .tn:hover{color:var(--tx);background:var(--surf2);}
.exp-tabs .tn.active{color:var(--ac);font-weight:600;}
.exp-tabs .tn.active::after{
  content:'';position:absolute;left:8px;right:8px;bottom:-2px;height:3px;
  background:var(--ac);border-radius:2px;
}

/* Body de tabs con fondo de tarjeta */
.exp-tabs-body{
  background:var(--surf);border:1px solid var(--bdr);border-top:0;border-radius:0 0 10px 10px;
  padding:18px;
}

/* Cards de formulario dentro de las tabs */
.exp-card{
  background:var(--surf);border:1px solid var(--bdr);border-radius:10px;
  padding:14px 16px;
}
.exp-card-title{
  font-size:11px;color:var(--tx2);text-transform:uppercase;letter-spacing:.06em;
  font-weight:700;margin-bottom:10px;padding-bottom:6px;border-bottom:1px solid var(--bdr);
  display:flex;align-items:center;gap:6px;
}
.exp-card-title .ico{font-size:14px;}
.exp-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.exp-stack{display:flex;flex-direction:column;gap:14px;}
.exp-full{grid-column:1 / -1;}

@media (max-width:960px){
  .exp-grid{grid-template-columns:1fr;}
  .exp-hero-row{flex-direction:column;align-items:stretch;}
  .exp-hero-kpis{justify-content:space-between;}
}

/* ── PROGRESS ─────────────────────────────── */
.pbar{height:5px;background:var(--bdr);border-radius:3px;overflow:hidden;}
.pbfill{height:100%;border-radius:3px;background:var(--ac);transition:width .3s;}

/* ── PIPELINE ─────────────────────────────── */
.pipeline{display:grid;grid-template-columns:repeat(5,1fr);gap:10px;margin-bottom:16px;}
.pcol{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);box-shadow:var(--shd);}
.pchd{padding:8px 12px;font-size:10px;font-weight:700;color:var(--tx2);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--bdr);display:flex;justify-content:space-between;align-items:center;}
.pcbd{padding:8px;min-height:80px;}
.pcard{background:var(--surf2);border:1px solid var(--bdr);border-radius:5px;padding:10px;margin-bottom:6px;cursor:pointer;transition:box-shadow .12s;}
.pcard:hover{box-shadow:0 2px 8px rgba(0,0,0,.1);}
.pcard-t{font-size:12.5px;font-weight:500;color:var(--tx);margin-bottom:3px;}
.pcard-s{font-size:11px;color:var(--tx2);}

/* ── TIMELINE ─────────────────────────────── */
.tl{position:relative;padding-left:20px;}
.tl::before{content:'';position:absolute;left:6px;top:0;bottom:0;width:1px;background:var(--bdr);}
.tli{position:relative;padding-bottom:14px;}
.tldot{position:absolute;left:-16px;top:3px;width:10px;height:10px;border-radius:50%;background:var(--blue);border:2px solid var(--surf);}
.tldot.done{background:var(--green);}
.tldate{font-size:10px;color:var(--tx3);margin-bottom:2px;}
.tltext{font-size:12.5px;color:var(--tx);font-weight:500;}
.tlsub{font-size:11px;color:var(--tx2);}

/* ── GUARDAMUEBLES GRID ───────────────────── */
.gmgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;}
.gmcell{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:11px;text-align:center;cursor:pointer;transition:all .12s;}
.gmcell:hover{box-shadow:0 2px 8px rgba(0,0,0,.1);}
.gmcell.libre{border-color:#86efac;background:#f0fdf4;}
.gmcell.ocupado{border-color:#fca5a5;background:#fff1f2;}
.gmcell.parcial{border-color:#fcd34d;background:#fffbeb;}
.gmcell.reservado{border-color:#c4b5fd;background:#faf5ff;}
.gmcod{font-family:'Space Mono',monospace;font-size:14px;font-weight:700;color:var(--tx);}
.gmst{font-size:10px;font-weight:600;margin-top:4px;}
.gmst.libre{color:#16a34a;}.gmst.ocupado{color:#dc2626;}.gmst.parcial{color:#d97706;}.gmst.reservado{color:#7c3aed;}

/* Mapa visual GM v2 */
.gm-cell{transition:background .15s, border-color .15s;}
.gm-cell:hover{background:#eff6ff;border-color:#93c5fd !important;}
.gm-card{user-select:none;transition:transform .1s, box-shadow .1s;}
.gm-card:hover{transform:translateY(-1px);box-shadow:0 2px 6px rgba(0,0,0,.12);}
.gm-card:active{cursor:grabbing;}
#page-gm-mapa:fullscreen{background:#fff;padding:20px;overflow:auto;}

/* ── FLOTA CARDS ──────────────────────────── */
.fgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:12px;}
.fcard{background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);padding:14px;box-shadow:var(--shd);}
.fmat{font-family:'Space Mono',monospace;font-size:13px;font-weight:700;background:var(--surf2);padding:4px 10px;border-radius:5px;display:inline-block;margin-bottom:8px;letter-spacing:1px;}
.finfo{font-size:11.5px;color:var(--tx2);line-height:2.1;}

/* ── TOAST ────────────────────────────────── */
#toast{position:fixed;bottom:18px;right:18px;z-index:9999;background:var(--tx);color:#fff;border-radius:var(--rad);padding:10px 16px;font-size:13px;transform:translateY(12px);opacity:0;transition:all .2s;pointer-events:none;max-width:300px;box-shadow:0 4px 20px rgba(0,0,0,.25);}
#toast.show{transform:none;opacity:1;}
#toast.ok{background:#14532d;border-left:3px solid #22c55e;}
#toast.err{background:#7f1d1d;border-left:3px solid var(--ac2);}

.spin{display:inline-block;width:16px;height:16px;border:2px solid var(--bdr);border-top-color:var(--blue);border-radius:50%;animation:sp .7s linear infinite;}
@keyframes sp{to{transform:rotate(360deg)}}
.ldrow td{text-align:center;padding:28px;color:var(--tx2);}

.tbar-exp{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:8px;}
.tbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px;}
.tbar .exp-btns{margin-left:auto;display:flex;gap:5px;flex-wrap:wrap;}
.btn-xs{padding:3px 7px;font-size:11px;border-radius:4px;cursor:pointer;}

/* ── Searchable Select ───────────────────────── */
.ss-wrap{position:relative;}
.ss-input{cursor:text;}
.ss-dropdown{display:none;position:absolute;top:100%;left:0;right:0;z-index:200;background:var(--surf);border:1px solid var(--bdr);border-radius:var(--rad);box-shadow:0 8px 24px rgba(0,0,0,.12);max-height:240px;overflow-y:auto;}
.ss-option{padding:8px 12px;cursor:pointer;font-size:13px;}
.ss-option:hover,.ss-option.active{background:var(--ac);color:#fff;}
.ss-option b{font-weight:700;}
.ss-empty{padding:12px;color:var(--tx2);text-align:center;font-size:13px;}

/* ═══════════════════════════════════════════════
   RESPONSIVE — Mobile & Tablet
   ═══════════════════════════════════════════════ */

/* Tablas: forzar scroll horizontal en pantallas pequeñas */
.twrap table{min-width:1200px;}

/* Tablet (<1024px) */
@media (max-width:1024px) {
  :root{--sb-w:200px;}
  .content{padding:14px;}
  .shdr{flex-wrap:wrap;gap:8px;}
  .sacts{width:100%;display:flex;gap:6px;flex-wrap:wrap;}
  .fg2{grid-template-columns:1fr !important;}
  .fg3{grid-template-columns:1fr 1fr !important;}
  .modal{width:95vw !important;max-width:95vw !important;}
  .kcard{min-width:140px !important;}
}

/* Mobile (<768px) */
@media (max-width:768px) {
  #sidebar{position:fixed;left:-260px;z-index:900;width:260px;min-width:260px;transition:left .25s ease;box-shadow:4px 0 20px rgba(0,0,0,.3);}
  #sidebar.open{left:0;}
  .sb-toggle{display:block !important;}
  #main{margin-left:0 !important;}
  .content{padding:10px;}
  .topbar{padding:0 10px;}
  .fg2,.fg3{grid-template-columns:1fr !important;}
  .modal{width:100vw !important;max-width:100vw !important;max-height:100vh !important;border-radius:0 !important;}
  .shdr .stitle{font-size:16px;}
  .tbar{flex-direction:column;align-items:stretch;}
  .tbar .exp-btns{justify-content:flex-start;}
  .btn{font-size:11px;padding:5px 10px;}
  .kcard{min-width:100% !important;}
  #bdash-charts{grid-template-columns:1fr !important;}
  #bdash-kpis{grid-template-columns:repeat(2,1fr) !important;}
}

/* Sidebar toggle button (hidden by default, shown on mobile) */
.sb-toggle{display:none;position:fixed;top:8px;left:8px;z-index:901;background:var(--ac);color:#fff;border:none;border-radius:8px;width:40px;height:40px;cursor:pointer;font-size:20px;box-shadow:0 2px 8px rgba(0,0,0,.2);}

/* Botones de accion siempre visibles (no solo en hover) en mobile */
@media (max-width:1024px) {
  .tact{opacity:1 !important;}
}

/* ── RUTA · Toolbar + Mapa + Drag&Drop (sesión 34d) ─────────── */
.ruta-bar{
  background:var(--surf);border:1px solid var(--bdr);border-radius:8px;
  padding:10px 14px;margin-bottom:10px;
  display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
}
.ruta-bar-stats{display:flex;gap:18px;align-items:center;flex-wrap:wrap;}
.ruta-bar-stat{display:inline-flex;flex-direction:column;line-height:1.1;}
.ruta-bar-stat .lbl{font-size:10px;color:var(--tx2);text-transform:uppercase;letter-spacing:.06em;font-weight:600;}
.ruta-bar-stat .val{font-size:15px;font-weight:700;color:var(--tx);}
.ruta-bar-acts{display:flex;gap:6px;flex-wrap:wrap;}

.ruta-map{
  width:100%;min-height:380px;border:1px solid var(--bdr);border-radius:8px;
  background:var(--surf2);margin-bottom:14px;overflow:hidden;
  position:relative;
}
.ruta-map-loading{
  position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--tx2);
}
.ruta-map-config{
  padding:24px;background:#fffbeb;border:1px dashed #fde68a;border-radius:8px;color:#78350f;
}
.ruta-map-config a{color:#1e40af;}
.ruta-map-config code{background:#fef3c7;padding:1px 6px;border-radius:3px;font-size:11px;}
.ruta-map-err{
  padding:18px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:12px;
}

/* Drag handle visual */
.ruta-drag-handle{
  display:inline-block;color:var(--tx3);cursor:grab;font-size:14px;font-weight:700;
  padding:2px 4px;letter-spacing:-2px;user-select:none;
}
.ruta-drag-handle:hover{color:var(--tx2);}
.ruta-punto[draggable="true"]{cursor:move;}
.ruta-punto.ruta-dragging{opacity:.4;}
.ruta-punto.ruta-drop-target .ruta-contenido{
  outline:2px dashed var(--ac);outline-offset:-2px;
}

/* ── INVENTARIO VISITADOR · tablet-first (sesión 34f) ──────────
 * Rediseño visual del modal #m-inventario para uso en tablet 8-10":
 *   · Cards con bordes claros entre zonas.
 *   · Selects → pills táctiles grandes.
 *   · Stepper sustituye al tab-bar (UX wizard).
 *   · Sticky footer con Guardar + Siguiente siempre visibles.
 *
 * IDs internos (inv-origen-dir, inv-tipo-inmueble, etc.) se conservan
 * para que `invGuardarDetalles()` siga funcionando sin cambios. */
.inv-card {
  background:#fff; border:1px solid var(--bdr); border-radius:10px;
  padding:14px 16px; margin-bottom:14px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.inv-card-h {
  display:flex; align-items:center; gap:8px; margin:-2px 0 12px;
  padding-bottom:8px; border-bottom:1px solid var(--bdr);
}
.inv-card-h .ico { font-size:18px; }
.inv-card-h h3 {
  margin:0; font-size:11px; color:var(--tx2);
  text-transform:uppercase; letter-spacing:.08em; font-weight:700;
}
.inv-card-h .req {
  margin-left:auto; background:#dbeafe; color:#1e40af;
  font-size:10px; font-weight:600; padding:2px 8px; border-radius:99px;
  text-transform:uppercase; letter-spacing:.04em;
}
.inv-card-h .req.gray { background:var(--surf2); color:var(--tx2); }

.inv-kv-grid { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.inv-kv {
  background:var(--surf2); border:1px solid var(--bdr); border-radius:8px;
  padding:10px 12px;
}
.inv-kv-lbl { font-size:10px; color:var(--tx2); text-transform:uppercase; letter-spacing:.06em; font-weight:600; }
.inv-kv-val { font-size:14px; font-weight:700; color:var(--tx); margin-top:2px; }

.inv-fg { margin-bottom:0; }
.inv-fg-grid { display:grid; gap:12px; }
.inv-fg-2 { grid-template-columns:1fr 1fr; }
.inv-fg-3 { grid-template-columns:1fr 1fr 1fr; }
.inv-fl {
  display:flex; align-items:center; justify-content:space-between;
  font-size:11px; color:var(--tx2); font-weight:600;
  text-transform:uppercase; letter-spacing:.04em; margin-bottom:5px;
}
.inv-fl .hint { font-size:10px; color:var(--tx3); font-weight:500; text-transform:none; letter-spacing:0; font-style:italic; }
.inv-fi {
  width:100%; padding:10px 12px;
  border:1.5px solid var(--bdr); border-radius:7px;
  font-size:14px; background:#fff; color:var(--tx);
  transition:border-color .15s, box-shadow .15s;
  min-height:42px;
}
.inv-fi:focus { outline:0; border-color:#2563eb; box-shadow:0 0 0 4px rgba(37,99,235,.15); }
textarea.inv-fi { resize:vertical; min-height:60px; line-height:1.45; }

/* Pills sustituyendo selects */
.inv-pills {
  display:flex; flex-wrap:wrap; gap:6px;
  padding:4px; background:var(--surf2);
  border:1.5px solid var(--bdr); border-radius:8px;
}
.inv-pill {
  flex:1; min-width:0; min-height:38px; padding:8px 12px;
  background:#fff; border:1.5px solid var(--bdr); border-radius:6px;
  font-size:13px; font-weight:500; color:var(--tx2);
  cursor:pointer; transition:all .15s;
  display:inline-flex; align-items:center; justify-content:center; gap:6px;
  white-space:nowrap; text-align:center;
}
.inv-pill:hover { background:var(--surf2); border-color:#94a3b8; }
.inv-pill.active {
  background:var(--ac); color:#fff; border-color:var(--ac);
  box-shadow:0 2px 6px rgba(220,38,38,.25);
}

/* Alerta ámbar (contacto visita) */
.inv-alert-amber {
  background:#fffbeb; border:1px solid #fde68a; border-radius:8px;
  padding:10px 14px; color:#78350f; font-size:13px; line-height:1.5;
  display:flex; gap:10px; align-items:center; margin-bottom:14px;
}
.inv-alert-amber .ico { font-size:18px; flex-shrink:0; }

/* Stepper que sustituye a las tabs antiguas */
.inv-stepper {
  display:grid; grid-template-columns:repeat(5,1fr); gap:0;
  background:#f1f5f9; padding:14px 20px; border-bottom:1px solid var(--bdr);
  flex-shrink:0;
}
.inv-step {
  display:flex; align-items:center; gap:10px; position:relative;
  padding:6px 8px; cursor:pointer; transition:background .15s;
  border-radius:6px; border:0; background:transparent;
}
.inv-step:hover { background:rgba(0,0,0,.04); }
.inv-step:not(:last-child)::after {
  content:''; position:absolute; right:-6px; top:50%;
  width:12px; height:12px; border-top:2px solid #94a3b8; border-right:2px solid #94a3b8;
  transform:translateY(-50%) rotate(45deg);
}
.inv-step-num {
  width:30px; height:30px; border-radius:50%; background:#fff;
  border:2px solid var(--bdr); color:var(--tx2);
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; flex-shrink:0;
  transition:all .2s;
}
.inv-step-lbl { line-height:1.15; text-align:left; }
.inv-step-lbl .a { font-size:13px; font-weight:600; color:var(--tx2); }
.inv-step-lbl .b { font-size:10px; color:var(--tx3); margin-top:1px; text-transform:uppercase; letter-spacing:.04em; }
.inv-step.done .inv-step-num { background:#16a34a; border-color:#16a34a; color:#fff; }
.inv-step.done .inv-step-lbl .a { color:var(--tx); }
.inv-step.done .inv-step-lbl .b { color:#16a34a; font-weight:600; }
.inv-step.cur .inv-step-num { background:var(--ac); border-color:var(--ac); color:#fff; box-shadow:0 0 0 4px rgba(220,38,38,.18); }
.inv-step.cur .inv-step-lbl .a { color:var(--ac); font-weight:700; }
.inv-step.cur .inv-step-lbl .b { color:var(--ac); }

/* Sticky footer con Guardar + Siguiente */
.inv-mft {
  background:#fff; border-top:1px solid var(--bdr);
  padding:12px 20px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  box-shadow:0 -2px 8px rgba(15,23,42,.05);
  flex-shrink:0;
}
.inv-mft-info { font-size:12px; color:var(--tx3); display:flex; align-items:center; gap:6px; }
.inv-mft-info .dot { width:8px; height:8px; border-radius:50%; background:#16a34a; box-shadow:0 0 0 3px rgba(22,163,74,.2); }
.inv-mft-info.idle .dot { background:#94a3b8; box-shadow:0 0 0 3px rgba(148,163,184,.2); }
.inv-mft-acts { display:flex; gap:10px; }

/* Header con logo + título grande (sustituye al gris oscuro plano) */
.inv-mhd {
  background:linear-gradient(135deg,#1e293b 0%,#0f172a 100%);
  color:#fff; padding:14px 20px; display:flex; align-items:center; gap:14px;
  border-bottom:3px solid var(--ac);
  flex-shrink:0;
}
.inv-mhd-logo {
  background:#fff; padding:6px 10px; border-radius:6px; height:42px;
  display:flex; align-items:center;
}
.inv-mhd-title { flex:1; line-height:1.2; min-width:0; }
.inv-mhd-title .t1 { font-size:16px; font-weight:700; }
.inv-mhd-title .t2 { font-size:12px; opacity:.75; margin-top:2px; }
.inv-mhd-close {
  background:rgba(255,255,255,.15); border:0; color:#fff;
  width:42px; height:42px; border-radius:8px; font-size:18px; cursor:pointer;
  transition:background .15s; flex-shrink:0;
}
.inv-mhd-close:hover { background:rgba(255,255,255,.28); }

/* Card de Volumen total siempre visible en cabecera (ahorra la línea de
 * "Total vivienda" en la barra inferior de stats). */
.inv-mhd-voltot {
  background:rgba(255,255,255,.10); border:1px solid rgba(255,255,255,.18);
  border-radius:8px; padding:6px 14px; flex-shrink:0; line-height:1.1;
  text-align:right;
}
.inv-mhd-voltot-lbl { font-size:10px; letter-spacing:.08em; color:rgba(255,255,255,.65); font-weight:600; }
.inv-mhd-voltot-val { font-size:18px; font-weight:800; color:#fff; margin-top:1px; font-variant-numeric:tabular-nums; }
@media (max-width:760px) {
  .inv-mhd-voltot { padding:4px 10px; }
  .inv-mhd-voltot-lbl { font-size:9px; }
  .inv-mhd-voltot-val { font-size:14px; }
}

/* Body scrollable con gris suave */
.inv-mbody {
  flex:1; overflow-y:auto; padding:16px 20px 20px;
  background:#f1f5f9;
}

/* Adaptación tablet vertical / móvil */
@media (max-width:760px) {
  .inv-mhd-logo { display:none; }
  .inv-stepper { grid-template-columns:repeat(5,auto); overflow-x:auto; }
  .inv-step:not(:last-child)::after { display:none; }
  .inv-step-lbl .a { font-size:11px; }
  .inv-step-lbl .b { display:none; }
  .inv-kv-grid, .inv-fg-2, .inv-fg-3 { grid-template-columns:1fr; }
  .inv-mft-info { display:none; }
}

/* ─────────────────────────────────────────────────────────────────
 * INV · Gestor de direcciones del expediente (pestaña Agrupaciones)
 * Catálogo unificado: direcciones oficiales (origen/destino fijos del
 * expediente, no editables aquí) + direcciones añadidas en visita.
 * Tablet-first: targets táctiles ≥38px, pills en lugar de selects.
 * ───────────────────────────────────────────────────────────────── */
.inv-card {
  background:#fff; border:1px solid var(--bdr); border-radius:10px;
  padding:14px 16px; margin-bottom:14px;
}
.inv-card-h {
  display:flex; align-items:center; gap:8px;
  padding-bottom:8px; border-bottom:1px solid var(--bdr); margin-bottom:10px;
}
.inv-card-h .ico { font-size:18px; }
.inv-card-h h3 {
  margin:0; font-size:11px; color:var(--tx2);
  text-transform:uppercase; letter-spacing:.06em; font-weight:700;
}
.inv-card-h .count { margin-left:auto; font-size:11px; color:var(--tx3); font-weight:500; }

/* Tags semánticos */
.inv-tag {
  display:inline-flex; align-items:center; padding:2px 9px; border-radius:99px;
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.05em;
}
.inv-tag-origen   { background:#dbeafe; color:#1e40af; }
.inv-tag-destino  { background:#dcfce7; color:#166534; }
.inv-tag-parada   { background:#fed7aa; color:#9a3412; }
.inv-tag-oficial  { background:#1A1A1A; color:#fff; }
.inv-tag-visita   { background:var(--surf2); color:var(--tx2); border:1px solid var(--bdr); }

/* Lista de direcciones */
.inv-addr-list { display:flex; flex-direction:column; gap:8px; }
.inv-addr {
  border:1px solid var(--bdr); border-radius:8px; padding:12px 14px;
  display:flex; align-items:center; gap:12px; background:#fff;
  transition:border-color .15s, box-shadow .15s;
}
.inv-addr:hover { border-color:#2563eb; box-shadow:0 2px 6px rgba(37,99,235,.1); }
.inv-addr-icon { font-size:22px; flex-shrink:0; }
.inv-addr-info { flex:1; min-width:0; }
.inv-addr-info .top { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-bottom:3px; }
.inv-addr-info .alias { font-weight:700; font-size:14px; }
.inv-addr-info .dir { font-size:12px; color:var(--tx2); }
.inv-addr-acts { display:flex; gap:4px; flex-shrink:0; }

/* Botones internos del gestor */
.inv-ibtn {
  background:var(--surf2); border:1px solid var(--bdr);
  padding:8px 12px; border-radius:6px; font-size:12px; font-weight:600;
  cursor:pointer; min-height:36px; display:inline-flex; align-items:center; gap:4px;
  color:var(--tx);
}
.inv-ibtn:hover { border-color:#94a3b8; background:#fff; }
.inv-ibtn-add {
  background:var(--ac); color:#fff; border:0; padding:10px 18px;
  font-weight:700; min-height:42px; box-shadow:0 1px 3px rgba(220,38,38,.25);
  border-radius:7px; font-size:13px; cursor:pointer;
}
.inv-ibtn-add:hover { background:var(--ac2); }
.inv-ibtn-del { background:#fef2f2; color:#dc2626; border-color:#fecaca; }
.inv-ibtn-del:hover { background:#fee2e2; border-color:#fca5a5; }
.inv-ibtn-lock {
  background:transparent; color:var(--tx3); border-color:transparent;
  cursor:default; padding:8px 4px;
}

/* Pills tipo (origen/destino/parada) — variantes coloreadas */
.inv-pill.act-origen  { background:#2563eb; color:#fff; border-color:#2563eb; box-shadow:0 2px 6px rgba(37,99,235,.25); }
.inv-pill.act-destino { background:#16a34a; color:#fff; border-color:#16a34a; box-shadow:0 2px 6px rgba(22,163,74,.25); }
.inv-pill.act-parada  { background:#ea580c; color:#fff; border-color:#ea580c; box-shadow:0 2px 6px rgba(234,88,12,.25); }

/* Formulario inline (alta/edición de dirección de visita) */
.inv-form-inline {
  background:#fffbeb; border:2px dashed #fde68a; border-radius:10px;
  padding:14px 16px; margin-top:10px;
}
.inv-form-inline-h {
  display:flex; align-items:center; gap:8px; margin-bottom:10px;
  font-size:12px; font-weight:700; color:#78350f;
  text-transform:uppercase; letter-spacing:.06em;
}
.inv-fg { margin-bottom:10px; }
.inv-fg-grid { display:grid; gap:10px; }
.inv-fg-2 { grid-template-columns:1fr 1fr; }
.inv-fg-3 { grid-template-columns:1fr 1fr 1fr; }
.inv-fl {
  display:block; font-size:11px; color:var(--tx2); font-weight:600;
  text-transform:uppercase; letter-spacing:.04em; margin-bottom:4px;
}
.inv-fl .hint { font-weight:400; color:var(--tx3); font-style:italic; text-transform:none; letter-spacing:0; }
.inv-fi {
  width:100%; padding:9px 12px; border:1.5px solid var(--bdr); border-radius:7px;
  font-size:13px; min-height:42px; background:#fff;
}

@media (max-width:760px) {
  .inv-fg-2, .inv-fg-3 { grid-template-columns:1fr; }
}

/* ── INSPECCIONES · secciones del modal edit/new (sesión 35d) ── */
.insp-sec {
  background:#fff; border:1px solid var(--bdr); border-radius:10px;
  padding:14px 16px; margin-bottom:12px;
  box-shadow:0 1px 2px rgba(15,23,42,.04);
}
.insp-sec-h {
  display:flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; color:var(--tx2);
  text-transform:uppercase; letter-spacing:.06em;
  padding-bottom:8px; margin-bottom:10px;
  border-bottom:1px solid var(--bdr);
}
.insp-sec-h .ico { font-size:16px; color:var(--ac); }
.insp-sec .fg { margin-bottom:10px; }
.insp-sec .fg:last-child { margin-bottom:0; }
.insp-sec-grid { display:grid; gap:10px; }
.insp-sec-2 { grid-template-columns:1fr 1fr; }
.insp-sec-3 { grid-template-columns:1fr 1fr 1fr; }
@media (max-width:680px) {
  .insp-sec-2, .insp-sec-3 { grid-template-columns:1fr; }
}

/* ── INSPECCIONES · listado dentro del expediente (sesión 34g) ──
 * Cards clickables que abren editInspModal. Botones de acción
 * unificados con jerarquía visual clara y emoji + label. */
.insp-card {
  display:flex; align-items:stretch; gap:14px;
  border:1px solid var(--bdr); border-radius:10px;
  padding:12px 14px; margin-bottom:10px;
  background:var(--surf);
  box-shadow:0 1px 2px rgba(15,23,42,.04);
  cursor:pointer; transition:border-color .15s, box-shadow .15s, transform .12s;
}
.insp-card:hover {
  border-color:#2563eb; box-shadow:0 4px 12px rgba(37,99,235,.12);
  transform:translateY(-1px);
}
.insp-date {
  color:#fff; border-radius:8px; padding:8px 12px;
  text-align:center; min-width:72px; flex-shrink:0;
  display:flex; flex-direction:column; justify-content:center;
}
.insp-date .d { font-size:11px; font-weight:700; opacity:.95; }
.insp-date .h { font-size:17px; font-weight:800; margin:2px 0; letter-spacing:-0.5px; }
.insp-date .m { font-size:10px; opacity:.85; }
.insp-info { flex:1; min-width:0; align-self:center; }
.insp-title { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.insp-title .t { font-weight:700; font-size:14px; color:var(--tx); }
.insp-badge {
  font-size:10px; font-weight:700; padding:2px 9px; border-radius:99px;
  text-transform:uppercase; letter-spacing:.05em;
}
.insp-volbadge {
  font-size:11px; font-weight:600; padding:2px 9px; border-radius:99px;
  background:#dbeafe; color:#1e40af;
}
.insp-volbadge.zero { background:#f3f4f6; color:#64748b; }
.insp-meta {
  display:flex; flex-wrap:wrap; gap:14px;
  font-size:12px; color:var(--tx2); margin-top:6px;
}
.insp-meta-item { display:inline-flex; align-items:center; gap:5px; }
.insp-meta-item .ico { font-size:13px; }
.insp-obs {
  font-size:12px; color:var(--tx3); margin-top:6px;
  background:var(--surf2); padding:6px 10px; border-radius:6px;
  font-style:italic;
}

/* Botones de acción de la inspección — estilo coherente con jerarquía */
.insp-acts {
  display:flex; flex-direction:column; gap:6px; align-items:stretch;
  flex-shrink:0; min-width:130px;
}
.insp-btn {
  display:inline-flex; align-items:center; justify-content:flex-start; gap:6px;
  padding:6px 11px; border-radius:6px; font-size:12px; font-weight:600;
  border:1px solid transparent; cursor:pointer; transition:all .15s;
  text-align:left; min-height:30px; line-height:1;
  background:transparent;
}
.insp-btn .ico { font-size:14px; line-height:1; }
.insp-btn .lbl { line-height:1; }
.insp-btn:hover { transform:translateY(-1px); }

/* Variantes con semántica visual */
.insp-btn-edit     { background:#f8fafc; color:#0f172a; border-color:var(--bdr); }
.insp-btn-edit:hover    { background:#e2e8f0; border-color:#94a3b8; }
.insp-btn-realizar { background:#16a34a; color:#fff; }
.insp-btn-realizar:hover{ background:#15803d; box-shadow:0 2px 6px rgba(22,163,74,.3); }
.insp-btn-inv      { background:#1A1A1A; color:#fff; }
.insp-btn-inv:hover     { background:#000; box-shadow:0 2px 6px rgba(0,0,0,.3); }
.insp-btn-del      { background:#fef2f2; color:#dc2626; border-color:#fecaca; justify-content:center; min-width:36px; padding:6px 10px; }
.insp-btn-del:hover     { background:#fee2e2; border-color:#fca5a5; }
.insp-btn-del .ico { font-size:14px; }

/* Responsive: en pantallas estrechas las acciones bajan */
@media (max-width:760px) {
  .insp-card { flex-direction:column; }
  .insp-date { flex-direction:row; gap:8px; min-width:0; align-items:center; }
  .insp-acts { flex-direction:row; flex-wrap:wrap; min-width:0; }
  .insp-btn { flex:1; min-width:0; justify-content:center; }
}

/* ── DIRTY INDICATOR · cambios sin guardar (sesión 34d) ───── */
.btn.is-dirty::after{
  content:'';display:inline-block;width:7px;height:7px;border-radius:50%;
  background:#f59e0b;margin-left:6px;vertical-align:middle;
  box-shadow:0 0 0 2px rgba(245,158,11,.25);
  animation: dirty-pulse 1.6s infinite;
}
@keyframes dirty-pulse{
  0%   {box-shadow:0 0 0 0    rgba(245,158,11,.45);}
  70%  {box-shadow:0 0 0 6px  rgba(245,158,11,0);}
  100% {box-shadow:0 0 0 0    rgba(245,158,11,0);}
}
