/* ═══════════════════════════════════════════════════
   KP HIBA DIVINE HOSPITAL — GLASSMORPHISM PREMIUM
   Design: Floating Nav · Glass Cards · Rounded UI
═══════════════════════════════════════════════════ */

:root {
  --navy:        #060e1f;
  --navy-mid:    #0d1f3c;
  --blue:        #1a56db;
  --blue-light:  #3b82f6;
  --teal:        #0d9488;
  --teal-light:  #14b8a6;
  --teal-glow:   rgba(13,148,136,.35);
  --green:       #059669;
  --sky:         #e0f2fe;
  --bg:          #f0f6ff;
  --bg-section:  #f7faff;
  --white:       #ffffff;
  --text:        #0f172a;
  --text-muted:  #64748b;
  --border:      rgba(148,163,184,.18);
  --glass-bg:    rgba(255,255,255,.65);
  --glass-dark:  rgba(255,255,255,.08);
  --glass-border:rgba(255,255,255,.35);
  --glass-shadow:0 8px 40px rgba(10,22,40,.12), inset 0 1px 0 rgba(255,255,255,.6);
  --shadow-sm:   0 2px 12px rgba(10,22,40,.06);
  --shadow-md:   0 10px 40px rgba(10,22,40,.12);
  --shadow-lg:   0 24px 70px rgba(10,22,40,.18);
  --shadow-glow: 0 8px 32px rgba(13,148,136,.25);
  --radius-xl:   28px;
  --radius-lg:   20px;
  --radius:      16px;
  --radius-sm:   12px;
  --radius-xs:   8px;
  --transition:  all .3s cubic-bezier(.4,0,.2,1);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: 'DM Sans', sans-serif;
  color: var(--text);
  background: var(--bg);
  overflow-x: hidden;
  line-height: 1.7;
}

/* Subtle mesh background */
body::before {
  content:'';
  position:fixed;
  inset:0;
  background:
    radial-gradient(ellipse 80% 50% at 10% 20%, rgba(26,86,219,.06) 0%, transparent 60%),
    radial-gradient(ellipse 60% 60% at 90% 80%, rgba(13,148,136,.06) 0%, transparent 60%);
  pointer-events:none;
  z-index:0;
}

img { width:100%; height:100%; object-fit:cover; display:block; }
a   { text-decoration:none; color:inherit; }
ul  { list-style:none; }

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 2rem;
  position: relative;
  z-index: 1;
}

/* ═══ GLASS MIXIN CLASSES ══════════════════════════ */
.glass {
  background: var(--glass-bg);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-shadow);
}
.glass-dark {
  background: var(--glass-dark);
  backdrop-filter: blur(24px) saturate(160%);
  -webkit-backdrop-filter: blur(24px) saturate(160%);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 8px 32px rgba(0,0,0,.2);
}

/* ═══ TYPOGRAPHY ═══════════════════════════════════ */
.section-label {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--teal);
  background: rgba(13,148,136,.1);
  border: 1px solid rgba(13,148,136,.2);
  padding: .38rem 1rem;
  border-radius: 50px;
  margin-bottom: 1rem;
}
.section-label.light {
  color: rgba(255,255,255,.9);
  background: rgba(255,255,255,.1);
  border-color: rgba(255,255,255,.2);
}
.section-label::before {
  content:'';
  width:6px; height:6px;
  border-radius:50%;
  background:var(--teal);
  box-shadow:0 0 6px var(--teal);
}
.section-label.light::before { background:rgba(255,255,255,.9); box-shadow:none; }

.section-title {
  font-family: 'Playfair Display', serif;
  font-size: clamp(1.9rem, 4vw, 2.75rem);
  font-weight: 700;
  color: var(--navy);
  line-height: 1.18;
  margin-bottom: 1rem;
}
.section-title em { font-style:italic; color:var(--teal); }
.section-title.light { color:#fff; }
.section-title.light em { color:var(--teal-light); }

.section-desc { color:var(--text-muted); max-width:580px; margin:0 auto; }
.section-desc.light { color:rgba(255,255,255,.7); }

.section-header { text-align:center; margin-bottom:3.5rem; }
.section-header .section-label { margin:0 auto 1rem; display:flex; width:max-content; }

/* ═══ BUTTONS ══════════════════════════════════════ */
.btn {
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  padding:.85rem 2rem;
  border-radius:50px;
  font-family:'DM Sans',sans-serif;
  font-weight:700;
  font-size:.92rem;
  cursor:pointer;
  border:none;
  transition:var(--transition);
  white-space:nowrap;
  position:relative;
  overflow:hidden;
}
.btn::after {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(rgba(255,255,255,.15),transparent);
  border-radius:inherit;
  opacity:0;
  transition:opacity .3s;
}
.btn:hover::after { opacity:1; }

.btn-primary {
  background:linear-gradient(135deg,var(--blue),var(--teal));
  color:#fff;
  box-shadow:0 4px 24px rgba(26,86,219,.35), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover {
  transform:translateY(-2px);
  box-shadow:0 8px 36px rgba(26,86,219,.45), 0 0 0 3px rgba(26,86,219,.1);
}
.btn-emergency {
  background:rgba(255,255,255,.12);
  color:#fff;
  border:1.5px solid rgba(255,255,255,.3);
  backdrop-filter:blur(10px);
}
.btn-emergency:hover { background:rgba(255,255,255,.22); transform:translateY(-2px); }
.btn-white { background:#fff; color:var(--navy); font-weight:700; }
.btn-white:hover { background:var(--sky); transform:translateY(-2px); }
.btn-doc {
  background:rgba(26,86,219,.08);
  color:var(--blue);
  font-size:.83rem;
  padding:.6rem 1.4rem;
  border-radius:50px;
  font-weight:700;
  width:100%;
  justify-content:center;
  border:1px solid rgba(26,86,219,.15);
}
.btn-doc:hover { background:var(--blue); color:#fff; border-color:var(--blue); }
.btn-full { width:100%; justify-content:center; }

/* ═══ FLOATING ELEMENTS ════════════════════════════ */
.float-emergency {
  position:fixed;
  bottom:7.5rem; right:1.5rem;
  background:linear-gradient(135deg,#dc2626,#b91c1c);
  color:#fff;
  padding:.7rem 1.15rem;
  border-radius:50px;
  display:flex;
  align-items:center;
  gap:.5rem;
  font-weight:700;
  font-size:.82rem;
  box-shadow:0 4px 24px rgba(220,38,38,.45),inset 0 1px 0 rgba(255,255,255,.2);
  z-index:999;
  animation:pulse-red 2.5s infinite;
}
.float-emergency:hover { transform:scale(1.05); }
.float-whatsapp {
  position:fixed;
  bottom:2rem; right:1.5rem;
  background:linear-gradient(135deg,#25d366,#1da851);
  color:#fff;
  width:54px; height:54px;
  border-radius:50%;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.4rem;
  box-shadow:0 4px 24px rgba(37,211,102,.45),inset 0 1px 0 rgba(255,255,255,.2);
  z-index:999;
  animation:bounce-gentle 3s ease-in-out infinite;
}
@keyframes pulse-red {
  0%,100%{ box-shadow:0 4px 24px rgba(220,38,38,.45); }
  50%{ box-shadow:0 4px 36px rgba(220,38,38,.75),0 0 0 6px rgba(220,38,38,.1); }
}
@keyframes bounce-gentle {
  0%,100%{ transform:translateY(0); }
  50%{ transform:translateY(-7px); }
}

/* ═══ FLOATING NAVBAR ══════════════════════════════ */
.navbar {
  position:fixed;
  top:1.2rem;
  left:50%;
  transform:translateX(-50%);
  width:calc(100% - 3rem);
  max-width:1160px;
  z-index:1000;
  border-radius:var(--radius-xl);
  padding:0;
  transition:var(--transition);
  /* Initial: fully transparent glass */
  background:rgba(255,255,255,0);
  backdrop-filter:blur(0px);
  border:1px solid transparent;
  box-shadow:none;
}
.navbar.scrolled {
  background:rgba(255,255,255,.75);
  backdrop-filter:blur(28px) saturate(200%);
  -webkit-backdrop-filter:blur(28px) saturate(200%);
  border:1px solid rgba(255,255,255,.5);
  box-shadow:0 8px 40px rgba(10,22,40,.12),inset 0 1px 0 rgba(255,255,255,.8);
}
.nav-container {
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:.75rem 1.25rem;
}
.nav-brand { display:flex; align-items:center; }
.brand-logo { display:flex; align-items:center; gap:.85rem; }
.logo-mark {
  width:42px; height:42px;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  border-radius:12px;
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow:0 4px 14px rgba(26,86,219,.35);
  flex-shrink:0;
}
.cross-h,.cross-v {
  position:absolute;
  background:#fff;
  border-radius:2px;
}
.cross-h { width:55%; height:22%; }
.cross-v { width:22%; height:55%; }
.brand-text { display:flex; flex-direction:column; }
.brand-main {
  font-family:'Playfair Display',serif;
  font-size:1.02rem;
  font-weight:700;
  color:var(--navy);
  line-height:1.2;
}
.brand-sub {
  font-size:.62rem;
  color:var(--text-muted);
  font-weight:600;
  letter-spacing:.04em;
}
/* On transparent hero bg, invert brand text */
.navbar:not(.scrolled) .brand-main { color:#fff; }
.navbar:not(.scrolled) .brand-sub { color:rgba(255,255,255,.55); }

.nav-links {
  display:flex;
  align-items:center;
  gap:.1rem;
}
.nav-links a {
  font-size:.875rem;
  font-weight:500;
  padding:.5rem .9rem;
  border-radius:50px;
  color:rgba(255,255,255,.85);
  transition:var(--transition);
}
.navbar.scrolled .nav-links a { color:var(--text); }
.nav-links a:hover {
  background:rgba(255,255,255,.15);
  color:#fff;
}
.navbar.scrolled .nav-links a:hover {
  background:var(--sky);
  color:var(--blue);
}
.nav-links .nav-cta {
  background:linear-gradient(135deg,var(--blue),var(--teal));
  color:#fff !important;
  padding:.55rem 1.3rem;
  border-radius:50px;
  font-weight:700;
  box-shadow:0 4px 16px rgba(26,86,219,.3);
}
.nav-cta:hover { transform:translateY(-1px); box-shadow:0 6px 22px rgba(26,86,219,.4) !important; background:rgba(255,255,255,.1) !important; }
.nav-cta { background:linear-gradient(135deg,var(--blue),var(--teal)) !important; }

.nav-toggle {
  display:none;
  flex-direction:column;
  gap:5px;
  background:none;
  border:none;
  cursor:pointer;
  padding:.5rem;
}
.nav-toggle span {
  width:24px; height:2px;
  background:#fff;
  border-radius:2px;
  transition:var(--transition);
  display:block;
}
.navbar.scrolled .nav-toggle span { background:var(--navy); }

/* ═══ HERO ══════════════════════════════════════════ */
.hero {
  min-height:100vh;
  background:linear-gradient(135deg, var(--navy) 0%, #112244 45%, #0c3356 100%);
  position:relative;
  display:flex;
  align-items:center;
  overflow:hidden;
}
.hero-bg { position:absolute; inset:0; }
.hero-mesh {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 65% 60% at 70% 35%, rgba(13,148,136,.3) 0%, transparent 65%),
    radial-gradient(ellipse 45% 45% at 15% 75%, rgba(26,86,219,.25) 0%, transparent 55%),
    radial-gradient(ellipse 30% 30% at 85% 80%, rgba(59,130,246,.15) 0%, transparent 50%);
}
/* Decorative grid lines */
.hero-bg::after {
  content:'';
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.025) 1px, transparent 1px);
  background-size:60px 60px;
}
.hero-particles { position:absolute; inset:0; }

.hero-container {
  max-width:1200px;
  margin:0 auto;
  padding:9rem 2rem 5rem;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
  position:relative;
  z-index:2;
}

.hero-badge {
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  background:rgba(255,255,255,.08);
  border:1px solid rgba(255,255,255,.18);
  color:rgba(255,255,255,.9);
  font-size:.78rem;
  font-weight:600;
  padding:.45rem 1.1rem;
  border-radius:50px;
  margin-bottom:1.6rem;
  backdrop-filter:blur(10px);
  letter-spacing:.03em;
}
.badge-dot {
  width:8px; height:8px;
  border-radius:50%;
  background:var(--teal-light);
  box-shadow:0 0 0 3px rgba(20,184,166,.3);
  animation:pulse-dot 2s infinite;
}
@keyframes pulse-dot {
  0%,100%{ box-shadow:0 0 0 3px rgba(20,184,166,.3); }
  50%{ box-shadow:0 0 0 8px rgba(20,184,166,.08); }
}

.hero-headline {
  font-family:'Playfair Display',serif;
  font-size:clamp(2.4rem,5vw,3.9rem);
  font-weight:700;
  color:#fff;
  line-height:1.1;
  margin-bottom:1.5rem;
  text-shadow:0 2px 20px rgba(0,0,0,.2);
}
.hero-headline em { font-style:italic; color:var(--teal-light); }

.hero-sub {
  color:rgba(255,255,255,.72);
  font-size:1.05rem;
  line-height:1.85;
  margin-bottom:2.5rem;
  max-width:500px;
}
.hero-sub strong { color:var(--teal-light); font-weight:700; }

.hero-actions { display:flex; gap:1rem; flex-wrap:wrap; margin-bottom:3rem; }

/* Hero glass stats bar */
.hero-stats {
  display:flex;
  align-items:center;
  gap:0;
  background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.12);
  backdrop-filter:blur(20px) saturate(160%);
  border-radius:var(--radius-lg);
  padding:1.2rem 1.5rem;
  box-shadow:0 8px 32px rgba(0,0,0,.2),inset 0 1px 0 rgba(255,255,255,.1);
  overflow:hidden;
}
.hstat { text-align:center; flex:1; }
.hstat-num {
  font-family:'Playfair Display',serif;
  font-size:1.75rem;
  font-weight:700;
  color:#fff;
}
.hstat span { color:var(--teal-light); font-weight:700; font-size:1.3rem; }
.hstat p { font-size:.7rem; color:rgba(255,255,255,.55); margin-top:2px; font-weight:600; letter-spacing:.04em; }
.hstat-div { width:1px; height:40px; background:rgba(255,255,255,.12); }

/* ── Hero visual ── */
.hero-visual {
  position:relative;
  display:flex;
  align-items:center;
  justify-content:center;
}
.hero-card-main {
  width:340px; height:420px;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:0 30px 80px rgba(0,0,0,.4),inset 0 1px 0 rgba(255,255,255,.15);
  border:2px solid rgba(255,255,255,.15);
  position:relative;
  z-index:2;
}
.hcard-img { position:relative; width:100%; height:100%; }
.hcard-badge {
  position:absolute;
  bottom:1.2rem; left:50%;
  transform:translateX(-50%);
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(16px);
  color:var(--navy);
  font-size:.76rem;
  font-weight:800;
  padding:.55rem 1.1rem;
  border-radius:50px;
  display:flex;
  align-items:center;
  gap:.4rem;
  white-space:nowrap;
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 4px 16px rgba(0,0,0,.15);
}
.hcard-badge i { color:var(--blue); }

.hero-card-float {
  position:absolute;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid rgba(255,255,255,.7);
  border-radius:var(--radius);
  padding:1rem 1.25rem;
  display:flex;
  align-items:center;
  gap:.85rem;
  box-shadow:0 10px 40px rgba(0,0,0,.18),inset 0 1px 0 rgba(255,255,255,.9);
  z-index:3;
  min-width:180px;
}
.hero-card-float i { font-size:1.4rem; }
.card-top { top:1.5rem; left:-2.5rem; }
.card-top i { color:#dc2626; }
.card-bottom { bottom:2.5rem; right:-2rem; }
.card-bottom i { color:var(--teal); }
.hero-card-float strong { display:block; font-size:.9rem; color:var(--navy); }
.hero-card-float span { font-size:.75rem; color:var(--text-muted); }
.hero-ring {
  position:absolute;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.07);
}
.ring1 { width:460px; height:460px; animation:spin 30s linear infinite; }
.ring2 { width:620px; height:620px; animation:spin 50s linear infinite reverse; border-color:rgba(13,148,136,.08); }
@keyframes spin { from{transform:rotate(0deg)} to{transform:rotate(360deg)} }

.hero-wave { position:absolute; bottom:0; left:0; right:0; line-height:0; }

/* ═══ ABOUT ════════════════════════════════════════ */
.about { padding:7rem 0; background:var(--bg-section); }
.about-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5rem;
  align-items:center;
}
.about-visual { position:relative; }
.about-img-stack { position:relative; }
.aimg-main {
  width:100%; height:420px;
  border-radius:var(--radius-xl);
  box-shadow:var(--shadow-lg);
}
.aimg-thumb {
  position:absolute;
  bottom:-2rem; right:-2rem;
  width:200px; height:160px;
  border-radius:var(--radius-lg);
  border:4px solid #fff;
  box-shadow:var(--shadow-md);
}
.about-since {
  position:absolute;
  top:-1.5rem; left:-1.5rem;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  color:#fff;
  width:96px; height:96px;
  border-radius:50%;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  box-shadow:0 8px 30px rgba(26,86,219,.4),inset 0 1px 0 rgba(255,255,255,.2);
}
.as-year { font-family:'Playfair Display',serif; font-size:1.5rem; font-weight:700; line-height:1; }
.as-text { font-size:.52rem; text-align:center; line-height:1.4; font-weight:700; opacity:.85; }

.about-content .section-title { margin-bottom:1.2rem; }
.about-content p { color:var(--text-muted); margin-bottom:1rem; }
.about-features { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-top:2rem; }
.af-item {
  display:flex;
  align-items:flex-start;
  gap:.85rem;
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  padding:1.1rem;
  border-radius:var(--radius-lg);
  box-shadow:var(--glass-shadow);
  transition:var(--transition);
}
.af-item:hover {
  box-shadow:0 16px 50px rgba(10,22,40,.14),inset 0 1px 0 rgba(255,255,255,.8);
  transform:translateY(-3px);
}
.af-item i { font-size:1.25rem; color:var(--teal); margin-top:.1rem; flex-shrink:0; }
.af-item strong { display:block; font-size:.9rem; color:var(--navy); }
.af-item span { font-size:.78rem; color:var(--text-muted); }

/* ═══ CSR ══════════════════════════════════════════ */
.csr { padding:7rem 0; position:relative; overflow:hidden; }
.csr-bg {
  position:absolute; inset:0;
  background:linear-gradient(135deg,#060e1f 0%,#0d1f3c 55%,#0a2840 100%);
}
/* Decorative orbs */
.csr-bg::before {
  content:'';
  position:absolute;
  width:600px; height:600px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(13,148,136,.18) 0%, transparent 65%);
  top:-150px; right:-100px;
}
.csr-bg::after {
  content:'';
  position:absolute;
  width:400px; height:400px;
  border-radius:50%;
  background:radial-gradient(circle, rgba(26,86,219,.15) 0%, transparent 65%);
  bottom:-100px; left:-50px;
}
.csr .container { position:relative; z-index:2; }

.csr-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.4rem;
}
.csr-card {
  background:rgba(255,255,255,.06);
  backdrop-filter:blur(20px) saturate(150%);
  -webkit-backdrop-filter:blur(20px) saturate(150%);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-xl);
  padding:2rem;
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.csr-card::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.04) 0%,transparent 50%);
  border-radius:inherit;
}
.csr-card:hover {
  background:rgba(255,255,255,.1);
  border-color:rgba(255,255,255,.18);
  transform:translateY(-5px);
  box-shadow:0 20px 60px rgba(0,0,0,.3);
}
.csr-card-highlight {
  background:linear-gradient(135deg,rgba(13,148,136,.2),rgba(26,86,219,.2));
  border-color:rgba(20,184,166,.25);
}
.csr-icon {
  width:56px; height:56px;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  border-radius:var(--radius);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.3rem;
  color:#fff;
  margin-bottom:1.25rem;
  box-shadow:0 6px 20px rgba(13,148,136,.3);
}
.csr-card h3 { color:#fff; font-size:1.02rem; margin-bottom:.75rem; font-weight:700; }
.csr-card p { color:rgba(255,255,255,.6); font-size:.88rem; line-height:1.75; margin-bottom:1rem; }
.csr-stat {
  display:inline-block;
  background:rgba(20,184,166,.15);
  border:1px solid rgba(20,184,166,.25);
  color:var(--teal-light);
  font-size:.75rem;
  font-weight:800;
  padding:.3rem .85rem;
  border-radius:50px;
  letter-spacing:.03em;
}

/* ═══ DEPARTMENTS ══════════════════════════════════ */
.departments { padding:7rem 0; background:var(--bg); }
.dept-grid {
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:1.2rem;
}
.dept-card {
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  padding:1.5rem;
  box-shadow:var(--glass-shadow);
  transition:var(--transition);
}
.dept-card:hover {
  background:rgba(255,255,255,.88);
  transform:translateY(-6px);
  box-shadow:0 20px 60px rgba(10,22,40,.14),inset 0 1px 0 rgba(255,255,255,.9);
}
.dept-icon {
  width:50px; height:50px;
  background:color-mix(in srgb, var(--dc) 12%, white);
  border-radius:var(--radius);
  display:flex;
  align-items:center;
  justify-content:center;
  font-size:1.2rem;
  color:var(--dc);
  margin-bottom:1rem;
  border:1px solid color-mix(in srgb, var(--dc) 15%, transparent);
}
.dept-card h4 { font-size:.92rem; font-weight:700; color:var(--navy); margin-bottom:.45rem; }
.dept-card p { font-size:.78rem; color:var(--text-muted); line-height:1.65; margin-bottom:.9rem; }
.dept-card a { font-size:.78rem; font-weight:700; color:var(--blue); }
.dept-card:hover a { color:var(--teal); }

/* ═══ DOCTORS ══════════════════════════════════════ */
.doctors { padding:7rem 0; background:var(--bg-section); }
.doctors-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.4rem;
}
.doctor-card {
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--glass-shadow);
  transition:var(--transition);
}
.doctor-card:hover {
  transform:translateY(-6px);
  box-shadow:0 24px 64px rgba(10,22,40,.16),inset 0 1px 0 rgba(255,255,255,.9);
}
.doc-img-wrap { position:relative; height:260px; overflow:hidden; }
.doc-img-wrap img { transition:transform .5s ease; }
.doctor-card:hover .doc-img-wrap img { transform:scale(1.06); }
.doc-avail {
  position:absolute;
  top:.85rem; right:.85rem;
  font-size:.68rem;
  font-weight:800;
  padding:.3rem .8rem;
  border-radius:50px;
  backdrop-filter:blur(10px);
  border:1px solid;
}
.doc-avail.available {
  background:rgba(220,252,231,.85);
  color:#15803d;
  border-color:rgba(21,128,61,.2);
}
.doc-avail.tomorrow {
  background:rgba(254,249,195,.85);
  color:#854d0e;
  border-color:rgba(133,77,14,.2);
}
.doc-info { padding:1.3rem; }
.doc-info h4 { font-size:1rem; font-weight:700; color:var(--navy); margin-bottom:.3rem; }
.doc-spec { display:block; font-size:.8rem; color:var(--teal); font-weight:700; margin-bottom:.45rem; }
.doc-exp { display:flex; align-items:center; gap:.4rem; font-size:.76rem; color:var(--text-muted); margin-bottom:1rem; }
.doc-exp i { color:#f59e0b; }

/* ═══ LABORATORY ═══════════════════════════════════ */
.laboratory { padding:7rem 0; background:var(--bg); }
.lab-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:5rem;
  align-items:center;
}
.lab-content .section-title { margin-bottom:1.2rem; }
.lab-content p { color:var(--text-muted); margin-bottom:1.5rem; }
.lab-features { display:flex; flex-direction:column; gap:.65rem; }
.lf { display:flex; align-items:center; gap:.7rem; font-size:.9rem; color:var(--text); }
.lf i { color:var(--teal); font-size:.95rem; }

.lab-visual { position:relative; }
.lab-img-wrap {
  height:420px;
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--shadow-lg);
}
.lab-ui-card {
  position:absolute;
  bottom:-1rem; left:-2rem;
  background:rgba(255,255,255,.88);
  backdrop-filter:blur(24px) saturate(180%);
  -webkit-backdrop-filter:blur(24px) saturate(180%);
  border:1px solid rgba(255,255,255,.7);
  border-radius:var(--radius-lg);
  padding:1.3rem;
  box-shadow:0 16px 50px rgba(10,22,40,.15),inset 0 1px 0 rgba(255,255,255,.9);
  width:220px;
}
.lui-header {
  font-size:.8rem; font-weight:800;
  color:var(--navy);
  display:flex; align-items:center; gap:.5rem;
  margin-bottom:.9rem;
  padding-bottom:.75rem;
  border-bottom:1px solid var(--border);
}
.lui-header i { color:var(--teal); }
.lui-item {
  display:flex; align-items:center; gap:.6rem;
  font-size:.77rem; color:var(--text);
  margin-bottom:.5rem;
}
.lui-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.lui-dot.green { background:#22c55e; box-shadow:0 0 6px #22c55e; }
.lui-dot.yellow { background:#f59e0b; animation:blink .9s ease-in-out infinite; }
.lui-dot.blue { background:var(--blue); }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.25} }
.lui-footer {
  margin-top:.75rem; padding-top:.75rem;
  border-top:1px solid var(--border);
  font-size:.74rem; font-weight:800;
  color:var(--blue);
  display:flex; align-items:center; gap:.4rem;
  cursor:pointer;
}

/* ═══ FACILITIES ═══════════════════════════════════ */
.facilities { padding:7rem 0; background:var(--bg-section); }
.fac-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:1.2rem;
}
.fac-card {
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  padding:1.8rem;
  text-align:center;
  box-shadow:var(--glass-shadow);
  transition:var(--transition);
  position:relative;
  overflow:hidden;
}
.fac-card::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(135deg,var(--blue),var(--teal));
  opacity:0;
  transition:opacity .3s;
  border-radius:inherit;
}
.fac-card:hover::before { opacity:1; }
.fac-card:hover { transform:translateY(-6px); box-shadow:0 20px 60px rgba(26,86,219,.25); border-color:transparent; }
.fac-icon {
  width:60px; height:60px;
  background:var(--sky);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem;
  color:var(--blue);
  margin:0 auto 1.2rem;
  transition:var(--transition);
  position:relative; z-index:1;
}
.fac-card:hover .fac-icon { background:rgba(255,255,255,.2); color:#fff; }
.fac-card h4 { font-size:.93rem; font-weight:700; color:var(--navy); margin-bottom:.5rem; transition:var(--transition); position:relative; z-index:1; }
.fac-card p { font-size:.8rem; color:var(--text-muted); line-height:1.65; transition:var(--transition); position:relative; z-index:1; }
.fac-card:hover h4,.fac-card:hover p { color:rgba(255,255,255,.92); }

/* ═══ IMPACT ════════════════════════════════════════ */
.impact { padding:7rem 0; position:relative; overflow:hidden; }
.impact-bg {
  position:absolute; inset:0;
  background:linear-gradient(135deg,var(--teal) 0%,#0a6661 50%,var(--navy-mid) 100%);
}
.impact-bg::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 60% at 0% 50%,rgba(255,255,255,.08) 0%,transparent 60%),
    radial-gradient(ellipse 40% 40% at 100% 50%,rgba(255,255,255,.06) 0%,transparent 60%);
}
.impact .container { position:relative; z-index:2; }
.impact-header { text-align:center; margin-bottom:3.5rem; }
.impact-grid {
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:1rem;
}
.impact-card {
  background:rgba(255,255,255,.1);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,.15);
  border-radius:var(--radius-xl);
  padding:1.75rem 1rem;
  text-align:center;
  transition:var(--transition);
}
.impact-card:hover {
  background:rgba(255,255,255,.18);
  transform:translateY(-5px);
  box-shadow:0 16px 40px rgba(0,0,0,.2);
  border-color:rgba(255,255,255,.25);
}
.impact-card i { font-size:1.8rem; color:rgba(255,255,255,.75); margin-bottom:.75rem; display:block; }
.impact-num { display:flex; align-items:baseline; justify-content:center; gap:.1rem; }
.counter { font-family:'Playfair Display',serif; font-size:2rem; font-weight:700; color:#fff; }
.impact-num span:last-child { font-size:1.4rem; color:rgba(255,255,255,.7); font-weight:700; }
.impact-card p { font-size:.76rem; color:rgba(255,255,255,.65); margin-top:.45rem; font-weight:600; line-height:1.4; }

/* ═══ TESTIMONIALS ════════════════════════════════ */
.testimonials { padding:7rem 0; background:var(--bg); }
.testi-slider { position:relative; max-width:760px; margin:0 auto; }
.testi-track { overflow:hidden; }
.testi-card {
  display:none;
  background:var(--glass-bg);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  padding:2.5rem;
  box-shadow:var(--glass-shadow);
  animation:fadeInCard .4s ease;
}
.testi-card.active { display:block; }
@keyframes fadeInCard { from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:translateY(0)} }
.testi-stars { color:#f59e0b; margin-bottom:1.25rem; font-size:1rem; }
.testi-card p { color:var(--text-muted); font-size:1rem; line-height:1.85; font-style:italic; margin-bottom:1.5rem; }
.testi-author { display:flex; align-items:center; gap:1rem; }
.ta-avatar {
  width:46px; height:46px;
  border-radius:50%;
  background:var(--blue);
  color:#fff;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:1.1rem;
  flex-shrink:0;
  box-shadow:0 4px 14px rgba(26,86,219,.3);
}
.testi-author strong { display:block; font-size:.95rem; color:var(--navy); }
.testi-author span { font-size:.8rem; color:var(--text-muted); }
.testi-dots { display:flex; justify-content:center; gap:.5rem; margin-top:1.5rem; }
.tdot { width:8px; height:8px; border-radius:50%; background:var(--border); cursor:pointer; transition:var(--transition); }
.tdot.active { background:var(--teal); width:24px; border-radius:4px; }
.testi-controls { display:flex; justify-content:center; gap:.75rem; margin-top:1rem; }
.tc-btn {
  width:44px; height:44px;
  border-radius:50%;
  border:1px solid var(--glass-border);
  background:var(--glass-bg);
  backdrop-filter:blur(12px);
  cursor:pointer;
  color:var(--text-muted);
  font-size:.9rem;
  transition:var(--transition);
  box-shadow:var(--shadow-sm);
}
.tc-btn:hover { background:var(--teal); border-color:var(--teal); color:#fff; }

/* ═══ APPOINTMENT ══════════════════════════════════ */
.appointment {
  padding:7rem 0;
  background:linear-gradient(135deg,var(--navy),#1a2f54);
  position:relative;
  overflow:hidden;
}
.appointment::before {
  content:'';
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 50% 70% at 0% 50%,rgba(13,148,136,.15) 0%,transparent 60%),
    radial-gradient(ellipse 40% 50% at 100% 50%,rgba(26,86,219,.12) 0%,transparent 60%);
}
.appt-grid {
  display:grid;
  grid-template-columns:1fr 1.4fr;
  gap:4rem;
  align-items:center;
  position:relative;
  z-index:1;
}
.appt-contact { display:flex; flex-direction:column; gap:1rem; }
.ac-item {
  display:flex; align-items:flex-start; gap:1rem;
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radius-lg);
  padding:1rem 1.25rem;
  transition:var(--transition);
}
.ac-item:hover { background:rgba(255,255,255,.11); }
.ac-item i { font-size:1.1rem; color:var(--teal-light); margin-top:.15rem; flex-shrink:0; }
.ac-item strong { display:block; color:#fff; font-size:.9rem; }
.ac-item span { font-size:.83rem; color:rgba(255,255,255,.55); }

.appt-form-wrap {
  background:rgba(255,255,255,.92);
  backdrop-filter:blur(24px) saturate(200%);
  -webkit-backdrop-filter:blur(24px) saturate(200%);
  border:1px solid rgba(255,255,255,.8);
  border-radius:var(--radius-xl);
  padding:2.5rem;
  box-shadow:0 24px 80px rgba(0,0,0,.25),inset 0 1px 0 rgba(255,255,255,1);
}
.appt-form h3 {
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
  color:var(--navy);
  margin-bottom:1.5rem;
  padding-bottom:1rem;
  border-bottom:1px solid var(--border);
}
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; }
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-size:.8rem; font-weight:700; color:var(--text-muted); margin-bottom:.45rem; }
.form-group input,
.form-group select,
.form-group textarea {
  width:100%;
  padding:.75rem 1rem;
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  font-family:'DM Sans',sans-serif;
  font-size:.9rem;
  color:var(--text);
  background:rgba(248,251,255,.8);
  transition:var(--transition);
  outline:none;
  resize:none;
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color:var(--teal);
  box-shadow:0 0 0 4px rgba(13,148,136,.1);
  background:#fff;
}
.form-note { font-size:.76rem; color:var(--text-muted); text-align:center; margin-top:.75rem; }

/* ═══ GALLERY ══════════════════════════════════════ */
.gallery { padding:7rem 0; background:var(--bg-section); }
.gallery-grid {
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-template-rows:auto auto;
  gap:1rem;
}
.gallery-item { position:relative; border-radius:var(--radius-lg); overflow:hidden; height:200px; cursor:pointer; }
.gallery-item.gi-tall { grid-row:span 2; height:auto; min-height:410px; }
.gallery-item.gi-wide { grid-column:span 2; }
.gallery-item img { transition:transform .5s ease; }
.gallery-item:hover img { transform:scale(1.08); }
.gi-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(6,14,31,.75) 0%,transparent 55%);
  display:flex; align-items:flex-end; padding:1.1rem;
  opacity:0; transition:var(--transition);
}
.gallery-item:hover .gi-overlay { opacity:1; }
.gi-overlay span { color:#fff; font-weight:700; font-size:.85rem; }

/* ═══ NEWS ═════════════════════════════════════════ */
.news { padding:7rem 0; background:var(--bg); }
.news-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.4rem; }
.news-card {
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-xl);
  overflow:hidden;
  box-shadow:var(--glass-shadow);
  transition:var(--transition);
}
.news-card:hover { box-shadow:0 20px 60px rgba(10,22,40,.14); transform:translateY(-5px); }
.news-img { height:200px; overflow:hidden; }
.news-img img { transition:transform .5s ease; }
.news-card:hover .news-img img { transform:scale(1.05); }
.news-content { padding:1.5rem; }
.news-tag {
  font-size:.68rem; font-weight:800;
  text-transform:uppercase; letter-spacing:.08em;
  background:var(--sky); color:var(--blue);
  padding:.25rem .75rem; border-radius:50px;
  display:inline-block; margin-bottom:.75rem;
}
.news-tag.csr { background:rgba(5,150,105,.1); color:var(--green); }
.news-tag.initiative { background:rgba(13,148,136,.1); color:var(--teal); }
.news-content h4 { font-size:.97rem; font-weight:700; color:var(--navy); margin-bottom:.6rem; line-height:1.5; }
.news-content p { font-size:.82rem; color:var(--text-muted); line-height:1.75; margin-bottom:1rem; }
.news-meta { display:flex; justify-content:space-between; align-items:center; }
.news-meta span { font-size:.75rem; color:var(--text-muted); display:flex; align-items:center; gap:.3rem; }
.news-meta a { font-size:.8rem; font-weight:700; color:var(--teal); }

/* ═══ CONTACT ══════════════════════════════════════ */
.contact { padding:7rem 0; background:var(--bg-section); }
.contact-grid { display:grid; grid-template-columns:1fr 1.4fr; gap:3rem; align-items:start; }
.ci-card {
  display:flex; align-items:flex-start; gap:1rem;
  padding:1.25rem;
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--glass-shadow);
  margin-bottom:1rem;
  transition:var(--transition);
}
.ci-card:hover { transform:translateX(4px); box-shadow:0 12px 40px rgba(10,22,40,.1); }
.ci-card i { font-size:1.2rem; color:var(--teal); margin-top:.2rem; flex-shrink:0; }
.ci-card strong { display:block; font-size:.9rem; color:var(--navy); margin-bottom:.3rem; }
.ci-card p { font-size:.84rem; color:var(--text-muted); line-height:1.7; }
.ci-social { display:flex; gap:.75rem; margin-top:1.25rem; }
.ci-social a {
  width:42px; height:42px;
  border-radius:50%;
  background:var(--glass-bg);
  backdrop-filter:blur(12px);
  border:1px solid var(--glass-border);
  color:var(--blue);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem;
  box-shadow:var(--shadow-sm);
  transition:var(--transition);
}
.ci-social a:hover { background:var(--blue); color:#fff; border-color:var(--blue); transform:translateY(-2px); }
.contact-map { height:420px; border-radius:var(--radius-xl); overflow:hidden; box-shadow:var(--shadow-lg); }

/* ═══ FOOTER ════════════════════════════════════════ */
.footer { background:var(--navy); }
.footer-top { padding:5rem 0 3rem; }
.footer-grid { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; gap:3rem; }
.footer-brand p { color:rgba(255,255,255,.45); font-size:.87rem; line-height:1.85; margin-top:1.25rem; }
.footer-csr-badge {
  display:inline-flex; align-items:center; gap:.5rem;
  background:rgba(13,148,136,.15);
  border:1px solid rgba(13,148,136,.25);
  color:var(--teal-light);
  font-size:.76rem; font-weight:800;
  padding:.5rem 1rem; border-radius:50px;
  margin-top:1rem; letter-spacing:.03em;
}
.footer-csr-badge i { color:#f87171; }
.footer-col h5 { color:#fff; font-size:.88rem; font-weight:800; margin-bottom:1.25rem; letter-spacing:.03em; }
.footer-col ul { display:flex; flex-direction:column; gap:.6rem; }
.footer-col a { color:rgba(255,255,255,.4); font-size:.84rem; transition:var(--transition); }
.footer-col a:hover { color:var(--teal-light); padding-left:5px; }
.fe-num {
  display:inline-flex; align-items:center; gap:.5rem;
  background:linear-gradient(135deg,#dc2626,#b91c1c);
  color:#fff;
  padding:.75rem 1.25rem; border-radius:50px;
  font-size:1rem; font-weight:800;
  box-shadow:0 4px 20px rgba(220,38,38,.35);
}
.footer-emergency p { color:rgba(255,255,255,.4); font-size:.78rem; margin-top:.5rem; }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:1.5rem 0; }
.footer-bottom .container { display:flex; justify-content:space-between; align-items:center; }
.footer-bottom p { color:rgba(255,255,255,.35); font-size:.8rem; }
.footer-bottom a { color:rgba(255,255,255,.35); transition:var(--transition); }
.footer-bottom a:hover { color:var(--teal-light); }

/* ═══ TOAST ════════════════════════════════════════ */
.toast {
  position:fixed;
  bottom:2rem; left:50%;
  transform:translateX(-50%) translateY(100px);
  background:linear-gradient(135deg,var(--green),#047857);
  color:#fff;
  padding:1rem 2rem;
  border-radius:50px;
  font-weight:700; font-size:.9rem;
  display:flex; align-items:center; gap:.5rem;
  box-shadow:0 8px 32px rgba(5,150,105,.4);
  z-index:9999;
  transition:transform .4s cubic-bezier(.4,0,.2,1);
  backdrop-filter:blur(10px);
}
.toast.show { transform:translateX(-50%) translateY(0); }

/* ═══ SCROLLBAR ════════════════════════════════════ */
::-webkit-scrollbar { width:6px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--teal); border-radius:6px; }
::-webkit-scrollbar-thumb:hover { background:var(--blue); }

/* ═══ RESPONSIVE ═══════════════════════════════════ */
@media (max-width:1100px) {
  .dept-grid { grid-template-columns:repeat(3,1fr); }
  .impact-grid { grid-template-columns:repeat(3,1fr); }
  .footer-grid { grid-template-columns:1fr 1fr; gap:2rem; }
  .navbar { width:calc(100% - 2rem); }
}
@media (max-width:900px) {
  .hero-container { grid-template-columns:1fr; text-align:center; }
  .hero-visual { display:none; }
  .hero-stats { justify-content:center; flex-wrap:wrap; }
  .hero-actions { justify-content:center; }
  .about-grid,.lab-grid,.appt-grid,.contact-grid { grid-template-columns:1fr; }
  .aimg-thumb { display:none; }
  .about-features { grid-template-columns:1fr; }
  .csr-grid { grid-template-columns:1fr 1fr; }
  .doctors-grid { grid-template-columns:1fr 1fr; }
  .fac-grid { grid-template-columns:repeat(2,1fr); }
  .news-grid { grid-template-columns:1fr 1fr; }
  .gallery-grid { grid-template-columns:1fr 1fr; }
  .gallery-item.gi-wide { grid-column:span 2; }
  .gallery-item.gi-tall { grid-row:auto; height:200px; }
  .form-row { grid-template-columns:1fr; }
  .contact-map { height:300px; }
  .nav-toggle { display:flex; }
  .nav-links {
    position:fixed;
    top:0; right:-100%;
    height:100vh; width:290px;
    background:rgba(6,14,31,.95);
    backdrop-filter:blur(24px);
    flex-direction:column;
    align-items:flex-start;
    padding:5rem 2rem 2rem;
    gap:.25rem;
    transition:right .35s cubic-bezier(.4,0,.2,1);
    z-index:999;
    border-left:1px solid rgba(255,255,255,.1);
  }
  .nav-links.open { right:0; }
  .nav-links a { color:rgba(255,255,255,.8) !important; width:100%; padding:.8rem 1rem; border-radius:var(--radius-sm); }
  .nav-links a:hover { background:rgba(255,255,255,.08) !important; color:#fff !important; }
  .nav-links .nav-cta { background:linear-gradient(135deg,var(--blue),var(--teal)) !important; color:#fff !important; margin-top:.5rem; }
}
@media (max-width:600px) {
  .csr-grid { grid-template-columns:1fr; }
  .dept-grid { grid-template-columns:1fr 1fr; }
  .impact-grid { grid-template-columns:repeat(2,1fr); }
  .doctors-grid { grid-template-columns:1fr; }
  .fac-grid { grid-template-columns:1fr; }
  .news-grid { grid-template-columns:1fr; }
  .gallery-grid { grid-template-columns:1fr; }
  .gallery-item.gi-tall,.gallery-item.gi-wide { grid-row:auto; grid-column:auto; height:200px; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-bottom .container { flex-direction:column; gap:.5rem; text-align:center; }
  .hero-stats { gap:.5rem; padding:1rem; }
  .appt-form-wrap { padding:1.5rem; }
  .float-emergency span { display:none; }
  .float-emergency { padding:.75rem; border-radius:50%; width:52px; height:52px; justify-content:center; }
  .navbar { width:calc(100% - 1.5rem); top:.75rem; }
}

/* ══════════════════════════════════════════════════
   PACKAGES SECTION
══════════════════════════════════════════════════ */
.packages { padding:7rem 0; position:relative; overflow:hidden; }
.pkg-bg {
  position:absolute; inset:0;
  background:linear-gradient(135deg, #060e1f 0%, #0d1f3c 60%, #0a2840 100%);
}
.pkg-bg::before {
  content:''; position:absolute;
  width:700px; height:700px; border-radius:50%;
  background:radial-gradient(circle, rgba(13,148,136,.15) 0%, transparent 65%);
  top:-200px; right:-150px;
}
.pkg-bg::after {
  content:''; position:absolute;
  width:500px; height:500px; border-radius:50%;
  background:radial-gradient(circle, rgba(26,86,219,.12) 0%, transparent 65%);
  bottom:-100px; left:-80px;
}
.packages .container { position:relative; z-index:2; }

.pkg-grid {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:1.5rem;
  align-items:start;
}

.pkg-card {
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(22px) saturate(150%);
  -webkit-backdrop-filter:blur(22px) saturate(150%);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-xl);
  overflow:hidden;
  transition:var(--transition);
  position:relative;
}
.pkg-card:hover {
  transform:translateY(-6px);
  background:rgba(255,255,255,.11);
  box-shadow:0 24px 70px rgba(0,0,0,.35);
  border-color:rgba(255,255,255,.2);
}
.pkg-featured {
  background:rgba(255,255,255,.1);
  border-color:rgba(20,184,166,.35);
  box-shadow:0 0 0 1px rgba(20,184,166,.2), 0 20px 60px rgba(0,0,0,.3);
}
.pkg-featured:hover { box-shadow:0 0 0 1px rgba(20,184,166,.3), 0 28px 80px rgba(0,0,0,.4); }

.pkg-popular {
  position:absolute;
  top:1rem; right:1rem;
  background:linear-gradient(135deg,var(--teal),var(--blue));
  color:#fff;
  font-size:.68rem;
  font-weight:800;
  padding:.3rem .9rem;
  border-radius:50px;
  letter-spacing:.06em;
  text-transform:uppercase;
  z-index:3;
  box-shadow:0 4px 14px rgba(13,148,136,.4);
}

.pkg-header {
  padding:1.75rem 1.75rem 1.25rem;
  display:flex;
  align-items:flex-start;
  gap:1.1rem;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.pkg-header.heart  { background:linear-gradient(135deg,rgba(220,38,38,.2),rgba(185,28,28,.1)); }
.pkg-header.cardiac{ background:linear-gradient(135deg,rgba(13,148,136,.25),rgba(26,86,219,.2)); }
.pkg-header.senior { background:linear-gradient(135deg,rgba(124,58,237,.2),rgba(99,102,241,.1)); }

.pkg-icon {
  width:52px; height:52px;
  border-radius:var(--radius);
  display:flex; align-items:center; justify-content:center;
  font-size:1.4rem;
  flex-shrink:0;
  box-shadow:0 4px 16px rgba(0,0,0,.2);
}
.heart  .pkg-icon { background:linear-gradient(135deg,#dc2626,#b91c1c); color:#fff; }
.cardiac .pkg-icon { background:linear-gradient(135deg,var(--teal),var(--blue)); color:#fff; }
.senior  .pkg-icon { background:linear-gradient(135deg,#7c3aed,#6366f1); color:#fff; }

.pkg-header h3 {
  color:#fff;
  font-size:.95rem;
  font-weight:700;
  line-height:1.4;
  margin-bottom:.4rem;
}
.pkg-price {
  font-family:'Playfair Display',serif;
  font-size:1.4rem;
  font-weight:700;
  color:var(--teal-light);
}
.heart .pkg-price { color:#fca5a5; }
.senior .pkg-price { color:#c4b5fd; }

.pkg-body { padding:1.25rem 1.75rem; }
.pkg-section { margin-bottom:1.1rem; }
.pkg-section h5 {
  font-size:.73rem;
  font-weight:800;
  text-transform:uppercase;
  letter-spacing:.1em;
  color:rgba(255,255,255,.55);
  display:flex;
  align-items:center;
  gap:.4rem;
  margin-bottom:.45rem;
  padding-bottom:.35rem;
  border-bottom:1px solid rgba(255,255,255,.07);
}
.pkg-section h5 i { color:var(--teal-light); font-size:.75rem; }
.pkg-section ul { padding-left:0; display:flex; flex-direction:column; gap:.2rem; }
.pkg-section ul li {
  color:rgba(255,255,255,.7);
  font-size:.8rem;
  padding:.1rem 0 .1rem .9rem;
  position:relative;
  line-height:1.5;
}
.pkg-section ul li::before {
  content:'·';
  position:absolute;
  left:0;
  color:var(--teal-light);
  font-weight:900;
}
.pkg-section.consult ul li { color:rgba(255,255,255,.85); font-weight:600; }
.pkg-section.consult ul li::before { color:#fbbf24; }

.btn-pkg {
  display:flex;
  width:calc(100% - 3.5rem);
  justify-content:center;
  align-items:center;
  margin:0 1.75rem 1.75rem;
  padding:.85rem;
  border-radius:50px;
  font-weight:700;
  font-size:.9rem;
  cursor:pointer;
  border:none;
  transition:var(--transition);
}
.heart-btn  { background:linear-gradient(135deg,#dc2626,#b91c1c); color:#fff; box-shadow:0 4px 20px rgba(220,38,38,.3); }
.cardiac-btn{ background:linear-gradient(135deg,var(--teal),var(--blue)); color:#fff; box-shadow:0 4px 20px rgba(13,148,136,.35); }
.senior-btn { background:linear-gradient(135deg,#7c3aed,#6366f1); color:#fff; box-shadow:0 4px 20px rgba(124,58,237,.3); }
.btn-pkg:hover { transform:translateY(-2px); filter:brightness(1.1); }

/* Package notes */
.pkg-notes {
  background:rgba(255,255,255,.07);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius-xl);
  padding:1.75rem 2rem;
  margin-top:2.5rem;
}
.pkg-notes h4 {
  color:#fff;
  font-size:1rem;
  font-weight:700;
  margin-bottom:1.1rem;
  display:flex;
  align-items:center;
  gap:.6rem;
}
.pkg-notes h4 i { color:var(--teal-light); }
.pkg-notes ul { display:grid; grid-template-columns:1fr 1fr; gap:.65rem; }
.pkg-notes ul li {
  color:rgba(255,255,255,.65);
  font-size:.85rem;
  display:flex;
  align-items:flex-start;
  gap:.6rem;
  line-height:1.6;
}
.pkg-notes ul li i { color:var(--teal-light); font-size:.85rem; flex-shrink:0; margin-top:.2rem; }

/* About address card */
.about-address-card {
  display:flex;
  align-items:flex-start;
  gap:1rem;
  background:var(--glass-bg);
  backdrop-filter:blur(16px) saturate(160%);
  -webkit-backdrop-filter:blur(16px) saturate(160%);
  border:1px solid var(--glass-border);
  border-radius:var(--radius-lg);
  box-shadow:var(--glass-shadow);
  padding:1.1rem 1.25rem;
  margin-bottom:1.5rem;
}
.about-address-card i { color:var(--teal); font-size:1.2rem; flex-shrink:0; margin-top:.2rem; }
.about-address-card strong { display:block; font-size:.88rem; color:var(--navy); line-height:1.6; margin-bottom:.5rem; }
.addr-contacts { display:flex; gap:1rem; flex-wrap:wrap; }
.addr-contacts a { font-size:.8rem; font-weight:700; color:var(--blue); display:flex; align-items:center; gap:.35rem; }
.addr-contacts a:hover { color:var(--teal); }

@media (max-width:900px) {
  .pkg-grid { grid-template-columns:1fr; }
  .pkg-notes ul { grid-template-columns:1fr; }
}
@media (max-width:600px) {
  .pkg-notes ul { grid-template-columns:1fr; }
  .pkg-grid { grid-template-columns:1fr; }
}
