/* =============================================================
   Dentlion · contacto.css
   Tarjetas de contacto, info, horarios, mapa y métodos de pago
   ============================================================= */

/* ---- Tarjetas principales: Llamar + WhatsApp ---- */
.contact-cards { display: grid; grid-template-columns: 1fr; gap: 1rem; margin-bottom: 2.5rem; }
@media (min-width: 720px) { .contact-cards { grid-template-columns: 1fr 1fr; gap: 1.25rem; } }

.contact-card {
  position: relative; overflow: hidden; color: #fff;
  border-radius: var(--r-lg); padding: 2rem 1.5rem; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  transition: transform var(--t), box-shadow var(--t);
}
.contact-card:hover { transform: translateY(-5px); box-shadow: var(--sh-lg); }
.contact-card--call { background: linear-gradient(135deg, var(--teal-700), var(--teal-500)); }
.contact-card--wa   { background: linear-gradient(135deg, #0f8a6c, var(--wa-500)); }
.contact-card__icon {
  width: 64px; height: 64px; border-radius: 50%; margin-bottom: 0.25rem;
  display: grid; place-items: center; background: rgba(255, 255, 255, 0.18);
}
.contact-card h2 { color: #fff; font-size: 1.3rem; }
.contact-card p  { opacity: 0.92; font-size: 0.95rem; }
.contact-card__big {
  font-family: var(--font-head); font-weight: 700;
  font-size: clamp(1.4rem, 1.1rem + 1.6vw, 1.85rem); letter-spacing: -0.01em;
}
.contact-card__pill {
  display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 0.4rem;
  padding: 0.6rem 1.2rem; border-radius: var(--r-pill);
  background: rgba(255, 255, 255, 0.2); border: 1px solid rgba(255, 255, 255, 0.3);
  font-family: var(--font-head); font-weight: 600; font-size: 0.9rem;
  transition: transform var(--t), background var(--t), color var(--t);
}
.contact-card:hover .contact-card__pill { background: #fff; color: var(--navy-800); transform: scale(1.04); }
.contact-card--call .contact-card__pill svg { animation: ring 3.6s infinite; }
@keyframes ring {
  0%, 88%, 100% { transform: rotate(0); }
  90% { transform: rotate(-9deg); } 92% { transform: rotate(8deg); }
  94% { transform: rotate(-5deg); } 96% { transform: rotate(3deg); }
}
@media (prefers-reduced-motion: reduce) { .contact-card--call .contact-card__pill svg { animation: none; } }

/* ---- Tarjetas de información ---- */
.info-grid { display: grid; grid-template-columns: 1fr; gap: 1.25rem; }
@media (min-width: 720px)  { .info-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .info-grid { grid-template-columns: 1.1fr 1.1fr 0.9fr; } }
.info-card {
  background: #fff; border: 1px solid var(--line);
  border-radius: var(--r-md); padding: 1.5rem;
}
.info-card__icon {
  width: 50px; height: 50px; border-radius: 13px; margin-bottom: 0.85rem;
  display: grid; place-items: center; background: var(--teal-50); color: var(--teal-600);
}
.info-card h3 { font-size: 1.05rem; color: var(--navy-800); margin-bottom: 0.5rem; }
.info-card p, .info-card address { font-size: 0.92rem; color: var(--ink-soft); font-style: normal; line-height: 1.6; }
.map-link {
  display: inline-flex; align-items: center; gap: 0.4rem; margin-top: 0.75rem;
  color: var(--teal-700); font-weight: 600; font-size: 0.85rem;
  transition: gap var(--t);
}
.map-link:hover { gap: 0.7rem; }

/* ---- Tabla de horarios ---- */
.hours { width: 100%; border-collapse: collapse; font-size: 0.9rem; color: var(--ink-soft); }
.hours th {
  text-align: left; font-weight: 600; color: var(--navy-700);
  padding: 0.2rem 0.85rem 0.2rem 0; white-space: nowrap; vertical-align: top;
}
.hours td { padding: 0.2rem 0; }
.hours .is-closed { color: #c0392b; font-weight: 600; }

/* ---- Mapa embebido ---- */
.map {
  margin-top: 2.5rem; border-radius: var(--r-lg); overflow: hidden;
  box-shadow: var(--sh-md); border: 1px solid var(--line);
}
.map iframe { width: 100%; height: clamp(260px, 40vw, 420px); border: 0; display: block; }

/* ---- Métodos de pago ---- */
.methods { margin-top: 1.75rem; display: flex; flex-wrap: wrap; gap: 0.6rem; justify-content: center; }
.chip {
  display: inline-flex; align-items: center; gap: 0.45rem;
  background: #fff; border: 1px solid var(--teal-100); border-radius: var(--r-pill);
  padding: 0.5rem 0.9rem; font-size: 0.85rem; font-weight: 500; color: var(--navy-800);
}
.chip svg { width: 16px; height: 16px; color: var(--teal-600); }
