/* =====================================================================
   PIÑEYRO AUTOS — ESTILOS DEL ECOSISTEMA
   Compartido por: servicios.html (hub), vertical.html, socio.html
   Usa los tokens de tema de styles.css (--bg, --text, --red, etc.)
   ===================================================================== */

.eco-wrap { max-width: 1240px; margin: 0 auto; padding: 0 5%; }

/* ---------- Encabezado de sección ---------- */
.eco-hero { padding: 150px 5% 50px; max-width: 1240px; margin: 0 auto; }
.eco-kicker { font-size: 12px; letter-spacing: 3px; text-transform: uppercase;
  color: var(--red); font-weight: 700; margin-bottom: 14px; }
.eco-title { font-family: var(--font-display); font-size: clamp(40px, 6vw, 72px);
  font-weight: 500; line-height: 1.02; letter-spacing: -1px; margin: 0 0 18px; color: var(--text); }
.eco-lead { font-size: 17px; color: var(--text-muted); max-width: 620px; line-height: 1.6; margin: 0; }
.eco-back { display: inline-flex; align-items: center; gap: 7px; color: var(--text-muted);
  text-decoration: none; font-size: 13.5px; margin-bottom: 22px; transition: color .2s; }
.eco-back:hover { color: var(--text); }

/* ---------- Grid de verticales (hub) ---------- */
.eco-verticales { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px;
  padding: 0 5% 110px; max-width: 1240px; margin: 0 auto; }
.eco-vcard { position: relative; overflow: hidden; text-decoration: none; color: var(--text);
  background: var(--card); border: 1px solid var(--border); border-radius: 16px;
  padding: 34px 30px; min-height: 220px; display: flex; flex-direction: column;
  transition: transform .35s var(--ease), border-color .3s, box-shadow .3s; }
.eco-vcard:hover { transform: translateY(-6px); border-color: var(--border-strong);
  box-shadow: 0 30px 60px rgba(0,0,0,.35); }
.eco-vcard .vc-icon { font-size: 34px; margin-bottom: 18px; }
.eco-vcard .vc-name { font-family: var(--font-display); font-size: 27px; font-weight: 500;
  line-height: 1.1; margin-bottom: 10px; }
.eco-vcard .vc-desc { font-size: 14px; color: var(--text-muted); line-height: 1.55; flex: 1; }
.eco-vcard .vc-foot { display: flex; align-items: center; justify-content: space-between;
  margin-top: 20px; font-size: 12.5px; color: var(--text-faint); }
.eco-vcard .vc-foot .arrow { color: var(--red); font-size: 18px; transition: transform .3s; }
.eco-vcard:hover .vc-foot .arrow { transform: translateX(5px); }
.eco-vcard .vc-count { background: var(--bg-3); border: 1px solid var(--border);
  border-radius: 30px; padding: 4px 11px; font-weight: 600; color: var(--text-muted); }

/* ---------- Filtros ---------- */
.eco-filtros { display: flex; flex-wrap: wrap; gap: 9px; padding: 8px 5% 30px;
  max-width: 1240px; margin: 0 auto; }
.eco-chip { background: var(--bg-3); border: 1px solid var(--border); color: var(--text-muted);
  border-radius: 30px; padding: 9px 16px; font-family: var(--font-body); font-size: 13px;
  cursor: pointer; transition: .2s; white-space: nowrap; }
.eco-chip:hover { color: var(--text); border-color: var(--border-strong); }
.eco-chip.active { background: var(--red); border-color: var(--red); color: #fff; }

/* ---------- Grid de partners ---------- */
.eco-partners { display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
  gap: 18px; padding: 0 5% 110px; max-width: 1240px; margin: 0 auto; }
.eco-pcard { display: flex; flex-direction: column; background: var(--card);
  border: 1px solid var(--border); border-radius: 16px; padding: 26px 26px 22px;
  text-decoration: none; color: var(--text); transition: transform .3s var(--ease), border-color .3s, box-shadow .3s; }
.eco-pcard:hover { transform: translateY(-5px); border-color: var(--border-strong);
  box-shadow: 0 26px 54px rgba(0,0,0,.32); }
.eco-pcard.is-destacado { border-color: rgba(239,35,60,.4); }
.pc-top { display: flex; align-items: center; gap: 14px; margin-bottom: 16px; }
.pc-logo { width: 54px; height: 54px; border-radius: 13px; flex: 0 0 auto; object-fit: cover;
  background: var(--bg-3); display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 24px; font-weight: 600; color: var(--text-muted);
  border: 1px solid var(--border); }
.pc-headings { min-width: 0; }
.pc-name { font-size: 19px; font-weight: 600; line-height: 1.2; }
.pc-tipo { font-size: 12px; color: var(--text-faint); text-transform: capitalize; margin-top: 2px; }
.pc-badge { display: inline-block; font-size: 10px; letter-spacing: 1px; text-transform: uppercase;
  font-weight: 700; color: var(--red); background: rgba(239,35,60,.1); border-radius: 5px;
  padding: 3px 7px; margin-left: 8px; vertical-align: middle; }
.pc-resumen { font-size: 14px; color: var(--text-muted); line-height: 1.55; flex: 1; margin-bottom: 16px; }
.pc-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 16px; }
.pc-tag { font-size: 11.5px; color: var(--text-muted); background: var(--bg-3);
  border: 1px solid var(--border); border-radius: 20px; padding: 4px 10px; }
.pc-meta { display: flex; align-items: center; justify-content: space-between;
  border-top: 1px solid var(--border); padding-top: 14px; font-size: 13px; color: var(--text-faint); }
.pc-loc { display: flex; align-items: center; gap: 6px; }
.pc-cta { color: var(--red); font-weight: 600; }

/* ---------- Estado vacío / cargando ---------- */
.eco-empty { text-align: center; padding: 70px 5% 110px; color: var(--text-muted); }
.eco-empty h3 { font-family: var(--font-display); font-size: 28px; color: var(--text); font-weight: 500; margin-bottom: 10px; }
.eco-skeleton { background: linear-gradient(90deg, var(--bg-2) 25%, var(--bg-3) 50%, var(--bg-2) 75%);
  background-size: 200% 100%; animation: eco-shine 1.4s infinite; border-radius: 16px; min-height: 200px; }
@keyframes eco-shine { to { background-position: -200% 0; } }

/* ---------- Perfil de socio ---------- */
.sp-head { display: grid; grid-template-columns: auto 1fr; gap: 26px; align-items: center;
  padding: 130px 5% 36px; max-width: 1060px; margin: 0 auto; }
.sp-logo { width: 92px; height: 92px; border-radius: 20px; object-fit: cover; background: var(--bg-3);
  border: 1px solid var(--border); display: flex; align-items: center; justify-content: center;
  font-family: var(--font-display); font-size: 40px; font-weight: 600; color: var(--text-muted); }
.sp-name { font-family: var(--font-display); font-size: clamp(34px, 5vw, 54px); font-weight: 500;
  line-height: 1.04; margin: 0 0 8px; }
.sp-resumen { font-size: 16px; color: var(--text-muted); max-width: 640px; line-height: 1.55; }
.sp-body { display: grid; grid-template-columns: 1fr 340px; gap: 40px; padding: 20px 5% 110px;
  max-width: 1060px; margin: 0 auto; align-items: start; }
.sp-section { margin-bottom: 38px; }
.sp-section h2 { font-size: 13px; letter-spacing: 2px; text-transform: uppercase; color: var(--text-muted);
  font-weight: 700; margin: 0 0 18px; }
.sp-desc { font-size: 16px; color: var(--text); line-height: 1.7; }
.sp-serv { display: grid; gap: 12px; }
.sp-serv-item { background: var(--card); border: 1px solid var(--border); border-radius: 13px; padding: 18px 20px; }
.sp-serv-item .ss-name { font-size: 16px; font-weight: 600; margin-bottom: 4px; }
.sp-serv-item .ss-desc { font-size: 13.5px; color: var(--text-muted); line-height: 1.5; }
.sp-serv-item .ss-price { font-size: 13px; color: var(--red); font-weight: 600; margin-top: 8px; }
.sp-aside { position: sticky; top: 100px; background: var(--card); border: 1px solid var(--border);
  border-radius: 18px; padding: 26px; }
.sp-aside .sa-row { display: flex; gap: 11px; padding: 12px 0; border-bottom: 1px solid var(--border); font-size: 14px; }
.sp-aside .sa-row:last-of-type { border-bottom: none; }
.sp-aside .sa-ic { flex: 0 0 22px; font-size: 17px; }
.sp-aside .sa-row a { color: var(--text); text-decoration: none; }
.sp-aside .sa-row a:hover { color: var(--red); }
.sp-cta { display: block; width: 100%; box-sizing: border-box; text-align: center; margin-top: 20px;
  background: var(--red); color: #fff; border: none; border-radius: 12px; padding: 15px;
  font-family: var(--font-body); font-size: 15px; font-weight: 600; cursor: pointer; transition: background .2s; }
.sp-cta:hover { background: var(--red-h); }
.sp-wa { display: flex; align-items: center; justify-content: center; gap: 8px; width: 100%; box-sizing: border-box;
  margin-top: 10px; background: transparent; color: var(--green); border: 1px solid var(--green);
  border-radius: 12px; padding: 13px; font-family: var(--font-body); font-size: 14px; font-weight: 600;
  text-decoration: none; cursor: pointer; }
.sp-wa:hover { background: rgba(37,211,102,.08); }
.sp-pill { display: inline-block; font-size: 12px; color: var(--text-muted); background: var(--bg-3);
  border: 1px solid var(--border); border-radius: 20px; padding: 5px 12px; margin: 0 6px 6px 0; }

/* ---------- Footer compartido ---------- */
.eco-footer { background: var(--bg-2); padding: 70px 5% 40px; border-top: 1px solid var(--border);
  display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 36px; }
.eco-footer h3 { font-size: 13px; text-transform: uppercase; letter-spacing: 2px; margin: 0 0 20px; color: var(--text-muted); }
.eco-footer a { display: block; color: var(--text); text-decoration: none; font-size: 14px; margin-bottom: 11px; transition: color .2s; }
.eco-footer a:hover { color: var(--red); }
.eco-footer .ef-copy { grid-column: 1 / -1; border-top: 1px solid var(--border); padding-top: 24px;
  margin-top: 10px; font-size: 12px; color: var(--text-faint); }

@media (max-width: 900px) {
  .eco-verticales { grid-template-columns: 1fr 1fr; }
  .sp-body { grid-template-columns: 1fr; }
  .sp-aside { position: static; }
}
@media (max-width: 600px) {
  .eco-verticales { grid-template-columns: 1fr; }
  .eco-partners { grid-template-columns: 1fr; }
  .sp-head { grid-template-columns: 1fr; text-align: center; padding-top: 110px; }
  .sp-head .sp-logo { margin: 0 auto; }
  .eco-hero { padding-top: 120px; }
}
