/* ===== IMEDIX - CHINA HEALTHCARE AGENCY ===== */
/* Color: Crimson Red #C8102E + White + Light Blue */

:root {
  --red: #C8102E;
  --red-dark: #9E0020;
  --red-light: #E8304A;
  --red-glow: rgba(200,16,46,0.08);

  --blue: #1B4FD8;
  --blue-dark: #1340B0;
  --blue-light: #4A7AFF;
  --blue-mid: #2563EB;
  --blue-glow: rgba(27,79,216,0.08);

  --dark: #0F1B35;
  --dark2: #132040;

  --bg: #F0F4FF;
  --bg2: #E8EEFF;
  --bg3: #FFFFFF;

  --card: #FFFFFF;
  --card2: #F6F8FF;

  --border: rgba(27,79,216,0.18);
  --border-light: rgba(27,79,216,0.1);
  --border-red: rgba(200,16,46,0.18);

  --text: #0F1B35;
  --text-muted: #4A5A7A;
  --text-dim: #8A9ABB;
  --white: #FFFFFF;

  --font-display: 'Cormorant Garamond', Georgia, serif;
  --font-body: 'DM Sans', system-ui, sans-serif;
  --font-mono: 'Space Grotesk', monospace;

  --shadow: 0 4px 24px rgba(27,79,216,0.10);
  --shadow-lg: 0 12px 48px rgba(27,79,216,0.14);
  --shadow-red: 0 8px 30px rgba(200,16,46,0.22);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; font-size: 16px; }
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  overflow-x: hidden;
}

/* ===== PRELOADER ===== */
#preloader {
  position: fixed; inset: 0;
  background: var(--white);
  display: flex; align-items: center; justify-content: center;
  z-index: 9999;
  transition: opacity 0.6s ease, visibility 0.6s;
}
#preloader.done { opacity: 0; visibility: hidden; pointer-events: none; }
.pre-inner { text-align: center; }
.pre-logo { width: 200px; margin-bottom: 24px; animation: preLogoPulse 1.5s ease infinite; }
@keyframes preLogoPulse { 0%,100%{opacity:1} 50%{opacity:0.6} }
.pre-bar { width: 220px; height: 3px; background: var(--bg2); border-radius: 2px; margin: 0 auto 16px; overflow: hidden; }
.pre-fill { height: 100%; background: linear-gradient(90deg, var(--red), var(--blue)); border-radius: 2px; animation: preLoad 2.2s ease forwards; }
@keyframes preLoad { 0%{width:0} 100%{width:100%} }
.pre-inner p { color: var(--text-muted); font-family: var(--font-mono); font-size: 0.85rem; letter-spacing: 0.1em; }

/* ===== NAVBAR ===== */
#navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--border-light);
  transition: all 0.3s ease;
  box-shadow: 0 2px 16px rgba(27,79,216,0.07);
}
#navbar.scrolled { background: rgba(255,255,255,0.98); box-shadow: var(--shadow); }
.nav-container {
  max-width: 1400px; margin: 0 auto;
  display: flex; align-items: center; justify-content: space-between;
  padding: 0 2rem; height: 70px;
}
.nav-logo img { height: 44px; width: auto; }
.nav-links { display: flex; gap: 0.1rem; }
.nav-links a {
  color: var(--text-muted);
  text-decoration: none;
  font-size: 0.88rem;
  font-family: var(--font-mono);
  padding: 0.5rem 0.85rem;
  border-radius: 6px;
  transition: all 0.2s;
  letter-spacing: 0.02em;
}
.nav-links a:hover { color: var(--blue); background: var(--blue-glow); }
.nav-links a.active { color: var(--blue); font-weight: 600; }
.btn-whatsapp {
  display: flex; align-items: center; gap: 0.5rem;
  background: #25D366; color: white;
  text-decoration: none; padding: 0.5rem 1.2rem;
  border-radius: 50px; font-size: 0.88rem; font-weight: 600;
  transition: all 0.2s; white-space: nowrap;
}
.btn-whatsapp:hover { background: #1ebe5a; transform: translateY(-1px); box-shadow: 0 4px 20px rgba(37,211,102,0.35); }
.hamburger { display: none; flex-direction: column; gap: 5px; background: none; border: none; cursor: pointer; padding: 4px; }
.hamburger span { display: block; width: 24px; height: 2px; background: var(--text); border-radius: 2px; transition: all 0.3s; }

/* ===== HERO ===== */
.hero {
  min-height: 100vh;
  background: linear-gradient(135deg, #0F1B35 0%, #1B2E58 40%, #1B4FD8 100%);
  display: flex; align-items: center;
  position: relative; overflow: hidden;
  padding-top: 70px;
}
.hero-bg-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.04) 1px, transparent 1px);
  background-size: 60px 60px;
}
.hero::before {
  content:''; position: absolute; top: -100px; right: -80px;
  width: 650px; height: 650px;
  background: radial-gradient(circle, rgba(200,16,46,0.18) 0%, transparent 70%);
  border-radius: 50%;
}
.hero::after {
  content:''; position: absolute; bottom: -200px; left: -80px;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%);
  border-radius: 50%;
}
.hero-particles { position: absolute; inset: 0; pointer-events: none; }
.particle {
  position: absolute; width: 2px; height: 2px;
  background: rgba(255,255,255,0.6); border-radius: 50%;
  animation: particleFloat linear infinite; opacity: 0;
}
@keyframes particleFloat {
  0%{transform:translateY(100vh) scale(0);opacity:0}
  10%{opacity:0.5} 90%{opacity:0.3}
  100%{transform:translateY(-10vh) scale(1);opacity:0}
}
.hero-container {
  max-width: 1400px; margin: 0 auto;
  padding: 4rem 2rem; position: relative; z-index: 2;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 0.6rem;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50px; padding: 0.4rem 1.2rem;
  font-family: var(--font-mono); font-size: 0.82rem;
  color: rgba(255,255,255,0.85); margin-bottom: 2rem;
  letter-spacing: 0.05em;
  animation: fadeSlideUp 0.8s ease 0.2s both;
}
.pulse-dot {
  width: 8px; height: 8px; background: #7FFF7F;
  border-radius: 50%; animation: pulseDot 2s ease infinite;
}
@keyframes pulseDot {
  0%,100%{box-shadow:0 0 0 0 rgba(127,255,127,0.5)}
  50%{box-shadow:0 0 0 6px rgba(127,255,127,0)}
}
.hero-title {
  font-family: var(--font-display); font-size: clamp(3rem, 6vw, 6.5rem);
  font-weight: 300; line-height: 1.05; margin-bottom: 1.5rem;
  color: white; animation: fadeSlideUp 0.8s ease 0.4s both; max-width: 900px;
}
.hero-title em { color: #FFB3BE; font-style: italic; }
.stroke-text { -webkit-text-stroke: 1px rgba(255,255,255,0.5); color: transparent; }
.hero-sub {
  font-size: 1.1rem; color: rgba(255,255,255,0.75);
  max-width: 680px; margin-bottom: 2.5rem;
  animation: fadeSlideUp 0.8s ease 0.6s both; line-height: 1.7;
}
.hero-actions {
  display: flex; gap: 1rem; flex-wrap: wrap; margin-bottom: 4rem;
  animation: fadeSlideUp 0.8s ease 0.8s both;
}
.btn-primary {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: var(--red); color: white; text-decoration: none;
  padding: 0.9rem 2rem; border-radius: 8px; font-weight: 600;
  font-size: 0.95rem; transition: all 0.3s; border: none; cursor: pointer;
  font-family: var(--font-body);
}
.btn-primary:hover { background: var(--red-dark); transform: translateY(-2px); box-shadow: var(--shadow-red); }
.btn-ghost {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: rgba(255,255,255,0.12); color: white; text-decoration: none;
  padding: 0.9rem 2rem; border-radius: 8px; font-weight: 500;
  font-size: 0.95rem; border: 1px solid rgba(255,255,255,0.25); transition: all 0.3s;
}
.btn-ghost:hover { background: rgba(255,255,255,0.22); }
.hero-stats {
  display: inline-flex; flex-wrap: wrap;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 16px; overflow: hidden;
  background: rgba(255,255,255,0.08);
  backdrop-filter: blur(10px);
  animation: fadeSlideUp 0.8s ease 1s both;
}
.stat { padding: 1.5rem 2rem; text-align: center; }
.stat-num { font-family: var(--font-display); font-size: 2.5rem; font-weight: 600; color: #FFB3BE; display: inline; }
.stat > span:last-of-type { font-size: 1.5rem; color: #FFB3BE; }
.stat p { font-size: 0.78rem; color: rgba(255,255,255,0.65); margin-top: 0.2rem; font-family: var(--font-mono); letter-spacing: 0.05em; }
.stat-div { width: 1px; background: rgba(255,255,255,0.15); margin: 1rem 0; }
.hero-scroll {
  position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%);
  display: flex; flex-direction: column; align-items: center; gap: 0.5rem;
  color: rgba(255,255,255,0.4); font-size: 0.75rem;
  letter-spacing: 0.1em; font-family: var(--font-mono);
  animation: fadeIn 1s ease 1.5s both;
}
.scroll-line { width: 1px; height: 40px; background: linear-gradient(to bottom, rgba(255,255,255,0.6), transparent); animation: scrollPulse 2s ease infinite; }
@keyframes scrollPulse { 0%,100%{opacity:0.3} 50%{opacity:1} }

/* ===== SHARED ===== */
@keyframes fadeSlideUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes fadeIn { from{opacity:0} to{opacity:1} }
.container { max-width: 1300px; margin: 0 auto; padding: 0 2rem; }
.section-tag {
  display: inline-block; font-family: var(--font-mono); font-size: 0.78rem;
  letter-spacing: 0.15em; text-transform: uppercase; color: var(--blue);
  border: 1px solid var(--border); padding: 0.35rem 1rem;
  border-radius: 50px; margin-bottom: 1.5rem; background: var(--blue-glow);
}
.section-title {
  font-family: var(--font-display); font-size: clamp(2.2rem, 4vw, 3.8rem);
  font-weight: 300; line-height: 1.15; margin-bottom: 1.5rem; color: var(--dark);
}
.section-title em { color: var(--red); font-style: italic; }
.section-sub { color: var(--text-muted); font-size: 1.05rem; max-width: 600px; margin-bottom: 3rem; line-height: 1.7; }

/* ===== WHY SECTION ===== */
.why-section { padding: 7rem 0; background: var(--white); }
.why-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.why-card {
  background: var(--bg); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 2rem; transition: all 0.3s; position: relative; overflow: hidden;
}
.why-card::before {
  content:''; position: absolute; top:0; left:0; right:0; height:3px;
  background: linear-gradient(90deg, var(--red), var(--blue));
  opacity:0; transition: opacity 0.3s;
}
.why-card:hover { border-color: var(--border); transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.why-card:hover::before { opacity:1; }
.why-icon {
  width: 50px; height: 50px; background: var(--blue-glow);
  border: 1px solid var(--border); border-radius: 12px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; color: var(--blue); margin-bottom: 1.2rem;
}
.why-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.75rem; font-family: var(--font-mono); color: var(--dark); }
.why-card p { color: var(--text-muted); font-size: 0.9rem; line-height: 1.6; }

/* ===== SERVICES ===== */
.services-section { padding: 7rem 0; background: var(--bg); position: relative; }
.services-bg {
  position: absolute; inset:0;
  background: radial-gradient(ellipse at top right, rgba(27,79,216,0.04) 0%, transparent 60%);
  pointer-events: none;
}
.services-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.service-card {
  background: var(--white); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 2rem; position: relative; overflow: hidden; transition: all 0.3s;
}
.service-card:hover { border-color: var(--border); transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.sc-number {
  position: absolute; top:1.5rem; right:1.5rem;
  font-family: var(--font-display); font-size: 4rem;
  font-weight: 300; color: rgba(27,79,216,0.07); line-height:1;
}
.sc-icon { font-size: 1.5rem; color: var(--blue); margin-bottom: 1rem; }
.service-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 0.75rem; line-height:1.4; color: var(--dark); }
.service-card p { color: var(--text-muted); font-size: 0.88rem; line-height:1.6; margin-bottom:1.2rem; }
.sc-tags { display: flex; gap: 0.5rem; flex-wrap: wrap; }
.sc-tags span {
  font-size: 0.72rem; font-family: var(--font-mono);
  padding: 0.25rem 0.7rem; background: var(--blue-glow);
  border: 1px solid var(--border); border-radius: 50px; color: var(--blue);
}

/* ===== TREATMENTS ===== */
.treatments-section { padding: 7rem 0; background: var(--white); }
.treatments-tabs {
  display: flex; gap: 0.5rem; flex-wrap: wrap; margin-bottom: 2.5rem;
  border-bottom: 2px solid var(--border-light); padding-bottom: 0;
}
.tab-btn {
  background: none; border: none; cursor: pointer;
  font-family: var(--font-mono); font-size: 0.85rem;
  color: var(--text-muted); padding: 0.7rem 1.2rem;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
  transition: all 0.2s; white-space: nowrap;
}
.tab-btn:hover { color: var(--blue); }
.tab-btn.active { color: var(--blue); border-bottom-color: var(--blue); font-weight: 600; }
.tab-content { display: none; }
.tab-content.active { display: block; animation: fadeIn 0.3s ease; }
.treat-grid { display: grid; grid-template-columns:1fr 1fr; gap: 3rem; align-items: center; }
.treat-info h3 { font-family: var(--font-display); font-size: 2rem; font-weight: 400; margin-bottom: 1rem; color: var(--dark); }
.treat-info p { color: var(--text-muted); line-height: 1.7; margin-bottom: 1.5rem; }
.treat-list { list-style: none; margin-bottom: 2rem; }
.treat-list li {
  display: flex; align-items: flex-start; gap: 0.75rem;
  padding: 0.5rem 0; font-size: 0.92rem;
  border-bottom: 1px solid var(--border-light); color: var(--text);
}
.treat-list li i { color: var(--blue); margin-top: 0.15rem; flex-shrink: 0; }
.treat-cost {
  display: flex; align-items: center; gap: 1rem; flex-wrap: wrap;
  background: linear-gradient(135deg, var(--bg) 0%, #EEF2FF 100%);
  border: 1px solid var(--border); border-radius: 12px; padding: 1.2rem 1.5rem;
}
.cost-badge {
  font-family: var(--font-mono); font-size: 0.72rem;
  color: var(--text-muted); letter-spacing: 0.08em;
  background: var(--white); padding: 0.3rem 0.7rem; border-radius: 4px;
  border: 1px solid var(--border-light);
}
.cost-range { font-family: var(--font-display); font-size: 1.5rem; color: var(--red); font-weight: 500; }
.cost-note { font-size: 0.82rem; color: var(--text-dim); }
.treat-img { border-radius: 20px; overflow: hidden; box-shadow: var(--shadow-lg); }
.treat-img-inner { height: 420px; position: relative; border-radius: 20px; }
.kidney-bg  { background: linear-gradient(135deg, #0a1a3a 0%, #1B4FD8 60%, #C8102E 100%); }
.cancer-bg  { background: linear-gradient(135deg, #0d1528 0%, #1a2a5e 60%, #6B21A8 100%); }
.ortho-bg   { background: linear-gradient(135deg, #0a2010 0%, #1B4FD8 50%, #16a34a 100%); }
.cardio-bg  { background: linear-gradient(135deg, #1f050a 0%, #C8102E 50%, #1B4FD8 100%); }
.neuro-bg   { background: linear-gradient(135deg, #05101f 0%, #0d2060 60%, #1B4FD8 100%); }
.other-bg   { background: linear-gradient(135deg, #101828 0%, #1B4FD8 60%, #059669 100%); }
.treat-img-inner::before {
  content:''; position: absolute; inset:0;
  background: linear-gradient(to top, rgba(10,20,50,0.85) 0%, rgba(10,20,50,0.1) 60%, transparent 100%);
}
.treat-overlay {
  position: absolute; bottom:0; left:0; right:0; padding: 2rem 1.5rem 1.5rem;
}
.treat-overlay p { font-family: var(--font-display); font-style: italic; font-size: 1.05rem; line-height:1.5; margin-bottom: 0.5rem; color: white; }
.treat-overlay span { font-size: 0.8rem; color: #FFB3BE; font-family: var(--font-mono); }

/* ===== COST TABLE ===== */
.cost-section { padding: 7rem 0; background: var(--bg); }
.cost-table-wrap { overflow-x: auto; border-radius: 16px; border: 1px solid var(--border-light); box-shadow: var(--shadow); }
.cost-table { width: 100%; border-collapse: collapse; background: var(--white); }
.cost-table th {
  padding: 1.2rem 1.5rem; text-align: left;
  font-family: var(--font-mono); font-size: 0.8rem;
  letter-spacing: 0.08em; color: var(--text-muted);
  background: var(--bg2); border-bottom: 2px solid var(--border-light); white-space: nowrap;
}
.cost-table th.hl-col { color: var(--blue); background: #EEF4FF; }
.cost-table td {
  padding: 1.2rem 1.5rem; border-bottom: 1px solid var(--border-light);
  vertical-align: top; font-size: 0.9rem; color: var(--text);
}
.cost-table td strong { display: block; font-weight: 600; margin-bottom: 0.2rem; }
.cost-table td small { color: var(--text-muted); font-size: 0.78rem; }
.cost-table td.hl-col { background: #F0F5FF; }
.china-price { color: var(--red); font-weight: 700; font-family: var(--font-mono); font-size: 0.9rem; }
.cost-table tr:last-child td { border-bottom: none; }
.cost-table tr:hover td { background: var(--bg); }
.cost-table tr:hover td.hl-col { background: #EBF2FF; }
.cost-note-text { margin-top: 1.5rem; color: var(--text-muted); font-size: 0.88rem; }
.cost-note-text a { color: var(--blue); text-decoration: none; }

/* ===== HOSPITALS ===== */
.hospitals-section { padding: 7rem 0; background: var(--white); }
.hosp-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.hosp-card {
  background: var(--bg); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 2rem; transition: all 0.3s;
}
.hosp-card.featured {
  border-color: var(--blue); border-width: 2px;
  background: linear-gradient(135deg, var(--white) 0%, #EEF4FF 100%);
}
.hosp-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); border-color: var(--border); }
.hosp-badge { font-family: var(--font-mono); font-size: 0.72rem; color: var(--blue); letter-spacing: 0.08em; margin-bottom: 0.8rem; }
.hosp-card h3 { font-size: 1.05rem; font-weight: 700; margin-bottom: 0.3rem; color: var(--dark); }
.hosp-subtitle { color: var(--text-dim); font-size: 0.78rem; margin-bottom: 0.8rem; font-style: italic; }
.hosp-card p { color: var(--text-muted); font-size: 0.87rem; line-height:1.6; margin-bottom:1.2rem; }
.hosp-tags { display: flex; gap: 0.4rem; flex-wrap: wrap; margin-bottom: 1.5rem; }
.hosp-tags span {
  font-size: 0.7rem; font-family: var(--font-mono);
  padding: 0.2rem 0.6rem; background: var(--white);
  border: 1px solid var(--border-light); border-radius: 4px; color: var(--text-muted);
}
.hosp-stats { display: flex; border: 1px solid var(--border-light); border-radius: 8px; overflow: hidden; }
.hosp-stats > div { flex:1; text-align: center; padding: 0.8rem 0.5rem; border-right: 1px solid var(--border-light); background: var(--white); }
.hosp-stats > div:last-child { border-right: none; }
.hosp-stats strong { display: block; font-size: 0.9rem; color: var(--blue); font-family: var(--font-mono); }
.hosp-stats p { font-size: 0.7rem; color: var(--text-dim); margin-top: 0.2rem; }
.hosp-cta { text-align: center; margin-top: 3rem; }
.hosp-cta p { color: var(--text-muted); margin-bottom: 1rem; }

/* ===== PROCESS ===== */
.process-section { padding: 7rem 0; background: var(--bg); position: relative; }
.process-bg {
  position: absolute; inset:0;
  background: radial-gradient(ellipse at bottom left, rgba(27,79,216,0.04) 0%, transparent 60%);
}
.timeline { position: relative; }
.timeline::before {
  content:''; position: absolute; left: 22px; top:0; bottom:0;
  width: 2px;
  background: linear-gradient(to bottom, var(--blue), rgba(27,79,216,0.08));
}
.tl-item { display: flex; gap: 2rem; margin-bottom: 2.5rem; position: relative; }
.tl-dot {
  flex-shrink: 0; width: 46px; height: 46px;
  background: linear-gradient(135deg, var(--blue), var(--blue-light));
  border-radius: 50%; display: flex; align-items: center; justify-content: center; z-index:1;
  box-shadow: 0 4px 16px rgba(27,79,216,0.3);
}
.tl-dot span { font-family: var(--font-mono); font-weight: 700; font-size: 0.85rem; color: white; }
.tl-content {
  background: var(--white); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 1.8rem; flex:1; transition: all 0.3s; box-shadow: var(--shadow);
}
.tl-content:hover { border-color: var(--border); transform: translateX(4px); box-shadow: var(--shadow-lg); }
.tl-phase { font-family: var(--font-mono); font-size: 0.75rem; color: var(--blue); letter-spacing: 0.1em; margin-bottom: 0.5rem; }
.tl-content h3 { font-size: 1.1rem; font-weight: 600; margin-bottom: 0.75rem; color: var(--dark); }
.tl-content p { color: var(--text-muted); font-size: 0.9rem; line-height:1.6; margin-bottom: 1rem; }
.tl-actions { display: flex; gap: 1rem; flex-wrap: wrap; }
.tl-actions span { font-size: 0.8rem; color: var(--text-muted); display: flex; align-items: center; gap: 0.4rem; }
.tl-actions i { color: var(--blue); }

/* ===== TESTIMONIALS ===== */
.testimonials-section { padding: 7rem 0; background: var(--white); }
.testi-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.testi-card {
  background: var(--bg); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 2rem; transition: all 0.3s;
}
.testi-card.featured {
  border-color: var(--blue); border-width: 2px;
  background: linear-gradient(135deg, var(--white) 0%, #EEF4FF 100%);
}
.testi-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.testi-stars { color: #F59E0B; font-size: 0.9rem; letter-spacing: 0.1em; margin-bottom: 1rem; }
.testi-text { font-family: var(--font-display); font-style: italic; font-size: 1rem; line-height:1.7; color: var(--text); margin-bottom: 1.5rem; }
.testi-author { display: flex; gap: 1rem; align-items: flex-start; }
.testi-avatar {
  width: 44px; height: 44px;
  background: linear-gradient(135deg, var(--blue), var(--blue-light));
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700; color: white; flex-shrink: 0;
}
.testi-author strong { display: block; font-size: 0.9rem; margin-bottom: 0.2rem; color: var(--dark); }
.testi-author p { font-size: 0.78rem; color: var(--text-muted); }
.testi-author span { font-size: 0.75rem; color: var(--blue); font-family: var(--font-mono); }

/* ===== COUNTRIES ===== */
.countries-section { padding: 5rem 0; background: var(--bg); }
.countries-grid { display: flex; flex-wrap: wrap; gap: 1rem; justify-content: center; }
.country-item {
  display: flex; align-items: center; gap: 0.7rem;
  background: var(--white); border: 1px solid var(--border-light);
  border-radius: 50px; padding: 0.7rem 1.5rem; transition: all 0.2s;
  box-shadow: var(--shadow);
}
.country-item:hover { border-color: var(--border); transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.flag { font-size: 1.5rem; }
.country-item strong { font-size: 0.88rem; font-family: var(--font-mono); color: var(--dark); }

/* ===== CONTACT ===== */
.contact-section { padding: 7rem 0; background: var(--white); }
.contact-grid { display: grid; grid-template-columns: 1fr 400px; gap: 3rem; align-items: start; }
.contact-form-wrap {
  background: var(--bg); border: 1px solid var(--border-light);
  border-radius: 20px; padding: 2.5rem; box-shadow: var(--shadow);
}
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.form-group { margin-bottom: 1.2rem; }
.form-group label {
  display: block; font-size: 0.82rem; color: var(--text-muted);
  font-family: var(--font-mono); letter-spacing: 0.05em; margin-bottom: 0.5rem;
}
.form-group input, .form-group select, .form-group textarea {
  width: 100%; background: var(--white);
  border: 1.5px solid var(--border-light); border-radius: 8px;
  padding: 0.8rem 1rem; color: var(--text);
  font-family: var(--font-body); font-size: 0.9rem; transition: all 0.2s; outline: none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--blue); box-shadow: 0 0 0 3px rgba(27,79,216,0.1);
}
.form-group select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%234A5A7A' d='M6 8L0 0h12z'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 1rem center;
}
.form-group textarea { resize: vertical; min-height: 100px; }
.file-upload-area {
  border: 2px dashed var(--border); border-radius: 12px;
  padding: 2rem; text-align: center; cursor: pointer; transition: all 0.2s;
  position: relative; background: var(--white);
}
.file-upload-area:hover, .file-upload-area.dragover { border-color: var(--blue); background: var(--blue-glow); }
.file-upload-area i { font-size: 2rem; color: var(--blue); margin-bottom: 0.75rem; display: block; }
.file-upload-area p { color: var(--text-muted); font-size: 0.9rem; }
.file-upload-area p span { color: var(--blue); cursor: pointer; font-weight: 600; }
.file-upload-area small { color: var(--text-dim); font-size: 0.78rem; }
.file-upload-area input[type="file"] { position: absolute; inset:0; opacity:0; cursor: pointer; width:100%; }
#fileList { margin-top: 0.75rem; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.file-tag {
  display: flex; align-items: center; gap: 0.4rem;
  background: var(--blue-glow); border: 1px solid var(--border);
  border-radius: 6px; padding: 0.3rem 0.7rem;
  font-size: 0.78rem; color: var(--blue);
}
.btn-full { width: 100%; justify-content: center; padding: 1rem 2rem; font-size: 1rem; }
.form-msg { margin-top: 1rem; padding: 1rem; border-radius: 8px; font-size: 0.9rem; display: none; }
.form-msg.success { background: rgba(37,211,102,0.08); border: 1px solid rgba(37,211,102,0.3); color: #16a34a; display: block; }
.form-msg.error { background: rgba(200,16,46,0.06); border: 1px solid var(--border-red); color: var(--red); display: block; }
.contact-info { display: flex; flex-direction: column; gap: 1.2rem; }
.ci-card {
  background: var(--bg); border: 1px solid var(--border-light);
  border-radius: 16px; padding: 1.8rem; box-shadow: var(--shadow);
}
.ci-card h3 { font-size: 1rem; font-weight: 600; margin-bottom: 1.2rem; color: var(--dark); }
.ci-item { display: flex; gap: 1rem; align-items: flex-start; margin-bottom: 1.2rem; }
.ci-item:last-child { margin-bottom: 0; }
.ci-item > i { font-size: 1.2rem; color: var(--blue); margin-top: 0.2rem; flex-shrink: 0; }
.ci-item strong { display: block; font-size: 0.85rem; margin-bottom: 0.3rem; color: var(--dark); }
.ci-item a { display: block; color: var(--blue); font-size: 0.9rem; text-decoration: none; }
.ci-item a:hover { text-decoration: underline; }
.ci-item p { color: var(--text-muted); font-size: 0.88rem; line-height:1.5; }
.response-card { background: linear-gradient(135deg, var(--bg) 0%, #EEF4FF 100%); border-color: var(--border); }
.rc-icon { font-size: 1.5rem; color: var(--blue); margin-bottom: 0.75rem; }
.rc-steps { list-style: decimal; padding-left: 1.2rem; color: var(--text-muted); font-size: 0.87rem; }
.rc-steps li { margin-bottom: 0.5rem; padding-left: 0.3rem; }
.wa-card { padding:0; overflow: hidden; border-radius: 16px; }
.wa-btn-large {
  display: flex; align-items: center; gap: 1rem;
  background: #25D366; color: white; text-decoration: none;
  padding: 1.5rem; transition: all 0.2s;
}
.wa-btn-large:hover { background: #1ebe5a; }
.wa-btn-large i { font-size: 2rem; flex-shrink: 0; }
.wa-btn-large strong { display: block; font-size: 0.95rem; margin-bottom: 0.2rem; }
.wa-btn-large span { font-size: 0.8rem; opacity: 0.85; }

/* ===== FOOTER ===== */
.footer {
  background: linear-gradient(135deg, #0F1B35 0%, #1B2E58 60%, #1B4FD8 100%);
  border-top: none; padding: 5rem 0 0;
}
.footer-container {
  max-width: 1300px; margin: 0 auto; padding: 0 2rem 4rem;
  display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem;
}
.footer-brand img { height: 50px; margin-bottom: 1rem;}
.footer-brand p { color: rgba(255,255,255,0.6); font-size: 0.88rem; line-height:1.7; max-width: 280px; margin-bottom: 1.5rem; }
.footer-socials { display: flex; gap: 0.75rem; }
.footer-socials a {
  width: 36px; height: 36px; background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.15); border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.6); text-decoration: none; font-size: 0.85rem; transition: all 0.2s;
}
.footer-socials a:hover { background: rgba(255,255,255,0.2); color: white; border-color: rgba(255,255,255,0.3); }
.footer-col h4 { font-size: 0.85rem; font-weight: 600; font-family: var(--font-mono); margin-bottom: 1.2rem; color: white; }
.footer-col a { display: block; color: rgba(255,255,255,0.55); text-decoration: none; font-size: 0.88rem; margin-bottom: 0.6rem; transition: color 0.2s; }
.footer-col a:hover { color: white; }
.footer-addr { color: rgba(255,255,255,0.5); font-size: 0.85rem; line-height:1.6; margin-top: 0.5rem; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding: 1.5rem 2rem;
  max-width: 1300px; margin: 0 auto;
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem;
}
.footer-bottom p { color: rgba(255,255,255,0.35); font-size: 0.78rem; }

/* ===== CHATBOT ===== */
.chatbot-bubble {
  position: fixed; bottom: 100px; right: 2rem;
  width: 60px; height: 60px;
  background: linear-gradient(135deg, var(--blue), var(--blue-light));
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 1.4rem; color: white; cursor: pointer; z-index: 900;
  box-shadow: 0 8px 30px rgba(27,79,216,0.5); transition: all 0.3s;
  animation: chatBounce 3s ease-in-out 3s infinite;
}
@keyframes chatBounce { 0%,100%{transform:scale(1)} 50%{transform:scale(1.08)} }
.chatbot-bubble:hover { transform: scale(1.1); box-shadow: 0 12px 40px rgba(27,79,216,0.6); }
.chat-notif {
  position: absolute; top:-4px; right:-4px;
  width: 20px; height: 20px; background: var(--red);
  border-radius: 50%; font-size: 0.7rem; font-weight: 700; color: white;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid white;
}
.chatbot-widget {
  position: fixed; bottom: 170px; right: 2rem; width: 370px;
  background: var(--white); border: 1px solid var(--border-light);
  border-radius: 20px; overflow: hidden; z-index: 901;
  box-shadow: 0 20px 60px rgba(27,79,216,0.2);
  transform: scale(0.9) translateY(20px); opacity: 0;
  pointer-events: none;
  transition: all 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: flex; flex-direction: column;
}
.chatbot-widget.open { transform: scale(1) translateY(0); opacity:1; pointer-events: all; }
.cw-header {
  background: linear-gradient(135deg, var(--blue-dark), var(--blue));
  padding: 1rem 1.2rem;
  display: flex; align-items: center; gap: 0.8rem;
}
.cw-header img { height: 32px; filter: brightness(0) invert(1); }
.cw-header div { flex: 1; }
.cw-header strong { display: block; font-size: 0.9rem; color: white; }
.cw-online { display: flex; align-items: center; gap: 0.4rem; font-size: 0.75rem; color: rgba(255,255,255,0.75); }
.cw-online .pulse-dot { width: 6px; height: 6px; background: #7FFF7F; }
#chatbotClose { background: none; border: none; color: rgba(255,255,255,0.7); cursor: pointer; font-size: 1rem; padding: 4px; margin-left: auto; transition: color 0.2s; }
#chatbotClose:hover { color: white; }
.cw-messages {
  flex: 1; padding: 1.2rem; overflow-y: auto;
  max-height: 350px; display: flex; flex-direction: column; gap: 0.8rem;
  background: var(--bg);
}
.cw-msg { display: flex; gap: 0.6rem; align-items: flex-end; }
.cw-msg.bot { justify-content: flex-start; }
.cw-msg.user { justify-content: flex-end; }
.cw-avatar {
  width: 28px; height: 28px;
  background: linear-gradient(135deg, var(--blue), var(--blue-light));
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 0.7rem; color: white; flex-shrink: 0;
}
.cw-bubble { max-width: 80%; padding: 0.7rem 1rem; border-radius: 16px; font-size: 0.87rem; line-height:1.5; }
.cw-msg.bot .cw-bubble { background: var(--white); border: 1px solid var(--border-light); color: var(--text); border-bottom-left-radius: 4px; box-shadow: var(--shadow); }
.cw-msg.user .cw-bubble { background: linear-gradient(135deg, var(--blue), var(--blue-light)); color: white; border-bottom-right-radius: 4px; }
.cw-typing {
  display: flex; gap: 4px; padding: 0.7rem 1rem;
  background: var(--white); border: 1px solid var(--border-light);
  border-radius: 16px; border-bottom-left-radius: 4px; width: fit-content;
  box-shadow: var(--shadow);
}
.cw-typing span { width: 6px; height: 6px; background: var(--text-muted); border-radius: 50%; animation: typingBounce 1.2s ease infinite; }
.cw-typing span:nth-child(2){ animation-delay:0.2s }
.cw-typing span:nth-child(3){ animation-delay:0.4s }
@keyframes typingBounce { 0%,80%,100%{transform:translateY(0)} 40%{transform:translateY(-6px)} }
.cw-quick-replies { padding: 0 1.2rem 0.8rem; display: flex; flex-wrap: wrap; gap: 0.5rem; background: var(--bg); }
.cw-qr {
  background: var(--white); border: 1.5px solid var(--border);
  border-radius: 50px; padding: 0.4rem 0.9rem;
  font-size: 0.8rem; color: var(--blue); cursor: pointer; transition: all 0.2s; white-space: nowrap;
}
.cw-qr:hover { background: var(--blue); color: white; border-color: var(--blue); }
.cw-input-area {
  display: flex; gap: 0.5rem; padding: 0.8rem 1.2rem;
  border-top: 1px solid var(--border-light); background: var(--white);
}
#cwInput {
  flex: 1; background: var(--bg);
  border: 1.5px solid var(--border-light); border-radius: 50px;
  padding: 0.6rem 1rem; color: var(--text); font-size: 0.88rem; outline: none;
}
#cwInput:focus { border-color: var(--blue); }
#cwSend {
  width: 36px; height: 36px;
  background: linear-gradient(135deg, var(--blue), var(--blue-light));
  border: none; border-radius: 50%; color: white; cursor: pointer;
  display: flex; align-items: center; justify-content: center; font-size: 0.85rem; transition: all 0.2s;
}
#cwSend:hover { background: var(--blue-dark); }

/* ===== WA FLOAT ===== */
.wa-float {
  position: fixed; bottom: 2rem; right: 2rem;
  width: 56px; height: 56px; background: #25D366;
  border-radius: 50%; display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem; color: white; text-decoration: none; z-index: 800;
  box-shadow: 0 6px 25px rgba(37,211,102,0.5); transition: all 0.3s;
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 10px 35px rgba(37,211,102,0.6); }

/* ===== REVEAL ANIMATION ===== */
.reveal { opacity: 0; transform: translateY(30px); transition: all 0.7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px) {
  .why-grid, .services-grid, .hosp-grid, .testi-grid { grid-template-columns: repeat(2,1fr); }
  .footer-container { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .nav-links {
    display: none; position: fixed; top: 70px; left:0; right:0;
    background: var(--white); border-bottom: 1px solid var(--border-light);
    flex-direction: column; padding: 1rem; gap: 0;
    box-shadow: var(--shadow-lg);
  }
  .nav-links.open { display: flex; }
  .nav-links a { padding: 0.8rem 1rem; border-bottom: 1px solid var(--border-light); }
  .hamburger { display: flex; }
  .treat-grid { grid-template-columns: 1fr; }
  .contact-grid { grid-template-columns: 1fr; }
  .form-row { grid-template-columns: 1fr; }
  .chatbot-widget { width: calc(100vw - 2rem); right: 1rem; }
}
@media (max-width: 700px) {
  .why-grid, .services-grid, .hosp-grid, .testi-grid { grid-template-columns: 1fr; }
  .hero-stats { flex-direction: column; width: 100%; }
  .stat-div { width:100%; height:1px; margin:0; }
  .stat { padding:1rem; display:flex; align-items:center; justify-content:space-between; }
  .cost-table { font-size: 0.8rem; }
  .cost-table th, .cost-table td { padding: 0.8rem 0.7rem; }
  .footer-container { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; }
  .treatments-tabs { gap: 0.25rem; }
  .tab-btn { font-size: 0.78rem; padding: 0.5rem 0.8rem; }
}

/* ===== PREMIUM 2026 REDESIGN OVERRIDES ===== */
:root {
  --ink: #101828;
  --sea: #0f766e;
  --mint: #d9fff4;
  --coral: #f9735b;
  --gold: #c9973f;
  --mist: #f7fbfc;
  --line: rgba(16, 24, 40, 0.1);
  --soft-shadow: 0 18px 55px rgba(15, 23, 42, 0.11);
  --deep-shadow: 0 28px 80px rgba(15, 23, 42, 0.18);
  --radius: 8px;
}

body {
  background:
    linear-gradient(180deg, #fbfefe 0%, #f4faf9 42%, #fff 100%);
  color: var(--ink);
}

#navbar {
  background: rgba(255,255,255,0.84);
  border-bottom: 1px solid rgba(15,118,110,0.13);
}

.nav-container { height: 78px; }
.nav-logo img { height: 50px; }
.nav-links { gap: 0.25rem; }
.nav-links a {
  border-radius: var(--radius);
  color: #344054;
  font-family: var(--font-body);
  font-weight: 600;
}
.nav-links a:hover,
.nav-links a.active {
  color: var(--sea);
  background: rgba(15,118,110,0.08);
}

.btn-primary,
.btn-whatsapp,
.wa-btn-large {
  border-radius: var(--radius);
  box-shadow: 0 10px 24px rgba(15,118,110,0.15);
}
.btn-primary {
  background: linear-gradient(135deg, var(--sea), #12a594);
}
.btn-primary:hover { background: linear-gradient(135deg, #0b625c, var(--sea)); }
.btn-ghost {
  border-radius: var(--radius);
  background: rgba(255,255,255,0.12);
}

.hero {
  min-height: 92vh;
  background:
    linear-gradient(120deg, rgba(12, 44, 52, 0.92), rgba(15, 118, 110, 0.76)),
    url('https://images.unsplash.com/photo-1586773860418-d37222d8fce3?auto=format&fit=crop&w=1800&q=80') center/cover;
  padding-top: 78px;
}
.hero::before,
.hero::after { display: none; }
.hero-bg-grid {
  background-image:
    linear-gradient(rgba(255,255,255,0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.055) 1px, transparent 1px);
  mask-image: linear-gradient(to bottom, black 0%, transparent 78%);
}
.hero-container {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(320px, 0.72fr);
  gap: 3rem;
  align-items: center;
}
.hero-badge,
.hero-title,
.hero-sub,
.hero-actions,
.hero-stats { grid-column: 1; }
.hero-badge {
  width: fit-content;
  border-radius: 999px;
  background: rgba(255,255,255,0.13);
  border-color: rgba(255,255,255,0.25);
}
.hero-title {
  font-family: var(--font-body);
  font-weight: 800;
  letter-spacing: 0;
  max-width: 780px;
}
.hero-title em { color: #abf7e5; font-style: normal; }
.stroke-text {
  -webkit-text-stroke: 0;
  color: #ffdca8;
}
.hero-sub { color: rgba(255,255,255,0.86); max-width: 720px; }
.hero-stats {
  border-radius: var(--radius);
  background: rgba(255,255,255,0.12);
  box-shadow: 0 18px 55px rgba(0,0,0,0.16);
}
.stat-num,
.stat > span:last-of-type { color: #ffdca8; }

.hero-visual {
  grid-column: 2;
  grid-row: 1 / span 5;
  position: relative;
  min-height: 500px;
}
.care-card {
  position: absolute;
  border: 1px solid rgba(255,255,255,0.22);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.93);
  color: var(--ink);
  box-shadow: var(--deep-shadow);
  backdrop-filter: blur(20px);
}
.care-card-main {
  inset: 34px 14px auto auto;
  width: min(420px, 100%);
  padding: 1.35rem;
}
.care-card-top,
.care-patient,
.care-steps div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.care-card-top span,
.care-mini-label {
  font-size: 0.75rem;
  color: #667085;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.care-card-top strong { color: var(--sea); }
.care-patient {
  justify-content: flex-start;
  margin: 1.4rem 0;
  padding: 1rem;
  background: #f4fbfa;
  border: 1px solid rgba(15,118,110,0.11);
  border-radius: var(--radius);
}
.care-avatar {
  width: 54px;
  height: 54px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, var(--sea), #2dd4bf);
}
.care-patient h3 { font-size: 1.05rem; margin-bottom: 0.15rem; }
.care-patient p,
.care-card-side p { color: #667085; font-size: 0.88rem; }
.care-progress {
  height: 10px;
  border-radius: 999px;
  background: #e8f4f2;
  overflow: hidden;
  margin-bottom: 1rem;
}
.care-progress span {
  display: block;
  height: 100%;
  background: linear-gradient(90deg, var(--sea), var(--gold));
  border-radius: inherit;
}
.care-steps { display: grid; gap: 0.65rem; }
.care-steps div {
  justify-content: flex-start;
  color: #344054;
  font-size: 0.9rem;
}
.care-steps i { color: var(--sea); }
.care-card-side {
  width: 190px;
  padding: 1rem;
  left: 0;
  bottom: 100px;
}
.care-card-side.accent {
  left: auto;
  right: 0;
  bottom: 24px;
  background: #102a2e;
  color: #fff;
}
.care-card-side strong { display: block; font-size: 2rem; line-height: 1.1; margin: 0.3rem 0; }
.care-card-side.accent p,
.care-card-side.accent .care-mini-label { color: rgba(255,255,255,0.72); }

.why-section,
.treatments-section,
.testimonials-section,
.contact-section { background: #fff; }
.services-section,
.cost-section,
.process-section,
.countries-section { background: var(--mist); }
.why-section,
.services-section,
.treatments-section,
.cost-section,
.hospitals-section,
.process-section,
.testimonials-section,
.contact-section { padding: 6rem 0; }
.section-tag {
  border-radius: 999px;
  color: var(--sea);
  background: rgba(15,118,110,0.08);
  border-color: rgba(15,118,110,0.16);
}
.section-title {
  font-family: var(--font-body);
  font-weight: 800;
  letter-spacing: 0;
}
.section-title em { color: var(--coral); font-style: normal; }
.section-sub { color: #667085; }
.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.contact-form-wrap,
.ci-card,
.cost-table-wrap,
.treat-cost {
  border-radius: var(--radius);
  border-color: var(--line);
  box-shadow: var(--soft-shadow);
}
.why-card,
.service-card,
.hosp-card,
.testi-card,
.ci-card { background: #fff; }
.why-card:hover,
.service-card:hover,
.hosp-card:hover,
.testi-card:hover {
  border-color: rgba(15,118,110,0.25);
  transform: translateY(-5px);
}
.why-icon,
.sc-icon,
.tl-dot,
.testi-avatar {
  background: linear-gradient(135deg, var(--sea), #2dd4bf);
  color: #fff;
  border: 0;
}
.sc-tags span,
.hosp-tags span,
.country-item,
.cost-badge {
  border-radius: var(--radius);
}
.treatments-tabs {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 0.35rem;
  background: #fff;
}
.tab-btn {
  border-radius: 6px;
  border-bottom: 0;
  margin-bottom: 0;
}
.tab-btn.active { color: #fff; background: var(--sea); }
.treat-img,
.treat-img-inner { border-radius: var(--radius); }
.timeline::before { background: linear-gradient(to bottom, var(--sea), rgba(15,118,110,0.08)); }
.contact-form-wrap { background: #f8fcfb; }
.form-group input,
.form-group select,
.form-group textarea,
.file-upload-area { border-radius: var(--radius); }
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--sea);
  box-shadow: 0 0 0 4px rgba(15,118,110,0.11);
}
.footer {
  background: linear-gradient(135deg, #102a2e 0%, #143f42 58%, #0f766e 100%);
}

/* Chatbot premium comfort layer */
.chatbot-bubble {
  right: 1.25rem;
  bottom: 1.25rem;
  z-index: 1201;
  width: 64px;
  height: 64px;
  background: linear-gradient(135deg, var(--sea), #2dd4bf);
  box-shadow: 0 18px 45px rgba(15,118,110,0.35);
}
.wa-float {
  right: 1.25rem;
  bottom: 6rem;
  z-index: 1199;
  border-radius: var(--radius);
}
.chatbot-widget {
  right: 1.25rem;
  bottom: 6rem;
  width: min(410px, calc(100vw - 2rem));
  max-height: min(680px, calc(100dvh - 7.5rem));
  border-radius: var(--radius);
  z-index: 1202;
  border-color: rgba(15,118,110,0.16);
  box-shadow: 0 28px 90px rgba(15,23,42,0.24);
  overflow: hidden;
}
.cw-header { background: linear-gradient(135deg, #102a2e, var(--sea)); }
.cw-messages {
  min-height: 280px;
  max-height: none;
  background: #f5fbfa;
}
.cw-bubble,
.cw-typing,
.cw-qr,
#cwInput,
#cwSend { border-radius: var(--radius); }
.cw-msg.user .cw-bubble,
#cwSend { background: linear-gradient(135deg, var(--sea), #2dd4bf); }
.cw-msg.bot .cw-bubble { box-shadow: 0 8px 24px rgba(15,23,42,0.08); }
.cw-quick-replies { max-height: 128px; overflow-y: auto; background: #f5fbfa; }
.cw-qr { color: var(--sea); border-color: rgba(15,118,110,0.22); white-space: normal; text-align: left; }
.cw-qr:hover { background: var(--sea); border-color: var(--sea); }

@media (max-width: 1100px) {
  .hero-container { grid-template-columns: 1fr; }
  .hero-badge,
  .hero-title,
  .hero-sub,
  .hero-actions,
  .hero-stats,
  .hero-visual { grid-column: 1; }
  .hero-visual { grid-row: auto; min-height: 380px; max-width: 560px; width: 100%; }
  .care-card-main { left: 0; right: auto; }
}
@media (max-width: 900px) {
  .nav-container { height: 70px; padding: 0 1rem; }
  .nav-links { top: 70px; }
  .nav-cta { display: none; }
  .hero { padding-top: 70px; min-height: auto; }
  .hero-container { padding: 4rem 1rem 5rem; }
  .hero-title { font-size: clamp(2.4rem, 11vw, 4.4rem); }
  .hero-visual { min-height: 430px; }
  .chatbot-widget {
    left: 1rem;
    right: 1rem;
    bottom: 5.5rem;
    width: auto;
    max-height: calc(100dvh - 6.5rem);
  }
  .wa-float { left: 1rem; right: auto; bottom: 1.25rem; }
}
@media (max-width: 560px) {
  .container { padding: 0 1rem; }
  .hero-actions a { width: 100%; justify-content: center; }
  .hero-stats { display: grid; grid-template-columns: 1fr 1fr; width: 100%; }
  .stat { display: block; padding: 1rem 0.75rem; }
  .stat-div { display: none; }
  .hero-visual { min-height: 390px; }
  .care-card-main { width: 100%; inset: 0 auto auto 0; }
  .care-card-side { width: calc(50% - 0.5rem); left: 0; bottom: 34px; }
  .care-card-side.accent { right: 0; bottom: 34px; }
  .care-card-side strong { font-size: 1.55rem; }
  .chatbot-widget { border-radius: 8px; }
  .cw-header { padding: 0.85rem; }
  .cw-messages { min-height: 220px; padding: 0.9rem; }
}

.cw-whatsapp-cta {
  display: inline-flex;
  align-items: center;
  gap: 0.65rem;
  max-width: 80%;
  background: #25D366;
  color: #fff;
  text-decoration: none;
  padding: 0.78rem 1rem;
  border-radius: var(--radius);
  font-size: 0.86rem;
  font-weight: 700;
  box-shadow: 0 10px 24px rgba(37,211,102,0.22);
}
.cw-whatsapp-cta i { font-size: 1.2rem; }

.inner-hero {
  padding: 9rem 0 5rem;
  background:
    linear-gradient(120deg, rgba(16,42,46,0.94), rgba(15,118,110,0.78)),
    url('https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=1800&q=80') center/cover;
  color: #fff;
}
.inner-hero h1 {
  max-width: 920px;
  font-family: var(--font-body);
  font-size: clamp(2.4rem, 5vw, 5rem);
  line-height: 1.04;
  letter-spacing: 0;
  margin: 0 0 1.2rem;
}
.inner-hero p {
  max-width: 720px;
  color: rgba(255,255,255,0.82);
  font-size: 1.08rem;
  line-height: 1.75;
}
.inner-hero .section-tag {
  color: #abf7e5;
  border-color: rgba(255,255,255,0.25);
  background: rgba(255,255,255,0.12);
}
.inner-hero .hero-actions { margin-top: 2rem; margin-bottom: 0; }
.inner-hero .btn-ghost { background: rgba(255,255,255,0.15); }
@media (max-width: 700px) {
  .inner-hero { padding: 7rem 0 4rem; }
}

/* ===== WRAPPED INNER PAGE LAYOUT ===== */
.inner-page-body {
  background:
    radial-gradient(circle at top left, rgba(15,118,110,0.1), transparent 32rem),
    linear-gradient(180deg, #f7fbfc 0%, #eef7f6 42%, #ffffff 100%);
}
.inner-page-body #navbar {
  left: 50%;
  right: auto;
  width: min(1180px, calc(100% - 2rem));
  transform: translateX(-50%);
  top: 1rem;
  border-radius: var(--radius);
  box-shadow: 0 14px 44px rgba(15,23,42,0.08);
}
.inner-page-body .inner-hero {
  width: min(1180px, calc(100% - 2rem));
  margin: 7.25rem auto 1.5rem;
  padding: clamp(2rem, 5vw, 4.25rem);
  border-radius: var(--radius);
  overflow: hidden;
  box-shadow: var(--deep-shadow);
}
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  width: min(1180px, calc(100% - 2rem));
  margin: 0 auto 1.5rem;
  padding: clamp(2rem, 4vw, 4rem) 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--soft-shadow);
  overflow: hidden;
}
.inner-page-body .footer {
  width: min(1180px, calc(100% - 2rem));
  margin: 0 auto 1rem;
  border-radius: var(--radius);
  overflow: hidden;
}
.inner-page-body .wa-float {
  border-radius: 50%;
}
@media (max-width: 900px) {
  .inner-page-body #navbar {
    top: 0;
    width: 100%;
    border-radius: 0;
  }
  .inner-page-body .inner-hero {
    margin-top: 5.5rem;
  }
}

/* ===== FULL HEADER FOOTER + RICH PREMIUM PALETTE ===== */
:root {
  --ink: #111827;
  --sea: #0f8f7f;
  --mint: #c8fff1;
  --coral: #ff6f61;
  --gold: #d6a84f;
  --plum: #5b3b8c;
  --indigo: #243b7a;
  --mist: #f3faf8;
  --line: rgba(17, 24, 39, 0.11);
  --soft-shadow: 0 20px 55px rgba(17, 24, 39, 0.1);
  --deep-shadow: 0 32px 90px rgba(17, 24, 39, 0.2);
}

body,
.inner-page-body {
  background:
    radial-gradient(circle at 8% 10%, rgba(214,168,79,0.13), transparent 24rem),
    radial-gradient(circle at 92% 16%, rgba(91,59,140,0.11), transparent 28rem),
    linear-gradient(180deg, #f8fcfb 0%, #eff8f6 38%, #fffaf2 100%);
}

#navbar,
.inner-page-body #navbar {
  left: 0;
  right: 0;
  top: 0;
  width: 100%;
  transform: none;
  border-radius: 0;
  background: rgba(255,255,255,0.9);
  border-bottom: 1px solid rgba(15,143,127,0.15);
  box-shadow: 0 10px 36px rgba(17,24,39,0.07);
}

#navbar.scrolled,
.inner-page-body #navbar.scrolled {
  background: rgba(255,255,255,0.97);
}

.nav-container,
.footer-container,
.footer-bottom {
  max-width: 1180px;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--sea);
  background: linear-gradient(135deg, rgba(15,143,127,0.1), rgba(214,168,79,0.12));
}

.btn-primary {
  background: linear-gradient(135deg, var(--sea), var(--indigo));
  box-shadow: 0 16px 34px rgba(15,143,127,0.24);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #0b7167, var(--plum));
}
.btn-whatsapp,
.wa-btn-large {
  background: linear-gradient(135deg, #20c76f, #0f8f7f);
}

.hero {
  background:
    linear-gradient(120deg, rgba(18, 32, 70, 0.9), rgba(15, 143, 127, 0.76), rgba(91, 59, 140, 0.46)),
    url('https://images.unsplash.com/photo-1586773860418-d37222d8fce3?auto=format&fit=crop&w=1800&q=80') center/cover;
}
.hero-title em { color: var(--mint); }
.stroke-text { color: #ffe1a3; }
.hero-stats {
  background: rgba(255,255,255,0.16);
  border-color: rgba(255,255,255,0.24);
}
.stat-num,
.stat > span:last-of-type { color: #ffe1a3; }

.care-avatar,
.why-icon,
.sc-icon,
.tl-dot,
.testi-avatar,
#cwSend {
  background: linear-gradient(135deg, var(--sea), var(--indigo));
}
.care-card-top strong,
.care-steps i,
.section-tag,
.ci-item > i,
.ci-item a,
.cost-note-text a,
.testi-author span,
.hosp-badge {
  color: var(--sea);
}
.care-progress span {
  background: linear-gradient(90deg, var(--sea), var(--gold), var(--coral));
}
.care-card-side.accent,
.cw-header {
  background: linear-gradient(135deg, #172554, var(--plum));
}

.why-section,
.treatments-section,
.testimonials-section,
.contact-section {
  background: linear-gradient(180deg, #ffffff 0%, #fbfffd 100%);
}
.services-section,
.cost-section,
.process-section,
.countries-section {
  background: linear-gradient(180deg, #f4fbfa 0%, #fff9ee 100%);
}
.section-tag {
  background: linear-gradient(135deg, rgba(15,143,127,0.1), rgba(214,168,79,0.14));
  border-color: rgba(15,143,127,0.18);
}
.section-title em { color: var(--plum); }
.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.contact-form-wrap,
.ci-card,
.cost-table-wrap,
.treat-cost {
  background: rgba(255,255,255,0.92);
  border-color: rgba(17,24,39,0.1);
}
.why-card::before {
  background: linear-gradient(90deg, var(--sea), var(--gold), var(--plum));
}
.why-card:hover,
.service-card:hover,
.hosp-card:hover,
.testi-card:hover {
  border-color: rgba(15,143,127,0.28);
  box-shadow: 0 24px 70px rgba(17,24,39,0.14);
}
.sc-tags span,
.hosp-tags span,
.cost-badge,
.country-item {
  background: linear-gradient(135deg, rgba(15,143,127,0.08), rgba(214,168,79,0.1));
  border-color: rgba(15,143,127,0.16);
  color: #245b55;
}
.tab-btn.active {
  background: linear-gradient(135deg, var(--sea), var(--plum));
}
.cost-table th.hl-col,
.cost-table td.hl-col {
  background: #eef9f6;
}
.china-price,
.cost-range { color: var(--plum); }

.inner-page-body .inner-hero {
  width: min(1180px, calc(100% - 2rem));
  margin: 7rem auto 1.5rem;
  background:
    linear-gradient(125deg, rgba(23,37,84,0.94), rgba(15,143,127,0.78), rgba(91,59,140,0.55)),
    url('https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=1800&q=80') center/cover;
  border: 1px solid rgba(255,255,255,0.28);
}
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  width: min(1180px, calc(100% - 2rem));
  margin: 0 auto 1.5rem;
  background: rgba(255,255,255,0.78);
  backdrop-filter: blur(14px);
}

.footer,
.inner-page-body .footer {
  width: 100%;
  margin: 0;
  border-radius: 0;
  background:
    radial-gradient(circle at 15% 0%, rgba(214,168,79,0.22), transparent 22rem),
    linear-gradient(135deg, #111827 0%, #172554 42%, #0f8f7f 100%);
}
.footer-socials a:hover {
  background: rgba(214,168,79,0.22);
  border-color: rgba(214,168,79,0.45);
}

.chatbot-bubble,
.cw-msg.user .cw-bubble {
  background: linear-gradient(135deg, var(--sea), var(--plum));
}
.cw-messages,
.cw-quick-replies {
  background: linear-gradient(180deg, #f5fbfa, #fff8ed);
}
.cw-qr {
  color: var(--indigo);
  border-color: rgba(36,59,122,0.18);
}
.cw-qr:hover {
  background: var(--indigo);
  border-color: var(--indigo);
}

@media (max-width: 900px) {
  .inner-page-body .inner-hero {
    margin-top: 5.5rem;
  }
}

/* ===== 940PX CONTENT WRAP UPDATE ===== */
.inner-page-body .inner-hero,
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  width: min(940px, calc(100% - 2rem));
}
.inner-page-body .inner-hero .container,
.inner-page-body .services-section .container,
.inner-page-body .treatments-section .container,
.inner-page-body .hospitals-section .container,
.inner-page-body .contact-section .container {
  max-width: 940px;
}

/* ===== 940PX HOMEPAGE + PREMIUM MOTION SYSTEM ===== */
:root {
  --wrap: 940px;
  --motion-ease: cubic-bezier(0.22, 1, 0.36, 1);
}

.container,
.hero-container,
.nav-container,
.footer-container,
.footer-bottom {
  max-width: var(--wrap);
}

.hero-container {
  grid-template-columns: minmax(0, 1fr);
  gap: 2rem;
}
.hero-badge,
.hero-title,
.hero-sub,
.hero-actions,
.hero-stats,
.hero-visual {
  grid-column: 1;
}
.hero-visual {
  grid-row: auto;
  width: 100%;
  max-width: var(--wrap);
  min-height: 360px;
  margin-top: 0.5rem;
}
.care-card-main {
  left: 0;
  right: auto;
  width: min(540px, 100%);
}
.care-card-side {
  left: auto;
  right: 210px;
  bottom: 42px;
}
.care-card-side.accent {
  right: 0;
  bottom: 42px;
}

.why-grid,
.services-grid,
.hosp-grid,
.testi-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.contact-grid {
  grid-template-columns: minmax(0, 1fr);
}
.contact-info {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.contact-info .wa-card {
  grid-column: 1 / -1;
}
.treat-grid {
  grid-template-columns: minmax(0, 1fr);
}
.treat-img-inner {
  height: 340px;
}
.cost-table-wrap {
  max-width: 100%;
}

.hero-title,
.section-title,
.inner-hero h1 {
  text-wrap: balance;
}
.hero-sub,
.section-sub,
.inner-hero p,
.why-card p,
.service-card p,
.hosp-card p,
.testi-text,
.tl-content p {
  text-wrap: pretty;
}

/* Motion: premium, calm, not noisy */
@keyframes premiumFloat {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}
@keyframes sheenSweep {
  0% { transform: translateX(-120%) skewX(-18deg); opacity: 0; }
  18% { opacity: 0.42; }
  44% { opacity: 0; }
  100% { transform: translateX(220%) skewX(-18deg); opacity: 0; }
}
@keyframes softGlowPulse {
  0%, 100% { box-shadow: 0 20px 55px rgba(17,24,39,0.10); }
  50% { box-shadow: 0 28px 78px rgba(15,143,127,0.18); }
}
@keyframes slideFadeIn {
  from { opacity: 0; transform: translateY(22px) scale(0.985); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

.hero-visual,
.care-card-side {
  animation: premiumFloat 6s var(--motion-ease) infinite;
}
.care-card-side.accent {
  animation-delay: -2.5s;
}
.care-card-main,
.contact-form-wrap,
.inner-page-body .inner-hero {
  animation: softGlowPulse 5.5s ease-in-out infinite;
}

.btn-primary,
.btn-whatsapp,
.wa-btn-large,
.cw-whatsapp-cta,
.service-card,
.why-card,
.hosp-card,
.testi-card,
.tl-content,
.country-item,
.ci-card {
  position: relative;
  overflow: hidden;
}
.btn-primary::after,
.btn-whatsapp::after,
.wa-btn-large::after,
.cw-whatsapp-cta::after,
.service-card::after,
.why-card::after,
.hosp-card::after,
.testi-card::after,
.ci-card::after {
  content: '';
  position: absolute;
  inset: -40% auto -40% 0;
  width: 34%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.55), transparent);
  pointer-events: none;
  transform: translateX(-120%) skewX(-18deg);
}
.btn-primary:hover::after,
.btn-whatsapp:hover::after,
.wa-btn-large:hover::after,
.cw-whatsapp-cta:hover::after,
.service-card:hover::after,
.why-card:hover::after,
.hosp-card:hover::after,
.testi-card:hover::after,
.ci-card:hover::after {
  animation: sheenSweep 1.15s ease forwards;
}

.reveal.visible,
.hero-badge,
.hero-title,
.hero-sub,
.hero-actions,
.hero-stats,
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  animation-name: slideFadeIn;
  animation-duration: 0.75s;
  animation-timing-function: var(--motion-ease);
  animation-fill-mode: both;
}
.hero-title { animation-delay: 0.08s; }
.hero-sub { animation-delay: 0.16s; }
.hero-actions { animation-delay: 0.24s; }
.hero-stats { animation-delay: 0.32s; }

.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.ci-card,
.country-item,
.tab-btn,
.cw-qr,
.btn-primary,
.btn-ghost,
.btn-whatsapp {
  transition:
    transform 0.35s var(--motion-ease),
    box-shadow 0.35s var(--motion-ease),
    border-color 0.35s var(--motion-ease),
    background 0.35s var(--motion-ease),
    color 0.25s ease;
}
.why-card:hover,
.service-card:hover,
.hosp-card:hover,
.testi-card:hover,
.ci-card:hover {
  transform: translateY(-8px) scale(1.01);
}
.tab-btn:hover,
.cw-qr:hover,
.country-item:hover {
  transform: translateY(-2px);
}

/* Mobile comfort */
@media (max-width: 980px) {
  :root { --wrap: calc(100% - 2rem); }
  .container,
  .hero-container,
  .nav-container,
  .footer-container,
  .footer-bottom {
    max-width: var(--wrap);
  }
  .inner-page-body .inner-hero,
  .inner-page-body .services-section,
  .inner-page-body .treatments-section,
  .inner-page-body .hospitals-section,
  .inner-page-body .contact-section {
    width: var(--wrap);
  }
}

@media (max-width: 760px) {
  .why-grid,
  .services-grid,
  .hosp-grid,
  .testi-grid,
  .contact-info {
    grid-template-columns: 1fr;
  }
  .hero-container {
    padding: 3.2rem 1rem 4rem;
  }
  .hero-visual {
    min-height: 470px;
  }
  .care-card-main {
    width: 100%;
    inset: 0 auto auto 0;
  }
  .care-card-side,
  .care-card-side.accent {
    width: calc(50% - 0.5rem);
    bottom: 26px;
  }
  .care-card-side { left: 0; right: auto; }
  .care-card-side.accent { right: 0; left: auto; }
  .inner-page-body .inner-hero,
  .inner-page-body .services-section,
  .inner-page-body .treatments-section,
  .inner-page-body .hospitals-section,
  .inner-page-body .contact-section {
    width: calc(100% - 1rem);
    margin-bottom: 0.75rem;
  }
  .inner-page-body .inner-hero {
    margin-top: 5rem;
    padding: 2rem 1rem;
  }
  .inner-hero h1 {
    font-size: clamp(2rem, 11vw, 3.4rem);
  }
  .treat-img-inner {
    height: 280px;
  }
  .footer-container,
  .footer-bottom {
    max-width: calc(100% - 2rem);
  }
}

@media (max-width: 520px) {
  .hero-title {
    font-size: clamp(2.1rem, 12vw, 3.4rem);
  }
  .hero-sub,
  .section-sub,
  .inner-hero p {
    font-size: 0.98rem;
  }
  .hero-stats {
    grid-template-columns: 1fr 1fr;
  }
  .stat p {
    font-size: 0.7rem;
  }
  .contact-form-wrap,
  .ci-card,
  .service-card,
  .why-card,
  .hosp-card,
  .testi-card,
  .tl-content {
    padding: 1.35rem;
  }
  .tl-item {
    gap: 1rem;
  }
  .tl-actions {
    gap: 0.55rem;
  }
  .care-patient {
    align-items: flex-start;
  }
  .care-card-side p {
    font-size: 0.76rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}

/* ===== EXECUTIVE PREMIUM REDESIGN FINAL PASS ===== */
:root {
  --wrap: 940px;
  --lux-ink: #0b1220;
  --lux-navy: #101b3d;
  --lux-indigo: #24346f;
  --lux-teal: #0b8f83;
  --lux-emerald: #16b08f;
  --lux-gold: #d8af5f;
  --lux-rose: #c65d6e;
  --lux-ivory: #fffaf0;
  --lux-paper: #fbfdfc;
  --lux-border: rgba(16, 27, 61, 0.12);
  --lux-shadow: 0 26px 80px rgba(11, 18, 32, 0.14);
  --lux-shadow-deep: 0 38px 110px rgba(11, 18, 32, 0.28);
}

html { background: var(--lux-paper); }
body {
  background:
    radial-gradient(circle at 8% 8%, rgba(216,175,95,0.14), transparent 24rem),
    radial-gradient(circle at 92% 18%, rgba(198,93,110,0.11), transparent 25rem),
    linear-gradient(180deg, #f9fcfb 0%, #f3f8f6 45%, #fffaf0 100%);
}

#navbar {
  background: rgba(255,255,255,0.88);
  backdrop-filter: blur(24px) saturate(1.15);
  border-bottom: 1px solid rgba(16,27,61,0.08);
  box-shadow: 0 12px 44px rgba(11,18,32,0.07);
}
.nav-container {
  max-width: var(--wrap);
  height: 82px;
}
.nav-logo img { height: 54px; }
.nav-links a {
  color: #344054;
  padding: 0.58rem 0.78rem;
  font-size: 0.86rem;
  border-radius: 999px;
}
.nav-links a:hover,
.nav-links a.active {
  color: var(--lux-navy);
  background: linear-gradient(135deg, rgba(216,175,95,0.18), rgba(11,143,131,0.12));
}

.hero {
  min-height: 94vh;
  padding-top: 82px;
  background:
    linear-gradient(115deg, rgba(8,15,34,0.96) 0%, rgba(16,27,61,0.9) 38%, rgba(11,143,131,0.72) 100%),
    url('https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=2200&q=85') center/cover;
  isolation: isolate;
}
.hero::before {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 28%, rgba(216,175,95,0.22), transparent 18rem),
    radial-gradient(circle at 84% 18%, rgba(198,93,110,0.16), transparent 18rem),
    linear-gradient(90deg, rgba(255,255,255,0.04), transparent 35%, rgba(255,255,255,0.035));
  pointer-events: none;
  z-index: 0;
}
.hero-bg-grid {
  opacity: 0.65;
  background-size: 72px 72px;
}
.hero-container {
  max-width: var(--wrap);
  width: 100%;
  min-height: calc(94vh - 82px);
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(300px, 0.78fr);
  grid-template-areas:
    "badge visual"
    "title visual"
    "sub visual"
    "actions visual"
    "stats visual";
  gap: 1.4rem 2.2rem;
  align-content: center;
  padding: 4.5rem 0 5rem;
  position: relative;
  z-index: 2;
}
.hero-badge { grid-area: badge; }
.hero-title { grid-area: title; }
.hero-sub { grid-area: sub; }
.hero-actions { grid-area: actions; }
.hero-stats { grid-area: stats; }
.hero-visual { grid-area: visual; }

.hero-badge {
  color: #fef7df;
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.26);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.18);
}
.hero-title {
  font-size: clamp(3rem, 6vw, 5.75rem);
  line-height: 0.98;
  color: #fff;
  letter-spacing: -0.015em;
  margin-bottom: 0.6rem;
}
.hero-title em {
  color: #b9fff0;
  text-shadow: 0 0 40px rgba(22,176,143,0.24);
}
.stroke-text {
  color: #f7d892;
  text-shadow: 0 16px 45px rgba(216,175,95,0.22);
}
.hero-sub {
  max-width: 560px;
  color: rgba(255,255,255,0.82);
  font-size: 1.04rem;
  line-height: 1.75;
}
.hero-actions { margin-bottom: 1.25rem; }
.btn-primary,
.btn-ghost,
.btn-whatsapp {
  min-height: 48px;
  border-radius: 999px;
}
.btn-primary {
  background: linear-gradient(135deg, var(--lux-gold), var(--lux-teal) 52%, var(--lux-indigo));
  color: #fff;
  box-shadow: 0 18px 45px rgba(11,143,131,0.28);
}
.btn-primary:hover {
  transform: translateY(-3px);
  background: linear-gradient(135deg, #e6bf70, var(--lux-emerald), var(--lux-navy));
}
.btn-ghost {
  background: rgba(255,255,255,0.12);
  border-color: rgba(255,255,255,0.28);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.12);
}
.hero-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  width: 100%;
  border-radius: 14px;
  background: rgba(255,255,255,0.11);
  border: 1px solid rgba(255,255,255,0.2);
  box-shadow: 0 20px 70px rgba(0,0,0,0.18), inset 0 1px 0 rgba(255,255,255,0.16);
}
.stat {
  padding: 1rem 0.75rem;
}
.stat-num,
.stat > span:last-of-type { color: #f7d892; }
.stat p { color: rgba(255,255,255,0.68); }
.stat-div { display: none; }

.hero-visual {
  width: 100%;
  min-height: 470px;
  margin: 0;
}
.care-card {
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.28);
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(248,252,250,0.88));
  box-shadow: var(--lux-shadow-deep);
}
.care-card-main {
  inset: 1rem 0 auto auto;
  width: min(360px, 100%);
  padding: 1.25rem;
}
.care-card-top strong { color: var(--lux-teal); }
.care-patient {
  background: linear-gradient(135deg, rgba(11,143,131,0.08), rgba(216,175,95,0.12));
  border-color: rgba(11,143,131,0.14);
}
.care-avatar {
  background: linear-gradient(135deg, var(--lux-navy), var(--lux-teal));
  box-shadow: 0 12px 28px rgba(11,143,131,0.28);
}
.care-progress span { background: linear-gradient(90deg, var(--lux-teal), var(--lux-gold), var(--lux-rose)); }
.care-card-side {
  right: auto;
  left: 0;
  bottom: 88px;
  width: 172px;
}
.care-card-side.accent {
  right: 18px;
  bottom: 18px;
  background: linear-gradient(135deg, var(--lux-navy), var(--lux-indigo) 52%, #2d1f52);
}

section:not(.hero):not(.inner-hero) > .container {
  max-width: var(--wrap);
}
.why-section,
.services-section,
.treatments-section,
.cost-section,
.hospitals-section,
.process-section,
.testimonials-section,
.countries-section,
.contact-section {
  position: relative;
  padding: 5.6rem 0;
}
.why-section::before,
.services-section::before,
.treatments-section::before,
.cost-section::before,
.hospitals-section::before,
.process-section::before,
.testimonials-section::before,
.contact-section::before {
  content: '';
  position: absolute;
  inset: 1.2rem max(1rem, calc((100vw - var(--wrap)) / 2 - 1rem));
  border: 1px solid rgba(16,27,61,0.06);
  border-radius: 26px;
  pointer-events: none;
  background: linear-gradient(180deg, rgba(255,255,255,0.52), rgba(255,255,255,0));
}
.section-tag {
  color: var(--lux-teal);
  background: linear-gradient(135deg, rgba(11,143,131,0.1), rgba(216,175,95,0.16));
  border-color: rgba(11,143,131,0.18);
}
.section-title {
  font-size: clamp(2rem, 4.8vw, 3.4rem);
  line-height: 1.05;
  color: var(--lux-navy);
}
.section-title em { color: var(--lux-rose); }
.section-sub { color: #5b6472; }

.why-grid,
.services-grid,
.hosp-grid,
.testi-grid {
  gap: 1.1rem;
}
.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.contact-form-wrap,
.ci-card,
.cost-table-wrap,
.treat-cost,
.country-item {
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,253,252,0.9));
  border: 1px solid var(--lux-border);
  box-shadow: var(--lux-shadow);
}
.why-card,
.service-card,
.hosp-card,
.testi-card,
.ci-card {
  padding: 1.55rem;
}
.why-card::before,
.service-card::before,
.hosp-card::before,
.testi-card::before,
.ci-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--lux-teal), var(--lux-gold), var(--lux-rose));
  opacity: 0.9;
}
.why-icon,
.sc-icon,
.tl-dot,
.testi-avatar {
  background: linear-gradient(135deg, var(--lux-navy), var(--lux-teal));
  box-shadow: 0 12px 26px rgba(11,143,131,0.2);
}
.sc-icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  color: #fff;
}
.sc-number { color: rgba(36,52,111,0.08); }
.sc-tags span,
.hosp-tags span,
.cost-badge,
.country-item {
  color: #25465a;
  background: linear-gradient(135deg, rgba(11,143,131,0.08), rgba(216,175,95,0.13));
  border-color: rgba(11,143,131,0.16);
}
.treatments-tabs {
  border-radius: 16px;
  padding: 0.45rem;
  box-shadow: var(--lux-shadow);
}
.tab-btn { border-radius: 12px; }
.tab-btn.active { background: linear-gradient(135deg, var(--lux-navy), var(--lux-teal)); }
.treat-img,
.treat-img-inner { border-radius: 22px; }
.treat-img { box-shadow: var(--lux-shadow-deep); }
.treat-cost { background: linear-gradient(135deg, rgba(11,143,131,0.08), rgba(255,250,240,0.95)); }
.cost-range,
.china-price { color: var(--lux-rose); }
.cost-table-wrap { overflow: hidden; }
.cost-table th { background: #f4f8f7; }
.cost-table th.hl-col,
.cost-table td.hl-col { background: #ecf8f5; }
.timeline::before { background: linear-gradient(to bottom, var(--lux-gold), var(--lux-teal), rgba(11,143,131,0.08)); }
.contact-form-wrap { background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(242,250,248,0.92)); }
.form-group input,
.form-group select,
.form-group textarea,
.file-upload-area {
  border-radius: 14px;
  border-color: rgba(16,27,61,0.12);
}
.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
  border-color: var(--lux-teal);
  box-shadow: 0 0 0 4px rgba(11,143,131,0.12);
}

.inner-page-body .inner-hero,
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  width: min(var(--wrap), calc(100% - 2rem));
}
.inner-page-body .inner-hero {
  border-radius: 26px;
  background:
    linear-gradient(120deg, rgba(8,15,34,0.94), rgba(36,52,111,0.84), rgba(11,143,131,0.7)),
    url('https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=1800&q=85') center/cover;
  box-shadow: var(--lux-shadow-deep);
}
.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section {
  border-radius: 26px;
  background: rgba(255,255,255,0.74);
  border-color: rgba(16,27,61,0.08);
}

.footer {
  margin-top: 1rem;
  background:
    radial-gradient(circle at 18% 0%, rgba(216,175,95,0.2), transparent 22rem),
    radial-gradient(circle at 86% 0%, rgba(11,143,131,0.22), transparent 24rem),
    linear-gradient(135deg, #080f22 0%, #101b3d 48%, #0b615a 100%);
}
.footer-container,
.footer-bottom { max-width: var(--wrap); }

@media (max-width: 980px) {
  :root { --wrap: calc(100% - 2rem); }
  .hero-container {
    grid-template-columns: 1fr;
    grid-template-areas:
      "badge"
      "title"
      "sub"
      "actions"
      "stats"
      "visual";
    min-height: auto;
    padding: 4rem 0 4.5rem;
  }
  .hero-visual {
    max-width: 560px;
    min-height: 420px;
  }
  section:not(.hero):not(.inner-hero) > .container,
  .nav-container,
  .footer-container,
  .footer-bottom {
    max-width: var(--wrap);
  }
}

@media (max-width: 760px) {
  :root { --wrap: calc(100% - 1rem); }
  .nav-container { height: 70px; }
  .hero {
    padding-top: 70px;
    min-height: auto;
  }
  .hero-container {
    padding: 3.2rem 0 4rem;
  }
  .hero-title {
    font-size: clamp(2.35rem, 12vw, 3.85rem);
  }
  .hero-stats {
    grid-template-columns: 1fr 1fr;
  }
  .hero-visual { min-height: 465px; }
  .care-card-main { width: 100%; inset: 0 auto auto 0; }
  .care-card-side,
  .care-card-side.accent {
    width: calc(50% - 0.5rem);
    bottom: 24px;
  }
  .care-card-side { left: 0; right: auto; }
  .care-card-side.accent { right: 0; left: auto; }
  .why-grid,
  .services-grid,
  .hosp-grid,
  .testi-grid,
  .contact-info { grid-template-columns: 1fr; }
  .why-section,
  .services-section,
  .treatments-section,
  .cost-section,
  .hospitals-section,
  .process-section,
  .testimonials-section,
  .countries-section,
  .contact-section {
    padding: 4rem 0;
  }
  .why-section::before,
  .services-section::before,
  .treatments-section::before,
  .cost-section::before,
  .hospitals-section::before,
  .process-section::before,
  .testimonials-section::before,
  .contact-section::before {
    inset: 0.55rem;
    border-radius: 20px;
  }
  .inner-page-body .inner-hero,
  .inner-page-body .services-section,
  .inner-page-body .treatments-section,
  .inner-page-body .hospitals-section,
  .inner-page-body .contact-section {
    width: calc(100% - 1rem);
    border-radius: 20px;
  }
}

@media (max-width: 520px) {
  .hero-actions a { width: 100%; justify-content: center; }
  .hero-stats { gap: 0; }
  .stat { padding: 0.9rem 0.5rem; }
  .care-card-side strong { font-size: 1.45rem; }
  .care-card-side p { display: none; }
  .why-card,
  .service-card,
  .hosp-card,
  .testi-card,
  .ci-card,
  .tl-content,
  .contact-form-wrap { padding: 1.25rem; }
  .section-title { font-size: clamp(1.9rem, 10vw, 2.65rem); }
}

/* ===== FINAL CALMCARE PREMIUM THEME ===== */
:root {
  --wrap: 940px;
  --final-ink: #101828;
  --final-blue: #172554;
  --final-cobalt: #2453a6;
  --final-teal: #087f78;
  --final-aqua: #35c9b4;
  --final-sage: #e8f5ef;
  --final-ivory: #fff8ea;
  --final-gold: #d9b56d;
  --final-clay: #b56b5f;
  --final-paper: #ffffff;
  --final-soft: #f6faf8;
  --final-line: rgba(16, 24, 40, 0.1);
  --final-shadow: 0 22px 70px rgba(16, 24, 40, 0.12);
  --final-deep: 0 42px 120px rgba(16, 24, 40, 0.26);
}

body,
.inner-page-body {
  color: var(--final-ink);
  background:
    radial-gradient(circle at 0% 4%, rgba(53,201,180,0.14), transparent 26rem),
    radial-gradient(circle at 100% 10%, rgba(217,181,109,0.16), transparent 28rem),
    linear-gradient(180deg, #fbfefd 0%, #f2f8f5 48%, #fff8ea 100%);
}

/* Full-width banners and bars; wrapped content */
#navbar,
.inner-page-body #navbar {
  width: 100%;
  left: 0;
  right: 0;
  top: 0;
  transform: none;
  border-radius: 0;
  background: rgba(255,255,255,0.9);
  backdrop-filter: blur(22px) saturate(1.2);
  border-bottom: 1px solid rgba(23,37,84,0.08);
}
.nav-container,
.hero-container,
.inner-hero .container,
.footer-container,
.footer-bottom,
section:not(.hero):not(.inner-hero) > .container {
  max-width: var(--wrap);
}

.hero,
.inner-page-body .inner-hero {
  width: 100%;
  border-radius: 0;
  margin-left: 0;
  margin-right: 0;
  overflow: hidden;
}
.hero {
  min-height: 92vh;
  background:
    linear-gradient(112deg, rgba(10,18,40,0.96) 0%, rgba(23,37,84,0.9) 46%, rgba(8,127,120,0.78) 100%),
    url('https://images.unsplash.com/photo-1519494026892-80bbd2d6fd0d?auto=format&fit=crop&w=2200&q=88') center/cover;
}
.hero::before,
.inner-page-body .inner-hero::before {
  content: '';
  display: block;
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 26%, rgba(53,201,180,0.2), transparent 20rem),
    radial-gradient(circle at 78% 16%, rgba(217,181,109,0.2), transparent 18rem),
    linear-gradient(90deg, rgba(255,255,255,0.05), transparent 42%);
  pointer-events: none;
}
.hero-container {
  position: relative;
  z-index: 2;
}
.inner-page-body .inner-hero {
  position: relative;
  margin: 82px 0 0;
  padding: 5rem 0;
  background:
    linear-gradient(112deg, rgba(10,18,40,0.95), rgba(36,83,166,0.78), rgba(8,127,120,0.75)),
    url('https://images.unsplash.com/photo-1505751172876-fa1923c5c528?auto=format&fit=crop&w=1800&q=88') center/cover;
  box-shadow: none;
}
.inner-page-body .inner-hero .container {
  position: relative;
  z-index: 2;
}
.inner-page-body .inner-hero h1 {
  max-width: 820px;
  color: #fff;
}
.inner-page-body .inner-hero p {
  max-width: 680px;
  color: rgba(255,255,255,0.82);
}

.nav-links a {
  border-radius: 999px;
  color: #344054;
}
.nav-links a:hover,
.nav-links a.active {
  color: var(--final-blue);
  background: linear-gradient(135deg, rgba(53,201,180,0.14), rgba(217,181,109,0.15));
}

.hero-title {
  color: #fff;
  letter-spacing: -0.01em;
}
.hero-title em { color: #bffff3; }
.stroke-text { color: #ffe1a7; }
.hero-sub { color: rgba(255,255,255,0.84); }
.hero-badge,
.inner-hero .section-tag {
  color: #dffef8;
  background: rgba(255,255,255,0.11);
  border-color: rgba(255,255,255,0.24);
}
.btn-primary {
  background: linear-gradient(135deg, var(--final-aqua), var(--final-teal) 45%, var(--final-blue));
  box-shadow: 0 18px 48px rgba(8,127,120,0.28);
}
.btn-primary:hover {
  background: linear-gradient(135deg, #6ce5d4, var(--final-teal), #0f1f4f);
}
.btn-ghost {
  border-color: rgba(255,255,255,0.28);
  background: rgba(255,255,255,0.12);
}
.hero-stats,
.care-card,
.info-card,
.prep-panel,
.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.contact-form-wrap,
.ci-card,
.cost-table-wrap,
.treat-cost,
.country-item {
  border-radius: 22px;
}
.hero-stats {
  background: rgba(255,255,255,0.12);
  border: 1px solid rgba(255,255,255,0.22);
  box-shadow: 0 26px 80px rgba(0,0,0,0.2);
}
.stat-num,
.stat > span:last-of-type { color: #ffe1a7; }

.care-card,
.info-card,
.prep-panel,
.why-card,
.service-card,
.hosp-card,
.testi-card,
.tl-content,
.contact-form-wrap,
.ci-card,
.cost-table-wrap,
.treat-cost,
.country-item {
  background: linear-gradient(180deg, rgba(255,255,255,0.98), rgba(250,253,251,0.92));
  border: 1px solid var(--final-line);
  box-shadow: var(--final-shadow);
}
.care-avatar,
.why-icon,
.sc-icon,
.tl-dot,
.testi-avatar,
#cwSend {
  background: linear-gradient(135deg, var(--final-blue), var(--final-teal));
}
.care-progress span,
.why-card::before,
.service-card::before,
.hosp-card::before,
.testi-card::before,
.ci-card::before {
  background: linear-gradient(90deg, var(--final-aqua), var(--final-gold), var(--final-clay));
}
.section-tag {
  color: var(--final-teal);
  background: linear-gradient(135deg, rgba(53,201,180,0.12), rgba(217,181,109,0.15));
  border-color: rgba(8,127,120,0.16);
}
.section-title { color: var(--final-blue); }
.section-title em { color: var(--final-clay); }
.section-sub { color: #667085; }

.why-section,
.treatments-section,
.testimonials-section,
.contact-section,
.info-band {
  background: linear-gradient(180deg, #ffffff 0%, #f8fcfa 100%);
}
.services-section,
.cost-section,
.process-section,
.countries-section,
.comfort-section {
  background: linear-gradient(180deg, #f1f8f5 0%, #fff8ea 100%);
}

.comfort-section,
.info-band {
  position: relative;
  padding: 5.6rem 0;
}
.comfort-section::before,
.info-band::before {
  content: '';
  position: absolute;
  inset: 1rem max(1rem, calc((100vw - var(--wrap)) / 2 - 1rem));
  border-radius: 30px;
  border: 1px solid rgba(16,24,40,0.06);
  background: linear-gradient(180deg, rgba(255,255,255,0.5), rgba(255,255,255,0));
  pointer-events: none;
}
.info-grid {
  display: grid;
  gap: 1rem;
  position: relative;
  z-index: 1;
}
.info-grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.info-grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.info-card {
  padding: 1.45rem;
  position: relative;
  overflow: hidden;
}
.info-card::before {
  content: '';
  position: absolute;
  inset: 0 0 auto 0;
  height: 3px;
  background: linear-gradient(90deg, var(--final-aqua), var(--final-gold), var(--final-clay));
}
.info-card i {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  margin-bottom: 1rem;
  color: #fff;
  background: linear-gradient(135deg, var(--final-blue), var(--final-teal));
  box-shadow: 0 12px 28px rgba(8,127,120,0.2);
}
.info-card h3,
.prep-panel h3 {
  color: var(--final-blue);
  font-size: 1.02rem;
  margin-bottom: 0.55rem;
}
.info-card p,
.prep-panel li {
  color: #667085;
  font-size: 0.9rem;
  line-height: 1.65;
}
.prep-panel {
  margin-top: 1.2rem;
  padding: 1.55rem;
  display: grid;
  grid-template-columns: 0.75fr 1.25fr;
  gap: 1.5rem;
  align-items: start;
  position: relative;
  z-index: 1;
}
.prep-panel.compact {
  grid-template-columns: 0.8fr 1.2fr;
}
.prep-panel ul {
  margin: 0;
  padding-left: 1.1rem;
}
.prep-panel li { margin-bottom: 0.45rem; }
.mini-label {
  display: inline-block;
  color: var(--final-teal);
  font-size: 0.72rem;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  margin-bottom: 0.45rem;
}

.inner-page-body .services-section,
.inner-page-body .treatments-section,
.inner-page-body .hospitals-section,
.inner-page-body .contact-section,
.inner-page-body .info-band {
  width: min(var(--wrap), calc(100% - 2rem));
  margin: 1.2rem auto;
  border-radius: 30px;
  overflow: hidden;
  border: 1px solid rgba(16,24,40,0.08);
  box-shadow: var(--final-shadow);
}
.inner-page-body .info-band {
  background: rgba(255,255,255,0.82);
}

.footer,
.inner-page-body .footer {
  width: 100%;
  border-radius: 0;
  margin: 0;
  background:
    radial-gradient(circle at 18% 0%, rgba(217,181,109,0.22), transparent 24rem),
    radial-gradient(circle at 84% 6%, rgba(53,201,180,0.2), transparent 24rem),
    linear-gradient(135deg, #081128 0%, #172554 50%, #075f59 100%);
}

@media (max-width: 980px) {
  :root { --wrap: calc(100% - 2rem); }
  .info-grid.four,
  .info-grid.three { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .inner-page-body .inner-hero { margin-top: 70px; }
}
@media (max-width: 760px) {
  :root { --wrap: calc(100% - 1rem); }
  .inner-page-body .inner-hero {
    padding: 3.5rem 0;
  }
  .comfort-section,
  .info-band { padding: 4rem 0; }
  .info-grid.four,
  .info-grid.three { grid-template-columns: 1fr; }
  .prep-panel,
  .prep-panel.compact { grid-template-columns: 1fr; gap: 1rem; }
  .inner-page-body .services-section,
  .inner-page-body .treatments-section,
  .inner-page-body .hospitals-section,
  .inner-page-body .contact-section,
  .inner-page-body .info-band {
    width: calc(100% - 1rem);
    border-radius: 22px;
  }
}
@media (max-width: 520px) {
  .info-card,
  .prep-panel { padding: 1.2rem; }
  .hero-title { font-size: clamp(2.25rem, 12vw, 3.5rem); }
}

