/* ═══════════════════════════════════════════════════════════
   DCC – Contact Us Page Styles
   File: public/css/contact.css
   ═══════════════════════════════════════════════════════════ */

/* ─── HERO ───────────────────────────────────────────────── */
.contact-hero {
  background: linear-gradient(135deg, var(--navy) 0%, #0a2540 60%, #0f3d2e 100%);
  padding: 5rem 2rem 4rem; text-align: center; position: relative; overflow: hidden;
}
.contact-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 50% 50%, rgba(29,185,84,.15), transparent 70%); }
.contact-hero::after { content: ''; position: absolute; inset: 0; background-image: radial-gradient(circle, rgba(255,255,255,.03) 1px, transparent 1px); background-size: 35px 35px; pointer-events: none; }
.contact-hero .section-label { position: relative; z-index: 1; }
.contact-hero__title { font-family: 'Lora', serif; font-size: clamp(2.2rem, 4.5vw, 3.4rem); font-weight: 700; color: #fff; line-height: 1.15; margin-bottom: 1rem; position: relative; z-index: 1; }
.contact-hero__title em { color: var(--green); font-style: italic; }
.contact-hero__sub { color: rgba(255,255,255,.65); font-size: 1.05rem; max-width: 520px; margin: 0 auto 1.5rem; line-height: 1.7; position: relative; z-index: 1; }
.contact-hero__breadcrumb { font-size: .82rem; color: rgba(255,255,255,.4); position: relative; z-index: 1; }
.contact-hero__breadcrumb a { color: var(--green); font-weight: 600; }
.contact-hero__breadcrumb .current { color: rgba(255,255,255,.7); }

/* ─── INFO CARDS ─────────────────────────────────────────── */
.contact-info { padding: 4rem 0; background: var(--white); }
.contact-info__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.ci-card {
  background: var(--off-white); border-radius: 20px; padding: 2rem 1.5rem;
  text-align: center; border: 1px solid var(--gray-light); transition: var(--transition);
}
.ci-card:hover { transform: translateY(-6px); box-shadow: 0 12px 32px rgba(0,0,0,.08); border-color: var(--green); }
.ci-icon { font-size: 2.2rem; margin-bottom: .8rem; }
.ci-card h4 { font-family: 'Lora', serif; font-weight: 700; font-size: 1rem; color: var(--navy); margin-bottom: .5rem; }
.ci-main { display: block; font-size: 1.05rem; font-weight: 800; color: var(--green); margin-bottom: .3rem; text-decoration: none; }
.ci-main:hover { text-decoration: underline; }
.ci-card p { font-size: .78rem; color: var(--gray); }

/* ─── FORM + MAP GRID ────────────────────────────────────── */
.contact-main { padding: 4rem 0; background: var(--off-white); }
.contact-main__grid { display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; }

/* Form */
.contact-form-wrap .section-title { text-align: left; }
.contact-form { display: flex; flex-direction: column; gap: 1rem; }
.form-row-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }

.contact-form .form-group { display: flex; flex-direction: column; gap: .35rem; }
.contact-form .form-group label { font-size: .82rem; font-weight: 800; color: var(--navy); }
.contact-form .form-group input,
.contact-form .form-group select,
.contact-form .form-group textarea {
  padding: .78rem 1rem; border: 1.5px solid var(--gray-light); border-radius: 12px;
  font-family: 'Inter', sans-serif; font-size: .92rem; color: var(--navy);
  background: var(--white); outline: none; transition: var(--transition); resize: vertical;
}
.contact-form .form-group input:focus,
.contact-form .form-group select:focus,
.contact-form .form-group textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(29,185,84,.12); }

.contact-form__msg { margin-top: .5rem; font-size: .82rem; font-weight: 600; border-radius: 8px; }
.contact-form__msg:empty { display: none; }
.contact-form__msg:not(:empty) { padding: .7rem 1rem; animation: fadeSlideIn .3s ease both; }
.contact-form__msg.success { background: #f0fdf4; color: #166534; border: 1px solid #bbf7d0; }
.contact-form__msg.error { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; }
@keyframes fadeSlideIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* Map */
.contact-map-wrap .section-title { text-align: left; }
.contact-map { margin: 1.2rem 0; border-radius: 16px; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,.08); border: 1px solid var(--gray-light); }
.map-address {
  display: flex; align-items: flex-start; gap: .8rem;
  padding: 1rem; background: var(--white); border-radius: 12px;
  border: 1px solid var(--gray-light);
}
.map-address i { color: var(--green); font-size: 1.2rem; margin-top: .2rem; }
.map-address strong { display: block; font-family: 'Lora', serif; font-size: .95rem; color: var(--navy); margin-bottom: .2rem; }
.map-address p { font-size: .82rem; color: var(--gray); margin: 0; }

/* ─── CLINIC LOCATIONS ───────────────────────────────────── */
.contact-locations { padding: 5rem 0; background: var(--white); }
.locations-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.loc-card {
  background: var(--off-white); border-radius: 20px; padding: 2rem 1.5rem;
  border: 1px solid var(--gray-light); transition: var(--transition); text-align: center;
}
.loc-card:hover { transform: translateY(-6px); box-shadow: 0 16px 40px rgba(0,0,0,.08); border-color: var(--green); }
.loc-icon { font-size: 2.5rem; margin-bottom: .8rem; }
.loc-card h4 { font-family: 'Lora', serif; font-weight: 700; font-size: 1.1rem; color: var(--navy); margin-bottom: .4rem; }
.loc-address { font-size: .85rem; color: var(--gray); line-height: 1.5; margin-bottom: .8rem; }
.loc-details { display: flex; flex-direction: column; gap: .3rem; margin-bottom: .8rem; }
.loc-details span { font-size: .78rem; color: var(--gray-dark); font-weight: 600; display: flex; align-items: center; justify-content: center; gap: .4rem; }
.loc-details i { color: var(--green); font-size: .72rem; }
.loc-services { display: flex; gap: .35rem; flex-wrap: wrap; justify-content: center; margin-bottom: 1.2rem; }
.loc-card .btn-sm { padding: .45rem 1rem; font-size: .78rem; }

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .contact-info__grid { grid-template-columns: repeat(2, 1fr); }
  .contact-main__grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
  .contact-info__grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
  .locations-grid { grid-template-columns: 1fr; max-width: 400px; margin: 0 auto; }
  .form-row-2 { grid-template-columns: 1fr; }
  .contact-hero { padding: 4rem 1.5rem 3rem; }
  .contact-info, .contact-main, .contact-locations { padding: 3rem 0; }
}
