  :root{
  --azul:#003b71; --azul2:#005a9c; --dorado:#c9a227; --fondo:#f3f6fa;
  --texto:#243447; --muted:#64748b; --borde:#dbe4ee; --rojo:#b91c1c;
  --verde:#0f766e; --naranja:#b45309; --sombra:0 12px 30px rgba(0,39,77,.12);
}
*{box-sizing:border-box}
body{
  margin:0;font-family:Arial,Helvetica,sans-serif;color:var(--texto);
  background:radial-gradient(circle at top left,rgba(201,162,39,.13),transparent 30%),linear-gradient(180deg,#f8fbff,#eef4fa);
}
header{background:linear-gradient(135deg,var(--azul),var(--azul2));color:white;padding:28px 18px;border-bottom:6px solid var(--dorado)}
.header-inner{max-width:1280px;margin:auto;display:flex;justify-content:space-between;align-items:center;gap:18px;flex-wrap:wrap}
h1{margin:0;font-size:clamp(24px,4vw,40px)}
header p{margin:6px 0 0;color:rgba(255,255,255,.86)}
.badge{border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.12);border-radius:999px;padding:9px 14px;font-weight:800}
.institutional-brand{display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.logo-unsa{width:92px;height:92px;object-fit:contain;background:white;border-radius:18px;padding:8px;box-shadow:0 8px 22px rgba(0,0,0,.18)}
.logo-fallback{display:none;width:92px;height:92px;background:white;color:var(--azul);border-radius:18px;align-items:center;justify-content:center;font-weight:900;font-size:22px;box-shadow:0 8px 22px rgba(0,0,0,.18);border:1px solid rgba(255,255,255,.65)}
.sup-title{font-size:13px;letter-spacing:.08em;text-transform:uppercase;color:rgba(255,255,255,.78);font-weight:800;margin-bottom:4px}
.system-desc{max-width:810px;line-height:1.5;color:rgba(255,255,255,.88);font-size:14.5px;margin-top:8px}
.badge a{color:white;text-decoration:none;font-weight:900}.badge a:hover{text-decoration:underline}
.institutional-strip{background:#fff;border-bottom:1px solid var(--borde);box-shadow:0 8px 18px rgba(0,39,77,.04)}
.strip-inner{max-width:1280px;margin:auto;padding:12px 16px;color:#475569;font-size:14px;line-height:1.45}
.strip-inner strong{color:var(--azul)}
nav{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--borde)}
.nav-inner{max-width:1280px;margin:auto;padding:10px 16px;display:flex;gap:8px;flex-wrap:wrap}
.nav-inner a,.nav-inner button{width:auto;background:#fff;color:var(--azul);border:1px solid var(--borde);border-radius:999px;padding:9px 13px;font-weight:900;text-decoration:none;font-size:14px;cursor:pointer}
.nav-inner a.active,.nav-inner button.active,.nav-inner a:hover,.nav-inner button:hover{background:var(--azul);color:white}
main{max-width:1280px;margin:24px auto;padding:0 16px 42px}
.card{background:white;border:1px solid var(--borde);border-radius:22px;box-shadow:var(--sombra);padding:20px;margin-bottom:18px}
h2,h3{color:var(--azul);margin-top:0}
.grid{display:grid;gap:14px}.form-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.span-2{grid-column:span 2}.span-3{grid-column:span 3}.span-4{grid-column:span 4}
label{font-size:13px;font-weight:800;color:#334155;display:block;margin-bottom:6px}
input,select,textarea,button{width:100%;border:1px solid var(--borde);border-radius:12px;padding:11px 12px;font-size:14px;font-family:Arial,Helvetica,sans-serif}
textarea{min-height:88px;resize:vertical}
input:focus,select:focus,textarea:focus{outline:2px solid rgba(0,90,156,.22);border-color:var(--azul2)}
button{cursor:pointer;font-weight:900;background:var(--azul);color:white;border:none}
button:hover{background:var(--azul2)}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.btn-row button,.btn-row a{width:auto}
.btn-sec{background:#475569}.btn-gold{background:var(--dorado);color:#111}.btn-red{background:var(--rojo)}.btn-green{background:var(--verde)}.btn-orange{background:var(--naranja)}
.small{padding:7px 10px;border-radius:10px;font-size:12px}
.hidden{display:none!important}
.kpis{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.kpi{background:#f8fbff;border:1px solid var(--borde);border-radius:18px;padding:16px}
.kpi .num{font-size:32px;font-weight:900;color:var(--azul)}
.kpi .lbl{font-weight:800;color:var(--muted);margin-top:4px}
.filters{display:grid;grid-template-columns:2fr 1fr 1fr 1fr auto;gap:10px;margin-bottom:14px}
.table-wrap{overflow:auto;border:1px solid var(--borde);border-radius:16px}
table{width:100%;min-width:1180px;border-collapse:collapse;background:white}
thead{background:var(--azul);color:white}
th,td{padding:10px;border-bottom:1px solid var(--borde);text-align:left;font-size:13px;vertical-align:top}
tbody tr:hover{background:#f7fbff}
.tag{display:inline-block;padding:4px 8px;border-radius:999px;font-size:12px;font-weight:900;color:white;background:var(--azul2);margin:1px}
.tag.green{background:var(--verde)}.tag.red{background:var(--rojo)}.tag.orange{background:var(--naranja)}.tag.gray{background:#64748b}
.cards-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(320px,1fr));
  gap:18px;
  align-items:start;
  width:100%;
}

/* evita desbordes horizontales internos */
.cards-grid > *{
  min-width:0;
}
.vehicle-card{
  overflow:hidden;
  padding:0;
  border-radius:20px;
  background:#fff;
  border:1px solid var(--borde);
  box-shadow:0 8px 24px rgba(0,39,77,.08);
  max-width:100%;

}

.vehicle-card .thumb{
  width:100%;
  height:230px;
  overflow:hidden;
  background:#edf2f7;
  position:relative;
}

.vehicle-card .thumb{
  width:100%;
  height:230px;
  overflow:hidden;
  background:#edf2f7;
  position:relative;

  display:flex;
  align-items:center;
  justify-content:center;
}

.vehicle-card .thumb img{
  width:100%;
  height:100%;

  object-fit:contain;
  object-position:center;

  display:block;
  transition:transform .25s ease;
  cursor:pointer;

  background:#edf2f7;
}

.vehicle-card:hover .thumb img{
  transform:scale(1.02);
}

.vehicle-card .body{
  padding:16px;
}
.vehicle-title{font-weight:900;color:var(--azul);font-size:18px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 14px;margin-top:12px}
.detail-grid div{background:#f8fbff;border:1px solid var(--borde);border-radius:12px;padding:8px}
.detail-grid strong{display:block;color:#334155;font-size:12px;margin-bottom:2px}
.muted{color:var(--muted)}
.error{color:var(--rojo);font-size:12px;font-weight:800;margin-top:5px}
.invalid{border-color:var(--rojo)!important;background:#fff7f7}
.help{background:#fffaf0;border-left:7px solid var(--dorado);border-radius:18px;padding:16px;color:#334155}
.login{max-width:540px;margin:35px auto}
hr{border:none;border-top:1px solid var(--borde);margin:18px 0}
.bar-row{display:grid;grid-template-columns:minmax(170px,260px) 1fr 48px;gap:12px;align-items:center;margin:12px 0}
.bar-label{font-weight:800;font-size:14px}.bar-track{height:14px;background:#edf2f7;border-radius:999px;overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--azul2),var(--dorado));border-radius:999px}.bar-value{font-weight:900;color:var(--azul);text-align:right}
.preview-grid{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}
.preview-item{position:relative;border:1px solid var(--borde);border-radius:14px;overflow:hidden;background:#edf2f7}
.preview-item img{width:120px;height:85px;object-fit:cover;display:block}
.preview-item button{position:absolute;right:4px;top:4px;width:auto;padding:4px 7px;border-radius:8px;background:var(--rojo);font-size:11px}
.thumb{width:78px;height:55px;object-fit:cover;border-radius:10px;border:1px solid var(--borde);background:#edf2f7;cursor:pointer}
.gallery-count{font-size:12px;font-weight:800;color:var(--azul);margin-top:4px}
.modal{position:fixed;z-index:9999;inset:0;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;padding:22px}
.modal-content{max-width:1100px;width:100%;position:relative;text-align:center;color:white}
.modal-card{background:white;color:var(--texto);border-radius:22px;box-shadow:0 18px 45px rgba(0,0,0,.45);padding:24px;text-align:left;max-height:86vh;overflow:auto}
.modal img{max-width:100%;max-height:78vh;border-radius:14px;box-shadow:0 18px 45px rgba(0,0,0,.5)}
.modal-title{margin:12px 0 0;font-weight:900}
.modal-close,.modal-prev,.modal-next{position:absolute;width:auto;border-radius:999px;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.3);color:white}
.modal-close{right:0;top:-46px;padding:9px 14px}
.modal-prev{left:0;top:45%;padding:12px 16px}
.modal-next{right:0;top:45%;padding:12px 16px}
.report-box{background:white;border:1px solid var(--borde);padding:28px;border-radius:18px}
.report-title{text-align:center;color:var(--azul);margin-bottom:4px}.report-subtitle{text-align:center;color:#334155;margin-top:0}
.report-section{margin-top:22px}.report-section h3{border-bottom:2px solid var(--dorado);padding-bottom:6px}
.report-table{min-width:0;width:100%}.report-table th,.report-table td{font-size:12.5px}
.firma{margin-top:60px;display:flex;justify-content:flex-end}.firma div{text-align:center;min-width:260px;border-top:1px solid #111;padding-top:8px}
.subtitulo-ficha{
  grid-column:1 / -1;background:#f8fbff;border:1px solid var(--borde);
  border-left:7px solid var(--dorado);border-radius:16px;padding:12px 14px;
  font-weight:900;color:var(--azul);margin-top:8px;
}
.subtexto-ficha{grid-column:1 / -1;color:var(--muted);font-size:13px;margin-top:-6px}
.linklike{color:var(--azul2);font-weight:900;text-decoration:underline;cursor:pointer}
@media(max-width:980px){
  .form-grid,.filters,.kpis,.cards-grid,.detail-grid{grid-template-columns:1fr}
  .span-2,.span-3,.span-4{grid-column:span 1}
  .btn-row button,.btn-row a{width:100%}
  .bar-row{grid-template-columns:1fr}.bar-value{text-align:left}
  .modal-prev{left:10px}.modal-next{right:10px}
}
@media print{
  body{background:white}
  header,nav,.no-print,.filters,.btn-row,.help,.modal{display:none!important}
  main{margin:0;padding:0;max-width:none}
  .card,.report-box{box-shadow:none;border:none;border-radius:0}
  .report-box{padding:18mm}
  table{page-break-inside:auto}
  tr{page-break-inside:avoid;page-break-after:auto}
}

/* Perfil operativo Automotores */
.operativo-box{
  background:linear-gradient(180deg,#fffaf0,#ffffff);
  border:2px solid rgba(201,162,39,.55);
  border-left:9px solid var(--dorado);
  border-radius:20px;
  padding:14px;
  grid-column:1 / -1;
  box-shadow:0 8px 22px rgba(201,162,39,.10);
}
.operativo-box .subtitulo-ficha{
  margin-top:0;
}
.campo-operativo{
  background:#fffaf0;
  border:1px solid rgba(201,162,39,.55);
  border-radius:16px;
  padding:10px;
}
.campo-operativo label::after{
  content:"  · editable por Automotores";
  color:var(--naranja);
  font-weight:800;
  font-size:11px;
}
.campo-bloqueado{
  opacity:.72;
}
.campo-bloqueado input,
.campo-bloqueado select,
.campo-bloqueado textarea{
  background:#f1f5f9;
  color:#64748b;
  cursor:not-allowed;
}
.role-pill{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background:#fffaf0;
  border:1px solid rgba(201,162,39,.6);
  color:var(--naranja);
  font-weight:900;
  font-size:12px;
}


.btn-delete-img{
  display:block;
  margin-top:6px;
  padding:6px 8px;

  border-radius:8px;

  background:#b91c1c;
  color:#fff !important;

  text-align:center;
  text-decoration:none;

  font-size:11px;
  font-weight:700;
}

.btn-delete-img:hover{
  background:#991b1b;
}
.export-box{
  margin-top:22px;

  padding-top:18px;
  border-top:1px solid #d8e1ea;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  flex-wrap:wrap;
}

.export-title{
  font-size:15px;
  font-weight:800;
  color:#0b3b6e;
}

.export-actions{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}

.btn-export{
  border:none;
  border-radius:12px;

  padding:10px 16px;

  font-weight:800;
  font-size:13px;

  cursor:pointer;

  transition:.2s ease;
box-shadow:0 6px 16px rgba(0,0,0,.08);
}

.btn-export.pdf{
  background:#b91c1c;
  color:#fff;
}

.btn-export.pdf:hover{
  background:#991b1b;
}

.btn-export.excel{
  background:#0f766e;
  color:#fff;
}

.btn-export.excel:hover{
  background:#115e59;
}

/* ===== Administración SIPAU ===== */

.admin-form-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
}

.admin-search-box{
  margin-top:14px;
  margin-bottom:10px;
}

.admin-search-box input{
  background:#f8fbff;
  border:2px solid var(--borde);
  font-size:14px;
  font-weight:600;
}

#panelFormularioVehiculo.hidden{
  display:none !important;
}
/* ===== Buscador administración SIPAU ===== */

.admin-search-box{
  margin-top:16px;
  margin-bottom:14px;
}

.admin-search-box input{
  background:#ffffff;
  border:3px solid #111111;
  border-radius:14px;
  padding:14px 16px;
  font-size:15px;
  font-weight:700;
  color:#111111;
  box-shadow:0 4px 10px rgba(0,0,0,.08);
}

.admin-search-box input::placeholder{
  color:#111111;
  font-weight:800;
  opacity:1;
}

.admin-search-box input:focus{
  outline:none;
  border-color:#003b71;
  box-shadow:0 0 0 4px rgba(0,59,113,.18);
}