/* ==========================================================================
   VTV PBA — sistema de diseño "rebuild limpio"
   Subdominio por planta · estático · una sola hoja por subdominio
   Firma visual: la OBLEA (sticker de verificación) en el hero
   ========================================================================== */

:root{
  /* color */
  --azul-900:#06303f;   /* texto fuerte, header oscuro     */
  --azul-700:#0a4a60;
  --azul-600:#0584aa;   /* marca institucional (existente)  */
  --azul-500:#0183e4;   /* acción / enlaces (existente)     */
  --azul-050:#eef6fa;   /* fondos suaves                    */
  --amarillo:#ffc21f;   /* acento oblea / señal             */
  --amarillo-d:#e0a400;
  --verde:#14935a;      /* "aprobada" / check               */
  --verde-050:#e7f4ee;
  --bg:#f4f8fb;
  --card:#ffffff;
  --linea:#d9e7ef;
  --texto:#16282f;
  --gris:#566a73;
  --rojo:#c8413a;

  /* tipografía */
  --display:"Barlow Condensed","Arial Narrow",system-ui,sans-serif;
  --body:"Public Sans","Segoe UI",system-ui,-apple-system,sans-serif;

  /* medidas */
  --r:14px;            /* radio tarjetas */
  --r-s:9px;
  --max:1080px;
  --sombra:0 1px 2px rgba(6,48,63,.06),0 8px 26px rgba(6,48,63,.07);
  --sombra-s:0 1px 2px rgba(6,48,63,.08);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  color:var(--texto);
  background:var(--bg);
  line-height:1.65;
  font-size:17px;
  text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--azul-500);text-decoration:none}
a:hover{text-decoration:underline}

/* ---- tipografía display ---- */
h1,h2,h3{font-family:var(--display);line-height:1.05;color:var(--azul-900);letter-spacing:.2px}
h1{font-size:clamp(2.3rem,6vw,3.6rem);font-weight:800;text-transform:uppercase}
h2{font-size:clamp(1.7rem,4vw,2.4rem);font-weight:700;margin-bottom:.6rem}
h3{font-size:1.28rem;font-weight:700}
p{margin:0 0 1rem}
ul,ol{margin:0 0 1rem 1.2rem}
li{margin-bottom:.35rem}
strong{color:var(--azul-900)}

/* layout helpers ---------------------------------------------------------- */
.wrap{max-width:var(--max);margin-inline:auto;padding-inline:20px}
.seccion{padding-block:clamp(2.4rem,5vw,4rem)}
.bleed{width:100%}
.bleed--azul{background:var(--azul-900);color:#dcebf0}
.bleed--suave{background:var(--azul-050)}
.centro{text-align:center}
.eyebrow{
  font-family:var(--display);font-weight:700;text-transform:uppercase;
  letter-spacing:2px;font-size:.95rem;color:var(--azul-600);margin-bottom:.4rem
}

/* ===== HEADER ===== */
.cabecera{
  position:sticky;top:0;z-index:50;background:#fff;
  border-bottom:3px solid var(--azul-600);
}
.cabecera__in{display:flex;align-items:center;gap:16px;
  max-width:var(--max);margin-inline:auto;padding:10px 20px}
.marca{display:flex;align-items:center;gap:10px;font-family:var(--display);
  font-weight:800;font-size:1.45rem;text-transform:uppercase;color:var(--azul-900);
  letter-spacing:.5px;flex:0 0 auto}
.marca:hover{text-decoration:none}
.marca__chip{
  background:var(--azul-600);color:#fff;border-radius:7px;padding:3px 9px;
  font-size:1.1rem;line-height:1.1;box-shadow:inset 0 -3px 0 rgba(0,0,0,.18)}
.marca__pba{color:var(--amarillo-d)}
.nav{margin-left:auto;display:flex;gap:4px;flex-wrap:wrap}
.nav a{font-family:var(--display);text-transform:uppercase;font-weight:600;
  letter-spacing:.4px;color:var(--azul-900);padding:7px 11px;border-radius:8px;
  font-size:1rem}
.nav a:hover{background:var(--azul-050);text-decoration:none}
.nav a[aria-current="page"]{background:var(--azul-600);color:#fff}
.menu-btn{margin-left:auto;display:none;background:none;border:2px solid var(--linea);
  border-radius:9px;width:42px;height:38px;cursor:pointer;align-items:center;justify-content:center}
.menu-btn span{display:block;width:20px;height:2px;background:var(--azul-900);position:relative}
.menu-btn span::before,.menu-btn span::after{content:"";position:absolute;left:0;width:20px;height:2px;background:var(--azul-900)}
.menu-btn span::before{top:-6px}.menu-btn span::after{top:6px}

/* ===== HERO ===== */
.hero{padding-block:clamp(2rem,5vw,3.6rem)}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:40px;align-items:center}
.hero p.lead{font-size:1.18rem;color:var(--gris);max-width:34ch}
.hero h1 span{color:var(--azul-600)}

/* botonera */
.botones{display:flex;flex-wrap:wrap;gap:12px;margin-top:1.4rem}
.btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--display);
  text-transform:uppercase;font-weight:700;letter-spacing:.5px;font-size:1.08rem;
  padding:13px 22px;border-radius:11px;border:2px solid transparent;cursor:pointer;
  transition:transform .08s ease,box-shadow .15s ease;line-height:1}
.btn:hover{text-decoration:none;transform:translateY(-1px)}
.btn--primario{background:var(--azul-500);color:#fff;box-shadow:0 6px 16px rgba(1,131,228,.28)}
.btn--primario:hover{background:#0a74c4}
.btn--turno{background:var(--amarillo);color:var(--azul-900);box-shadow:0 6px 16px rgba(255,194,31,.35)}
.btn--turno:hover{background:var(--amarillo-d)}
.btn--ghost{background:#fff;color:var(--azul-700);border-color:var(--linea)}
.btn--ghost:hover{border-color:var(--azul-500);color:var(--azul-500)}
.btn--block{width:100%;justify-content:center}

/* ---- LA OBLEA (firma) ---- */
.oblea{
  --ob:#0584aa;
  position:relative;aspect-ratio:1;max-width:330px;margin-inline:auto;width:100%;
  background:
     repeating-linear-gradient(135deg,rgba(255,255,255,.5) 0 14px,rgba(255,255,255,0) 14px 28px),
     linear-gradient(150deg,var(--azul-600),var(--azul-700));
  border-radius:26px;color:#fff;padding:22px;
  display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 18px 40px rgba(6,48,63,.28);
  border:3px solid rgba(255,255,255,.55);
  overflow:hidden;
}
.oblea::after{ /* troquel perforado */
  content:"";position:absolute;inset:9px;border:2px dashed rgba(255,255,255,.45);border-radius:18px;pointer-events:none}
.oblea__top{display:flex;justify-content:space-between;align-items:flex-start;font-family:var(--display);font-weight:700;text-transform:uppercase;letter-spacing:1px}
.oblea__anio{background:var(--amarillo);color:var(--azul-900);border-radius:9px;
  padding:4px 11px;font-size:1.5rem;line-height:1;box-shadow:0 3px 0 var(--amarillo-d)}
.oblea__ciudad{font-family:var(--display);font-weight:800;text-transform:uppercase;
  font-size:clamp(1.8rem,6vw,2.7rem);line-height:.95;letter-spacing:.5px;
  text-shadow:0 2px 6px rgba(0,0,0,.2)}
.oblea__pie{display:flex;align-items:center;gap:10px;font-family:var(--display);
  text-transform:uppercase;font-weight:700;letter-spacing:1px;font-size:1.05rem}
.oblea__check{width:34px;height:34px;flex:0 0 auto;background:var(--verde);border-radius:50%;
  display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px rgba(0,0,0,.25)}
.oblea__sello{position:absolute;right:18px;bottom:64px;transform:rotate(-11deg);
  border:3px solid rgba(255,255,255,.85);color:rgba(255,255,255,.92);border-radius:8px;
  font-family:var(--display);font-weight:800;text-transform:uppercase;letter-spacing:2px;
  padding:4px 12px;font-size:1.05rem;opacity:.9}

/* ===== franja disclaimer ===== */
.aviso{background:#fff7e6;border-top:1px solid #f3e2b8;border-bottom:1px solid #f3e2b8;
  font-size:.92rem;color:#7a5a12}
.aviso .wrap{display:flex;gap:10px;align-items:flex-start;padding-block:11px}
.aviso b{color:#6a4d0c}

/* ===== tarjetas info rápida ===== */
.datos{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.dato{background:var(--card);border:1px solid var(--linea);border-radius:var(--r);
  padding:18px;box-shadow:var(--sombra-s);display:flex;flex-direction:column;gap:6px}
.dato__ico{width:40px;height:40px;border-radius:10px;background:var(--azul-050);
  color:var(--azul-600);display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.dato__k{font-family:var(--display);text-transform:uppercase;letter-spacing:1px;
  font-weight:700;font-size:.85rem;color:var(--gris)}
.dato__v{font-weight:700;color:var(--azul-900);font-size:1.06rem;line-height:1.3}
.dato__v small{display:block;font-weight:400;color:var(--gris);font-size:.85rem}

/* ===== tarjetas genéricas / grid de enlaces ===== */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:18px}
.card{background:var(--card);border:1px solid var(--linea);border-radius:var(--r);
  padding:22px;box-shadow:var(--sombra-s);display:flex;flex-direction:column}
.card h3{margin-bottom:.4rem}
.card p{color:var(--gris);font-size:.97rem;flex:1}
.card .btn{margin-top:14px}

/* ===== bloque mapa ===== */
.mapa{border-radius:var(--r);overflow:hidden;border:1px solid var(--linea);
  box-shadow:var(--sombra);aspect-ratio:16/8;background:var(--azul-050)}
.mapa iframe{width:100%;height:100%;border:0;display:block}

/* ===== pasos numerados ===== */
.pasos{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;counter-reset:p}
.paso{background:var(--card);border:1px solid var(--linea);border-radius:var(--r);
  padding:22px 20px;box-shadow:var(--sombra-s);position:relative}
.paso::before{counter-increment:p;content:counter(p,decimal-leading-zero);
  font-family:var(--display);font-weight:800;font-size:2.4rem;color:var(--amarillo);
  line-height:1;display:block;margin-bottom:8px}
.paso h3{font-size:1.12rem;margin-bottom:.3rem}
.paso p{color:var(--gris);font-size:.95rem;margin:0}

/* ===== caja destacada ===== */
.caja{background:var(--azul-050);border:1px solid var(--linea);border-left:5px solid var(--azul-600);
  border-radius:var(--r-s);padding:18px 20px;margin:1.3rem 0}
.caja--ok{background:var(--verde-050);border-left-color:var(--verde)}
.caja--ojo{background:#fff7e6;border-left-color:var(--amarillo-d)}
.caja p:last-child{margin-bottom:0}

/* tabla precios */
.tabla{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--linea);
  border-radius:var(--r);overflow:hidden;box-shadow:var(--sombra-s)}
.tabla th,.tabla td{padding:13px 16px;text-align:left;border-bottom:1px solid var(--linea)}
.tabla th{background:var(--azul-900);color:#fff;font-family:var(--display);
  text-transform:uppercase;letter-spacing:1px;font-weight:700;font-size:.95rem}
.tabla tr:last-child td{border-bottom:0}
.tabla td:last-child{font-weight:700;color:var(--azul-700);text-align:right}

/* ===== FAQ ===== */
.faq details{background:#fff;border:1px solid var(--linea);border-radius:var(--r-s);
  padding:0;margin-bottom:10px;box-shadow:var(--sombra-s);overflow:hidden}
.faq summary{cursor:pointer;color:var(--azul-900);font-weight:700;padding:15px 18px;
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:12px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-family:var(--display);color:var(--azul-600);font-size:1.6rem;line-height:1;flex:0 0 auto}
.faq details[open] summary::after{content:"–"}
.faq details[open] summary{border-bottom:1px solid var(--linea)}
.faq details > div{padding:14px 18px}
.faq details > div p:last-child{margin-bottom:0}

/* ===== CTA banda ===== */
.cta-banda{background:linear-gradient(150deg,var(--azul-600),var(--azul-700));color:#fff;text-align:center}
.cta-banda h2{color:#fff}
.cta-banda p{color:rgba(255,255,255,.85);max-width:48ch;margin-inline:auto}

/* ===== footer ===== */
.pie{background:var(--azul-900);color:#a9c4d1;font-size:.93rem}
.pie .wrap{padding-block:34px 22px}
.pie__grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:30px}
.pie h4{font-family:var(--display);text-transform:uppercase;letter-spacing:1px;
  color:#fff;font-size:1.05rem;margin-bottom:.6rem}
.pie a{color:#bcd6e2;display:block;padding:3px 0}
.pie a:hover{color:#fff}
.pie__legal{border-top:1px solid rgba(255,255,255,.12);margin-top:24px;padding-top:16px;
  font-size:.84rem;color:#7fa0b0;line-height:1.6}

/* migas */
.migas{font-size:.86rem;color:var(--gris);padding-block:14px 0}
.migas a{color:var(--azul-600)}

/* utilidades de contenido generado */
.prosa h2{margin-top:1.8rem}
.prosa h3{margin-top:1.3rem;margin-bottom:.3rem}
.prosa ul{list-style:none;margin-left:0}
.prosa ul li{position:relative;padding-left:26px}
.prosa ul li::before{content:"›";position:absolute;left:6px;top:-1px;color:var(--azul-600);font-weight:800;font-size:1.2rem}

/* ===== responsive ===== */
@media(max-width:860px){
  .hero__grid{grid-template-columns:1fr;gap:26px}
  .oblea{order:-1;max-width:280px}
  .datos{grid-template-columns:repeat(2,1fr)}
  .pasos{grid-template-columns:1fr}
  .pie__grid{grid-template-columns:1fr 1fr}
  .nav{display:none;width:100%;flex-direction:column;gap:2px;margin:0}
  .nav.abierto{display:flex}
  .cabecera__in{flex-wrap:wrap}
  .menu-btn{display:flex}
}
@media(max-width:480px){
  .datos{grid-template-columns:1fr}
  .pie__grid{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{scroll-behavior:auto;transition:none!important}}

/* ==========================================================================
   ANUNCIOS (AdSense)  — clases del sitio original
   ========================================================================== */
.anuncio{margin:1.8rem 0;text-align:center}
.code-block-label{font-family:var(--display);text-transform:uppercase;letter-spacing:2px;
  font-size:.7rem;color:#9bb0bb;margin-bottom:4px}
.ad-rectangle{display:block;height:300px}
@media(max-width:991px){.ad-rectangle{display:inline-block;width:300px;height:600px}}
.ad-rectangle-H{display:block;height:300px}
.ad-336-280{display:block;width:336px;height:280px;margin-inline:auto}

/* ==========================================================================
   CAPTURAS DEL PROCESO (paso a paso con imagen)
   ========================================================================== */
.proceso{display:flex;flex-direction:column;gap:26px;margin:1.4rem 0}
.proceso__paso{display:grid;grid-template-columns:54px 1fr;gap:18px;align-items:start}
.proceso__n{width:54px;height:54px;border-radius:13px;background:var(--azul-600);color:#fff;
  font-family:var(--display);font-weight:800;font-size:1.9rem;display:flex;align-items:center;
  justify-content:center;box-shadow:inset 0 -4px 0 rgba(0,0,0,.18)}
.proceso__cuerpo h3{margin:.1rem 0 .4rem}
.proceso__cuerpo p{color:var(--gris);margin-bottom:.7rem}
.captura{border:1px solid var(--linea);border-radius:12px;overflow:hidden;background:#fff;
  box-shadow:var(--sombra);max-width:560px}
.captura img{width:100%;display:block}
.captura figcaption{font-size:.82rem;color:var(--gris);padding:8px 12px;border-top:1px solid var(--linea);background:var(--azul-050)}

/* ==========================================================================
   PÁGINAS LEGALES / PROSA LARGA
   ========================================================================== */
.legal{max-width:780px}
.legal h2{font-size:1.4rem;background:none;border:0;padding:0;margin:1.8rem 0 .5rem}
.legal h3{font-size:1.12rem;margin:1.2rem 0 .3rem}
.legal p,.legal li{color:#2a3a42}
.legal ul{list-style:none;margin-left:0}
.legal ul li{position:relative;padding-left:22px;margin-bottom:.4rem}
.legal ul li::before{content:"›";position:absolute;left:4px;color:var(--azul-600);font-weight:800}

/* ==========================================================================
   FORMULARIO DE CONTACTO
   ========================================================================== */
.form-vtv{background:#fff;border:1px solid var(--linea);border-radius:var(--r);padding:24px;
  box-shadow:var(--sombra-s);max-width:620px;margin-top:1.2rem}
.form-vtv label{display:block;font-weight:700;color:var(--azul-900);margin:.8rem 0 .3rem;font-size:.95rem}
.form-vtv input,.form-vtv select,.form-vtv textarea{width:100%;padding:11px 13px;border:1px solid var(--linea);
  border-radius:9px;font:inherit;color:var(--texto);background:#fdfefe}
.form-vtv input:focus,.form-vtv select:focus,.form-vtv textarea:focus{outline:2px solid var(--azul-500);border-color:var(--azul-500)}
.form-vtv textarea{min-height:120px;resize:vertical}
.form-vtv .check{display:flex;gap:9px;align-items:flex-start;margin-top:.9rem;font-size:.9rem;color:var(--gris)}
.form-vtv .check input{width:auto;margin-top:3px}
.form-vtv .error{color:var(--rojo);font-size:.85rem;margin-top:.3rem;display:none}
.form-vtv .ok-msg{display:none;background:var(--verde-050);border:1px solid #bfe6d2;color:#0d6b41;
  border-radius:9px;padding:14px;margin-top:1rem;font-weight:600}

/* ==========================================================================
   DISCLAIMER FINAL (abajo del todo)
   ========================================================================== */
.disclaimer-final{background:#06222d;color:#9fc0ce;text-align:center;font-size:.9rem;
  padding:16px 20px;line-height:1.6}
.disclaimer-final b{color:#cfe3ec}
