/* ==========================================================================
   NEO HOSPITAL — CARDIOLOGY LANDING PAGE
   style.css — base design system + component styles (desktop-first)
   Responsive overrides live in responsive.css
   ========================================================================== */

/* ---------- DESIGN TOKENS ---------- */
:root{
  /* Brand palette (per brief) */
  --color-primary:      #00A9CE;
  --color-primary-dark: #007A9E;
  --color-primary-light:#E6F7FB;
  --color-secondary:    #F36C28;
  --color-secondary-light:#FFF1E8;
  --color-bg:           #F8FBFD;
  --color-text:         #1D3557;
  --color-white:        #FFFFFF;
  --color-success:      #2BB673;
  --color-border:       #E3EEF3;

  /* Gradients */
  --gradient-primary: linear-gradient(135deg, #00A9CE 0%, #007A9E 100%);
  --gradient-accent:  linear-gradient(135deg, #F36C28 0%, #FF8A50 100%);
  --gradient-hero:    radial-gradient(circle at 85% 15%, rgba(0,169,206,0.10), transparent 45%),
                       radial-gradient(circle at 5% 85%, rgba(243,108,40,0.08), transparent 40%);

  /* Typography */
  --font-main: 'Poppins', sans-serif;

  /* Shadows */
  --shadow-sm: 0 4px 14px rgba(29,53,87,0.06);
  --shadow-md: 0 10px 30px rgba(29,53,87,0.09);
  --shadow-lg: 0 20px 50px rgba(29,53,87,0.14);
  --shadow-glow: 0 12px 40px rgba(0,169,206,0.25);

  /* Radius */
  --radius-sm: 10px;
  --radius-md: 18px;
  --radius-lg: 26px;
  --radius-pill: 999px;

  /* Spacing */
  --section-pad: 50px;
  --container-w: 1240px;
}

/* ---------- RESET ---------- */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  font-family:var(--font-main);
  color:var(--color-text);
  background:var(--color-bg);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ text-decoration:none; color:inherit; }
ul{ list-style:none; }
button{ font-family:inherit; border:none; background:none; cursor:pointer; }
input{ font-family:inherit; }
:focus-visible{ outline:3px solid var(--color-secondary); outline-offset:2px; }
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:0.001ms !important; animation-iteration-count:1 !important; transition-duration:0.001ms !important; scroll-behavior:auto !important; }
}

.container{ max-width:var(--container-w); margin:0 auto; padding:0 24px; }

h1,h2,h3,h4{ font-family:var(--font-main); color:var(--color-text); font-weight:700; line-height:1.2; }
h1{ font-size:3.1rem; font-weight:800; letter-spacing:-0.02em; }
h2{ font-size:2.3rem; font-weight:700; letter-spacing:-0.01em; }
h3{ font-size:1.2rem; font-weight:600; }
p{ color:#48607F; }

.text-accent{ color:var(--color-secondary); }

.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  font-size:0.82rem; font-weight:600; letter-spacing:0.06em; text-transform:uppercase;
  color:var(--color-primary-dark);
  background:var(--color-primary-light);
  padding:7px 16px; border-radius:var(--radius-pill);
  margin-bottom:18px;
}
.section-heading{ max-width:100%; margin:0 auto 56px; text-align:center; }
.section-heading h2{ margin-bottom:12px; }
.section-heading p{ font-size:1.02rem; }
.section-heading--light .eyebrow{ background:rgba(255,255,255,0.14); color:var(--color-white); }
.section-heading--light h2{ color:var(--color-white); }
.section-heading--light p{ color:rgba(255,255,255,0.75); }

/* ---------- BUTTONS ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:9px;
  font-weight:600; font-size:0.96rem;
  padding:15px 30px; border-radius:var(--radius-pill);
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
  white-space:nowrap;
}
.btn:hover{ transform:translateY(-3px); }
.btn--primary{ background:var(--gradient-primary); color:var(--color-white); box-shadow:var(--shadow-glow); }
.btn--primary:hover{ box-shadow:0 16px 46px rgba(0,169,206,0.35); }
.btn--outline{ background:var(--color-white); color:var(--color-text); border:2px solid var(--color-border); }
.btn--outline:hover{ border-color:var(--color-primary); color:var(--color-primary); }
.btn--whatsapp{ background:#25D366; color:var(--color-white); }
.btn--whatsapp:hover{ box-shadow:0 14px 34px rgba(37,211,102,0.35); }
.btn--ghost{ background:var(--color-primary-light); color:var(--color-primary-dark); }
.btn--ghost:hover{ background:var(--color-primary); color:var(--color-white); }
.btn--white{ background:var(--color-white); color:var(--color-secondary); }
.btn--outline-white{ background:transparent; color:var(--color-white); border:2px solid rgba(255,255,255,0.6); }
.btn--outline-white:hover{ background:rgba(255,255,255,0.12); }
.btn--sm{ padding:10px 16px; font-size:0.82rem; border-radius:var(--radius-sm); }
.btn--full{ width:100%; }
.cta-inline{ text-align:center; margin-top:48px; }

/* ---------- SCROLL PULSE PROGRESS (signature element) ---------- */
.pulse-progress{ position:fixed; top:0; left:0; width:100%; height:5px; z-index:999; background:rgba(255,255,255,0.6); backdrop-filter:blur(2px); }
.pulse-progress__svg{ width:100%; height:100%; display:block; }
#pulseProgressPath{ stroke-dasharray:1400; stroke-dashoffset:1400; transition:stroke-dashoffset .1s linear; }

/* ---------- BREADCRUMB ---------- */
.breadcrumb-bar{ background:var(--color-white); border-bottom:1px solid var(--color-border); padding:16px 0; }
.breadcrumb-list{ display:flex; align-items:center; gap:10px; font-size:0.88rem; color:#7C8BA3; }
.breadcrumb-list li{ display:flex; align-items:center; gap:10px; }
.breadcrumb-list i{ font-size:0.65rem; color:#B9C6D6; }
.breadcrumb-list a{ transition:color .2s; }
.breadcrumb-list a:hover{ color:var(--color-primary); }
.breadcrumb-list span{ color:var(--color-text); font-weight:600; }

/* ---------- HERO ---------- */
.hero{ position:relative; padding:70px 0 130px; background:var(--gradient-hero), var(--color-bg); overflow:hidden; }
.hero__ekg-bg{ position:absolute; top:0; left:0; width:100%; height:300px; opacity:0.5; pointer-events:none; }
.hero__ekg-bg svg{ width:100%; height:100%; }
.ekg-trace{ stroke-dasharray:2000; stroke-dashoffset:2000; animation:drawEkg 3.2s ease forwards 0.3s; }
@keyframes drawEkg{ to{ stroke-dashoffset:0; } }

.hero__grid{ position:relative; z-index:2; display:grid; grid-template-columns:1.05fr 0.95fr; gap:60px; align-items:center; }
.hero__title{ margin-bottom:22px; }
.hero__desc{ font-size:1.08rem; max-width:520px; margin-bottom:28px; }

.trust-badges{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:36px; }
.trust-badges li{
  display:flex; align-items:center; gap:8px; font-size:0.86rem; font-weight:500;
  background:var(--color-white); padding:10px 16px; border-radius:var(--radius-pill);
  box-shadow:var(--shadow-sm); color:var(--color-text);
}
.trust-badges i{ color:var(--color-secondary); }
.trust-badges strong{ color:var(--color-primary-dark); }

.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; }

.hero__visual{ position:relative; }
.hero__image-wrap{ position:relative; border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-lg); }
.hero__doctor-img{ width:100%; height:560px; object-fit:cover; }

.hero__floating-tag{
  position:absolute; display:flex; align-items:center; gap:12px;
  background:rgba(255,255,255,0.85); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,0.5);
  padding:14px 18px; border-radius:var(--radius-md); box-shadow:var(--shadow-md);
}
.hero__floating-tag i{ font-size:1.4rem; color:var(--color-secondary); }
.hero__floating-tag strong{ display:block; font-size:1.05rem; color:var(--color-text); }
.hero__floating-tag span{ font-size:0.76rem; color:#6C7E96; }
.hero__floating-tag--top{ top:28px; left:-30px; }
.hero__floating-tag--bottom{ bottom:120px; right:-24px; }

.glass-card{
  background:rgba(255,255,255,0.82);
  backdrop-filter:blur(18px); -webkit-backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,0.6);
}
.appointment-card{
  margin:-90px 30px 0; position:relative; z-index:3;
  border-radius:var(--radius-lg); padding:30px 32px; box-shadow:var(--shadow-lg);
}
.appointment-card h3{ margin-bottom:4px; }
.appointment-card__sub{ font-size:0.85rem; color:var(--color-secondary); font-weight:500; margin-bottom:20px; }

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

.form-field{ margin-bottom:14px; }
.form-row{ display:grid; grid-template-columns:1fr 1fr; gap:12px; margin-bottom:14px; }
.form-row .form-field{ margin-bottom:0; }

.form-field input,
.form-field select,
.form-field textarea{
  width:100%; padding:16px 18px; border-radius:14px;
  border:1.5px solid var(--color-border); background:var(--color-white);
  font-family:var(--font-main); font-size:0.95rem; color:var(--color-text);
  transition:border-color .2s ease, box-shadow .2s ease;
}
.form-field input::placeholder,
.form-field textarea::placeholder{ color:#94A3B8; font-weight:400; }
.form-field select{ color:#94A3B8; appearance:none; -webkit-appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2394A3B8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 16px center; background-size:16px; padding-right:42px;
}
.form-field select:valid{ color:var(--color-text); }
.form-field textarea{ resize:vertical; min-height:90px; font-family:var(--font-main); }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus{ border-color:var(--color-primary); box-shadow:0 0 0 4px rgba(0,169,206,0.12); outline:none; }
.form-field input[type="date"]{ color:var(--color-text); }
.form-field input[type="date"]::-webkit-calendar-picker-indicator{ cursor:pointer; opacity:0.6; }

/* ---------- QUICK INFO CARDS ---------- */
.quick-info{ padding:0 0 var(--section-pad); margin-top:-60px; position:relative; z-index:4; }
.quick-info__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:26px; }
.info-card{
  background:var(--color-white); border-radius:var(--radius-md); padding:32px 26px;
  box-shadow:var(--shadow-sm); transition:transform .3s ease, box-shadow .3s ease;
  border:1px solid var(--color-border);
}
.info-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); border-color:var(--color-primary); }
.info-card__icon{
  width:58px; height:58px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  background:var(--gradient-primary); color:var(--color-white); font-size:1.4rem; margin-bottom:20px;
}
.info-card h3{ margin-bottom:10px; font-size:1.08rem; }
.info-card p{ font-size:0.9rem; }

/* ---------- WELCOME SECTION ---------- */
.welcome-section{ padding:var(--section-pad) 0; }
.welcome-section__grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:70px; align-items:center; }
.welcome-section__image{ position:relative; }
.welcome-section__image img{ border-radius:var(--radius-lg); box-shadow:var(--shadow-md); width:100%; height:440px; object-fit:cover; }
.welcome-section__badge{
  position:absolute; bottom:-24px; left:24px; display:flex; align-items:center; gap:12px;
  background:var(--color-white); padding:16px 20px; border-radius:var(--radius-md); box-shadow:var(--shadow-lg);
  font-weight:600; font-size:0.88rem;
}
.welcome-section__badge i{ color:var(--color-secondary); font-size:1.3rem; }
.welcome-section__content h2{ margin-bottom:20px; }
.welcome-section__content p{ margin-bottom:16px; }
.welcome-section__points{ margin:24px 0 30px; }
.welcome-section__points li{ display:flex; align-items:center; gap:10px; margin-bottom:12px; font-weight:500; font-size:0.95rem; }
.welcome-section__points i{ color:var(--color-success); }

/* ---------- SPECIALISTS ---------- */
.specialists{ padding:var(--section-pad) 0; background:var(--color-white); }
.doctors-slider{ padding-bottom:56px; }
.doctor-card{
  background:var(--color-bg); border-radius:var(--radius-lg); overflow:hidden;
  border:1px solid var(--color-border); transition:transform .3s ease, box-shadow .3s ease; height:100%;
}
.doctor-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.doctor-card__img img{ width:100%; height:250px; object-fit:cover; }
.doctor-card__body{ padding:24px; }
.doctor-card__degree{ font-size:0.78rem; color:var(--color-primary-dark); font-weight:600; }
.doctor-card__role{ font-size:0.88rem; color:var(--color-secondary); font-weight:500; margin:6px 0 14px; }
.doctor-card__meta li{ display:flex; align-items:center; gap:8px; font-size:0.82rem; color:#5A6E88; margin-bottom:8px; }
.doctor-card__meta i{ color:var(--color-primary); width:14px; }
.doctor-card__cta{ display:flex; gap:10px; margin-top:18px; }
.doctor-card__cta .btn{ flex:1 1 0; min-width:0; white-space:normal; text-align:center; line-height:1.25; }

.swiper-button-prev, .swiper-button-next{
  color:var(--color-primary) !important; background:var(--color-white); width:46px !important; height:46px !important;
  border-radius:50%; box-shadow:var(--shadow-sm); top:40% !important;
}
.swiper-button-prev::after, .swiper-button-next::after{ font-size:1rem !important; font-weight:700; }
.swiper-pagination-bullet-active{ background:var(--color-primary) !important; }

/* ---------- WHY CHOOSE ---------- */
.why-choose{ padding:var(--section-pad) 0; background:var(--color-text); position:relative; overflow:hidden; }
.why-choose::before{
  content:''; position:absolute; inset:0;
  background:radial-gradient(circle at 20% 20%, rgba(0,169,206,0.18), transparent 40%),
             radial-gradient(circle at 80% 80%, rgba(243,108,40,0.14), transparent 40%);
}
.why-choose__grid{ position:relative; display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.why-card{
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-md); padding:34px 28px; transition:transform .3s ease, background .3s ease;
}
.why-card:hover{ transform:translateY(-6px); background:rgba(255,255,255,0.1); }
.why-card i{ font-size:1.8rem; color:var(--color-secondary); margin-bottom:18px; display:block; }
.why-card h3{ color:var(--color-white); margin-bottom:8px; }
.why-card p{ color:rgba(255,255,255,0.68); font-size:0.9rem; }

/* ---------- STATS ---------- */
.stats{ padding:80px 0; background:var(--gradient-primary); }
.stats__grid{ display:grid; grid-template-columns:repeat(4,1fr); text-align:center; gap:20px; }
.stat-item__num{ font-size:3rem; font-weight:800; color:var(--color-white); }
.stat-item__plus{ font-size:2.2rem; font-weight:800; color:var(--color-white); }
.stat-item p{ color:rgba(255,255,255,0.85); font-weight:500; margin-top:6px; }

/* ---------- SYMPTOMS ---------- */
.symptoms{ padding:var(--section-pad) 0; }
.symptoms__grid{ display:grid; grid-template-columns:repeat(6,1fr); gap:20px; }
.symptom-card{
  background:var(--color-white); border:1px solid var(--color-border); border-radius:var(--radius-md);
  padding:28px 16px; text-align:center; transition:transform .3s ease, border-color .3s;
}
.symptom-card:hover{ transform:translateY(-6px); border-color:var(--color-secondary); }
.symptom-card i{ font-size:1.7rem; color:var(--color-secondary); margin-bottom:14px; display:block; }
.symptom-card span{ font-size:0.86rem; font-weight:600; }

/* ---------- CONDITIONS ---------- */
.conditions{ padding:var(--section-pad) 0; background:var(--color-white); }
.conditions__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.chip-card{
  display:flex; align-items:center; gap:12px; background:var(--color-primary-light);
  border-radius:var(--radius-md); padding:20px 22px; font-weight:600; font-size:0.92rem;
  color:var(--color-primary-dark); transition:background .3s ease, transform .3s ease;
}
.chip-card:hover{ background:var(--color-primary); color:var(--color-white); transform:translateY(-4px); }
.chip-card i{ font-size:1.2rem; }

/* ---------- TREATMENTS ---------- */
.treatments{ padding:var(--section-pad) 0; }
.treatments__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:20px; }
.treatment-card{
  background:var(--color-white); border-radius:var(--radius-md); padding:34px 20px; text-align:center;
  border:1px solid var(--color-border); transition:all .3s ease;
}
.treatment-card:hover{ background:var(--gradient-accent); border-color:transparent; transform:translateY(-6px); box-shadow:var(--shadow-md); }
.treatment-card:hover i, .treatment-card:hover h3{ color:var(--color-white); }
.treatment-card i{ font-size:1.8rem; color:var(--color-primary); margin-bottom:14px; display:block; transition:color .3s; }
.treatment-card h3{ font-size:1rem; transition:color .3s; }

/* ---------- FACILITIES ---------- */
.facilities{ padding:var(--section-pad) 0; background:var(--color-white); }
.facilities__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.facility-card{ border-radius:var(--radius-md); overflow:hidden; position:relative; box-shadow:var(--shadow-sm); }
.facility-card img{ width:100%; height:220px; object-fit:cover; transition:transform .4s ease; }
.facility-card:hover img{ transform:scale(1.08); }
.facility-card__body{
  position:absolute; bottom:0; left:0; right:0; padding:20px;
  background:linear-gradient(0deg, rgba(29,53,87,0.85), transparent);
  display:flex; align-items:center; gap:12px;
}
.facility-card__body i{ color:var(--color-secondary); font-size:1.3rem; }
.facility-card__body h3{ color:var(--color-white); }

/* ---------- PATIENT JOURNEY ---------- */
.journey{ padding:var(--section-pad) 0; }
.journey__track{ display:grid; grid-template-columns:repeat(6,1fr); gap:0; position:relative; }
.journey__track::before{
  content:''; position:absolute; top:38px; left:8%; right:8%; height:2px;
  background:repeating-linear-gradient(90deg, var(--color-border) 0 10px, transparent 10px 18px);
  z-index:0;
}
.journey__step{ text-align:center; position:relative; z-index:1; }
.journey__icon{
  width:78px; height:78px; border-radius:50%; background:var(--color-white); border:2px solid var(--color-primary);
  display:flex; align-items:center; justify-content:center; margin:0 auto 16px; box-shadow:var(--shadow-sm);
  transition:background .3s, transform .3s;
}
.journey__icon i{ font-size:1.5rem; color:var(--color-primary); transition:color .3s; }
.journey__step:hover .journey__icon{ background:var(--gradient-primary); transform:scale(1.08); }
.journey__step:hover .journey__icon i{ color:var(--color-white); }
.journey__step h3{ font-size:0.95rem; }

/* ---------- TESTIMONIALS ---------- */
.testimonials{ padding:var(--section-pad) 0; background:var(--color-text); }
.testimonials-slider{ padding-bottom:50px; }
.testimonial-card{
  background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.12);
  border-radius:var(--radius-lg); padding:34px; height:100%;
}
.testimonial-card__stars{ color:var(--color-secondary); margin-bottom:16px; font-size:0.95rem; }
.testimonial-card p{ color:rgba(255,255,255,0.82); font-size:0.96rem; margin-bottom:22px; font-style:italic; }
.testimonial-card__author{ display:flex; align-items:center; gap:14px; }
.testimonial-card__author img{ width:50px; height:50px; border-radius:50%; object-fit:cover; }
.testimonial-card__author strong{ color:var(--color-white); display:block; font-size:0.92rem; }
.testimonial-card__author span{ color:rgba(255,255,255,0.6); font-size:0.8rem; }

/* ---------- GOOGLE REVIEWS ---------- */
.google-reviews{ padding:70px 0; background:var(--color-white); }
.google-reviews__inner{ text-align:center; }
.google-reviews__inner > i{ font-size:2.6rem; color:#4285F4; margin-bottom:14px; }
.google-reviews__stars{ color:#FBBC05; font-size:1.5rem; margin-bottom:14px; }
.google-reviews__inner h3{ font-size:2rem; }
.google-reviews__inner p{ font-size:0.95rem; }

/* ---------- FAQ ---------- */
.faq{ padding:var(--section-pad) 0; }
.accordion{ max-width:840px; margin:0 auto; }
.accordion-item{ background:var(--color-white); border:1px solid var(--color-border); border-radius:var(--radius-md); margin-bottom:14px; overflow:hidden; }
.accordion-header{
  width:100%; text-align:left; padding:22px 26px; font-weight:600; font-size:1rem;
  display:flex; justify-content:space-between; align-items:center; color:var(--color-text);
}
.accordion-header i{ color:var(--color-primary); transition:transform .3s ease; }
.accordion-item.active .accordion-header i{ transform:rotate(180deg); }
.accordion-item.active .accordion-header{ color:var(--color-primary-dark); }
.accordion-body{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.accordion-body p{ padding:0 26px 22px; font-size:0.92rem; }

/* ---------- BLOGS ---------- */
.blogs{ padding:var(--section-pad) 0; background:var(--color-white); }
.blogs__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:28px; }
.blog-card{ border-radius:var(--radius-md); overflow:hidden; border:1px solid var(--color-border); transition:transform .3s ease, box-shadow .3s ease; }
.blog-card:hover{ transform:translateY(-8px); box-shadow:var(--shadow-md); }
.blog-card img{ width:100%; height:200px; object-fit:cover; }
.blog-card__body{ padding:22px; }
.blog-card__body h3{ font-size:1.02rem; margin-bottom:14px; min-height:52px; }
.blog-card__body a{ color:var(--color-secondary); font-weight:600; font-size:0.88rem; display:inline-flex; align-items:center; gap:6px; }

/* ---------- OTHER SPECIALISTS ---------- */
.other-specialists{ padding:var(--section-pad) 0; }
.other-specialists__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.specialist-chip{
  display:flex; align-items:center; gap:12px; font-weight:600; font-size:0.92rem; transition:all .3s ease;
}
.specialist-chip i{ color:var(--color-primary); font-size:1.1rem; }
.specialist-chip:hover{ background:var(--gradient-primary); color:var(--color-white); transform:translateY(-4px); box-shadow:var(--shadow-sm); }
.specialist-chip:hover i{ color:var(--color-white); }

/* ---------- TOP SPECIALITIES ---------- */
.top-specialities{ padding:var(--section-pad) 0; background:var(--color-white); }
.top-specialities__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.speciality-card{
  text-align:center; padding:34px 16px; border-radius:var(--radius-md); border:1px solid var(--color-border);
  transition:all .3s ease;
}
.speciality-card i{ font-size:1.8rem; color:var(--color-primary); margin-bottom:14px; display:block; transition:color .3s; }
.speciality-card span{ font-weight:600; font-size:0.92rem; }
.speciality-card:hover{ background:var(--gradient-accent); border-color:transparent; transform:translateY(-6px); box-shadow:var(--shadow-md); }
.speciality-card:hover i{ color:var(--color-white); }
.speciality-card:hover span{ color:var(--color-white); }

/* ---------- AWARDS ---------- */
.awards{ padding:var(--section-pad) 0; }
.awards__grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.award-card{
  display:flex; flex-direction:column; align-items:center; gap:14px; text-align:center;
  background:var(--color-white); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:32px 18px;
}
.award-card i{ font-size:2rem; color:var(--color-secondary); }
.award-card span{ font-weight:600; font-size:0.92rem; }

/* ---------- EMERGENCY CTA ---------- */
.emergency-cta{ position:relative; padding:80px 0; background:var(--hf-text); overflow:hidden; text-align:center; }
.emergency-cta__ekg{ position:absolute; inset:0; }
.emergency-cta__ekg svg{ width:100%; height:100%; }
.emergency-cta__inner{ position:relative; z-index:1; }
.emergency-cta h2{ color:var(--color-white); font-size:2.1rem; margin-bottom:14px; }
.emergency-cta p{ color:rgba(255,255,255,0.9); margin-bottom:30px; font-size:1.02rem; }
.emergency-cta__buttons{ display:flex; justify-content:center; gap:14px; flex-wrap:wrap; }

/* ---------- CONTACT INFO ---------- */
.contact-info{ padding:var(--section-pad) 0; background:var(--color-white); }
.contact-info__grid{ display:grid; grid-template-columns:0.9fr 1.1fr; gap:60px; align-items:stretch; }
.contact-info__details ul li{ display:flex; gap:16px; margin-bottom:26px; }
.contact-info__details i{
  width:46px; height:46px; border-radius:12px; background:var(--color-primary-light); color:var(--color-primary-dark);
  display:flex; align-items:center; justify-content:center; flex-shrink:0; font-size:1.1rem;
}
.contact-info__details strong{ display:block; font-size:0.95rem; margin-bottom:2px; }
.contact-info__details span, .contact-info__details a{ font-size:0.9rem; color:#5A6E88; }
.contact-info__map{ border-radius:var(--radius-lg); overflow:hidden; min-height:340px; box-shadow:var(--shadow-md); }

/* ---------- STICKY FLOATING BUTTONS ---------- */
.sticky-cta{ position:fixed; right:24px; bottom:28px; display:flex; flex-direction:column; gap:12px; z-index:500; }
.sticky-cta__btn{
  width:56px; height:56px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-size:1.35rem; color:var(--color-white); box-shadow:var(--shadow-lg); transition:transform .25s ease;
}
.sticky-cta__btn:hover{ transform:scale(1.1); }
.sticky-cta__btn--whatsapp{ background:#25D366; }
.sticky-cta__btn--call{ background:var(--color-secondary); }
.sticky-cta__btn--appointment{ background:var(--gradient-primary); }

/* ---------- AOS override so content isn't invisible if AOS fails to load ---------- */
[data-aos]{ opacity:1; }
/*=============================
When to Consult
=============================*/

.consult-section{
    background:#fff;
}

.consult-card{
    background:#ffffff;
    border-radius:18px;
    padding:45px;
    box-shadow:0 15px 40px rgba(0,0,0,.08);
}

.consult-list{
    list-style:none;
    margin:0;
    padding:0;
}

.consult-list li{
    position:relative;
    padding-left:55px;
    margin-bottom:30px;
    border-bottom:1px solid #edf2f7;
    padding-bottom:25px;
}

.consult-list li:last-child{
    margin-bottom:0;
    border:none;
}

.consult-list li::before{
    content:"✓";
    position:absolute;
    left:0;
    top:5px;
    width:34px;
    height:34px;
    border-radius:50%;
    background:#00A9CE;
    color:#fff;
    font-weight:700;
    display:flex;
    justify-content:center;
    align-items:center;
}

.consult-list h4{
    font-size:22px;
    font-weight:700;
    margin-bottom:10px;
    color:#1d3557;
}

.consult-list h4 i{
    color:#F36C28;
    margin-right:8px;
}

.consult-list p{
    margin:0;
    color:#555;
    line-height:1.9;
    font-size:16px;
}
@media(max-width:768px){

.consult-card{
    padding:25px;
}

.consult-list li{
    padding-left:45px;
}

.consult-list h4{
    font-size:18px;
}

.consult-list p{
    font-size:15px;
}

}


.section-heading h2{
    position: relative;
   
    padding-bottom: 12px;
    margin-bottom: 20px;
}

.section-heading h2::after{
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    transform: translateX(-50%);
    width: 180px;      /* underline ki width */
    height: 3px;
    background: #00A9CE; /* NEO Hospital primary color */
    border-radius: 10px;
}