/*
Theme Name: Dr. Samer Khalife
Theme URI:  https://drsamer.com
Author:     Dr. Samer Khalife Medical Practice
Description: Pixel-accurate WordPress theme for Dr. Samer Khalife — fully editable via Customizer.
Version:    2.0.1
License:    GNU General Public License v2 or later
Text Domain: dr-khalife
*/

/* ============================================================
   DESIGN TOKENS  (overridden at runtime by Customizer)
   ============================================================ */
:root {
  /* — medical palette (sky-blue family) — */
  --medical-50:  #f0f7ff;
  --medical-100: #e0f0fe;
  --medical-200: #bae2fd;
  --medical-300: #7dd3fc;
  --medical-400: #38bdf8;
  --medical-500: #0ea5e9;
  --medical-600: #0284c7;
  --medical-700: #0369a1;
  --medical-800: #075985;
  --medical-900: #0c4a6e;
  --medical-950: #082f49;

  /* — slate palette — */
  --slate-50:  #f8fafc;
  --slate-100: #f1f5f9;
  --slate-200: #e2e8f0;
  --slate-300: #cbd5e1;
  --slate-400: #94a3b8;
  --slate-500: #64748b;
  --slate-600: #475569;
  --slate-700: #334155;
  --slate-800: #1e293b;
  --slate-900: #0f172a;

  /* — customizer-driven accent tokens (defaults match original) — */
  --color-accent:           var(--medical-600);  /* logo bar, eyebrows, icon hover */
  --color-accent-hover:     var(--medical-400);  /* hero subtitle, eyebrow line */
  --color-hero-from:        #0f172a;             /* slate-900 */
  --color-hero-via:         #1e293b;             /* slate-800 */
  --color-hero-to:          #0c4a6e;             /* medical-900 */
  --color-hero-gradient-opacity: 0.9;
  --color-nav-bg:           rgba(255,255,255,0.95);
  --color-nav-cta-bg:       #0f172a;
  --color-nav-cta-text:     #ffffff;
  --color-section-dark-bg:  #0f172a;             /* IUS section */
  --color-stats-bg:         #f8fafc;             /* slate-50 */
  --color-primary-btn-bg:   #ffffff;
  --color-primary-btn-text: #0f172a;
  --color-footer-bg:        #ffffff;

  /* — typography — */
  --font-display: 'Plus Jakarta Sans', sans-serif;
  --font-body:    'Inter', sans-serif;

  /* — misc — */
  --shadow-soft: 0 4px 20px -2px rgba(0,0,0,0.05);
  --radius-2xl:  1rem;    /* rounded-2xl */
  --radius-3xl:  1.5rem;  /* rounded-3xl */
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-body);
  color: var(--slate-600);
  background: #fff;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
/* selection:bg-medical-100 selection:text-medical-900 */
::selection { background: var(--medical-100); color: var(--medical-900); }

/* scrollbar */
::-webkit-scrollbar { width: 8px; }
::-webkit-scrollbar-track { background: #fff; }
::-webkit-scrollbar-thumb { background: var(--slate-200); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--slate-300); }

img { max-width: 100%; height: auto; display: block; }
a { text-decoration: none; color: inherit; }
strong { font-weight: 600; }

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  max-width: 80rem;         /* max-w-7xl */
  margin-left: auto;
  margin-right: auto;
  padding-left:  1rem;      /* px-4 */
  padding-right: 1rem;
}
@media (min-width: 640px)  { .container { padding-left: 1.5rem; padding-right: 1.5rem; } }   /* sm:px-6 */
@media (min-width: 1024px) { .container { padding-left: 2rem;   padding-right: 2rem;   } }   /* lg:px-8 */

/* ============================================================
   NAVBAR  — glass-nav floating pill (exact match)
   ============================================================ */
#site-header {
  position: fixed;
  top: 0; left: 0; width: 100%;
  z-index: 50;
  padding-top: 1rem;          /* pt-4 */
  transition: padding-top .3s;
}
@media (min-width: 768px) { #site-header { padding-top: 1.5rem; } }   /* md:pt-6 */
#site-header.scrolled { padding-top: .5rem; }

/* glass-nav: rgba white + blur */
.navbar-inner {
  background: var(--color-nav-bg);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: var(--radius-2xl);    /* rounded-2xl */
  border: 1px solid var(--slate-100);
  padding: .75rem 1rem;               /* py-3 px-4 */
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: var(--shadow-soft);
  transition: padding .3s;
}
@media (min-width: 768px) { .navbar-inner { padding: 1rem 1.5rem; } }  /* md:py-4 md:px-6 */
#site-header.scrolled .navbar-inner { padding-top: .5rem; padding-bottom: .5rem; }

/* Logo */
.site-logo a { display: flex; align-items: center; gap: .75rem; }   /* gap-3 */
.logo-bar {
  width: .375rem; height: 1.5rem;     /* w-1.5 h-6 */
  background: var(--color-accent);
  border-radius: 9999px;
  flex-shrink: 0;
}
@media (min-width: 768px) { .logo-bar { width: .5rem; height: 2rem; } }   /* md:w-2 md:h-8 */
.logo-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1rem;                   /* text-base */
  color: var(--slate-900);
  line-height: 1;
  letter-spacing: -.025em;           /* tracking-tight */
  display: block;
}
@media (min-width: 768px) { .logo-name { font-size: 1.125rem; } }         /* md:text-lg */
.logo-tagline {
  font-size: .5625rem;               /* text-[9px] */
  color: var(--slate-500);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .1em;              /* tracking-widest */
  margin-top: .25rem;
  display: block;
}
@media (min-width: 768px) { .logo-tagline { font-size: .625rem; } }       /* md:text-[10px] */

/* Desktop nav */
.nav-links { display: none; align-items: center; gap: .5rem; }            /* space-x-2 */
@media (min-width: 768px) { .nav-links { display: flex; } }
.nav-links a {
  color: var(--slate-600);
  padding: .5rem 1rem;               /* px-4 py-2 */
  font-size: .875rem;                /* text-sm */
  font-weight: 500;
  border-radius: .5rem;
  transition: color .2s;
}
.nav-links a:hover { color: var(--slate-900); }
.nav-links .nav-cta {
  margin-left: .5rem;                /* ml-2 */
  background: var(--color-nav-cta-bg);
  color: var(--color-nav-cta-text);
  padding: .625rem 1.25rem;          /* px-5 py-2.5 */
  border-radius: .5rem;
  font-size: .875rem;
  font-weight: 500;
  transition: background .2s;
}
.nav-links .nav-cta:hover { background: var(--slate-700); }

/* Hamburger */
.menu-toggle {
  display: flex; background: none; border: none; cursor: pointer;
  color: var(--slate-600); padding: .5rem; border-radius: .5rem;
  transition: background .2s, color .2s;
}
.menu-toggle:hover { background: var(--slate-50); color: var(--slate-900); }
@media (min-width: 768px) { .menu-toggle { display: none; } }

/* Mobile dropdown */
.mobile-menu {
  display: none; position: absolute;
  width: 100%; padding: 0 1rem; margin-top: .5rem; z-index: 50;
}
.mobile-menu.is-open { display: block; }
.mobile-menu-inner {
  background: #fff;
  border-radius: var(--radius-2xl);
  border: 1px solid var(--slate-100);
  padding: 1rem;
  box-shadow: 0 20px 40px rgba(0,0,0,.12);
}
.mobile-menu-inner a {
  display: block; padding: .75rem 1rem; border-radius: .5rem;
  font-size: .875rem; font-weight: 500; color: var(--slate-700);
  transition: background .2s;
}
.mobile-menu-inner a:hover { background: var(--slate-50); }
.mobile-menu-inner .mob-cta {
  text-align: center; background: var(--color-nav-cta-bg);
  color: var(--color-nav-cta-text); font-weight: 700;
  margin-top: .5rem; box-shadow: 0 4px 16px rgba(0,0,0,.15);
}

/* ============================================================
   HERO  — pixel-exact match to original
   ============================================================
   Original classes:
     section:  min-h-screen flex items-center pt-28 md:pt-32 pb-16 md:pb-20 bg-slate-900 relative overflow-hidden
     layer 1:  absolute inset-0 bg-gradient-to-br from-slate-900 via-slate-800 to-medical-900 opacity-90
     layer 2:  absolute top-0 right-0 w-full h-full bg-[url(cubes.png)] opacity-5
     grid:     grid lg:grid-cols-12 gap-8 md:gap-12 items-center
     text col: lg:col-span-7 order-2 lg:order-1
     img col:  lg:col-span-5 relative order-1 lg:order-2 mb-8 lg:mb-0
     frame:    relative rounded-3xl overflow-hidden border border-slate-700 shadow-2xl aspect-[4/5] max-w-[280px] md:max-w-md mx-auto lg:mx-0
   ============================================================ */
#hero-section {
  background-color: var(--color-hero-from);   /* bg-slate-900 */
  position: relative;
  overflow: hidden;
  min-height: 100vh;                           /* min-h-screen */
  display: flex;
  align-items: center;                         /* items-center */
  padding-top:    7rem;                        /* pt-28 */
  padding-bottom: 4rem;                        /* pb-16 */
}
@media (min-width: 768px) {
  #hero-section { padding-top: 8rem; padding-bottom: 5rem; }  /* md:pt-32 md:pb-20 */
}

/* Layer 1 — gradient overlay with opacity-90 */
.hero-gradient-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(
    to bottom right,                          /* bg-gradient-to-br */
    var(--color-hero-from),                   /* from-slate-900 */
    var(--color-hero-via),                    /* via-slate-800 */
    var(--color-hero-to)                      /* to-medical-900 */
  );
  opacity: var(--color-hero-gradient-opacity); /* opacity-90 */
  pointer-events: none;
}

/* Layer 2 — cube texture */
.hero-texture-overlay {
  position: absolute; top: 0; right: 0;
  width: 100%; height: 100%;
  background-image: url('https://www.transparenttextures.com/patterns/cubes.png');
  opacity: .05;                               /* opacity-5 */
  pointer-events: none;
}

/* 12-column grid */
.hero-grid {
  position: relative; z-index: 10;
  display: grid;
  gap: 2rem;                                  /* gap-8 */
  align-items: center;
  width: 100%;
}
@media (min-width: 768px) { .hero-grid { gap: 3rem; } }        /* md:gap-12 */
@media (min-width: 1024px) {
  .hero-grid { grid-template-columns: 7fr 5fr; }               /* lg:col-span-7 + lg:col-span-5 */
}

/* Text column — order-2 lg:order-1 */
.hero-text { order: 2; }
@media (min-width: 1024px) { .hero-text { order: 1; } }

/* Eyebrow line */
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: .75rem;     /* gap-3 */
  margin-bottom: 1.5rem;                                        /* mb-6 */
}
@media (min-width: 768px) { .hero-eyebrow { margin-bottom: 2rem; } }   /* md:mb-8 */
.hero-eyebrow-line {
  width: 2rem; height: 1px;                                     /* w-8 h-[1px] */
  background: var(--color-accent-hover);                        /* bg-medical-400 */
  flex-shrink: 0;
}
.hero-eyebrow-text {
  color: var(--medical-100);                                    /* text-medical-100 */
  font-weight: 500;
  font-size: .75rem;                                            /* text-xs */
  text-transform: uppercase;
  letter-spacing: .1em;                                         /* tracking-widest */
}

/* H1  — text-3xl md:text-5xl lg:text-6xl font-display font-bold leading-tight tracking-tight */
.hero-h1 {
  font-family: var(--font-display);
  font-weight: 700;
  color: #fff;
  line-height: 1.25;                                            /* leading-tight */
  letter-spacing: -.025em;                                      /* tracking-tight */
  font-size: 1.875rem;                                          /* text-3xl */
  margin-bottom: 1.5rem;                                        /* mb-6 */
}
@media (min-width: 768px) { .hero-h1 { font-size: 3rem; margin-bottom: 2rem; } }        /* md:text-5xl md:mb-8 */
@media (min-width: 1024px) { .hero-h1 { font-size: 3.75rem; } }                         /* lg:text-6xl */

/* Subtitle span inside H1 — text-medical-400 text-xl md:text-2xl lg:text-4xl block mt-2 font-medium break-words */
.hero-h1 .hero-subtitle {
  display: block;
  margin-top: .5rem;
  color: var(--color-accent-hover);                             /* text-medical-400 */
  font-size: 1.25rem;                                           /* text-xl */
  font-weight: 500;
  line-height: 1.3;
  word-break: break-words;
}
@media (min-width: 768px) { .hero-h1 .hero-subtitle { font-size: 1.5rem; } }            /* md:text-2xl */
@media (min-width: 1024px) { .hero-h1 .hero-subtitle { font-size: 2.25rem; } }          /* lg:text-4xl */

/* Description — text-base md:text-lg text-slate-300 font-light mb-8 md:mb-10 leading-relaxed max-w-2xl border-l-2 border-slate-700 pl-4 md:pl-6 */
.hero-desc {
  color: var(--slate-300);
  font-weight: 300;
  font-size: 1rem;
  line-height: 1.625;
  margin-bottom: 2rem;
  max-width: 42rem;
  border-left: 2px solid var(--slate-700);
  padding-left: 1rem;
}
@media (min-width: 768px) { .hero-desc { font-size: 1.125rem; margin-bottom: 2.5rem; padding-left: 1.5rem; } }

/* CTAs — flex flex-col sm:flex-row gap-4 */
.hero-actions { display: flex; flex-direction: column; gap: 1rem; }
@media (min-width: 640px) { .hero-actions { flex-direction: row; } }

/* bg-white text-slate-900 px-8 py-4 rounded-lg font-semibold text-sm hover:bg-medical-50 shadow-lg hover:shadow-xl */
.btn-white {
  background: var(--color-primary-btn-bg);
  color: var(--color-primary-btn-text);
  padding: 1rem 2rem;
  border-radius: .5rem;
  font-weight: 600;
  font-size: .875rem;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  box-shadow: 0 10px 15px -3px rgba(0,0,0,.15), 0 4px 6px -4px rgba(0,0,0,.1);
  transition: background .2s, box-shadow .2s;
  white-space: nowrap;
}
.btn-white:hover {
  background: var(--medical-50);
  box-shadow: 0 20px 25px -5px rgba(0,0,0,.2), 0 8px 10px -6px rgba(0,0,0,.1);
}

/* px-8 py-4 rounded-lg font-semibold text-sm text-white border border-slate-700 hover:bg-slate-800/50 hover:border-slate-600 */
.btn-ghost {
  padding: 1rem 2rem;
  border-radius: .5rem;
  font-weight: 600;
  font-size: .875rem;
  display: inline-flex; align-items: center; justify-content: center; gap: .5rem;
  color: #fff;
  border: 1px solid var(--slate-700);
  transition: background .2s, border-color .2s;
  white-space: nowrap;
}
.btn-ghost:hover { background: rgba(30,41,59,.5); border-color: var(--slate-600); }

/* Image column — order-1 lg:order-2 mb-8 lg:mb-0 */
.hero-image-col { order: 1; margin-bottom: 2rem; }
@media (min-width: 1024px) { .hero-image-col { order: 2; margin-bottom: 0; } }

/* Frame — relative rounded-3xl overflow-hidden border border-slate-700 shadow-2xl aspect-[4/5] max-w-[280px] md:max-w-md mx-auto lg:mx-0 */
.hero-image-frame {
  position: relative;
  border-radius: var(--radius-3xl);
  overflow: hidden;
  border: 1px solid var(--slate-700);
  box-shadow: 0 25px 50px -12px rgba(0,0,0,.4);               /* shadow-2xl */
  aspect-ratio: 4 / 5;
  background-color: #b7bcc7;
  max-width: 280px;
  margin-left: auto; margin-right: auto;
}
@media (min-width: 768px) { .hero-image-frame { max-width: 28rem; } }
@media (min-width: 1024px) { .hero-image-frame { margin-left: 0; margin-right: 0; } }

/* w-full h-full object-cover object-top opacity-95 hover:opacity-100 transition duration-700 */
.hero-image-frame img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: top;
  opacity: .95;
  transition: opacity .7s;
}
.hero-image-frame img:hover { opacity: 1; }

/* Caption — absolute bottom-0 inset-x-0 bg-gradient-to-t from-slate-900 via-slate-900/80 to-transparent p-6 pr-20 */
.hero-caption {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, var(--slate-900), rgba(15,23,42,.8), transparent);
  padding: 1.5rem;
  padding-right: 5rem;
}
.hero-caption .cap-name  { color: #fff; font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; display: block; }
.hero-caption .cap-title { color: var(--medical-200); font-size: .875rem; display: block; }
.hero-caption .cap-cert  { color: var(--medical-200); font-size: .875rem; display: block; margin-top: .125rem; }

/* IBUS badge — absolute bottom-4 right-4 z-30 w-12 h-12 md:w-14 md:h-14 text-medical-200/80 */
.hero-ibus-badge {
  position: absolute; bottom: 1rem; right: 1rem; z-index: 30;
  color: rgba(186,226,253,.8);
  width: 3rem; height: 3rem;
  display: flex; align-items: center; justify-content: center;
}
@media (min-width: 768px) { .hero-ibus-badge { width: 3.5rem; height: 3.5rem; } }

/* Blobs behind frame — -top-4 -right-4 w-24 h-24 bg-medical-600 rounded-full blur-2xl opacity-20 -z-10 */
.hero-blob-1 {
  position: absolute; top: -1rem; right: -1rem;
  width: 6rem; height: 6rem;
  background: var(--color-accent);
  border-radius: 9999px; filter: blur(2rem); opacity: .2; pointer-events: none; z-index: -1;
}
/* -bottom-4 -left-4 w-32 h-32 bg-indigo-600 rounded-full blur-2xl opacity-20 -z-10 */
.hero-blob-2 {
  position: absolute; bottom: -1rem; left: -1rem;
  width: 8rem; height: 8rem;
  background: #4f46e5;
  border-radius: 9999px; filter: blur(2rem); opacity: .2; pointer-events: none; z-index: -1;
}

/* ============================================================
   SHARED SECTION UTILITIES
   ============================================================ */
.section-eyebrow {
  display: block;
  color: var(--color-accent);
  font-weight: 700; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .1em;
  margin-bottom: .5rem;
}
.section-heading {
  font-family: var(--font-display);
  font-weight: 700; font-size: 1.875rem;
  color: var(--slate-900);
  letter-spacing: -.025em; margin-bottom: 1rem;
}
@media (min-width: 768px) { .section-heading { font-size: 2.25rem; } }

/* hover-lift card — from original CSS */
.hover-lift { transition: transform .3s ease, box-shadow .3s ease; }
.hover-lift:hover { transform: translateY(-4px); box-shadow: 0 10px 30px -5px rgba(0,0,0,.08); }

/* ============================================================
   SERVICES  — py-16 md:py-24 bg-white
   ============================================================ */
#services { padding: 4rem 0; background: #fff; }
@media (min-width: 768px) { #services { padding: 6rem 0; } }

.services-intro { margin-bottom: 3rem; }
@media (min-width: 768px) { .services-intro { margin-bottom: 4rem; } }
.services-intro p { color: var(--slate-500); font-weight: 300; max-width: 48rem; font-size: 1rem; }
@media (min-width: 768px) { .services-intro p { font-size: 1.125rem; } }

/* grid grid-cols-1 md:grid-cols-2 lg:grid-cols-3 gap-4 md:gap-6 */
.services-grid { display: grid; grid-template-columns: 1fr; gap: 1rem; }
@media (min-width: 768px)  { .services-grid { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }
@media (min-width: 1024px) { .services-grid { grid-template-columns: repeat(3, 1fr); } }

/* bg-white p-6 md:p-8 rounded-2xl border border-slate-100 hover-lift group */
.service-card {
  background: #fff;
  padding: 1.5rem;
  border-radius: var(--radius-2xl);
  border: 1px solid var(--slate-100);
  transition: transform .3s ease, box-shadow .3s ease;
}
.service-card:hover { transform: translateY(-4px); box-shadow: 0 10px 30px -5px rgba(0,0,0,.08); }
@media (min-width: 768px) { .service-card { padding: 2rem; } }

/* w-12 h-12 bg-slate-50 rounded-lg flex items-center justify-center mb-4 md:mb-6 text-slate-900 group-hover:bg-medical-600 group-hover:text-white */
.service-icon {
  width: 3rem; height: 3rem;
  background: var(--slate-50);
  border-radius: .5rem;
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 1rem;
  color: var(--slate-900);
  transition: background .3s, color .3s;
}
@media (min-width: 768px) { .service-icon { margin-bottom: 1.5rem; } }
.service-card:hover .service-icon { background: var(--color-accent); color: #fff; }

/* font-display font-bold text-lg mb-2 text-slate-900 */
.service-card h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; margin-bottom: .5rem; color: var(--slate-900); }
/* text-slate-500 text-sm leading-relaxed */
.service-card p { color: var(--slate-500); font-size: .875rem; line-height: 1.625; }

/* ============================================================
   IUS (dark section)
   ============================================================ */
#ius { padding: 4rem 0; background: var(--color-section-dark-bg); color: #fff; }
@media (min-width: 768px) { #ius { padding: 6rem 0; } }

.ius-grid { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .ius-grid { grid-template-columns: 1fr 1fr; gap: 4rem; align-items: start; } }

.ius-badge { display: inline-block; border: 1px solid var(--slate-700); padding: .25rem .75rem; border-radius: 9999px; margin-bottom: 1.5rem; }
.ius-badge span { color: var(--slate-300); font-weight: 700; font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; }

.ius-heading { font-family: var(--font-display); font-weight: 700; font-size: 1.875rem; line-height: 1.1; letter-spacing: -.025em; margin-bottom: 1.5rem; }
@media (min-width: 768px) { .ius-heading { font-size: 3rem; } }

.ius-desc { color: var(--slate-400); font-size: 1rem; line-height: 1.625; font-weight: 300; margin-bottom: 2rem; }
@media (min-width: 768px) { .ius-desc { font-size: 1.125rem; } }

.ius-highlight-card {
  background: rgba(30,41,59,.5);
  padding: 1.5rem; border-radius: .75rem;
  border: 1px solid var(--slate-700);
  display: flex; gap: 1rem; align-items: flex-start;
  margin-bottom: 2rem; transition: background .3s;
}
.ius-highlight-card:hover { background: rgba(30,41,59,.8); }
.ius-highlight-card h4 { font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; margin-bottom: .25rem; }
.ius-highlight-card p  { font-size: .875rem; color: var(--slate-400); line-height: 1.625; }

@media (min-width: 1024px) { .ius-side { padding-top: 6rem; } }

.ius-benefit { margin-bottom: 2.5rem; }
.ius-benefit h4 { font-weight: 700; font-size: 1.25rem; margin-bottom: 1rem; display: flex; align-items: center; gap: .75rem; }
.ius-benefit-icon {
  width: 2.5rem; height: 2.5rem;
  background: rgba(12,74,110,.5);
  border: 1px solid rgba(14,165,233,.3);
  border-radius: 9999px;
  display: flex; align-items: center; justify-content: center;
  color: var(--medical-500); flex-shrink: 0;
}
.ius-benefit-body { background: rgba(30,41,59,.3); padding: 1.5rem; border-radius: var(--radius-2xl); border: 1px solid rgba(51,65,85,.5); }
.ius-benefit-body p { color: var(--slate-300); font-size: 1rem; line-height: 1.625; }

/* ============================================================
   STATS
   ============================================================ */
#stats { padding: 4rem 0 5rem; background: var(--color-stats-bg); border-bottom: 1px solid var(--slate-200); }

.stats-inner { display: flex; flex-direction: column; gap: 2rem; align-items: center; }
@media (min-width: 768px) { .stats-inner { flex-direction: row; justify-content: space-between; gap: 3rem; } }

@media (min-width: 768px) { .stats-copy { flex: 0 0 33.333%; } }
.stats-copy h2 { font-family: var(--font-display); font-weight: 700; color: var(--slate-900); font-size: 1.5rem; margin-bottom: .75rem; }
.stats-copy p  { color: var(--slate-500); font-size: .875rem; line-height: 1.625; }

.stats-cards { display: grid; grid-template-columns: 1fr; gap: 1.5rem; width: 100%; }
@media (min-width: 640px) { .stats-cards { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 768px) { .stats-cards { flex: 0 0 66.666%; } }

.stat-card { background: #fff; padding: 1.5rem; border-radius: .75rem; border: 1px solid var(--slate-200); display: flex; align-items: center; gap: 1.25rem; }
.stat-number { font-family: var(--font-display); font-weight: 700; font-size: 1.875rem; color: var(--slate-900); flex-shrink: 0; }
@media (min-width: 768px) { .stat-number { font-size: 2.25rem; } }
.stat-divider { width: 1px; height: 2rem; background: var(--slate-200); flex-shrink: 0; }
.stat-label { color: var(--slate-500); font-size: .75rem; font-weight: 700; text-transform: uppercase; letter-spacing: .05em; }

/* ============================================================
   ABOUT
   ============================================================ */
#about { padding: 4rem 0; background: #fff; }
@media (min-width: 768px) { #about { padding: 6rem 0; } }

.about-grid { display: grid; gap: 2.5rem; }
@media (min-width: 1024px) { .about-grid { grid-template-columns: 7fr 5fr; gap: 6rem; } }

.about-intro { font-size: 1rem; color: var(--slate-500); font-weight: 300; line-height: 1.625; margin-bottom: 1.5rem; }
@media (min-width: 768px) { .about-intro { font-size: 1.125rem; } }
.about-sub { font-size: .875rem; color: var(--slate-500); line-height: 1.625; margin-bottom: 2rem; }

/* Timeline */
.timeline { margin-top: 3rem; border-left: 1px solid var(--slate-200); margin-left: .75rem; padding-left: 1.5rem; }
@media (min-width: 768px) { .timeline { margin-top: 4rem; padding-left: 2.5rem; } }
.tl-item { position: relative; margin-bottom: 2.5rem; }
.tl-dot { position: absolute; left: -2.25rem; top: .25rem; width: .75rem; height: .75rem; border-radius: 9999px; box-shadow: 0 0 0 4px #fff; }
@media (min-width: 768px) { .tl-dot { left: -3.3rem; } }
.tl-dot.dot-primary  { background: var(--slate-900); }
.tl-dot.dot-inactive { background: var(--slate-400); }
.tl-dot.dot-active   { background: var(--medical-500); }
.tl-item h4 { font-family: var(--font-display); font-weight: 700; font-size: 1rem; color: var(--slate-900); }
@media (min-width: 768px) { .tl-item h4 { font-size: 1.125rem; } }
.tl-institution { color: var(--slate-500); font-size: .875rem; font-weight: 600; margin-top: .25rem; }
.tl-detail      { color: var(--slate-400); font-size: .75rem; margin-top: .25rem; }

/* Certs */
.certs-block { margin-top: 3rem; padding-top: 2.5rem; border-top: 1px solid var(--slate-100); }
.certs-heading { font-weight: 700; font-size: .875rem; color: var(--slate-900); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 1.5rem; }
.cert-tags { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1rem; }
.cert-tag {
  padding: .5rem 1rem; background: var(--slate-50); border-radius: .5rem;
  font-size: .75rem; font-weight: 600; color: var(--slate-600);
  border: 1px solid var(--slate-100);
  display: inline-flex; align-items: center; gap: .5rem;
}
.cert-tag svg { color: var(--medical-500); }
.cert-note { font-size: .75rem; font-style: italic; color: var(--slate-400); }

/* Philosophy card */
@media (min-width: 1024px) { .philosophy-sticky { position: sticky; top: 8rem; } }
.philosophy-card { background: #fff; border: 1px solid var(--slate-200); padding: 1.5rem; border-radius: var(--radius-2xl); box-shadow: var(--shadow-soft); }
@media (min-width: 768px) { .philosophy-card { padding: 2rem; } }
.philosophy-card .ph-icon { color: var(--slate-300); margin-bottom: 1rem; display: block; }
.philosophy-card h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; color: var(--slate-900); margin-bottom: .75rem; }
.philosophy-card blockquote { color: var(--slate-500); font-weight: 300; line-height: 1.625; font-size: .875rem; margin-bottom: 1rem; }
.philosophy-card p { color: var(--slate-500); font-weight: 300; font-size: .875rem; line-height: 1.625; }

/* ============================================================
   CONTACT
   ============================================================ */
#contact { padding: 4rem 0; background: #fff; }
@media (min-width: 768px) { #contact { padding: 6rem 0; } }

.contact-grid { display: grid; gap: 2.5rem; align-items: flex-start; }
@media (min-width: 1024px) { .contact-grid { grid-template-columns: 1fr 1fr; gap: 4rem; } }

.contact-intro p { font-size: 1rem; color: var(--slate-500); font-weight: 300; line-height: 1.625; margin-bottom: 2rem; }
@media (min-width: 768px) { .contact-intro p { font-size: 1.125rem; } }

.booking-card { background: var(--color-section-dark-bg); color: #fff; border-radius: var(--radius-2xl); padding: 1.5rem; margin-bottom: 2rem; }
@media (min-width: 768px) { .booking-card { padding: 2rem; } }
.booking-card h3 { font-weight: 700; font-size: 1rem; margin-bottom: 1.5rem; }
@media (min-width: 768px) { .booking-card h3 { font-size: 1.25rem; } }

.contact-row { display: flex; align-items: center; gap: 1rem; color: var(--slate-300); transition: color .2s; margin-bottom: 1rem; }
.contact-row:hover { color: #fff; }
.contact-icon { width: 2.5rem; height: 2.5rem; background: var(--slate-800); border-radius: 9999px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.contact-icon.emergency { color: #f87171; }
.contact-row span { font-size: .95rem; }
@media (min-width: 768px) { .contact-row span { font-size: 1.125rem; } }
.mono { font-family: monospace; }

.locations-heading { font-weight: 700; font-size: 1.25rem; color: var(--slate-900); margin-bottom: 1.5rem; }
.location-card { background: #fff; border-radius: .75rem; padding: 1.5rem; border: 1px solid var(--slate-200); transition: border-color .2s; margin-bottom: 1.5rem; }
.location-card:hover { border-color: var(--slate-300); }
.location-card-header { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: .5rem; }
.location-card-header h3 { font-family: var(--font-display); font-weight: 700; font-size: 1.125rem; color: var(--slate-900); }
@media (min-width: 768px) { .location-card-header h3 { font-size: 1.25rem; } }
.location-badge { font-size: .625rem; font-weight: 700; padding: .25rem .5rem; border-radius: .25rem; text-transform: uppercase; letter-spacing: .025em; white-space: nowrap; flex-shrink: 0; margin-left: .75rem; }
.location-badge.primary   { background: #dcfce7; color: #166534; }
.location-badge.secondary { background: var(--slate-100); color: var(--slate-600); }
.location-card p { color: var(--slate-500); font-size: .875rem; margin-bottom: 1rem; }
.location-type { display: flex; align-items: center; gap: .5rem; font-size: .75rem; font-weight: 700; color: var(--slate-400); text-transform: uppercase; letter-spacing: .05em; transition: color .2s; }
.location-type svg, .location-address svg { height: 1em; width: auto; flex-shrink: 0; }
.location-card:hover .location-type { color: var(--color-accent); }
.location-days { font-size: .75rem; font-style: italic; color: var(--slate-400); margin-top: .75rem; margin-bottom: 0; }

/* ============================================================
   FOOTER
   ============================================================ */
#site-footer { background: var(--color-footer-bg); border-top: 1px solid var(--slate-100); padding: 3rem 0; }

.footer-top { display: flex; flex-direction: column; align-items: center; gap: 1.5rem; margin-bottom: 2rem; text-align: center; }
@media (min-width: 768px) { .footer-top { flex-direction: row; justify-content: space-between; text-align: left; } }

.footer-brand-name { font-family: var(--font-display); font-weight: 700; font-size: 1.25rem; color: var(--slate-900); }
.footer-brand-sub  { color: var(--slate-500); font-size: .875rem; margin-top: .25rem; }

.footer-socials { display: flex; gap: 1rem; }
.footer-socials a { width: 2.5rem; height: 2.5rem; border-radius: 9999px; background: var(--slate-50); display: flex; align-items: center; justify-content: center; color: var(--slate-400); transition: background .2s, color .2s; }
.footer-socials a:hover { background: var(--slate-900); color: #fff; }

.footer-bottom { border-top: 1px solid var(--slate-100); padding-top: 2rem; display: flex; flex-direction: column; gap: 1rem; align-items: center; font-size: .875rem; color: var(--slate-400); text-align: center; }
@media (min-width: 768px) { .footer-bottom { flex-direction: row; justify-content: space-between; text-align: left; } }
.footer-links { display: flex; gap: 1.5rem; justify-content: center; }
.footer-links a { transition: color .2s; }
.footer-links a:hover { color: var(--slate-900); }

/* ============================================================
   ADMIN NOTICE — shown when a CPT section is empty
   (only visible to logged-in admins; hidden on frontend for guests)
   ============================================================ */
.dsk-admin-notice {
  background: #fff3cd;
  border: 1px solid #ffc107;
  padding: 1rem 1.25rem;
  border-radius: .5rem;
  color: #856404;
  font-size: .875rem;
  line-height: 1.5;
}
.dsk-admin-notice a {
  font-weight: 600;
  text-decoration: underline;
  color: #856404;
}
/* Hide from non-logged-in visitors */
body:not(.logged-in) .dsk-admin-notice { display: none; }

/* location address line */
.location-address {
  display: flex; align-items: center; gap: .5rem;
  font-size: .75rem; color: var(--slate-500);
  margin-bottom: .5rem;
}
