/* ============================================ CONTACTO.CSS ============================================ */
.contact-hero { background: linear-gradient(135deg, var(--navy) 0%, var(--navy-light) 100%); color: #fff; padding: 5rem 1.5rem 4rem; text-align: center; position: relative; overflow: hidden; }
.contact-hero::before { content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 4px; background: linear-gradient(90deg, transparent, var(--orange), transparent); }
.contact-hero h1 { color: #fff; margin-bottom: 0.75rem; } .contact-hero h1 span { color: var(--orange); }
.contact-hero p { color: rgba(255,255,255,0.8); max-width: 480px; margin: 0 auto; }
.contact-section { padding: 5rem 1.5rem; }
.contact-inner { display: grid; grid-template-columns: 1fr 1.2fr; gap: 4rem; max-width: var(--max-w); margin: 0 auto; align-items: start; }
.contact-info h2 { margin-bottom: 0.75rem; color: var(--navy); } .contact-info h2 span { color: var(--orange); }
.contact-info > p { margin-bottom: 2rem; }
.contact-block { display: flex; align-items: flex-start; gap: 1rem; padding: 1.25rem 0; border-bottom: 1px solid var(--border); }
.contact-block:last-of-type { border-bottom: none; }
.contact-block-icon { font-size: 1.3rem; flex-shrink: 0; width: 46px; height: 46px; background: var(--orange-light); border: 1.5px solid var(--orange-mid); border-radius: var(--radius); display: flex; align-items: center; justify-content: center; }
.contact-block-info strong { display: block; font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.1em; color: var(--orange); margin-bottom: 0.25rem; }
.contact-block-info a, .contact-block-info span { font-size: 1rem; font-weight: 600; color: var(--navy); transition: color 0.2s; }
.contact-block-info a:hover { color: var(--orange); }
.hours-card { background: #fff; border: 1.5px solid var(--border); border-radius: var(--radius-xl); padding: 1.75rem; box-shadow: var(--shadow-md); margin-top: 2rem; }
.hours-card-title { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: var(--orange); margin-bottom: 1.1rem; }
.hours-row-contact { display: flex; justify-content: space-between; font-size: 0.9rem; padding: 0.6rem 0; border-bottom: 1px solid var(--border); }
.hours-row-contact:last-child { border-bottom: none; }
.hours-row-contact .day { color: var(--muted); }
.hours-row-contact .time { font-weight: 700; color: var(--navy); }
.hours-row-contact.today .day { color: var(--orange); font-weight: 600; }
.hours-row-contact.today .time { color: var(--orange); }
.map-embed { border-radius: var(--radius-xl); overflow: hidden; border: 1.5px solid var(--border); height: 300px; margin-top: 1rem; box-shadow: var(--shadow-md); }
.map-embed iframe { width: 100%; height: 100%; border: 0; }
.whatsapp-btn { display: flex; align-items: center; justify-content: center; gap: 0.6rem; background: #25d366; color: #fff; font-weight: 700; font-size: 0.95rem; padding: 0.9rem 1.75rem; border-radius: var(--radius); transition: all 0.2s; margin-top: 1.5rem; width: 100%; }
.whatsapp-btn:hover { background: #1db954; color: #fff; transform: translateY(-2px); box-shadow: 0 8px 24px rgba(37,211,102,0.3); }
@media (max-width: 768px) { .contact-inner { grid-template-columns: 1fr; gap: 2.5rem; } .contact-hero { padding: 3.5rem 1rem 3rem; } }
