/*
Theme Name: Consulado PY Child
Theme URI: https://py.consuladode.com.mx/
Description: Tema hijo para el directorio de consulados y embajadas extranjeras en Paraguay. Basado en ASAP. Colores institucionales de la bandera paraguaya.
Author: Jose David Sánchez
Author URI: https://py.consuladode.com.mx/
Template: asap
Version: 1.2.0
Text Domain: consuladopy-child
*/

/* ============================================================
   CONSULADO PY — v1.2.0
   Paleta bandera paraguaya
   ============================================================ */
:root{
  --py-rojo:#D52B1E;
  --py-azul:#0038A8;
  --py-blanco:#FFFFFF;
  --py-azul-osc:#002A7A;
  --py-rojo-osc:#A81F15;
  --py-gris:#F4F6FB;
  --py-gris-borde:#E2E7F0;
  --py-texto:#1B2433;
  --py-texto-sec:#54607A;
  --py-radio:14px;
  --py-sombra:0 6px 24px rgba(0,56,168,.08);
  --py-sombra-fuerte:0 12px 40px rgba(0,56,168,.14);
  --py-cont:1140px;
  --py-fuente-tit:Georgia,"Times New Roman",serif;
  --py-fuente:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}

*{box-sizing:border-box}
body{
  font-family:var(--py-fuente);
  color:var(--py-texto);
  line-height:1.65;
  margin:0;
}
.py-cont{max-width:var(--py-cont);margin:0 auto;padding:0 20px}
a{color:var(--py-azul);text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto}

/* ---------- HERO ---------- */
.py-hero{
  position:relative;
  background:linear-gradient(135deg,var(--py-azul) 0%,var(--py-azul-osc) 100%);
  color:#fff;
  padding:72px 0 80px;
  overflow:hidden;
}
.py-hero::before{
  content:"";
  position:absolute;inset:0;
  background:
    radial-gradient(circle at 12% 20%,rgba(213,43,30,.30),transparent 38%),
    radial-gradient(circle at 88% 80%,rgba(255,255,255,.10),transparent 42%);
  pointer-events:none;
}
.py-hero .py-cont{position:relative;z-index:1}
.py-hero h1{
  font-family:var(--py-fuente-tit);
  font-size:clamp(2rem,4.5vw,3.1rem);
  line-height:1.15;
  margin:0 0 16px;
  font-weight:700;
}
.py-hero p{
  font-size:clamp(1.05rem,2vw,1.25rem);
  max-width:680px;
  color:rgba(255,255,255,.92);
  margin:0 0 28px;
}
.py-hero-cta{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--py-rojo);
  color:#fff;
  padding:14px 28px;
  border-radius:50px;
  font-weight:600;
  box-shadow:0 8px 24px rgba(213,43,30,.35);
  transition:transform .18s ease,box-shadow .18s ease;
}
.py-hero-cta:hover{transform:translateY(-2px);text-decoration:none;box-shadow:0 12px 30px rgba(213,43,30,.45)}

/* franja tricolor decorativa */
.py-franja{height:6px;display:flex}
.py-franja span{flex:1}
.py-franja span:nth-child(1){background:var(--py-rojo)}
.py-franja span:nth-child(2){background:var(--py-blanco)}
.py-franja span:nth-child(3){background:var(--py-azul)}

/* ---------- SECCIONES ---------- */
.py-seccion{padding:64px 0}
.py-seccion-alt{background:var(--py-gris)}
.py-seccion h2{
  font-family:var(--py-fuente-tit);
  font-size:clamp(1.6rem,3vw,2.2rem);
  color:var(--py-azul-osc);
  margin:0 0 12px;
}
.py-seccion .py-intro{
  color:var(--py-texto-sec);
  max-width:720px;
  margin:0 0 40px;
  font-size:1.08rem;
}

/* ---------- GRID DE PAÍSES / TARJETAS ---------- */
.py-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(250px,1fr));
  gap:22px;
}
.py-card{
  background:#fff;
  border:1px solid var(--py-gris-borde);
  border-radius:var(--py-radio);
  padding:26px 24px;
  box-shadow:var(--py-sombra);
  transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
  display:flex;flex-direction:column;gap:10px;
}
.py-card:hover{
  transform:translateY(-4px);
  box-shadow:var(--py-sombra-fuerte);
  border-color:var(--py-azul);
}
.py-card h3{
  font-size:1.18rem;
  margin:0;
  color:var(--py-azul-osc);
}
.py-card p{margin:0;color:var(--py-texto-sec);font-size:.96rem}
.py-card-ico{
  width:46px;height:46px;border-radius:12px;
  background:linear-gradient(135deg,var(--py-azul),var(--py-rojo));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1.3rem;font-weight:700;
}

/* ---------- BLOQUE PASOS ---------- */
.py-pasos{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.py-paso{position:relative;padding-left:54px}
.py-paso .num{
  position:absolute;left:0;top:0;
  width:38px;height:38px;border-radius:50%;
  background:var(--py-azul);color:#fff;
  display:flex;align-items:center;justify-content:center;
  font-weight:700;
}
.py-paso h4{margin:0 0 6px;color:var(--py-azul-osc);font-size:1.05rem}
.py-paso p{margin:0;color:var(--py-texto-sec);font-size:.95rem}

/* ---------- FAQ ---------- */
.py-faq{max-width:820px;margin:0 auto}
.py-faq details{
  background:#fff;
  border:1px solid var(--py-gris-borde);
  border-radius:12px;
  margin-bottom:14px;
  padding:0 20px;
  box-shadow:var(--py-sombra);
}
.py-faq summary{
  cursor:pointer;
  padding:18px 0;
  font-weight:600;
  color:var(--py-azul-osc);
  list-style:none;
  display:flex;justify-content:space-between;align-items:center;gap:12px;
}
.py-faq summary::-webkit-details-marker{display:none}
.py-faq summary::after{content:"+";font-size:1.5rem;color:var(--py-rojo);transition:transform .2s}
.py-faq details[open] summary::after{transform:rotate(45deg)}
.py-faq details p{margin:0 0 18px;color:var(--py-texto-sec)}

/* ---------- PÁGINAS LEGALES / CONTENIDO ---------- */
.py-legal{padding:56px 0;max-width:860px}
.py-legal h1{font-family:var(--py-fuente-tit);color:var(--py-azul-osc);font-size:clamp(1.8rem,3.5vw,2.4rem);margin:0 0 8px}
.py-legal .py-updated{color:var(--py-texto-sec);font-size:.92rem;margin:0 0 32px}
.py-legal h2{font-family:var(--py-fuente-tit);color:var(--py-azul);font-size:1.4rem;margin:36px 0 12px}
.py-legal h3{color:var(--py-azul-osc);font-size:1.12rem;margin:24px 0 10px}
.py-legal p,.py-legal li{color:var(--py-texto);font-size:1rem}
.py-legal ul{padding-left:22px}
.py-legal li{margin-bottom:8px}
.py-legal a{color:var(--py-azul);text-decoration:underline}

/* ---------- CTA FINAL ---------- */
.py-cta-final{
  background:linear-gradient(135deg,var(--py-azul-osc),var(--py-azul));
  color:#fff;border-radius:20px;
  padding:48px 40px;text-align:center;
  box-shadow:var(--py-sombra-fuerte);
}
.py-cta-final h2{color:#fff;margin:0 0 12px}
.py-cta-final p{color:rgba(255,255,255,.9);max-width:560px;margin:0 auto 24px}

/* ---------- FICHA ---------- */
.py-hero-ficha{padding:48px 0 56px}
.py-hero-ficha h1{font-size:clamp(1.7rem,3.5vw,2.5rem)}
.py-hero-ubic{font-size:1.05rem;color:rgba(255,255,255,.9);margin:0}
.py-ficha{padding:48px 20px 64px}
.py-ficha-grid{display:grid;grid-template-columns:1fr 340px;gap:40px;align-items:start}
.py-ficha-main h2{font-family:var(--py-fuente-tit);color:var(--py-azul);font-size:1.4rem;margin:32px 0 12px}
.py-ficha-main p{margin:0 0 16px}
.py-ficha-main .adsbygoogle{display:block;margin:30px 0;min-height:100px}
.py-mapa{border-radius:var(--py-radio);overflow:hidden;box-shadow:var(--py-sombra);margin:14px 0 24px}
.py-mapa iframe{width:100%;border:0;display:block;min-height:340px}
.py-fuente{font-size:.88rem;color:var(--py-texto-sec);background:var(--py-gris);border-left:3px solid var(--py-azul);padding:14px 16px;border-radius:0 8px 8px 0;margin-top:32px}
.py-datos{background:#fff;border:1px solid var(--py-gris-borde);border-radius:var(--py-radio);box-shadow:var(--py-sombra);padding:26px 24px}
.py-datos h2{font-family:var(--py-fuente-tit);color:var(--py-azul-osc);font-size:1.25rem;margin:0 0 18px}
.py-datos-lista{list-style:none;margin:0;padding:0}
.py-datos-lista li{padding:12px 0;border-bottom:1px solid var(--py-gris-borde);display:flex;flex-direction:column;gap:3px}
.py-datos-lista li:last-child{border-bottom:0}
.py-datos-lista strong{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--py-texto-sec)}
.py-datos-lista span{color:var(--py-texto);font-size:.98rem}
@media(max-width:860px){
	.py-ficha-grid{grid-template-columns:1fr;gap:28px}
}

/* trámites vinculados */
.py-tramites-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px;margin:14px 0 8px}
.py-tramite-card{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#fff;border:1px solid var(--py-gris-borde);border-radius:10px;color:var(--py-azul-osc);font-weight:500;box-shadow:var(--py-sombra);transition:transform .15s,border-color .15s}
.py-tramite-card:hover{transform:translateY(-2px);border-color:var(--py-azul);text-decoration:none}
.py-tramite-card::before{content:"›";font-size:1.2rem;color:var(--py-rojo);font-weight:700}
.py-otros-tramites li a{color:var(--py-azul)}

/* buscador + pestañas A-Z agrupadas */
.py-buscador-wrap{margin:28px 0 18px}
#py-pais-filter{width:100%;padding:14px 18px;border:1px solid var(--py-gris-borde);border-radius:10px;font-size:1rem;font-family:var(--py-fuente);box-shadow:var(--py-sombra)}
#py-pais-filter:focus{outline:none;border-color:var(--py-azul)}
.py-tabs{display:flex;flex-wrap:wrap;gap:8px;margin:0 0 22px}
.py-tab{border:1px solid var(--py-gris-borde);background:#fff;color:var(--py-azul-osc);padding:9px 16px;border-radius:50px;font-weight:600;font-size:.92rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.py-tab:hover{border-color:var(--py-azul)}
.py-tab-active{background:var(--py-azul);color:#fff;border-color:var(--py-azul)}
.py-pais-panel{display:none}
.py-panel-active{display:block}
.py-tramite-actual a{font-weight:700;color:var(--py-azul-osc)!important;pointer-events:none}
.py-tramite-actual{background:var(--py-gris)}

/* tabla de horario diario */
.py-horario{margin-top:20px}
.py-horario-tabla{width:100%;border-collapse:collapse;font-size:.95rem}
.py-horario-tabla th{text-align:left;font-weight:500;color:var(--py-texto);padding:9px 0;border-bottom:1px solid var(--py-gris-borde)}
.py-horario-tabla td{text-align:right;color:var(--py-texto-sec);padding:9px 0;border-bottom:1px solid var(--py-gris-borde)}
.py-horario-tabla tr:last-child th,.py-horario-tabla tr:last-child td{border-bottom:0}
.py-horario-tabla tr.py-hoy th,.py-horario-tabla tr.py-hoy td{color:var(--py-azul-osc);font-weight:700}
.py-badge{display:inline-block;background:var(--py-rojo);color:#fff;font-size:.66rem;font-weight:700;padding:2px 7px;border-radius:20px;margin-left:7px;vertical-align:middle;text-transform:uppercase;letter-spacing:.03em}
.py-horario-nota{font-size:.84rem;color:var(--py-texto-sec);margin:12px 0 0;font-style:italic}

/* mapa en sidebar */
.py-mapa-side{margin-top:20px}
.py-mapa-side .py-mapa{margin:0}
.py-mapa-side iframe{min-height:240px}

/* enlace volver a ficha desde trámite */
.py-volver-ficha{background:var(--py-gris);border-left:3px solid var(--py-rojo);padding:14px 16px;border-radius:0 8px 8px 0;margin-top:24px}

/* ---------- FOOTER ---------- */
.py-footer{background:var(--py-azul-osc);color:rgba(255,255,255,.82);margin-top:0}
.py-footer .py-franja{margin-bottom:48px}
.py-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:36px;padding-bottom:48px}
.py-footer-col h4{color:#fff;font-size:1rem;margin:0 0 16px;font-family:var(--py-fuente)}
.py-footer-col ul{list-style:none;margin:0;padding:0}
.py-footer-col li{margin-bottom:10px}
.py-footer-col a{color:rgba(255,255,255,.78);font-size:.95rem}
.py-footer-col a:hover{color:#fff;text-decoration:none}
.py-footer-brand p{font-size:.92rem;color:rgba(255,255,255,.7);margin:16px 0 0;max-width:300px}
.py-footer-bottom{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;font-size:.88rem;color:rgba(255,255,255,.6)}
.py-credito{background:#002460;color:rgba(255,255,255,.85);text-align:center;padding:14px 20px;font-size:.9rem}
.py-credito a{color:#fff;font-weight:600}
@media(max-width:860px){
	.py-footer-grid{grid-template-columns:1fr 1fr;gap:28px}
}
@media(max-width:520px){
	.py-footer-grid{grid-template-columns:1fr}
}

/* ---------- RESPONSIVE ---------- */
@media(max-width:640px){
  .py-hero{padding:54px 0 60px}
  .py-seccion{padding:48px 0}
  .py-legal{padding:40px 0}
}
