/* ************* MAIN COLORS ************* */
body {
	background: rgb(255, 255, 255);
	color: #474747;
}

.container .box .text {
	font-size: 14px;
}

#header {
	background-image: url('/images/head-bg.png');
	background-position: right;
	background-repeat: no-repeat;
}

#header #headerContent #logo {
	margin: 0px 0px 0px 20px;
}

#header #headerContent #logo {
	width: auto;
}

#header #headerContent #title {
	color: white;
	font-style: oblique;
}

#header #headerContent #title .heading a {
	color: white;
}

#header #headerContent #subtitle {
	color: #FFE26C;
}

@media only screen and (max-width : 680px) {
	#header {
		background-image: none;
		margin: auto;
	}
	
	#header #headerContent #logo{
		width: 100%;
		margin: 0px;
	}
	
	#header #logo img {
		margin: auto;
	}
}

#footer {
	background: #e0e0e0;
}

#footer #footerContent .text {
	color: #565656;
}

#footer #footerContent .disclaimer {
	color: #565656;
}

#footer #footerContent .contact {
	color: #565656;
}

#footer #footerContent .contact a {
	color: #565656;
}

#footer #footerContent .contact {
	color: #565656;
}

#footer #footerContent .contact a {
	color: #337ab7;
}

.footer-row .col-sm-12 {
	padding: 0px;
}

.header-row .col-sm-12 {
	padding: 0px;
}

div.container {
	background: #FFF;
    box-shadow: 2px 2px 14px #888888;
}

.container .box {
	box-shadow: none;
	-webkit-border-bottom-right-radius: 0px;
	-webkit-border-bottom-left-radius: 0px;
	-moz-border-radius-bottomright: 0px;
	-moz-border-radius-bottomleft: 0px;
	border-bottom-right-radius: 0px;
	border-bottom-left-radius: 0px;
}

.container .box:hover {
	box-shadow: none;
}

.container .boxHeading {
	background: #ddd;
	border: 1px solid #ccc;
	padding: 8px 3px;
}

.container .boxHeading h1,
.container .boxHeading h2 {
	color: rgb(64, 64, 65);
}

.container .boxHeading .new {
	color: #0066a4;
}

.container .box .subHeading {
	background-color: #f7f7f7;
    border-bottom: 2px solid #207146;
    color: #207146;
	padding: 0px 0px 0px 10px;
}

.container .box .controls .button {
	color: white;
	background: #9b9b9b;
}

.container .box .controls .button:hover {
	background: #666666;
}

/* *************************************** */

.container .box .subHeading.formOption {
	margin-top: 0px;
	margin-bottom: 10px;
	font-weight: normal;
	font-size: 17px;
	line-height: 24px;
}

.form-control {
	font-size: 16px;
}


#search-type-form-group {
	display: none;
	
}

#response-detail table {
	width: 100%;	
}

#response-detail table tr td {
	padding: 2px 7px;
}

.container .boxHeading {
	border-top-left-radius: 0px;
	border-top-right-radius: 0px;
}


.bg1 table tr td {
	border: 1px solid #ccc;
}

form .captchaImageHolder {
    width: 152px;
    height: 101px;
    position: relative;
    margin: 16px auto 12px auto;
}

#refreshCaptcha {
    position: absolute;
    right: -23px;
    top: 33px;
}

.captcha {
	padding-top: 34px;
	display:none;
}

.captcha.loaded {
	padding-top: 0px;
}

.form-horizontal .control-label {
	text-align: left;	
}

.externalLink {
	font-size: 12px;
    text-align: left;
    font-style: italic;
    color: #888;
    line-height: 24px;
}

.externalLink a{
	font-style: normal;
}

span.adv-search-link {
	color: #337ab7;
	text-decoration: underline;
	cursor: pointer;
}

#tab-info-vehiculo {
    font-size: 17px;
}

div#tab-info-vehiculo table tr:nth-child(even) {
    background-color: #f2f2f2
}

#form-error-msj {
	display: none;
}

#adv-search-inputs {
	display: none;
}

.form-horizontal .form-group {
	margin-bottom: 12px;
}

.container .boxHeading h1, .container .boxHeading h2 {
	font-size: 18px;
	font-family: Geneva, sans-serif
}

.alert.alert-service {
	margin-bottom: 0px;
	margin-top: 10px;
	display: block;
}

.refreshImg {
	cursor: pointer;
}

table.table-hover td {
	text-align: center;
	border: 1px solid #ddd;
}

.response-detail {
	padding-bottom: 15px;
}

#consulta .alert.alert-info {
    height: 30px;
    padding: 0px;
    margin: 0px;
}

.container .box .ad.links {
	margin-top: 8px;
}

.map-responsive {
    overflow:hidden;
    padding-bottom:56.25%;
    position:relative;
    height:0;
}
.map-responsive iframe {
    left:0;
    top:0;
    height:100%;
    width:100%;
    position:absolute;
    padding: 0px 10px;
}

.custom-bullet li {
  list-style-type: none;
  position: relative;
  margin: 2px;
  padding: 0.5em 0.5em 0.5em 2em;
  font-family: sans-serif;
}

.custom-bullet li::before {
  content: '';
  position: absolute;
  border-color: #1d6a43;
  border-style: solid;
  border-width: 0 0.3em 0.25em 0;
  height: 1em;
  top: 1.5em;
  left: 0.6em;
  margin-top: -1em;
  transform: rotate(45deg);
  width: 0.5em;
}

.custom-bullet ol li::before {
	top: 1.8em;
}

.container .box .text ul {
	padding-left: 10px;
}

a.report-img img{
	padding: 5px;
	border: 3px solid #ccc;
    -moz-border-radius: 10px;
    -webkit-border-radius: 10px;
    -khtml-border-radius: 10px;
    border-radius: 10px;
    margin: 0 auto 10px;
}

.possible-status .success {
	background: green;
	color: white;
}

.badge {
	margin-right: 4px;	
	font-size: 15px;
	vertical-align: baseline;
}

.badge-success {
    color: #fff;
    background-color: #28a745;
}

.badge-danger {
    color: #fff;
    background-color: #dc3545;
}

.badge-warning {
    color: #212529;
    background-color: #ffc107;
}

.container .box .text ul.possible-status {
	margin-left: 5px;
	list-style-type: none;
}

.container .box .text ul.possible-status li {
	line-height: 30px; 
}

.button-spinner {
	margin-left: 4px;
	margin-top: 5px; 	
}

table small {
	font-size: 16px;	
}

form label {
	font-size: 18px;
}

form .spinner {
	margin-top: 30px;
	display: none;
}

.container .box .controls .button.submit-button {
	border: 2px solid #9D2449;
  	color: #9D2449;
  	webkit-border-radius: 2px;
  	-moz-border-radius: 2px;
  	border-radius: 2px;
  	background: none;
  	font-size: 18px;
  	padding: 10px 17px;
}

.container .box .controls .button.submit-button:hover, .container .box .controls .button.submit-button.clicked {
  	background: #9D2449;
  	color: #fff;
}

.container .box .controls .button.submit-button strong {
	font-weight: normal;
}

/* ============================================================
   DESIGN SYSTEM 2026 — estilo limpio, sencillo, no cargado.
   Sobreescribe lo anterior (orden + !important). Solo afecta mx-repuve.
   ============================================================ */
:root{
	--verde:#0b8457; --verde-d:#096c47; --verde-bg:#e6f5ef;
	--tinta:#1f2d3d; --gris:#6b7a90; --linea:#e3e8ef;
	--bg:#f5f7fa; --blanco:#fff; --sombra:0 4px 18px rgba(31,45,61,.08);
	--radius:16px;
}

body{
	background:var(--bg) !important;
	color:var(--tinta);
	font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif;
}

/* contenedor sin la sombra/marco viejo */
div.container{
	background:transparent !important;
	box-shadow:none !important;
}

/* cajitas de contenido = tarjetas limpias */
.container .box{
	background:var(--blanco) !important;
	border:1px solid var(--linea);
	border-radius:var(--radius) !important;
	box-shadow:var(--sombra) !important;
	margin-bottom:16px;
	padding:2px 18px 18px;
	overflow:hidden;
}
.container .box:hover{ box-shadow:var(--sombra) !important; }

/* heading de la cajita: limpio, sin gris pesado */
.container .boxHeading{
	background:transparent !important;
	border:0 !important;
	border-bottom:1px solid var(--linea) !important;
	border-radius:0 !important;
	padding:16px 2px 12px !important;
	margin-bottom:14px;
}
.container .boxHeading h1,
.container .boxHeading h2{
	color:var(--tinta) !important;
	font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif !important;
	font-size:1.2rem !important;
	font-weight:700;
	line-height:1.35;
}
.container .boxHeading .new{ color:var(--verde) !important; }

/* texto de contenido */
.container .box .text{ font-size:15.5px; color:var(--tinta); line-height:1.6; }

/* subheadings (acentos) en verde */
.container .box .subHeading{
	background:var(--verde-bg) !important;
	border-bottom:2px solid var(--verde) !important;
	color:var(--verde) !important;
	border-radius:8px;
	padding:8px 12px !important;
}

/* botones → verde del sistema */
.container .box .controls .button,
.container .box .controls .button.submit-button{
	background:var(--verde) !important;
	border:0 !important;
	color:#fff !important;
	border-radius:11px !important;
	padding:13px 24px !important;
	font-size:1.05rem !important;
	font-weight:700;
	box-shadow:none !important;
}
.container .box .controls .button:hover,
.container .box .controls .button.submit-button:hover,
.container .box .controls .button.submit-button.clicked{
	background:var(--verde-d) !important;
	color:#fff !important;
}

/* badges de estado coherentes */
.badge-success{ background-color:var(--verde) !important; }

/* bullets verdes ya combinan; afinar color */
.custom-bullet li::before{ border-color:var(--verde); }

/* inputs del form actual (hasta migrar al form nuevo) */
.form-control{ border-radius:10px; border:2px solid var(--linea); }
.form-control:focus{ border-color:var(--verde); box-shadow:none; }

/* links de "control vehicular por estado" (cajita de áreas) */
.container .box a{ color:var(--verde); }

/* ---------- Formulario de consulta nuevo (toggle placa/VIN) ---------- */
.rp-form{ max-width:460px; margin:8px auto 4px; }
.rp-toggle{ display:flex; background:var(--bg); border-radius:12px; padding:4px; margin-bottom:14px; }
.rp-toggle button{ flex:1; border:0; background:transparent; padding:11px; border-radius:9px;
	font-size:1rem; font-weight:600; color:var(--gris); cursor:pointer; transition:.15s; }
.rp-toggle button.active{ background:var(--blanco); color:var(--verde); box-shadow:0 1px 4px rgba(0,0,0,.08); }
.rp-input{ width:100%; padding:16px 14px; font-size:1.25rem; letter-spacing:.06em; text-transform:uppercase;
	border:2px solid var(--linea); border-radius:12px; text-align:center; font-weight:700; transition:.15s; }
.rp-input:focus{ outline:0; border-color:var(--verde); }
.rp-input.err{ border-color:#d64545; }
.rp-hint{ text-align:center; color:var(--gris); font-size:.85rem; min-height:1.2em; margin:8px 0 14px; }
.rp-hint.err{ color:#d64545; font-weight:600; }
.rp-turnstile{ display:flex; justify-content:center; margin:6px 0 16px; min-height:65px; }
.rp-btn{ width:100%; border:0; background:var(--verde); color:#fff; font-size:1.15rem; font-weight:700;
	padding:16px; border-radius:12px; cursor:pointer; transition:.15s; }
.rp-btn:hover{ background:var(--verde-d); }
.rp-btn:disabled{ opacity:.6; cursor:not-allowed; }
.rp-badges{ display:flex; gap:14px; justify-content:center; margin-top:16px; color:var(--gris); font-size:.85rem; flex-wrap:wrap; }
.rp-badges span::before{ content:"✓ "; color:var(--verde); font-weight:700; }
.rp-hp{ position:absolute; left:-9999px; opacity:0; height:0; width:0; }

/* ---------- Header limpio (blanco + línea fina, sin sombra dura ni foto) ---------- */
#header{
	background:var(--blanco) !important;
	background-image:none !important;        /* quita la foto de autos del desktop */
	box-shadow:none !important;              /* quita la sombra dura #888 del core */
	border-bottom:1px solid var(--linea) !important;
}
header{ background:var(--blanco); }
#header #headerContent{ padding:14px 0; }
/* por si en el futuro se activan headings de texto en el header */
#header #headerContent #title .heading a{ color:var(--tinta) !important; text-shadow:none !important; }
#header #headerContent #subtitle{ color:var(--gris) !important; }

/* ---------- Footer suave (blanco + línea fina, sin text-shadow) ---------- */
#footer{
	background:var(--blanco) !important;
	border-top:1px solid var(--linea) !important;
	border-radius:0 !important;              /* quita las esquinas redondeadas del core */
}
#footer #footerContent{ padding:22px 0 18px; }
#footer #footerContent .text{
	color:var(--tinta) !important;
	text-shadow:none !important;
	font-family:system-ui,-apple-system,"Segoe UI",Roboto,Arial,sans-serif !important;
	font-weight:600;
}
#footer #footerContent .disclaimer{ color:var(--gris) !important; line-height:1.5; }
#footer #footerContent .contact{ color:var(--gris) !important; }
#footer #footerContent .contact a,
#footer #footerContent .policies a{ color:var(--verde) !important; }
#footer #footerContent .policies{ padding-bottom:16px; }


/* ============================================================
   DESIGN SYSTEM 2026 v2 — markup nuevo (entrega Claude Design)
   Componentes: .hdr/.ftr/.cajita/.destacada/.form-card/.verdict/.faq/.nextstep
   Portado de assets/site.css. Reconciliado con el .container del core.
   ============================================================ */
:root{
  --accent:#0b8457; --accent-hover:#096c47; --accent-soft:#e6f5ef;
  --ink:#1f2d3d; --muted:#6b7a90;
  --line:#e3e8ef; --page:#f5f7fa; --card:#ffffff;
  --ok:#0b8457; --ok-soft:#e6f5ef; --warn:#b7791f; --warn-soft:#fdf3e2;
  --alert:#c0392b; --alert-soft:#fcebe9;
  --shadow:0 4px 18px rgba(31,45,61,.08); --shadow-lg:0 12px 36px rgba(31,45,61,.12);
  --radius:16px; --radius-sm:10px; --radius-pill:999px;
  --font:system-ui,-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --gap:16px; --pad:18px; --maxw:430px;
}

/* --- Reconciliación: el core mete header+content+footer dentro de UN .container.
   Lo volvemos full-bleed y la columna la da .wrap (mobile 430 / desktop 1060). --- */
body{ overflow-x:hidden; }
div.container{ width:100% !important; max-width:none !important; padding:0 !important; margin:0 !important; background:transparent !important; box-shadow:none !important; min-height:0 !important; }
.header-row, .footer-row, .header-row .col-sm-12, .footer-row .col-sm-12{ padding:0 !important; margin:0 !important; }
.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 16px; }
/* Fallback: paginas no migradas (politicas, 404) que aun usan .row/.box del core */
.container > .row{ max-width:792px; margin:0 auto !important; }

* { box-sizing:border-box; }
img{ max-width:100%; }
.ds a{ color:inherit; }

/* icono base (sprite via <use>) */
.ic{ width:22px; height:22px; display:inline-block; vertical-align:middle; flex:0 0 auto; fill:none; stroke:currentColor; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.ic-sm{ width:16px; height:16px; } .ic-14{ width:14px; height:14px; } .ic-18{ width:18px; height:18px; } .ic-20{ width:20px; height:20px; } .ic-34{ width:34px; height:34px; }

/* ---------------- HEADER (burger) ---------------- */
.hdr{ position:sticky; top:0; z-index:40; background:rgba(255,255,255,.92); backdrop-filter:saturate(180%) blur(10px); border-bottom:1px solid var(--line); }
.hdr-note{ background:var(--accent-soft); color:var(--accent-hover); font-size:11.5px; font-weight:600; text-align:center; padding:5px 16px; display:flex; align-items:center; justify-content:center; gap:6px; border-bottom:1px solid var(--line); }
.hdr-bar{ display:flex; align-items:center; gap:12px; height:56px; }
.brand{ display:flex; align-items:center; gap:9px; font-weight:700; font-size:17px; letter-spacing:-.2px; color:var(--ink); text-decoration:none; }
.brand-mark{ width:30px; height:30px; border-radius:8px; background:var(--accent); color:#fff; display:grid; place-items:center; flex:0 0 auto; }
/* el icono del brand-mark siempre blanco, incluso dentro del drawer (donde .drawer a .ic lo pinta gris) */
.brand .brand-mark .ic{ color:#fff; }
.brand b{ color:var(--accent); }
.brand:hover, .brand:focus{ text-decoration:none; }
.hdr-spacer{ flex:1; }
.hdr-burger{ width:42px; height:42px; border-radius:11px; border:1px solid var(--line); background:#fff; display:grid; place-items:center; cursor:pointer; color:var(--ink); }

.drawer-scrim{ position:fixed; inset:0; background:rgba(31,45,61,.45); z-index:60; animation:fade .18s ease; }
.drawer{ position:fixed; top:0; right:0; bottom:0; width:82%; max-width:330px; z-index:61; background:#fff; box-shadow:var(--shadow-lg); padding:18px; display:flex; flex-direction:column; gap:6px; overflow-y:auto; animation:slideIn .22s cubic-bezier(.2,.7,.3,1); }
.drawer-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:10px; }
.drawer-x{ width:38px; height:38px; border-radius:10px; border:1px solid var(--line); background:#fff; display:grid; place-items:center; cursor:pointer; color:var(--ink); }
.drawer a{ display:flex; align-items:center; gap:12px; text-decoration:none; color:var(--ink); font-weight:600; font-size:16px; padding:13px 12px; border-radius:12px; }
.drawer a:hover{ background:var(--page); }
.drawer a .ic{ color:var(--muted); }
.drawer a.on{ color:var(--accent); background:var(--accent-soft); }
.drawer a.on .ic{ color:var(--accent); }
.drawer-sub{ font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--muted); padding:14px 12px 6px; }
.drawer-estados{ display:grid; grid-template-columns:1fr 1fr; gap:4px; padding:2px 4px 8px; }
.drawer-estados a{ font-size:13.5px; padding:9px 12px; }
.drawer-estados a.all{ grid-column:1 / -1; color:var(--accent); font-weight:700; }
[hidden]{ display:none !important; }
@keyframes slideIn{ from{ transform:translateX(100%); } to{ transform:translateX(0); } }
@keyframes fade{ from{ opacity:0; } to{ opacity:1; } }

/* ---------------- BOTONES ---------------- */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; font-family:var(--font); font-weight:700; font-size:16px; cursor:pointer; border-radius:12px; border:1px solid transparent; padding:13px 18px; transition:.15s; text-decoration:none; white-space:nowrap; }
.btn-lg{ padding:16px 20px; font-size:17px; width:100%; }
.btn-primary{ background:var(--accent); color:#fff; }
.btn-primary:hover{ background:var(--accent-hover); }
.btn-ghost{ background:#fff; color:var(--ink); border-color:var(--line); }
.btn-ghost:hover{ border-color:#cdd6e2; background:var(--page); }

/* ---------------- CAJITA ---------------- */
.cajita{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); padding:var(--pad); margin-bottom:var(--gap); }
.cajita-head{ display:flex; align-items:center; gap:11px; margin-bottom:10px; }
.cajita-ico{ width:38px; height:38px; border-radius:11px; flex:0 0 auto; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; }
.cajita h2, .cajita h3{ font-size:17px; font-weight:700; letter-spacing:-.2px; line-height:1.25; margin:0; }
.cajita .lede, .cajita p, .cajita .text{ font-size:14.5px; line-height:1.6; color:var(--ink); margin:0; }
.cajita .lede{ color:var(--muted); }
.cajita p + p, .cajita .text + .text{ margin-top:10px; }
.cajita .text ul, .cajita .text ol{ margin:10px 0; padding-left:20px; }
.cajita .text li{ margin:4px 0; }
.cajita-link{ display:flex; justify-content:center; align-items:center; gap:6px; margin-top:16px; color:var(--accent); font-weight:700; font-size:14.5px; text-decoration:none; }
.cajita-link:hover{ color:var(--accent-hover); gap:9px; }
/* botones que vienen del core (getButton) dentro de una cajita */
.cajita .text .button, .cajita .button{ display:inline-flex; align-items:center; justify-content:center; gap:8px; margin-top:14px; background:var(--accent); color:#fff !important; font-weight:700; font-size:15px; border-radius:12px; padding:13px 20px; text-decoration:none; border:0; }
.cajita .button:hover{ background:var(--accent-hover); }
/* imagenes reales (thumbnails fancybox) dentro de cajitas */
.cajita .text a.report-img, .cajita .text a.fancybox{ display:inline-block; margin-top:12px; line-height:0; }
.cajita .text img{ max-width:100%; height:auto; border-radius:10px; border:1px solid var(--line); }
/* Bullets: usamos el ::marker nativo (el browser lo alinea con la primera linea
   sin magic numbers). Anulamos cualquier ::before viejo. */
.cajita .text ul.custom-bullet{ list-style:disc; padding-left:24px; margin:12px 0; }
.cajita .text ul.custom-bullet li{ list-style:disc; margin:10px 0; padding-left:6px; }
.cajita .text ul.custom-bullet li::before{ content:none !important; }
.cajita .text ul.custom-bullet li::marker{ color:var(--accent); font-size:1.1em; }
.cajita .text a{ color:var(--accent); font-weight:600; }
/* badges de estatus (paginas de estado) */
.cajita .badge{ display:inline-block; font-size:11.5px; font-weight:700; padding:3px 10px; border-radius:999px; margin-right:8px; }
.cajita .badge-success{ background:var(--ok-soft) !important; color:var(--ok) !important; }
.cajita .badge-warning{ background:var(--warn-soft) !important; color:var(--warn) !important; }
.cajita .badge-danger{ background:var(--alert-soft) !important; color:var(--alert) !important; }
.cajita .text ul.possible-status{ list-style:none; padding-left:0; }
.cajita .text ul.possible-status li{ margin:12px 0; }
.cajita .text ul.possible-status p{ margin:0; }

.cajita.destacada{ background:linear-gradient(180deg,#ffffff 0%, var(--accent-soft) 165%); border-color:#cfe9dd; padding:24px 20px; display:flex; flex-direction:column; }
.eyebrow{ display:inline-flex; align-items:center; gap:7px; align-self:flex-start; background:var(--accent-soft); color:var(--accent-hover); font-size:12px; font-weight:700; padding:6px 12px; border-radius:var(--radius-pill); text-transform:uppercase; letter-spacing:.4px; margin-bottom:14px; }
.h1{ font-size:27px; line-height:1.15; font-weight:700; letter-spacing:-.6px; text-wrap:balance; margin:0; }
.h1 b{ color:var(--accent); }
.sub{ font-size:15.5px; line-height:1.55; color:var(--muted); margin:12px 0 0; text-wrap:pretty; }

.img-ph{ width:100%; border-radius:var(--radius-sm); border:1px dashed #c7d0dc; background-color:#fbfcfe; background-image:repeating-linear-gradient(135deg,#eef1f6 0 10px,#f7f9fc 10px 20px); display:grid; place-items:center; min-height:120px; color:var(--muted); font:600 12px/1.4 ui-monospace,"SF Mono",Menlo,monospace; text-align:center; padding:14px; margin-top:14px; }

/* ---------------- SECCIONES ---------------- */
.section-title{ display:flex; align-items:baseline; justify-content:space-between; margin:2px 2px 12px; }
.section-title h2{ font-size:19px; font-weight:700; letter-spacing:-.3px; margin:0; }
.section-title .count{ font-size:13px; font-weight:600; color:var(--muted); }
.stack{ padding-top:18px; } .stack-lg{ padding-top:22px; }
/* primera .stack pegada al chrome/ad de Ezoic: cierra el hueco con el banner de arriba */
.wrap > .stack:first-child{ padding-top:4px; }

/* ---------------- ESTADOS (acordeón) ---------------- */
.estados-acc{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow); }
.acc-head{ display:flex; align-items:center; gap:11px; padding:16px var(--pad); cursor:pointer; user-select:none; width:100%; background:none; border:none; font-family:var(--font); text-align:left; }
.acc-head h3{ font-size:16px; font-weight:700; margin:0; }
.acc-head .chev{ margin-left:auto; transition:transform .2s; color:var(--muted); }
.acc-head[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.acc-body{ padding:0 var(--pad) 16px; display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.acc-body a{ font-size:13.5px; font-weight:600; color:var(--ink); text-decoration:none; padding:9px 10px; border-radius:9px; background:var(--page); }
.acc-body a:hover{ background:var(--accent-soft); color:var(--accent); }

/* ---------------- FORMULARIO ---------------- */
.form-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow-lg); padding:22px 20px; }
.form-card.hero{ background:linear-gradient(180deg,#fff,#fff 60%, var(--accent-soft) 240%); }
.form-intro{ text-align:center; margin-bottom:18px; }
.form-intro .h1{ font-size:23px; }
.form-intro .sub{ font-size:14.5px; margin-top:8px; }
.toggle{ display:grid; grid-template-columns:1fr 1fr; gap:4px; padding:4px; background:var(--page); border:1px solid var(--line); border-radius:12px; margin-bottom:16px; }
.toggle button{ border:none; background:transparent; cursor:pointer; padding:11px 8px; border-radius:9px; font-family:var(--font); font-weight:700; font-size:14.5px; color:var(--muted); display:flex; align-items:center; justify-content:center; gap:7px; transition:.15s; }
.toggle button.on{ background:#fff; color:var(--accent); box-shadow:0 1px 4px rgba(31,45,61,.12); }
.field-label{ display:flex; align-items:center; justify-content:space-between; font-size:13px; font-weight:600; color:var(--muted); margin-bottom:7px; }
.field-label .hint{ color:var(--accent); cursor:pointer; }
.input-xl{ width:100%; font-family:ui-monospace,"SF Mono",Menlo,monospace; font-size:21px; font-weight:600; letter-spacing:2px; text-transform:uppercase; padding:16px; border-radius:12px; border:2px solid var(--line); background:#fff; color:var(--ink); outline:none; transition:.15s; }
.input-xl::placeholder{ color:#b7c1cf; letter-spacing:1px; font-weight:500; }
.input-xl:focus{ border-color:var(--accent); box-shadow:0 0 0 4px var(--accent-soft); }
.input-xl.err{ border-color:var(--alert); box-shadow:0 0 0 4px var(--alert-soft); }
.field-msg{ font-size:13px; margin-top:8px; display:flex; align-items:center; gap:6px; }
.field-msg.error{ color:var(--alert); } .field-msg.help{ color:var(--muted); }
.captcha{ margin:16px 0; display:flex; align-items:center; gap:12px; border:1px solid var(--line); border-radius:12px; padding:13px 14px; background:var(--page); }
.captcha .box{ width:26px; height:26px; border-radius:6px; border:2px solid #c7d0dc; background:#fff; flex:0 0 auto; }
.captcha .lbl{ font-size:14px; font-weight:600; color:var(--ink); flex:1; }
.trust{ display:flex; flex-wrap:wrap; gap:8px 16px; justify-content:center; margin-top:16px; }
.trust span{ display:inline-flex; align-items:center; gap:6px; font-size:12.5px; font-weight:600; color:var(--muted); }
.trust .ic{ color:var(--accent); }
.steps{ margin:0; padding:0; list-style:none; display:flex; flex-direction:column; gap:12px; }
.steps li{ display:flex; gap:12px; align-items:flex-start; }
.steps .n{ width:26px; height:26px; border-radius:50%; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; font-weight:700; font-size:13px; flex:0 0 auto; }
.steps li span.tx{ font-size:14.5px; line-height:1.5; padding-top:2px; }

/* ---------------- RESULTADO (veredicto) ---------------- */
.verdict{ border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg); border:1px solid var(--line); background:#fff; }
.verdict-top{ padding:24px 20px; display:flex; flex-direction:column; align-items:center; text-align:center; gap:12px; color:#fff; }
.verdict-badge{ width:64px; height:64px; border-radius:50%; display:grid; place-items:center; background:rgba(255,255,255,.22); }
.verdict-top h2{ font-size:22px; font-weight:700; letter-spacing:-.3px; margin:0; }
.verdict-top .vsub{ font-size:14.5px; opacity:.92; line-height:1.5; margin:0; }
.verdict.ok .verdict-top{ background:linear-gradient(160deg,#0b8457,#0a7a50); }
.verdict.warn .verdict-top{ background:linear-gradient(160deg,#c98a1e,#b7791f); }
.verdict.alert .verdict-top{ background:linear-gradient(160deg,#cf4436,#c0392b); }
.verdict.none .verdict-top{ background:linear-gradient(160deg,#7c8aa0,#6b7a90); }
.verdict-body{ padding:18px 20px; }
.vrow{ display:flex; justify-content:space-between; gap:14px; padding:12px 0; border-bottom:1px solid var(--line); }
.vrow:last-child{ border-bottom:none; }
.vrow .k{ font-size:13px; color:var(--muted); font-weight:600; }
.vrow .v{ font-size:14px; font-weight:700; text-align:right; font-family:ui-monospace,Menlo,monospace; }
.vnote{ margin-top:14px; display:flex; gap:10px; padding:13px 14px; border-radius:12px; font-size:13.5px; line-height:1.5; }
.vnote.ok{ background:var(--ok-soft); color:var(--ok); }
.vnote.warn{ background:var(--warn-soft); color:var(--warn); }
.vnote.alert{ background:var(--alert-soft); color:var(--alert); }

/* ---------------- SIGUIENTE PASO ---------------- */
.nextstep{ margin:22px 0 8px; }
.nextstep .lbl{ font-size:13px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--muted); margin:0 2px 12px; }
.ns-grid{ display:flex; flex-direction:column; gap:10px; }
.ns-card{ display:flex; align-items:center; gap:13px; text-decoration:none; background:#fff; border:1px solid var(--line); border-radius:14px; padding:15px; transition:.15s; }
.ns-card:hover{ border-color:var(--accent); box-shadow:var(--shadow); }
.ns-card .ns-ico{ width:40px; height:40px; border-radius:11px; background:var(--accent-soft); color:var(--accent); display:grid; place-items:center; flex:0 0 auto; }
.ns-card .ns-tx{ flex:1; min-width:0; }
.ns-card .ns-tx b{ display:block; font-size:15px; font-weight:700; color:var(--ink); }
.ns-card .ns-tx span{ font-size:13px; color:var(--muted); }
.ns-card > .ic{ color:var(--muted); }
.ns-card:hover > .ic{ color:var(--accent); }

/* ---------------- FAQ ---------------- */
.faq-item{ background:#fff; border:1px solid var(--line); border-radius:14px; margin-bottom:10px; overflow:hidden; }
.faq-q{ display:flex; align-items:center; gap:12px; padding:16px var(--pad); cursor:pointer; font-weight:700; font-size:15px; width:100%; background:none; border:none; font-family:var(--font); text-align:left; color:var(--ink); }
.faq-q .chev{ margin-left:auto; color:var(--muted); transition:transform .2s; }
.faq-q[aria-expanded="true"] .chev{ transform:rotate(180deg); }
.faq-a{ padding:0 var(--pad) 16px; font-size:14px; line-height:1.6; color:var(--muted); }
.faq-a .text{ font-size:14px; line-height:1.6; color:var(--muted); }

/* ---------------- OFICINAS (estado) ---------------- */
.office{ background:#fff; border:1px solid var(--line); border-radius:14px; padding:16px; margin-bottom:10px; }
.office h4{ font-size:15px; font-weight:700; margin:0 0 4px; }
.office .meta{ display:flex; align-items:flex-start; gap:8px; font-size:13.5px; color:var(--muted); line-height:1.5; padding:5px 0; }
.office .meta .ic{ color:var(--accent); flex:0 0 auto; margin-top:2px; }

/* ---------------- FOOTER (simple) ---------------- */
.ftr{ background:#fff; border-top:1px solid var(--line); margin-top:24px; }
.ftr-in{ padding:24px 16px 30px; max-width:var(--maxw); margin:0 auto; }
/* el contenido del footer ocupa el mismo ancho que la columna de la pagina */
.ftr-brand{ display:flex; align-items:center; gap:9px; font-weight:700; font-size:15px; margin-bottom:12px; }
.ftr-disc{ display:flex; gap:10px; background:var(--page); border:1px solid var(--line); border-radius:12px; padding:13px 14px; font-size:12.5px; line-height:1.55; color:var(--muted); margin-bottom:18px; }
.ftr-disc .ic{ color:var(--muted); flex:0 0 auto; margin-top:1px; }
.ftr-disc b{ color:var(--ink); }
.ftr-nav{ display:grid; grid-template-columns:1fr 1fr; gap:6px 12px; margin-bottom:18px; }
.ftr-nav a{ font-size:13px; color:var(--muted); text-decoration:none; padding:3px 0; }
.ftr-nav a:hover{ color:var(--accent); }
.ftr-nav .ftr-nav-h{ grid-column:1 / -1; font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:.5px; color:var(--muted); margin-top:8px; }
.ftr-base{ border-top:1px solid var(--line); padding-top:16px; display:flex; flex-direction:column; gap:10px; align-items:center; text-align:center; }
.ftr-legal{ display:flex; flex-wrap:wrap; gap:6px 16px; justify-content:center; }
.ftr-legal a{ font-size:12.5px; color:var(--muted); text-decoration:none; }
.ftr-legal a:hover{ color:var(--accent); }
.ftr-copy{ font-size:12px; color:var(--muted); }

/* ---------------- Interacción: sin anillo azul, feedback de pulsado ---------------- */
a, button{ -webkit-tap-highlight-color:transparent; }
/* quitar el outline azul del navegador / box-shadow azul de bootstrap al hacer click
   (aplica a enlaces, botones y .btn). El anillo verde solo aparece con teclado. */
a:focus, a:active{ outline:none; }
a:focus:not(:focus-visible), .btn:focus:not(:focus-visible), button:focus:not(:focus-visible){ outline:none; box-shadow:none; }
a:focus-visible, .btn:focus-visible, button:focus-visible{ outline:2px solid var(--accent); outline-offset:3px; box-shadow:none; border-radius:6px; }
.btn, .brand, .hdr-burger, .drawer-x, .toggle button, .acc-head, .faq-q, .ns-card, .cajita-link, .drawer a, .ftr-legal a{ transition:transform .12s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease, color .15s ease; }
.btn:active, .hdr-burger:active, .drawer-x:active, .toggle button:active{ transform:scale(.95); }
.ns-card:active, .acc-head:active, .faq-q:active, .cajita-link:active, .brand:active, .drawer a:active{ transform:scale(.97); }
/* feedback en el form de consulta (form-consulta.php, scoped a #rp-app) */
#rp-app .rp-btn{ transition:transform .12s ease, background .15s ease; }
#rp-app .rp-btn:active, #rp-app .rp-toggle button:active{ transform:scale(.96); }
#rp-app .rp-input:focus, #rp-app .rp-btn:focus:not(:focus-visible){ box-shadow:none; }
/* placeholder del input de consulta: gris mas tenue, no bold */
#rp-app .rp-input::placeholder{ color:#c5cdd9; font-weight:500; opacity:1; letter-spacing:.03em; }
/* boton principal "Consultar gratis": mas presencia */
.form-card #rp-app .rp-btn{ font-size:1.25rem; padding:18px; letter-spacing:.01em; }
/* resultado: titulos de seccion + grid de datos del vehiculo + fuentes -- mas legibles */
.form-card #rp-app .rp-h3{ font-size:.88rem; letter-spacing:.06em; }
.form-card #rp-app .rp-grid .cell{ padding:13px 16px; }
.form-card #rp-app .rp-grid .k{ font-size:.82rem; letter-spacing:.04em; }
.form-card #rp-app .rp-grid .v{ font-size:1.1rem; }
.form-card #rp-app .rp-fuente .nm{ font-size:1.02rem; }
.form-card #rp-app .rp-fuente .nm small{ font-size:.82rem; }
.form-card #rp-app .rp-estado{ font-size:.95rem; }
.form-card #rp-app .rp-banner h2{ font-size:1.25rem; }
.form-card #rp-app .rp-banner .vsub, .form-card #rp-app .rp-banner p{ font-size:.95rem; }
/* acordeón: la altura la anima el JS (slideOpen/slideClose) */
.acc-body, .drawer-estados, .faq-a{ transition:height .35s ease; }

/* ============================================================ DESKTOP (≥768px) */
@media (min-width:768px){
  .ftr-in{ max-width:1060px; padding-left:32px; padding-right:32px; }
  .wrap{ max-width:1060px; padding:0 32px; }
  body{ padding-bottom:48px; }
  .stack{ padding-top:26px; } .stack-lg{ padding-top:38px; }
  .wrap > .stack:first-child{ padding-top:8px; }
  .hdr-bar{ height:66px; } .hdr-note{ font-size:12.5px; padding:7px 16px; }
  .brand{ font-size:19px; } .brand-mark{ width:34px; height:34px; }
  .section-title h2{ font-size:24px; }
  .destacada{ padding:56px 48px; align-items:center; text-align:center; }
  .destacada .eyebrow, .destacada .btn{ align-self:center; }
  .destacada .btn{ width:auto; padding:16px 30px; }
  .destacada .h1{ font-size:42px; max-width:20ch; }
  .destacada .sub{ font-size:18px; max-width:58ch; }
  .destacada .trust{ justify-content:center; }
  .page-niv .destacada, .page-constancia .destacada, .page-estado .destacada,
  .page-motos .destacada, .page-citas .destacada, .page-rapi .destacada{ align-items:flex-start; text-align:left; }
  .page-niv .destacada .eyebrow, .page-niv .destacada .btn,
  .page-constancia .destacada .eyebrow, .page-constancia .destacada .btn,
  .page-estado .destacada .eyebrow, .page-estado .destacada .btn,
  .page-motos .destacada .eyebrow, .page-motos .destacada .btn,
  .page-citas .destacada .eyebrow, .page-citas .destacada .btn,
  .page-rapi .destacada .eyebrow, .page-rapi .destacada .btn{ align-self:flex-start; }
  /* en heroes de lectura (left-aligned) el h1/sub no deben llevar el max-width:20ch del hero centrado */
  .page-niv .destacada .h1, .page-constancia .destacada .h1, .page-estado .destacada .h1,
  .page-motos .destacada .h1, .page-citas .destacada .h1, .page-rapi .destacada .h1{ max-width:none; }
  .page-niv .destacada .sub, .page-constancia .destacada .sub, .page-estado .destacada .sub,
  .page-motos .destacada .sub, .page-citas .destacada .sub, .page-rapi .destacada .sub{ max-width:none; }
  .wrap.page-consulta, .wrap.page-resultado, .wrap.page-niv, .wrap.page-constancia, .wrap.page-estado,
  .wrap.page-motos, .wrap.page-citas, .wrap.page-rapi{ max-width:760px; }
  .acc-body{ grid-template-columns:repeat(5,1fr); }
  .cajita-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start; }
  .cajita-grid > .cajita{ margin-bottom:0; height:100%; }
  .cajita{ padding:26px; }
  .cajita h2, .cajita h3{ font-size:19px; }
  .cajita .lede, .cajita p, .cajita .text{ font-size:15.5px; }
  .ns-grid{ flex-direction:row; } .ns-grid .ns-card{ flex:1; }
  .form-card{ max-width:none; margin:0; padding:40px 44px; }
  .form-card #rp-app{ max-width:none; margin:0; }
  .form-intro .h1{ font-size:30px; } .input-xl{ font-size:24px; }
  .verdict{ max-width:620px; margin:0 auto; }
  .ftr-nav{ grid-template-columns:repeat(4,1fr); }
}



/* ===== Infografías (SVG inline en .cajita) ===== */
.infografia{margin:0}
.infografia svg{display:block;width:100%;height:auto;max-width:560px;margin:0 auto}
.infografia figcaption{margin-top:14px;font-size:14px;line-height:1.5;color:var(--muted);text-align:center}
.infografia-img{display:block;width:100%;max-width:560px;height:auto;margin:14px auto 0}
.foto-img{display:block;width:100%;max-width:400px;height:auto;margin:14px auto 0;border-radius:12px;border:1px solid var(--line)}
