/* ═══════════════════════════════════════════════════════════
   DCC – Services Page Styles
   File: public/css/services.css
   ═══════════════════════════════════════════════════════════ */

/* ─── HERO ───────────────────────────────────────────────── */
.svc-hero {
  background: linear-gradient(135deg, var(--navy) 0%, #0a2540 60%, #0f3d2e 100%);
  padding: 5rem 2rem 4rem; text-align: center;
  position: relative; overflow: hidden;
}
.svc-hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(ellipse 60% 50% at 50% 50%, rgba(29,185,84,.15) 0%, transparent 70%); }
.svc-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; }
.svc-hero .section-label { position: relative; z-index: 1; }
.svc-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;
}
.svc-hero__title em { color: var(--green); font-style: italic; }
.svc-hero__sub { color: rgba(255,255,255,.65); font-size: 1.05rem; max-width: 560px; margin: 0 auto 1.5rem; line-height: 1.7; position: relative; z-index: 1; }
.svc-hero__breadcrumb { font-size: .82rem; color: rgba(255,255,255,.4); position: relative; z-index: 1; }
.svc-hero__breadcrumb a { color: var(--green); font-weight: 600; }
.svc-hero__breadcrumb a:hover { text-decoration: underline; }
.svc-hero__breadcrumb .current { color: rgba(255,255,255,.7); }

/* ─── FILTER TABS ────────────────────────────────────────── */
.svc-filter { background: var(--white); padding: 1.5rem 0; border-bottom: 1px solid var(--gray-light); position: sticky; top: 52px; z-index: 90; box-shadow: 0 2px 8px rgba(0,0,0,.04); }
.svc-filter__tabs { display: flex; gap: .5rem; justify-content: center; flex-wrap: wrap; }
.svc-tab {
  padding: .55rem 1.3rem; border-radius: 9999px; font-family: 'Inter', sans-serif;
  font-size: .82rem; font-weight: 700; border: 2px solid var(--gray-light);
  background: var(--white); color: var(--navy); cursor: pointer; transition: var(--transition);
  white-space: nowrap;
}
.svc-tab:hover { border-color: var(--green); color: var(--green); }
.svc-tab.active { background: var(--green); color: var(--white); border-color: var(--green); box-shadow: 0 3px 12px rgba(29,185,84,.25); }

/* ─── SERVICE DETAIL CARDS ───────────────────────────────── */
.svc-main { padding: 4rem 0; background: var(--off-white); }
.svc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }

.svc-detail-card {
  background: var(--white); border-radius: 20px; padding: 2rem 1.8rem;
  box-shadow: 0 4px 20px rgba(0,0,0,.06); border: 1px solid var(--gray-light);
  transition: var(--transition); display: flex; flex-direction: column;
}
.svc-detail-card:hover { transform: translateY(-6px); box-shadow: 0 16px 44px rgba(0,0,0,.1); border-color: var(--green); }

/* Emergency card special */
.svc-detail-card--emergency { border-color: rgba(239,68,68,.3); background: linear-gradient(180deg, #fff 0%, #fef2f2 100%); }
.svc-detail-card--emergency:hover { border-color: #ef4444; }

.svc-detail__header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 1rem; }
.svc-detail__icon { font-size: 2.4rem; transition: var(--transition); }
.svc-detail-card:hover .svc-detail__icon { transform: scale(1.15); }

.svc-detail__badge {
  font-size: .65rem; font-weight: 800; padding: .25rem .7rem;
  border-radius: 9999px; letter-spacing: .04em; text-transform: uppercase;
}
.svc-detail__badge--clinic { background: rgba(29,185,84,.1); color: var(--green-dark); }
.svc-detail__badge--online { background: rgba(59,130,246,.1); color: #2563eb; }
.svc-detail__badge--emergency { background: rgba(239,68,68,.1); color: #dc2626; }

.svc-detail-card h3 { font-family: 'Lora', serif; font-weight: 700; font-size: 1.15rem; color: var(--navy); margin-bottom: .6rem; }
.svc-detail-card > p { font-size: .87rem; color: var(--gray); line-height: 1.65; margin-bottom: 1rem; }

.svc-detail__features { list-style: none; display: flex; flex-direction: column; gap: .45rem; margin-bottom: 1.2rem; flex: 1; }
.svc-detail__features li { display: flex; align-items: flex-start; gap: .5rem; font-size: .82rem; color: var(--gray-dark); line-height: 1.5; }
.svc-detail__features i { color: var(--green); font-size: .7rem; margin-top: 4px; flex-shrink: 0; }

.svc-detail__price { font-size: .82rem; color: var(--navy); font-weight: 700; margin-bottom: 1.2rem; padding: .6rem .8rem; background: var(--off-white); border-radius: 8px; }
.svc-detail__price strong { color: var(--green); font-size: 1.1rem; }

.svc-detail-card .btn-primary { text-align: center; font-size: .85rem; padding: .7rem 1.2rem; }

/* Hidden by filter */
.svc-detail-card.hidden { display: none; }

/* ─── WHY DCC ────────────────────────────────────────────── */
.svc-why { padding: 5rem 0; background: var(--white); }
.why-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; margin-top: 3rem; }

.why-card {
  background: var(--off-white); border-radius: 20px; padding: 2.2rem 1.8rem;
  text-align: center; border: 1px solid var(--gray-light);
  transition: var(--transition);
}
.why-card:hover { transform: translateY(-6px); box-shadow: 0 16px 44px rgba(0,0,0,.08); border-color: var(--green); background: var(--white); }

.why-icon { font-size: 2.6rem; margin-bottom: .8rem; display: block; }
.why-stat {
  font-family: 'Lora', serif; font-size: 2.4rem; font-weight: 700;
  color: var(--green); line-height: 1; margin-bottom: .4rem;
}
.why-card h4 { font-family: 'Inter', sans-serif; font-weight: 700; font-size: 1rem; color: var(--navy); margin-bottom: .6rem; }
.why-card p { font-size: .84rem; color: var(--gray); line-height: 1.65; }

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 1024px) {
  .svc-grid { grid-template-columns: repeat(2, 1fr); }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px) {
  .svc-grid { grid-template-columns: 1fr; }
  .why-grid { grid-template-columns: repeat(2, 1fr); }
  .svc-filter { top: 46px; }
  .svc-filter__tabs { gap: .35rem; }
  .svc-tab { padding: .45rem 1rem; font-size: .75rem; }
  .svc-hero { padding: 4rem 1.5rem 3rem; }
  .svc-main, .svc-why { padding: 3.5rem 0; }
}
@media (max-width: 480px) {
  .why-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .svc-filter__tabs { justify-content: flex-start; overflow-x: auto; flex-wrap: nowrap; padding-bottom: .3rem; }
  .svc-tab { flex-shrink: 0; }
}
