/* ciudad-municipio.css — componentes específicos páginas SERPAVI por municipio */

.ciudad-page{display:block;}
.ciudad-page section{padding:56px 0;border-bottom:1px solid var(--paper3);}
.ciudad-page section:nth-child(even){background:var(--paper2);}
.ciudad-page section:last-of-type{border-bottom:none;}
.ciudad-page .container{max-width:1200px;margin:0 auto;padding:0 24px;}

/* === HERO === */
.ciudad-page .hero{padding:48px 0 40px;background:var(--paper);border-bottom:1.5px solid var(--ink);}
.ciudad-page .hero h1{font-family:var(--serif);font-size:clamp(32px,4.6vw,56px);line-height:1.06;color:var(--ink);margin:14px 0 18px;font-weight:400;max-width:880px;}
.ciudad-page .hero h1 em{font-style:italic;color:var(--accent);}
.ciudad-page .hero .lead{font-size:17px;line-height:1.6;color:var(--ink3);max-width:680px;}
.ciudad-page .breadcrumb-mini{font-size:12px;color:var(--ink3);display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:6px;}
.ciudad-page .breadcrumb-mini a{color:var(--ink3);text-decoration:none;}
.ciudad-page .breadcrumb-mini a:hover{color:var(--accent);}
.ciudad-page .breadcrumb-mini .sep{opacity:.4;}
.ciudad-page .breadcrumb-mini .current{color:var(--ink);font-weight:500;}

/* === STATS HERO (3 grandes datos) === */
.stats-hero{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1.5px solid var(--ink);border-radius:var(--r2);overflow:hidden;margin:32px 0 16px;background:var(--paper);}
.stats-hero .stat{padding:28px 24px;border-right:1px solid var(--paper3);text-align:left;}
.stats-hero .stat:last-child{border-right:none;}
.stats-hero .stat-value{font-family:var(--serif);font-size:clamp(32px,4.4vw,52px);line-height:1;color:var(--accent);margin-bottom:10px;font-weight:400;}
.stats-hero .stat-label{font-size:13px;color:var(--ink3);line-height:1.4;}
.stats-hero .stat-sub{font-size:11px;color:var(--ink3);opacity:.65;margin-top:4px;}

/* === MINI CTA INLINE === */
.mini-cta{margin:18px 0 0;padding:14px 18px;background:var(--accent-light);border-left:3px solid var(--accent);border-radius:var(--r);font-size:14px;color:var(--ink2);}
.mini-cta a{color:var(--accent);font-weight:600;text-decoration:none;}
.mini-cta a:hover{text-decoration:underline;}

/* === RANGO DE MERCADO === */
.rango-visual{margin:24px 0 18px;padding:24px 8px 8px;background:var(--paper);border:1px solid var(--paper3);border-radius:var(--r2);}
.rango-bar{display:block;width:100%;max-width:100%;height:auto;}
.rango-interp{font-size:14px;color:var(--ink3);line-height:1.7;margin-top:8px;}
.rango-interp strong{color:var(--ink);}

/* === EVOLUCIÓN HISTÓRICA === */
.evolution-wrap{margin:24px 0 16px;padding:20px 8px 8px;background:var(--paper);border:1px solid var(--paper3);border-radius:var(--r2);}
.evolution-chart{display:block;width:100%;max-width:100%;height:auto;}
.evolution-legend{display:flex;flex-wrap:wrap;gap:24px;font-size:13px;color:var(--ink3);margin-top:12px;padding:0 12px 4px;}
.evolution-legend strong{color:var(--ink);font-weight:600;}

/* === VARIACIONES === */
.var-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:24px;}
.var-card{padding:24px 22px;background:var(--paper);border:1.5px solid var(--paper3);border-radius:var(--r2);transition:border-color .15s;}
.var-card:hover{border-color:var(--ink);}
.var-pct{font-family:var(--serif);font-size:38px;line-height:1;margin-bottom:10px;font-weight:400;}
.var-pct.up{color:#c1372a;}
.var-pct.down{color:var(--green);}
.var-pct.flat{color:var(--ink3);}
.var-card-label{font-size:13px;color:var(--ink3);line-height:1.5;}

/* === CTA BANNERS === */
.cta-banner{margin:0;padding:48px 0;background:linear-gradient(180deg,var(--paper2) 0%,var(--paper) 100%);border-top:1px solid var(--paper3);border-bottom:1px solid var(--paper3);}
.cta-banner .cta-content{max-width:680px;margin:0 auto;padding:0 24px;text-align:center;}
.cta-banner .cta-icon{font-size:36px;margin-bottom:14px;}
.cta-banner h3{font-family:var(--serif);font-size:clamp(22px,2.8vw,30px);line-height:1.2;color:var(--ink);margin-bottom:14px;font-weight:400;}
.cta-banner h3 em{font-style:italic;color:var(--accent);}
.cta-banner p{font-size:15px;color:var(--ink3);line-height:1.65;margin-bottom:22px;max-width:560px;margin-left:auto;margin-right:auto;}
.cta-banner .btn-primary{display:inline-block;background:var(--accent);color:#fff;font-family:var(--sans);font-size:15px;font-weight:600;padding:14px 28px;border-radius:8px;text-decoration:none;transition:background .15s;}
.cta-banner .btn-primary:hover{background:var(--ink);}
.cta-banner .btn-large{font-size:16px;padding:16px 32px;}
.cta-banner .cta-trust{display:flex;flex-wrap:wrap;justify-content:center;gap:18px;margin-top:18px;font-size:12px;color:var(--ink3);}
.cta-banner .cta-trust span{display:inline-flex;align-items:center;gap:4px;}
.cta-banner.cta-mid{background:var(--accent-light);border-top:1px solid rgba(214,58,31,.18);border-bottom:1px solid rgba(214,58,31,.18);}

/* === CIUDADES SIMILARES === */
.similares-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:24px;}
.similar-card{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:18px 20px;background:var(--paper);border:1.5px solid var(--paper3);border-radius:var(--r2);text-decoration:none;color:var(--ink);transition:all .15s;}
.similar-card:hover{border-color:var(--ink);box-shadow:var(--shadow);}
.similar-card .similar-info{display:flex;flex-direction:column;gap:2px;min-width:0;}
.similar-card .similar-name{font-size:15px;font-weight:600;color:var(--ink);}
.similar-card .similar-prov{font-size:12px;color:var(--ink3);}
.similar-card .similar-precio{font-family:var(--serif);font-size:22px;color:var(--accent);font-weight:400;flex-shrink:0;}

/* === FUENTE INFO (footer del main) === */
.fuente-info{padding:32px 0 40px;background:var(--paper2);}
.fuente-info p{max-width:1200px;margin:0 auto;padding:0 24px;font-size:12px;color:var(--ink3);line-height:1.65;}
.fuente-info strong{color:var(--ink);}

/* === FAQ === */
.ciudad-page .faq h2{margin-bottom:8px;}
.ciudad-page .faq details{border-bottom:1px solid var(--paper3);padding:0;}
.ciudad-page .faq details:first-of-type{border-top:1px solid var(--paper3);margin-top:18px;}
.ciudad-page .faq summary{padding:18px 4px;cursor:pointer;font-size:15px;font-weight:500;color:var(--ink);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:14px;}
.ciudad-page .faq summary::-webkit-details-marker{display:none;}
.ciudad-page .faq summary::after{content:'+';display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:var(--paper2);border-radius:50%;font-size:18px;font-weight:300;color:var(--ink2);flex-shrink:0;transition:transform .25s,background .15s;}
.ciudad-page .faq details[open] summary::after{transform:rotate(45deg);background:var(--accent);color:#fff;}
.ciudad-page .faq summary:hover{color:var(--accent);}
.ciudad-page .faq details p{font-size:14px;color:var(--ink3);line-height:1.75;padding:0 4px 18px;margin:0;}
.ciudad-page .faq details p strong{color:var(--ink);}
.ciudad-page .faq details p a{color:var(--accent);}

/* === RESPONSIVE === */
@media(max-width:900px){
  .stats-hero{grid-template-columns:1fr;}
  .stats-hero .stat{border-right:none;border-bottom:1px solid var(--paper3);}
  .stats-hero .stat:last-child{border-bottom:none;}
  .var-grid{grid-template-columns:1fr;}
  .similares-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:600px){
  .ciudad-page section{padding:40px 0;}
  .ciudad-page .hero{padding:32px 0 28px;}
  .similares-grid{grid-template-columns:1fr;}
  .cta-banner{padding:36px 0;}
  .var-pct{font-size:32px;}
}
