/* ============================================================
   DermaSan – Clinical Sanctuary Design System
   Primary: #002c7c / #1d439c | Secondary: #426900
   Fonts: Manrope (headlines) + Inter (body)
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&family=Inter:wght@300;400;500;600&display=swap');

/* Fallback pokud Google Fonts nejsou dostupné */
:root {
  --font-head: 'Manrope', 'Segoe UI', Arial, sans-serif;
  --font-body: 'Inter', 'Segoe UI', Arial, sans-serif;
}

/* ── Reset & Base ─────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --primary:        #002c7c;
  --primary-mid:    #1d439c;
  --primary-light:  #dbe1ff;
  --secondary:      #426900;
  --secondary-light:#b6f265;
  --surface:        #f8f9ff;
  --surface-low:    #eff4ff;
  --surface-high:   #dce9ff;
  --surface-card:   #ffffff;
  --on-surface:     #0b1c30;
  --on-muted:       #444652;
  --outline:        #c4c6d4;
  --error:          #ba1a1a;

  --gradient-cta: linear-gradient(135deg, #002c7c 0%, #1d439c 100%);
  --shadow-soft:  0 12px 40px rgba(11,28,48,0.06);
  --shadow-card:  0 4px 20px rgba(11,28,48,0.05);
  --radius-card:  0.75rem;
  --radius-btn:   0.5rem;
  --radius-full:  100px;

  --font-head: 'Manrope', sans-serif;
  --font-body: 'Inter', sans-serif;

  --max-w: 1200px;
  --section-py: clamp(4rem, 8vw, 7rem);
}

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  background: var(--surface);
  color: var(--on-surface);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; }
button { font-family: inherit; cursor: pointer; border: none; }

/* ── Utility ─────────────────────────────────────────────── */
.container { max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem; }
.section-py { padding: var(--section-py) 0; }
.surface-low { background: var(--surface-low); }
.surface-card { background: var(--surface-card); }
.text-center { text-align: center; }

/* ── Typography ──────────────────────────────────────────── */
.display { font-family: var(--font-head); font-weight: 800; line-height: 1.1; letter-spacing: -0.02em; }
.display-xl { font-size: clamp(2.4rem, 5vw, 3.7rem); }
.display-lg { font-size: clamp(2rem, 4vw, 3rem); }
.display-md { font-size: clamp(1.6rem, 3vw, 2.2rem); }
.display-sm { font-size: clamp(1.3rem, 2.5vw, 1.75rem); }

h1,h2,h3,h4 { font-family: var(--font-head); font-weight: 700; line-height: 1.2; }
h2 { font-size: clamp(1.7rem, 3vw, 2.4rem); letter-spacing: -0.01em; }
h3 { font-size: clamp(1.1rem, 2vw, 1.35rem); }

.label-section {
  display: inline-block;
  font-family: var(--font-body);
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--secondary);
  margin-bottom: 0.75rem;
}

.lead { font-size: 1.1rem; line-height: 1.7; color: var(--on-muted); max-width: 52ch; }
.lead-center { margin: 0 auto; text-align: center; }

/* ── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 0.5rem;
  padding: 0.8rem 1.75rem;
  border-radius: var(--radius-btn);
  font-family: var(--font-body);
  font-size: 0.95rem;
  font-weight: 600;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.btn-primary {
  background: var(--gradient-cta);
  color: #fff;
  box-shadow: 0 4px 16px rgba(0,44,124,0.25);
}
.btn-primary:hover { box-shadow: 0 6px 24px rgba(0,44,124,0.35); transform: translateY(-1px); }
.btn-secondary {
  background: var(--surface-card);
  color: var(--primary);
  border: 1.5px solid var(--outline);
}
.btn-secondary:hover { border-color: var(--primary-mid); background: var(--surface-low); }
.btn-ghost {
  background: transparent;
  color: var(--primary);
  padding: 0.8rem 0;
}
.btn-ghost:hover { color: var(--primary-mid); }
.btn-ghost svg { transition: transform 0.2s; }
.btn-ghost:hover svg { transform: translateX(3px); }
.btn-lg { padding: 1rem 2.2rem; font-size: 1rem; }
.btn-sm { padding: 0.55rem 1.2rem; font-size: 0.85rem; }

/* ── Navigation ──────────────────────────────────────────── */
.navbar {
  position: fixed; top: 0; left: 0; right: 0; z-index: 1000;
  background: rgba(248,249,255,0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(196,198,212,0.3);
  transition: background 0.3s, box-shadow 0.3s;
}
.navbar.scrolled { background: rgba(255,255,255,0.95); box-shadow: var(--shadow-soft); }
.navbar-inner {
  display: flex; align-items: center; justify-content: space-between;
  height: 72px;
  max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem;
}
.navbar-logo { display: flex; align-items: center; height: 100%; }
.navbar-logo img {
  height: 72px; /* Plně roztažené přes horní lištu */
  width: auto;
}
.navbar-nav { display: flex; align-items: center; gap: 2rem; }
.navbar-nav a {
  font-size: 0.9rem; font-weight: 500; color: var(--on-muted);
  transition: color 0.2s;
}
.navbar-nav a:hover { color: var(--primary); }
.navbar-cta { display: flex; align-items: center; gap: 0.75rem; }
.navbar-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 4px; }
.navbar-hamburger span { display: block; width: 24px; height: 2px; background: var(--on-surface); border-radius: 2px; transition: all 0.3s; }

/* Mobile nav drawer */
.mobile-nav {
  display: none; position: fixed; inset: 0; z-index: 999;
  background: rgba(11,28,48,0.4); backdrop-filter: blur(4px);
}
.mobile-nav.open { display: block; }
.mobile-nav-drawer {
  position: absolute; top: 0; right: 0; bottom: 0; width: min(320px, 90vw);
  background: var(--surface-card); padding: 2rem 1.5rem;
  display: flex; flex-direction: column; gap: 0.5rem;
  box-shadow: -8px 0 40px rgba(11,28,48,0.12);
}
.mobile-nav-close { align-self: flex-end; background: none; border: none; font-size: 1.5rem; cursor: pointer; color: var(--on-muted); margin-bottom: 1rem; }
.mobile-nav-drawer a { display: block; padding: 0.9rem 0; font-size: 1rem; font-weight: 500; border-bottom: 1px solid var(--surface-high); color: var(--on-surface); }
.mobile-nav-cta { margin-top: 1rem; margin-left: -1rem; }
.mobile-nav-cta .btn-primary { color: #fff !important; padding-left: calc(1.25rem + 1rem); }

/* ── Hero ────────────────────────────────────────────────── */
.hero {
  padding-top: 72px;
  min-height: 100svh;
  display: flex; align-items: center;
  background: linear-gradient(155deg, #f8f9ff 0%, #eff4ff 55%, #dce9ff 100%);
  position: relative; overflow: hidden;
}
.hero::before {
  content: '';
  position: absolute; top: -20%; right: -10%;
  width: 55vw; height: 55vw; max-width: 700px; max-height: 700px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(29,67,156,0.07) 0%, transparent 70%);
  pointer-events: none;
}
.hero::after {
  content: '';
  position: absolute; bottom: -15%; left: -5%;
  width: 35vw; height: 35vw; max-width: 450px; max-height: 450px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(66,105,0,0.05) 0%, transparent 70%);
  pointer-events: none;
}
.hero-inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4rem; align-items: center;
  max-width: var(--max-w); margin: 0 auto; padding: 5rem 1.5rem 4rem;
  width: 100%;
}
.hero-badge {
  display: inline-flex; align-items: center; gap: 0.5rem;
  background: rgba(29,67,156,0.08);
  color: var(--primary-mid);
  border-radius: var(--radius-full);
  padding: 0.35rem 1rem;
  font-size: 0.8rem; font-weight: 600;
  margin-bottom: 1.5rem;
}
.hero-badge::before { content: ''; width: 6px; height: 6px; border-radius: 50%; background: var(--secondary); }
.hero h1 { color: var(--primary); margin-bottom: 1.25rem; }
.hero-sub { font-size: 1.1rem; line-height: 1.75; color: var(--on-muted); margin-bottom: 2rem; max-width: 50ch; }
.hero-actions { display: flex; gap: 0.75rem; flex-wrap: wrap; margin-bottom: 2.5rem; }
.hero-trust { display: flex; align-items: center; gap: 1rem; font-size: 0.85rem; color: var(--on-muted); }
.hero-trust-divider { width: 1px; height: 1rem; background: var(--outline); }
.hero-trust strong { color: var(--on-surface); font-weight: 600; }

.hero-visual {
  position: relative; display: flex; justify-content: center; align-items: center;
}
.hero-card-main {
  background: var(--surface-card);
  border-radius: 1.25rem;
  padding: 2rem;
  box-shadow: var(--shadow-soft);
  width: 100%; max-width: 380px;
  position: relative; z-index: 2;
}
.hero-card-accent {
  position: absolute;
  background: var(--gradient-cta);
  color: #fff;
  border-radius: var(--radius-card);
  padding: 1rem 1.25rem;
  font-size: 0.85rem; font-weight: 600;
  box-shadow: 0 8px 24px rgba(0,44,124,0.3);
}
.hero-card-accent-1 { top: -1rem; right: -2rem; }
.hero-card-accent-2 { bottom: 0rem; left: -2rem; background: linear-gradient(135deg, #426900, #5a8c00); }
.hero-stat { text-align: center; padding: 1rem 0; }
.hero-stat-num { font-family: var(--font-head); font-size: 2.2rem; font-weight: 800; color: var(--primary); line-height: 1; }
.hero-stat-label { font-size: 0.8rem; color: var(--on-muted); margin-top: 0.25rem; }
.hero-icon-wrap { width: 64px; height: 64px; border-radius: 50%; background: var(--surface-low); display: flex; align-items: center; justify-content: center; margin: 0 auto 0.75rem; }

/* ── Hero logo overflow ──────────────────────────────────── */
.hero-logo-big {
  display: block;
  width: clamp(320px, 45vw, 600px);
  height: auto;
  position: relative;
  z-index: 10;
  filter: drop-shadow(0 20px 50px rgba(0,44,124,0.22));
  margin: 0 auto;
}

.hero-logo-overflow {
  text-align: center;
  margin-bottom: -120px;
  position: relative;
  z-index: 5;
}

/* ── Trust Strip ─────────────────────────────────────────── */
.trust-strip {
  background: var(--primary);
  padding: 9rem 0 1.5rem; /* top padding kvůli přesahu loga */
}
.trust-strip-inner {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 0; max-width: var(--max-w); margin: 0 auto; padding: 0 1.5rem;
}
.trust-item {
  display: flex; align-items: center; gap: 0.6rem;
  color: rgba(255,255,255,0.92);
  font-size: 0.87rem; font-weight: 500;
  padding: 0.4rem 1.5rem;
  border-right: 1px solid rgba(255,255,255,0.15);
}
.trust-item:last-child { border-right: none; }
.trust-item svg { flex-shrink: 0; opacity: 0.85; }

/* ── Section header ─────────────────────────────────────── */
.section-header { margin-bottom: 3rem; }
.section-header.centered { text-align: center; }
.section-header.centered .lead { margin: 0.75rem auto 0; }
.section-header .lead { margin-top: 0.75rem; }

/* ── About ───────────────────────────────────────────────── */
.about-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center;
}
.about-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; margin-top: 2rem; }
.pillar-card {
  background: var(--surface-low);
  border-radius: var(--radius-card);
  padding: 1.25rem;
}
.pillar-icon { font-size: 1.5rem; margin-bottom: 0.5rem; }
.pillar-card h4 { font-size: 0.9rem; font-weight: 600; color: var(--primary); margin-bottom: 0.25rem; }
.pillar-card p { font-size: 0.82rem; color: var(--on-muted); line-height: 1.5; }
.about-visual-block {
  background: var(--gradient-cta);
  border-radius: 1.25rem;
  padding: 3rem 2.5rem;
  color: #fff;
  position: relative; overflow: hidden;
}
.about-visual-block::before {
  content: '';
  position: absolute; top: -30%; right: -20%;
  width: 200px; height: 200px; border-radius: 50%;
  background: rgba(255,255,255,0.06);
}
.about-visual-block h3 { font-size: 1.5rem; margin-bottom: 1.25rem; color: #fff; }
.about-stats { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.about-stat-num { font-family: var(--font-head); font-size: 2.2rem; font-weight: 800; }
.about-stat-label { font-size: 0.82rem; opacity: 0.8; margin-top: 0.2rem; }
.about-stat-divider { border: none; border-top: 1px solid rgba(255,255,255,0.15); margin: 1.5rem 0; }

/* ── Services ────────────────────────────────────────────── */
.services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.25rem;
}
.service-card {
  background: var(--surface-card);
  border-radius: var(--radius-card);
  padding: 1.75rem 1.5rem;
  box-shadow: var(--shadow-card);
  transition: background 0.2s, box-shadow 0.2s, transform 0.2s;
  display: flex; flex-direction: column; gap: 0.75rem;
  position: relative; overflow: hidden;
}
.service-card::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0;
  height: 3px;
  background: var(--gradient-cta);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.3s ease;
}
.service-card:hover { background: var(--surface-low); box-shadow: var(--shadow-soft); transform: translateY(-2px); }
.service-card:hover::after { transform: scaleX(1); }
.service-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--surface-low);
  display: flex; align-items: center; justify-content: center;
  color: var(--primary-mid); flex-shrink: 0;
}
.service-card h3 { font-size: 1rem; font-weight: 700; color: var(--on-surface); }
.service-card p { font-size: 0.85rem; color: var(--on-muted); line-height: 1.55; flex: 1; }
.service-link { font-size: 0.82rem; font-weight: 600; color: var(--primary-mid); display: flex; align-items: center; gap: 0.3rem; margin-top: 0.25rem; }

/* ── Feature Sections ────────────────────────────────────── */
.feature-section { overflow: hidden; }
.feature-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.feature-grid.reverse .feature-content { order: 2; }
.feature-grid.reverse .feature-visual { order: 1; }

.feature-content p { color: var(--on-muted); margin: 1rem 0 1.5rem; line-height: 1.7; }
.feature-points { display: flex; flex-direction: column; gap: 0.75rem; margin-bottom: 2rem; }
.feature-point {
  display: flex; align-items: flex-start; gap: 0.75rem;
  font-size: 0.92rem; color: var(--on-surface);
}
.feature-point-icon {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--secondary-light);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0; margin-top: 0.1rem;
  color: var(--secondary);
}

.bio-visual {
  background: linear-gradient(145deg, #001a4d 0%, #002c7c 50%, #1d439c 100%);
  border-radius: 1.5rem;
  padding: 3rem 2.5rem;
  color: #fff;
  position: relative; overflow: hidden;
}
.bio-visual::before {
  content: '';
  position: absolute; top: -50px; right: -50px;
  width: 250px; height: 250px; border-radius: 50%;
  background: rgba(255,255,255,0.04);
}
.bio-visual-title { font-size: 1rem; font-weight: 600; opacity: 0.8; margin-bottom: 1.5rem; }
.bio-conditions { display: flex; flex-direction: column; gap: 0.75rem; }
.bio-condition {
  background: rgba(255,255,255,0.08);
  border-radius: 0.5rem;
  padding: 1rem 1.25rem;
  display: flex; align-items: center; gap: 1rem;
}
.bio-condition-dot { width: 10px; height: 10px; border-radius: 50%; background: var(--secondary-light); flex-shrink: 0; }
.bio-condition-name { font-weight: 600; font-size: 0.95rem; }
.bio-condition-desc { font-size: 0.8rem; opacity: 0.7; margin-top: 0.1rem; }

.photo-visual {
  background: var(--surface-high);
  border-radius: 1.5rem;
  padding: 2.5rem;
  position: relative;
}
.photo-tech-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
.photo-tech-card {
  background: var(--surface-card);
  border-radius: var(--radius-card);
  padding: 1.25rem;
  box-shadow: var(--shadow-card);
  text-align: center;
}
.photo-tech-icon { font-size: 2rem; margin-bottom: 0.5rem; }
.photo-tech-name { font-size: 0.85rem; font-weight: 600; color: var(--on-surface); }
.photo-tech-desc { font-size: 0.75rem; color: var(--on-muted); margin-top: 0.2rem; }

/* ── Accreditation ───────────────────────────────────────── */
.accred-card {
  background: var(--surface-card);
  border-radius: 1.25rem;
  padding: 3rem;
  box-shadow: var(--shadow-soft);
  display: grid; grid-template-columns: auto 1fr auto;
  gap: 3rem; align-items: center;
}
.accred-badge {
  width: 96px; height: 96px; border-radius: 50%;
  background: var(--gradient-cta);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 8px 24px rgba(0,44,124,0.25);
}
.accred-body h3 { font-size: 1.35rem; color: var(--primary); margin-bottom: 0.5rem; }
.accred-body p { color: var(--on-muted); max-width: 60ch; line-height: 1.65; }
.accred-seal {
  text-align: center; flex-shrink: 0;
  padding: 1.25rem 2rem;
  background: var(--surface-low);
  border-radius: var(--radius-card);
}
.accred-seal-year { font-family: var(--font-head); font-size: 2rem; font-weight: 800; color: var(--primary); }
.accred-seal-label { font-size: 0.75rem; color: var(--on-muted); margin-top: 0.2rem; }

/* ── Insurance ───────────────────────────────────────────── */
.insurance-inner {
  display: grid; grid-template-columns: 1fr 2fr; gap: 4rem; align-items: center;
}
.insurance-claim h2 { margin-bottom: 0.75rem; }
.insurance-claim p { color: var(--on-muted); max-width: 38ch; line-height: 1.65; }
.insurance-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0.75rem; }
.insurance-badge {
  background: var(--surface-card);
  border-radius: var(--radius-card);
  padding: 1rem 1.25rem;
  box-shadow: var(--shadow-card);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.25rem;
  border-top: 3px solid var(--secondary);
  transition: transform 0.2s, box-shadow 0.2s;
  text-align: left;
}
.insurance-badge:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-soft);
}
.insurance-badge-logo {
  width: 44px;
  height: 44px;
  object-fit: contain;
  flex-shrink: 0;
  border-radius: 4px;
}
.insurance-badge-code { font-family: var(--font-head); font-size: 1.35rem; font-weight: 800; color: var(--primary); line-height: 1; }
.insurance-badge-name { font-size: 0.75rem; font-weight: 500; color: var(--on-muted); margin-top: 0.25rem; line-height: 1.2; text-transform: uppercase; letter-spacing: 0.02em; }


/* ── Team ────────────────────────────────────────────────── */
.team-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.team-card {
  background: var(--surface-card);
  border-radius: var(--radius-card);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: transform 0.2s, box-shadow 0.2s;
}
.team-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-soft); }
.team-photo {
  background: var(--surface-high);
  height: 220px;
  display: flex; align-items: center; justify-content: center;
  font-size: 4rem; color: var(--primary-light);
}
.team-info { padding: 1.5rem; }
.team-name { font-weight: 700; font-size: 1.05rem; color: var(--on-surface); }
.team-title { font-size: 0.82rem; color: var(--primary-mid); font-weight: 500; margin-top: 0.15rem; }
.team-spec { font-size: 0.82rem; color: var(--on-muted); margin-top: 0.5rem; line-height: 1.5; }
.team-cta { font-size: 0.8rem; color: var(--on-muted); font-style: italic; margin-top: 0.75rem; }

/* ── Contact / Booking ───────────────────────────────────── */
.contact-section { background: var(--primary); color: #fff; }
.contact-header { text-align: center; margin-bottom: 3rem; }
.contact-header h2 { color: #fff; }
.contact-header p { color: rgba(255,255,255,0.75); margin-top: 0.75rem; }
.contact-cta-row { display: flex; justify-content: center; gap: 1rem; margin-bottom: 3.5rem; flex-wrap: wrap; }
.btn-white { background: #fff; color: var(--primary); font-weight: 700; }
.btn-white:hover { background: var(--surface-low); }
.btn-white-outline { background: transparent; color: #fff; border: 1.5px solid rgba(255,255,255,0.4); }
.btn-white-outline:hover { background: rgba(255,255,255,0.1); border-color: #fff; }

.ordinace-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.ordinace-card {
  background: rgba(255,255,255,0.07);
  border-radius: var(--radius-card);
  padding: 1.75rem 1.5rem;
  backdrop-filter: blur(8px);
}
.ordinace-card-header { display: flex; align-items: center; gap: 0.75rem; margin-bottom: 1.25rem; }
.ordinace-icon {
  width: 40px; height: 40px; border-radius: 10px;
  background: rgba(255,255,255,0.12);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.ordinace-name { font-weight: 700; font-size: 0.95rem; }
.ordinace-phone { font-size: 0.82rem; color: rgba(255,255,255,0.65); margin-top: 0.1rem; }
.hours-row { display: flex; justify-content: space-between; align-items: flex-start; padding: 0.45rem 0; border-bottom: 1px solid rgba(255,255,255,0.1); font-size: 0.83rem; }
.hours-row:last-child { border-bottom: none; }
.hours-day { color: rgba(255,255,255,0.7); min-width: 5rem; flex-shrink: 0; }
.hours-time { color: #fff; font-weight: 500; text-align: right; font-size: 0.8rem; }
.hours-note { font-size: 0.72rem; color: rgba(255,255,255,0.5); margin-top: 0.1rem; }

.contact-bottom {
  display: grid; grid-template-columns: 1fr 1fr; gap: 2rem;
  margin-top: 3rem; padding-top: 2.5rem;
  border-top: 1px solid rgba(255,255,255,0.15);
}
.contact-info-block { display: flex; flex-direction: column; gap: 0.5rem; }
.contact-info-label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.1em; color: rgba(255,255,255,0.5); margin-bottom: 0.25rem; }
.contact-info-val { font-weight: 600; font-size: 1.05rem; }
.contact-info-sub { font-size: 0.82rem; color: rgba(255,255,255,0.65); }

/* ── FAQ ─────────────────────────────────────────────────── */
.faq-list { max-width: 780px; margin: 0 auto; display: flex; flex-direction: column; gap: 0.75rem; }
.faq-item {
  background: var(--surface-card);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.faq-question {
  width: 100%; display: flex; align-items: center; justify-content: space-between;
  padding: 1.25rem 1.5rem; background: none;
  font-family: var(--font-body); font-size: 0.95rem; font-weight: 600;
  color: var(--on-surface); text-align: left;
  cursor: pointer; gap: 1rem;
}
.faq-question svg { flex-shrink: 0; color: var(--primary-mid); transition: transform 0.25s; }
.faq-item.open .faq-question svg { transform: rotate(180deg); }
.faq-answer { display: none; padding: 0 1.5rem 1.25rem; font-size: 0.9rem; color: var(--on-muted); line-height: 1.65; }
.faq-item.open .faq-answer { display: block; }

/* ── Footer ──────────────────────────────────────────────── */
.footer { background: var(--on-surface); color: rgba(255,255,255,0.8); padding: 4rem 0 2rem; }
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.5fr; gap: 3rem; margin-bottom: 3rem; }
.footer-logo { margin-bottom: 1rem; filter: brightness(0) invert(1); }
.footer-about { font-size: 0.85rem; line-height: 1.65; color: rgba(255,255,255,0.6); max-width: 30ch; }
.footer-col h4 { font-size: 0.85rem; font-weight: 700; color: #fff; margin-bottom: 1rem; text-transform: uppercase; letter-spacing: 0.06em; }
.footer-col ul { display: flex; flex-direction: column; gap: 0.5rem; }
.footer-col ul li a { font-size: 0.85rem; color: rgba(255,255,255,0.6); transition: color 0.2s; }
.footer-col ul li a:hover { color: #fff; }
.footer-contact-item { display: flex; align-items: flex-start; gap: 0.5rem; font-size: 0.85rem; color: rgba(255,255,255,0.65); margin-bottom: 0.6rem; }
.footer-bottom {
  border-top: 1px solid rgba(255,255,255,0.1);
  padding-top: 2rem;
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 1rem;
  font-size: 0.78rem; color: rgba(255,255,255,0.4);
}
.footer-bottom a { color: rgba(255,255,255,0.5); }
.footer-bottom a:hover { color: rgba(255,255,255,0.8); }
.footer-legal { display: flex; gap: 1.5rem; }

/* ── Mobile sticky CTA ───────────────────────────────────── */
.sticky-cta {
  display: none;
  position: fixed; bottom: 0; left: 0; right: 0; z-index: 900;
  background: var(--surface-card);
  padding: 0.75rem 1rem;
  box-shadow: 0 -4px 20px rgba(11,28,48,0.12);
  gap: 0.5rem;
}
.sticky-cta .btn { flex: 1; justify-content: center; }

/* ── Responsive ──────────────────────────────────────────── */
@media (max-width: 1024px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .team-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
  .about-grid, .feature-grid { gap: 3rem; }
  .insurance-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (max-width: 768px) {
  .navbar-nav, .navbar-cta { display: none; }
  .navbar-hamburger { display: flex; }

  .navbar-logo img {
    height: 56px;
    width: auto;
  }

  .hero-inner { grid-template-columns: 1fr; gap: 2.5rem; padding: 4rem 1.5rem 3rem; }
  .hero-visual { display: none; }
  .hero { min-height: auto; }

  .trust-strip-inner { gap: 0; }
  .trust-item { border-right: none; border-bottom: 1px solid rgba(255,255,255,0.15); width: 100%; justify-content: center; }

  .about-grid, .feature-grid { grid-template-columns: 1fr; }
  .feature-grid.reverse .feature-content { order: 1; }
  .feature-grid.reverse .feature-visual { order: 2; }
  .about-pillars { grid-template-columns: 1fr; }

  .services-grid { grid-template-columns: 1fr; }
  .ordinace-grid { grid-template-columns: 1fr; }
  .team-grid { grid-template-columns: 1fr; }
  .insurance-inner { grid-template-columns: 1fr; }
  .insurance-grid { grid-template-columns: repeat(2, 1fr); }

  .accred-card { grid-template-columns: 1fr; gap: 1.5rem; }
  .accred-badge { margin: 0 auto; }
  .accred-seal { text-align: left; }

  .contact-bottom { grid-template-columns: 1fr; }
  .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
  .footer-bottom { flex-direction: column; }

  .sticky-cta { display: flex; }
  body { padding-bottom: 76px; }
}

@media (max-width: 480px) {
  .hero-actions { display: none; }
  .hero-trust { flex-wrap: wrap; gap: 0.5rem; }
  .hero-trust-divider { display: none; }
  .about-stats { grid-template-columns: 1fr; }
}

/* ── Scroll reveal animation ─────────────────────────────── */
.reveal {
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.reveal.visible { opacity: 1; transform: none; }
.reveal-delay-1 { transition-delay: 0.1s; }
.reveal-delay-2 { transition-delay: 0.2s; }
.reveal-delay-3 { transition-delay: 0.3s; }

/* ── Card Hover Effects ─────────────────────────────── */
.service-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.service-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 32px rgba(11, 28, 48, 0.08); /* Premium shadow */
}

.team-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.team-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 16px 32px rgba(11, 28, 48, 0.08);
}

.accred-card {
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}
.accred-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 24px rgba(11, 28, 48, 0.06);
}
