/* ============================================================================
   Caputo Oral Restoration — Global Design System
   styles.css
   ============================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@400;500;600;700&family=Jost:wght@300;400;500;600&display=swap');

/* ── CUSTOM PROPERTIES ──────────────────────────────────────────────────── */
:root {
  --font-display: 'Cormorant Garamond', 'Times New Roman', Georgia, serif;
  --font-sans:    'Jost', system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;
  --font-mono:    ui-monospace, SFMono-Regular, Menlo, monospace;

  /* Brand colors */
  --primary:      #2b2a2f;
  --on-primary:   #f6f1e7;
  --ink:          #2b2a2f;
  --ink-strong:   #1b1a1e;
  --body:         #46434b;
  --body-mid:     #6c675f;
  --mute:         #8f897d;
  --mute-soft:    #b4ac9d;
  --hairline:     #ddd3c2;
  --canvas:       #f6f1e7;
  --canvas-soft:  #efe6d6;

  /* Brand metals */
  --bronze:       #9c7b4d;
  --bronze-deep:  #7e6038;
  --gold:         #b89668;
  --taupe:        #9a8975;
  --slate:        #565a60;
  --charcoal:     #2b2a2f;
  --ivory:        #f6f1e7;

  /* Accents */
  --accent-purple:    #9c7b4d;
  --accent-pink:      #9a8975;
  --accent-blue:      #565a60;
  --accent-orange:    #7e6038;
  --accent-green:     #8c7a45;
  --accent-blue-deep: #7e6038;
  --accent-blue-info: #9c7b4d;
  --accent-yellow:    #c2a266;
  --accent-red:       #a3402f;
  --link:             var(--accent-blue-deep);

  /* Spacing */
  --space-xs:  4px;
  --space-sm:  8px;
  --space-md:  12px;
  --space-lg:  16px;
  --space-xl:  20px;
  --space-2xl: 24px;
  --space-3xl: 32px;
  --space-4xl: 48px;
  --space-5xl: 64px;
  --space-6xl: 96px;

  /* Radius */
  --radius-xs:   2px;
  --radius-sm:   4px;
  --radius-md:   8px;
  --radius-full: 9999px;

  /* Shadows */
  --shadow-1: 0 0 0 1px var(--hairline);
  --shadow-2: 0 84px 24px rgba(0,0,0,0), 0 54px 22px rgba(0,0,0,.01),
              0 30px 18px rgba(0,0,0,.04), 0 13px 13px rgba(0,0,0,.08),
              0 3px 7px rgba(0,0,0,.09);
  --shadow-3: 0 84px 24px rgba(0,0,0,0), 0 54px 22px rgba(0,0,0,.02),
              0 30px 18px rgba(0,0,0,.06), 0 13px 13px rgba(0,0,0,.10),
              0 3px 7px rgba(0,0,0,.12);
  --shadow-4: 0 24px 24px rgba(0,0,0,.26), 0 6px 13px rgba(0,0,0,.29);

  /* Nav height for hero offset */
  --nav-height: 82px;
}

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

html, body {
  background: var(--canvas);
  color: var(--ink);
  font-family: var(--font-sans);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  scroll-behavior: smooth;
}

img { max-width: 100%; height: auto; display: block; }
a   { color: inherit; }
ul  { list-style: none; }
button { font-family: var(--font-sans); }

h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  font-feature-settings: 'liga' 1, 'dlig' 1;
  letter-spacing: -0.005em;
  color: var(--ink);
}

/* ── LAYOUT UTILITIES ───────────────────────────────────────────────────── */
.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 32px;
}

.section { padding: 80px 0; }
.section--dark { background: var(--charcoal); }
.section--soft { background: var(--canvas-soft); }

/* ── TYPOGRAPHY ─────────────────────────────────────────────────────────── */
.eyebrow {
  font-family: var(--font-sans);
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.6px;
  text-transform: uppercase;
  color: var(--mute);
}

.section-eyebrow {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 2.4px;
  text-transform: uppercase;
  color: var(--bronze);
  margin-bottom: 16px;
}

/* ── BUTTONS ────────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.16px;
  line-height: 1.6;
  padding: 12px 20px;
  border-radius: var(--radius-sm);
  border: none;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition: background .15s ease, color .15s ease, transform .15s ease;
}
.btn:active { transform: translateY(1px); }

.btn-primary   { background: var(--charcoal); color: #fff; }
.btn-primary:hover { background: #222; }

.btn-secondary { background: #fff; color: var(--charcoal); border: 1px solid var(--hairline); }
.btn-secondary:hover { background: var(--canvas-soft); }

.btn-ghost     { background: transparent; color: var(--charcoal); }
.btn-ghost:hover { background: var(--canvas-soft); }

.btn-on-dark   { background: #fff; color: var(--charcoal); }
.btn-on-dark:hover { background: #f0f0f0; }

.btn-lg { padding: 14px 24px; }
.btn-full { width: 100%; }

/* ── BADGES ─────────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--font-sans);
  font-size: 12.8px;
  font-weight: 550;
  padding: 5px 9px;
  border-radius: var(--radius-sm);
}
.badge-neutral  { background: var(--canvas-soft); color: var(--body); }
.badge-info     { background: var(--accent-blue-info); color: #fff; }
.badge-info-soft { background: #fff; color: var(--accent-blue-info); border: 1px solid var(--hairline); }

/* ── TEXT ARROW LINK ────────────────────────────────────────────────────── */
.text-arrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-sans);
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.16px;
  color: var(--charcoal);
  text-decoration: none;
  padding: 8px 0;
  transition: text-decoration .15s ease;
}
.text-arrow:hover { text-decoration: underline; text-underline-offset: 3px; }
.text-arrow svg   { transition: transform .15s ease; }
.text-arrow:hover svg { transform: translateX(3px); }

/* ── ICON CIRCLE ─────────────────────────────────────────────────────────── */
.icon-circle {
  width: 44px; height: 44px;
  border-radius: var(--radius-full);
  border: 1px solid var(--hairline);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.icon-circle--dark { border-color: rgba(255,255,255,.18); }

/* ── STARS ───────────────────────────────────────────────────────────────── */
.stars { display: flex; gap: 2px; }
.stars svg { fill: var(--accent-yellow); }

/* ── HEADER ─────────────────────────────────────────────────────────────── */
.eb-header {
  position: sticky;
  top: 0;
  z-index: 50;
  height: var(--nav-height);
  background: rgba(246,241,231,0.86);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--hairline);
  transition: background .25s ease;
}

.eb-header .container {
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

/* Logo — override global max-width reset */
.eb-logo img {
  height: 60px !important;
  width: auto !important;
  max-width: none !important;
  display: block;
}

/* Desktop nav */
.eb-nav {
  display: flex;
  align-items: center;
  gap: 30px;
}

.eb-nav a, .eb-nav-item {
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: #363636;
  text-decoration: none;
  padding: 8px 0;
  position: relative;
  cursor: pointer;
  background: none;
  border: none;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  transition: color .15s ease;
}
.eb-nav a:hover, .eb-nav-item:hover { color: var(--charcoal); }
.eb-nav a.active, .eb-nav-item.active { color: var(--charcoal); }
.eb-nav a.active::after, .eb-nav-item.active::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: var(--charcoal);
  border-radius: 2px;
}

/* Dropdown menus */
.eb-dropdown { position: relative; display: flex; align-items: center; }
.eb-dropdown-menu {
  display: none;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 60;
  padding-top: 16px; /* bridges gap so mouse stays in hover zone */
}
.eb-dropdown-menu-inner {
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
  padding: 20px;
}
.eb-dropdown:hover .eb-dropdown-menu,
.eb-dropdown-menu:hover { display: block; }

.eb-dropdown-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 28px; width: 520px; }
.eb-dropdown-col-title {
  display: flex; align-items: center; gap: 8px;
  padding: 0 10px; margin-bottom: 10px;
  font-family: var(--font-sans); font-size: 12px; font-weight: 600;
  letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--mute); text-decoration: none; cursor: default;
}
.eb-dropdown-col-title--link {
  cursor: pointer;
  color: var(--charcoal);
  transition: color .15s ease;
}
.eb-dropdown-col-title--link:hover { color: var(--bronze); }
.eb-dropdown-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  font-family: var(--font-sans); font-size: 14px; font-weight: 500;
  color: var(--body); text-decoration: none;
  transition: background .12s ease, color .12s ease;
}
.eb-dropdown-item:hover { background: var(--canvas-soft); color: var(--charcoal); }
.eb-dropdown-dot {
  width: 6px; height: 6px;
  border-radius: var(--radius-full);
  flex-shrink: 0;
}
.eb-dropdown-items  { display: flex; flex-direction: column; gap: 2px; }
.eb-dropdown-simple { display: flex; flex-direction: column; gap: 2px; width: 200px; }

/* Header actions */
.eb-header-actions {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-shrink: 0;
}
.eb-phone {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: var(--font-sans);
  font-size: 14px;
  font-weight: 500;
  color: var(--charcoal);
  text-decoration: none;
  white-space: nowrap;
}

/* Mobile toggle */
.eb-mobile-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px; height: 40px;
  background: none; border: none; cursor: pointer;
  padding: 8px;
}
.eb-mobile-toggle span {
  display: block;
  height: 2px;
  background: var(--charcoal);
  border-radius: 2px;
  transition: transform .25s ease, opacity .25s ease;
}
.eb-mobile-toggle.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.eb-mobile-toggle.open span:nth-child(2) { opacity: 0; }
.eb-mobile-toggle.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* Mobile menu overlay */
.eb-mobile-menu {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 49;
  background: var(--canvas);
  padding: calc(var(--nav-height) + 24px) 32px 40px;
  overflow-y: auto;
  flex-direction: column;
  gap: 8px;
}
.eb-mobile-menu.open { display: flex; }
.eb-mobile-menu a {
  font-family: var(--font-sans);
  font-size: 18px; font-weight: 500;
  color: var(--charcoal);
  text-decoration: none;
  padding: 14px 0;
  border-bottom: 1px solid var(--hairline);
}
.eb-mobile-menu .mobile-sub {
  padding-left: 16px;
  font-size: 15px;
  color: var(--body);
}
.eb-mobile-cta { margin-top: 24px; }

/* Chevron icon */
.chevron {
  display: inline-block;
  width: 14px; height: 14px;
  transition: transform .15s ease;
  vertical-align: middle;
}
.eb-dropdown:hover .chevron { transform: rotate(180deg); }

/* ── HERO ────────────────────────────────────────────────────────────────── */
.eb-hero {
  background: var(--canvas);
  padding: 72px 0 64px;
}

.eb-hero-grid {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: 56px;
  align-items: center;
}

.eb-hero-h1 {
  font-family: var(--font-display);
  font-size: 80px;
  font-weight: 600;
  line-height: 1.04;
  letter-spacing: -0.8px;
  color: #080808;
  margin: 0 0 24px;
}

.eb-hero-lead {
  font-size: 20px;
  line-height: 1.6;
  letter-spacing: -0.2px;
  color: var(--body);
  margin: 0 0 32px;
  max-width: 480px;
}

.eb-hero-ctas {
  display: flex;
  gap: 12px;
  margin-bottom: 44px;
  flex-wrap: wrap;
}

.eb-hero-stats {
  display: flex;
  gap: 48px;
  padding-top: 28px;
  border-top: 1px solid var(--hairline);
}

.stat-value {
  font-family: var(--font-display);
  font-size: 44px;
  font-weight: 500;
  line-height: 1;
  color: var(--ink);
}

.stat-label {
  font-size: 13px;
  line-height: 1.4;
  color: var(--body-mid);
  margin-top: 6px;
  letter-spacing: 0.2px;
}

.eb-hero-img-wrap {
  position: relative;
}
.eb-hero-img-frame {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-2);
  overflow: hidden;
  aspect-ratio: 4 / 5;
}
.eb-hero-img-frame img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 55% 45%;
}

.eb-hero-badge {
  position: absolute;
  left: -28px; bottom: 36px;
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
  padding: 16px 20px;
  display: flex;
  align-items: center;
  gap: 14px;
}
.eb-hero-badge-title {
  font-size: 16px; font-weight: 600; line-height: 1.2; color: #080808;
}
.eb-hero-badge-sub {
  font-size: 13px; line-height: 1.3; color: var(--body-mid); margin-top: 2px;
}

/* ── SERVICE CARDS ───────────────────────────────────────────────────────── */
.eb-services-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.eb-service-card {
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  text-decoration: none;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease;
}
.eb-service-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--shadow-3);
}
.eb-service-card--span {
  grid-column: span 2;
  display: grid;
  grid-template-columns: 42% 1fr;
  flex-direction: unset;
}

.eb-card-photo {
  position: relative;
  overflow: hidden;
}
.eb-card-photo img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
}
.eb-card-photo--fill { min-height: 340px; }

.eb-card-tag {
  position: absolute;
  top: 14px; left: 14px;
  display: inline-flex; align-items: center; gap: 7px;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(4px);
  border-radius: var(--radius-sm);
  padding: 5px 10px;
}
.eb-card-tag-dot {
  width: 8px; height: 8px;
  border-radius: var(--radius-full);
}
.eb-card-tag-text {
  font-size: 11px; font-weight: 500;
  letter-spacing: 0.8px; text-transform: uppercase;
  color: #080808;
}

.eb-card-caption {
  padding: 20px 22px;
  display: flex; flex-direction: column; justify-content: center; gap: 0;
  flex: 1;
}
.eb-card-caption--span { padding: 32px 38px; }

.eb-card-title {
  font-family: var(--font-display);
  font-size: 19px; font-weight: 600; line-height: 1.2;
  letter-spacing: -0.4px; color: #080808;
  margin-bottom: 10px;
}
.eb-card-title--span { font-size: 26px; }

.eb-card-desc {
  font-size: 14px; line-height: 1.55; color: var(--body);
  margin: 0 0 16px; max-width: 380px;
}
.eb-card-desc--span { font-size: 16px; }

.eb-card-more {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 500; color: #080808;
}
.eb-service-card:hover .eb-card-more svg { transform: translateX(3px); }
.eb-card-more svg { transition: transform .18s ease; }

/* ── WHY BAND ─────────────────────────────────────────────────────────────── */
.eb-why { background: #080808; padding: 88px 0; }
.eb-why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 40px; }
.eb-why-icon { margin-bottom: 20px; }
.eb-why-title { font-size: 20px; font-weight: 500; letter-spacing: -0.2px; color: #fff; margin-bottom: 10px; }
.eb-why-desc  { font-size: 15px; line-height: 1.6; color: var(--mute-soft); }

/* ── DOCTOR INTRO ─────────────────────────────────────────────────────────── */
.eb-doctor-grid {
  display: grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap: 56px;
  align-items: center;
}
.eb-doctor-img {
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-2);
  overflow: hidden;
  aspect-ratio: 4 / 5;
}
.eb-doctor-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: 50% 20%;
}
.eb-doctor-h2 {
  font-size: 44.8px; font-weight: 600; line-height: 1.04;
  letter-spacing: -0.45px; color: #080808;
  margin: 0 0 20px; max-width: 540px;
}
.eb-doctor-body {
  font-size: 18px; line-height: 1.6; color: var(--body);
  margin: 0 0 16px; max-width: 520px;
}
.eb-doctor-badges { display: flex; gap: 12px; flex-wrap: wrap; margin-bottom: 28px; }

/* ── TESTIMONIALS ──────────────────────────────────────────────────────────── */
.eb-quotes-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  align-items: stretch;
}
.eb-quote-card {
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  padding: 28px;
  display: flex; flex-direction: column; gap: 18px;
}
.eb-quote-card--featured {
  box-shadow: var(--shadow-2);
  grid-column: span 2;
}
.eb-quote-text { font-size: 16px; line-height: 1.5; letter-spacing: -0.2px; color: var(--ink-strong); flex: 1; }
.eb-quote-text--featured { font-size: 24px; }
.eb-quote-attr {
  display: flex; align-items: center; gap: 12px;
  padding-top: 6px; border-top: 1px solid var(--hairline);
}
.eb-quote-avatar {
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  background: var(--canvas-soft);
  border: 1px solid var(--hairline);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 600; color: var(--body-mid);
  flex-shrink: 0;
}
.eb-quote-name   { font-size: 14px; font-weight: 600; color: #080808; }
.eb-quote-detail { font-size: 12.5px; color: var(--mute); }

/* ── CTA BAND ─────────────────────────────────────────────────────────────── */
.eb-cta-band {
  background: var(--charcoal);
  padding: 80px 0;
}
.eb-cta-box {
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 48px;
  align-items: center;
}
.eb-cta-h2 {
  font-size: 48px; font-weight: 600; line-height: 1.05;
  letter-spacing: -0.6px; color: #fff; margin: 0 0 16px;
}
.eb-cta-desc { font-size: 18px; line-height: 1.6; color: var(--mute-soft); margin: 0; max-width: 460px; }
.eb-cta-actions { display: flex; flex-direction: column; gap: 12px; }
.eb-cta-phone {
  display: inline-flex; align-items: center; justify-content: center; gap: 9px;
  font-size: 16px; font-weight: 500; line-height: 1.6;
  color: #fff; text-decoration: none; padding: 12px;
  border: 1px solid rgba(255,255,255,.22);
  border-radius: var(--radius-sm);
}

/* ── FOOTER ───────────────────────────────────────────────────────────────── */
.eb-footer {
  background: var(--canvas);
  border-top: 1px solid var(--hairline);
  padding: 56px 0 40px;
}
.eb-footer-grid {
  display: grid;
  grid-template-columns: 1.3fr 1fr 1fr 1fr 1fr;
  gap: 28px;
  padding-bottom: 44px;
}
.eb-footer-brand img {
  height: 80px !important;
  width: auto !important;
  max-width: none !important;
}
.eb-footer-tagline {
  font-size: 14px; line-height: 1.6; color: var(--body-mid);
  margin: 20px 0 0; max-width: 250px;
}
.eb-footer-contact { display: flex; flex-direction: column; gap: 8px; margin-top: 20px; }
.eb-footer-contact-item {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; line-height: 1.4; color: var(--body);
}
.eb-footer-col-title {
  font-size: 12px; font-weight: 500;
  letter-spacing: 0.6px; text-transform: uppercase;
  color: var(--mute); margin-bottom: 16px;
}
.eb-footer-links { display: flex; flex-direction: column; gap: 11px; }
.eb-footer-links a {
  font-size: 14px; line-height: 1.4;
  color: var(--body-mid); text-decoration: none;
  transition: color .15s ease;
}
.eb-footer-links a:hover { color: var(--charcoal); }

.eb-footer-divider {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  padding: 8px 0 28px;
}
.eb-footer-divider-line {
  flex: 0 1 80px; height: 1px;
  background: var(--bronze); opacity: 0.5;
}
.eb-footer-divider-text {
  font-size: 13px; letter-spacing: 2.8px; text-transform: uppercase;
  color: var(--bronze); text-align: center;
}

.eb-footer-bottom {
  border-top: 1px solid var(--hairline);
  padding-top: 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 12px;
}
.eb-footer-copy { font-size: 13px; line-height: 1.4; color: var(--mute); }
.eb-footer-legal { display: flex; gap: 24px; }
.eb-footer-legal a {
  font-size: 13px; color: var(--body-mid);
  text-decoration: none; transition: color .15s ease;
}
.eb-footer-legal a:hover { color: var(--charcoal); }

/* ── SECTION HEADERS ──────────────────────────────────────────────────────── */
.eb-section-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  margin-bottom: 36px;
}
.eb-section-h2 {
  font-size: 44.8px; font-weight: 600; line-height: 1.04;
  letter-spacing: -0.45px; color: #080808;
  margin: 0; max-width: 600px;
}

/* ── SVG ICON HELPER ─────────────────────────────────────────────────────── */
.icon { display: inline-block; vertical-align: middle; flex-shrink: 0; }

/* ── LEGAL DISCLAIMER ────────────────────────────────────────────────────── */
.legal-disclaimer {
  font-size: 13px; line-height: 1.5; color: var(--mute);
  margin-top: 12px;
}
.legal-disclaimer a { color: var(--bronze); text-decoration: underline; }

/* ── CONSENT LABELS ──────────────────────────────────────────────────────── */
.consent-label {
  display: flex; align-items: flex-start; gap: 10px;
  font-size: 13px; line-height: 1.5; color: var(--body);
  cursor: pointer;
}
.consent-label input { margin-top: 3px; flex-shrink: 0; accent-color: var(--bronze); }
.consent-label a { color: var(--bronze); }

/* ── FORM FIELDS ─────────────────────────────────────────────────────────── */
.field-label {
  display: block;
  font-size: 14px; font-weight: 500; color: var(--charcoal);
  margin-bottom: 6px;
}
.field-input, .field-select, .field-textarea {
  width: 100%;
  font-family: var(--font-sans);
  font-size: 16px; line-height: 1.6;
  letter-spacing: -0.16px;
  color: var(--charcoal);
  background: #fff;
  border: 1px solid var(--hairline);
  border-radius: var(--radius-sm);
  padding: 11px 14px;
  outline: none;
  transition: border-color .15s ease, box-shadow .15s ease;
}
.field-input:focus, .field-select:focus, .field-textarea:focus {
  border-color: var(--bronze);
  box-shadow: 0 0 0 2px rgba(156,123,77,.22);
}
.field-textarea { resize: vertical; min-height: 120px; }
.field-help { font-size: 12px; line-height: 1.4; color: var(--mute); margin-top: 6px; }
.field-group { display: flex; flex-direction: column; gap: 16px; }
.field-row   { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }

/* ── RESPONSIVE ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .container { padding: 0 20px; }

  .eb-nav, .eb-header-actions { display: none; }
  .eb-mobile-toggle { display: flex; }

  .eb-hero-grid { grid-template-columns: 1fr; gap: 40px; }
  .eb-hero-h1   { font-size: 48px; }
  .eb-hero-badge { left: 0; right: 0; width: fit-content; }

  .eb-services-grid { grid-template-columns: 1fr; }
  .eb-service-card--span {
    grid-column: span 1;
    display: flex; flex-direction: column;
    grid-template-columns: unset;
  }
  .eb-card-photo--fill { min-height: 220px; }

  .eb-why-grid { grid-template-columns: 1fr; gap: 32px; }

  .eb-doctor-grid { grid-template-columns: 1fr; gap: 32px; }
  .eb-doctor-h2   { font-size: 32px; }

  .eb-quotes-grid { grid-template-columns: 1fr; }
  .eb-quote-card--featured { grid-column: span 1; }
  .eb-quote-text--featured { font-size: 18px; }

  .eb-cta-band { padding: 56px 0; }
  .eb-cta-box { grid-template-columns: 1fr; gap: 32px; }
  .eb-cta-h2  { font-size: 32px; }

  .eb-section-header { flex-direction: column; align-items: flex-start; gap: 16px; }
  .eb-section-h2 { font-size: 32px; }

  .eb-footer-grid { grid-template-columns: 1fr 1fr; }
  .eb-footer-brand { grid-column: span 2; }
  .eb-footer-bottom { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 480px) {
  .eb-hero-h1 { font-size: 36px; }
  .eb-hero-stats { flex-direction: column; gap: 20px; }
  .eb-footer-grid { grid-template-columns: 1fr; }
  .eb-footer-brand { grid-column: span 1; }
  .field-row { grid-template-columns: 1fr; }
}

/* =============================================================================
   HOME PAGE — Dr Lakani-inspired layout sections
   Uses Caputo brand tokens only. Prefixed lk-/dk- to avoid collisions.
   ============================================================================= */

/* wider content wrapper used by home-page sections */
.wrap { max-width: 1240px; margin: 0 auto; padding: 0 40px; }
@media (max-width: 768px) { .wrap { padding: 0 20px; } }

/* lk-section — section spacing */
.lk-section { padding: clamp(64px, 9vw, 112px) 0; }
.lk-section.soft { background: var(--canvas-soft); }

/* dk-eyebrow — eyebrow with leading rule */
.dk-eyebrow {
  font-family: var(--font-sans);
  font-size: 13.5px; font-weight: 600; text-transform: uppercase;
  letter-spacing: 1.6px; color: var(--bronze);
  display: inline-flex; align-items: center; gap: 9px;
}
.dk-eyebrow::before { content: ""; width: 22px; height: 1.5px; background: currentColor; display: inline-block; }
.dk-eyebrow.alt { color: var(--bronze-deep); }

/* display headings */
.display { font-family: var(--font-display); font-size: clamp(40px, 5.2vw, 68px); font-weight: 600; line-height: 1.02; letter-spacing: -0.03em; color: var(--ink); }
.display .accent { color: var(--bronze); }
.lk-h2 { font-family: var(--font-display); font-size: clamp(30px, 3.6vw, 46px); font-weight: 600; letter-spacing: -0.025em; color: var(--ink); line-height: 1.06; }
.lk-lead { font-size: clamp(17px, 1.4vw, 20px); line-height: 1.6; color: var(--body-mid); font-weight: 400; font-family: var(--font-sans); }

/* section head */
.lk-section-head { max-width: 760px; }
.lk-section-head .dk-eyebrow { margin-bottom: 18px; }
.lk-section-head .lk-h2 { margin-bottom: 18px; }
.lk-section-head .lk-lead { max-width: 620px; }

/* ── UTILITY BAR ────────────────────────────────────────────────────────────── */
.utility { background: var(--charcoal); color: rgba(246,241,231,.65); font-family: var(--font-sans); font-size: 13px; }
.utility .container { display: flex; align-items: center; justify-content: space-between; height: 40px; gap: 24px; }
.utility a { color: rgba(246,241,231,.8); text-decoration: none; transition: color .15s ease; }
.utility a:hover { color: var(--canvas); }
.u-left { display: flex; align-items: center; gap: 22px; }
.u-item { display: inline-flex; align-items: center; gap: 7px; white-space: nowrap; }
.u-item svg { width: 14px; height: 14px; stroke: var(--bronze); flex-shrink: 0; }
.u-right { display: flex; align-items: center; gap: 18px; }
.u-right a { color: rgba(246,241,231,.55); }
.u-right a:hover { color: var(--canvas); }
@media (max-width: 860px) { .u-item.areas { display: none; } }
@media (max-width: 600px) { .utility { display: none; } }

/* ── HERO ────────────────────────────────────────────────────────────────────── */
.lk-hero { position: relative; padding: clamp(48px,6vw,88px) 0 clamp(56px,7vw,96px); overflow: hidden; }
.lk-hero::before {
  content: ""; position: absolute; inset: 0; z-index: -1;
  background: radial-gradient(120% 90% at 92% 0%, rgba(156,123,77,.12) 0%, transparent 55%),
              radial-gradient(80%  70% at  0% 100%, rgba(126,96,56,.08)  0%, transparent 50%);
}
.lk-hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: clamp(32px,4vw,64px); align-items: center; }
.lk-hero-copy .dk-eyebrow { margin-bottom: 22px; }
.lk-hero-copy h1 { margin-bottom: 22px; }
.lk-hero-copy .lk-lead { margin-bottom: 30px; max-width: 540px; }
.lk-hero-actions { display: flex; flex-wrap: wrap; gap: 14px; align-items: center; }
.lk-hero-trust {
  margin-top: 38px; display: flex; gap: 28px; flex-wrap: wrap;
  padding-top: 28px; border-top: 1px solid var(--hairline);
}
.lk-hero-trust .t b { display: block; font-family: var(--font-display); font-size: 26px; font-weight: 600; color: var(--ink); letter-spacing: -0.02em; line-height: 1; }
.lk-hero-trust .t span { font-size: 13.5px; color: var(--body-mid); margin-top: 6px; display: block; font-family: var(--font-sans); }
.lk-hero-media { position: relative; }
.lk-hero-media .photo { border-radius: 14px; overflow: hidden; box-shadow: var(--shadow-3); border: 1px solid var(--hairline); aspect-ratio: 4/5; max-height: 560px; }
.lk-hero-media .photo img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 28%; }
.lk-hero-badge {
  position: absolute; left: -22px; bottom: 30px;
  background: #fff; border: 1px solid var(--hairline); border-radius: var(--radius-md);
  box-shadow: var(--shadow-2); padding: 16px 20px;
  display: flex; align-items: center; gap: 14px; max-width: 280px;
}
.lk-hero-badge .ic { width: 44px; height: 44px; border-radius: 9999px; background: rgba(156,123,77,.12); display: grid; place-items: center; flex-shrink: 0; }
.lk-hero-badge .ic svg { width: 22px; height: 22px; stroke: var(--bronze); }
.lk-hero-badge b { display: block; font-size: 15px; color: var(--ink); font-weight: 600; font-family: var(--font-sans); }
.lk-hero-badge span { font-size: 13px; color: var(--body-mid); font-family: var(--font-sans); }
@media (max-width: 920px) {
  .lk-hero-grid { grid-template-columns: 1fr; }
  .lk-hero-media { max-width: 520px; }
  .lk-hero-badge { left: 14px; }
}
@media (max-width: 480px) { .lk-hero-trust { flex-direction: column; gap: 20px; } }

/* ── TRUST STRIP ─────────────────────────────────────────────────────────────── */
.lk-strip { border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); background: #fff; }
.lk-strip .container { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; justify-content: space-between; padding-top: 22px; padding-bottom: 22px; }
.lk-strip-label { font-family: var(--font-sans); font-size: 13px; font-weight: 600; letter-spacing: 1.2px; text-transform: uppercase; color: var(--mute); }
.lk-strip-items { display: flex; gap: 30px; flex-wrap: wrap; }
.lk-strip-item { display: inline-flex; align-items: center; gap: 9px; font-family: var(--font-sans); font-size: 14.5px; font-weight: 500; color: var(--charcoal); }
.lk-strip-item svg { width: 18px; height: 18px; stroke: var(--bronze-deep); flex-shrink: 0; }
@media (max-width: 768px) { .lk-strip-items { gap: 18px; } .lk-strip-item { font-size: 13.5px; } }

/* ── SERVICES BENTO GRID ─────────────────────────────────────────────────────── */
.svc-bento { display: grid; grid-template-columns: repeat(12,1fr); grid-auto-rows: 224px; gap: 16px; margin-top: 48px; }
.svc-tile { position: relative; overflow: hidden; border-radius: var(--radius-md); border: 1px solid var(--hairline); background: var(--charcoal); display: block; isolation: isolate; cursor: pointer; text-decoration: none; }
.svc-tile .media { position: absolute; inset: 0; z-index: 0; background: var(--charcoal); }
.svc-tile .media.empty { background: repeating-linear-gradient(135deg,#2b2a2f 0 14px,#363537 14px 28px); display: grid; place-items: center; }
.svc-tile .media.empty::after { content: "Add image"; font-family: var(--font-sans); font-size: 12px; font-weight: 500; letter-spacing: .4px; color: rgba(246,241,231,.35); border: 1px dashed rgba(246,241,231,.25); border-radius: var(--radius-sm); padding: 8px 14px; }
.svc-tile .media img, .svc-tile .media video { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .6s cubic-bezier(.2,.6,.2,1); }
.svc-tile:hover .media img, .svc-tile:hover .media video { transform: scale(1.05); }
.svc-tile .scrim { position: absolute; inset: 0; z-index: 1; background: linear-gradient(180deg,rgba(43,42,47,0) 30%,rgba(43,42,47,.18) 52%,rgba(43,42,47,.85) 100%); transition: background .3s ease; }
.svc-tile:hover .scrim { background: linear-gradient(180deg,rgba(43,42,47,.05) 18%,rgba(43,42,47,.38) 50%,rgba(43,42,47,.92) 100%); }
.svc-tile .tile-body { position: absolute; inset: 0; z-index: 2; display: flex; flex-direction: column; justify-content: flex-end; padding: 22px 24px; }
.svc-tile .kicker { font-family: var(--font-sans); font-size: 11.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.4px; color: rgba(246,241,231,.75); margin-bottom: 8px; display: inline-flex; align-items: center; gap: 8px; }
.svc-tile .kicker .dot { width: 7px; height: 7px; border-radius: 50%; background: var(--bronze); display: inline-block; }
.svc-tile .kicker .dot.alt { background: var(--bronze-deep); }
.svc-tile h3 { font-family: var(--font-display); color: #f6f1e7; font-size: 21px; line-height: 1.1; letter-spacing: -0.02em; margin-bottom: 6px; font-weight: 600; }
.svc-tile p { font-family: var(--font-sans); color: rgba(246,241,231,.78); font-size: 13.5px; line-height: 1.5; max-width: 34ch; max-height: 0; opacity: 0; overflow: hidden; transition: max-height .35s ease, opacity .3s ease, margin .35s ease; }
.svc-tile:hover p { max-height: 80px; opacity: 1; margin-top: 2px; }
.svc-tile .tile-go { position: absolute; top: 18px; right: 18px; z-index: 2; width: 38px; height: 38px; border-radius: 50%; background: rgba(246,241,231,.12); backdrop-filter: blur(6px); border: 1px solid rgba(246,241,231,.22); display: grid; place-items: center; transition: background .2s ease; }
.svc-tile .tile-go svg { width: 17px; height: 17px; stroke: var(--canvas); transition: transform .2s ease; }
.svc-tile:hover .tile-go { background: var(--canvas); }
.svc-tile:hover .tile-go svg { stroke: var(--ink); transform: translate(2px,-2px); }
.svc-tile.feature { grid-column: span 7; grid-row: span 2; }
.svc-tile.feature h3 { font-size: clamp(26px,2.6vw,36px); }
.svc-tile.feature p { font-size: 15px; max-width: 42ch; }
.svc-tile.feature .tile-body { padding: 32px 34px; }
.svc-tile.wide   { grid-column: span 5; }
.svc-tile.third  { grid-column: span 4; }
.svc-foot { margin-top: 34px; display: flex; align-items: center; gap: 16px; flex-wrap: wrap; }
@media (max-width: 920px) {
  .svc-bento { grid-auto-rows: 200px; }
  .svc-tile.feature { grid-column: span 12; grid-row: span 2; }
  .svc-tile.wide   { grid-column: span 6; }
  .svc-tile.third  { grid-column: span 6; }
}
@media (max-width: 560px) {
  .svc-bento { grid-template-columns: 1fr; grid-auto-rows: 220px; }
  .svc-tile.feature { grid-column: span 1; grid-row: span 1; height: 300px; }
  .svc-tile.wide, .svc-tile.third { grid-column: span 1; }
  .svc-tile p { max-height: 80px; opacity: 1; }
}

/* ── MEET DOCTOR ─────────────────────────────────────────────────────────────── */
.lk-meet-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: clamp(32px,5vw,72px); align-items: center; }
.lk-meet-photo { position: relative; }
.lk-meet-photo .frame { border-radius: 14px; overflow: hidden; border: 1px solid var(--hairline); box-shadow: var(--shadow-3); aspect-ratio: 4/5; }
.lk-meet-photo .frame img { width: 100%; height: 100%; object-fit: cover; object-position: 50% 20%; }
.lk-meet-sig { position: absolute; right: -18px; top: 28px; background: var(--charcoal); color: var(--canvas); border-radius: var(--radius-md); padding: 16px 20px; box-shadow: var(--shadow-3); }
.lk-meet-sig b { font-family: var(--font-display); font-size: 28px; font-weight: 600; letter-spacing: -0.02em; display: block; line-height: 1; }
.lk-meet-sig span { font-family: var(--font-sans); font-size: 12.5px; color: rgba(246,241,231,.6); letter-spacing: .3px; }
.lk-meet-copy .dk-eyebrow { margin-bottom: 18px; }
.lk-meet-copy h2 { margin-bottom: 20px; }
.lk-meet-copy p { font-family: var(--font-sans); font-size: 16.5px; line-height: 1.62; color: var(--body); margin-bottom: 16px; max-width: 580px; }
.lk-creds { display: grid; grid-template-columns: 1fr 1fr; gap: 14px 26px; margin: 26px 0 30px; }
.lk-cred { display: flex; gap: 12px; align-items: flex-start; }
.lk-cred svg { width: 20px; height: 20px; stroke: var(--bronze-deep); flex-shrink: 0; margin-top: 2px; }
.lk-cred b { font-family: var(--font-sans); display: block; font-size: 15px; color: var(--ink); font-weight: 600; }
.lk-cred span { font-family: var(--font-sans); font-size: 13.5px; color: var(--body-mid); }
@media (max-width: 880px) { .lk-meet-grid { grid-template-columns: 1fr; } .lk-meet-photo { max-width: 460px; } .lk-creds { grid-template-columns: 1fr; } }

/* ── GALLERY + TABS ──────────────────────────────────────────────────────────── */
.lk-tabs { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 30px; }
.lk-tab { font-family: var(--font-sans); font-size: 14.5px; font-weight: 500; padding: 9px 18px; border-radius: 9999px; border: 1px solid var(--hairline); background: #fff; color: var(--charcoal); cursor: pointer; transition: all .15s; }
.lk-tab:hover { border-color: var(--mute-soft); }
.lk-tab.active { background: var(--charcoal); color: var(--canvas); border-color: var(--charcoal); }
.lk-gallery { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 32px; }
.lk-shot { border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--hairline); background: #fff; }
.lk-shot .img { position: relative; aspect-ratio: 1/1; overflow: hidden; background: var(--canvas-soft); }
.lk-shot .img img { width: 100%; height: 100%; object-fit: cover; }
.lk-shot .ba { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; }
.lk-shot .ba span { font-family: var(--font-sans); font-size: 11px; font-weight: 600; letter-spacing: .4px; padding: 4px 9px; border-radius: var(--radius-sm); background: rgba(255,255,255,.92); color: var(--ink); text-transform: uppercase; }
.lk-shot .cap { padding: 16px 18px; display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.lk-shot .cap b { font-family: var(--font-sans); font-size: 15px; color: var(--ink); font-weight: 600; }
.lk-shot .cap .tag { font-family: var(--font-sans); font-size: 12px; font-weight: 600; color: var(--bronze); text-transform: uppercase; letter-spacing: .5px; }
.lk-shot[hidden] { display: none; }
@media (max-width: 920px) { .lk-gallery { grid-template-columns: repeat(2,1fr); } }
@media (max-width: 560px) { .lk-gallery { grid-template-columns: 1fr; } }

/* ── COMPARISON TABLE ────────────────────────────────────────────────────────── */
.lk-compare { margin-top: 48px; border: 1px solid var(--hairline); border-radius: 14px; overflow: hidden; background: #fff; box-shadow: var(--shadow-2); }
.lk-compare table { width: 100%; border-collapse: collapse; }
.lk-compare thead th { text-align: left; padding: 24px 26px; vertical-align: bottom; }
.lk-compare thead th.feat { width: 46%; }
.lk-compare thead th.col { width: 27%; text-align: center; }
.lk-compare thead th.col.us { background: var(--charcoal); }
.lk-compare thead .colhead { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.lk-compare thead .colhead .logo { height: 30px; }
.lk-compare thead .colhead .nm { font-family: var(--font-sans); font-size: 16px; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
.lk-compare thead th.col.us .nm { color: var(--canvas); }
.lk-compare thead .colhead .sub { font-family: var(--font-sans); font-size: 12px; font-weight: 500; text-transform: uppercase; letter-spacing: .8px; color: var(--mute); }
.lk-compare thead th.col.us .sub { color: rgba(246,241,231,.5); }
.lk-compare tbody td { font-family: var(--font-sans); padding: 17px 26px; border-top: 1px solid var(--hairline); font-size: 15.5px; color: var(--body); }
.lk-compare tbody td.feat { font-weight: 500; color: var(--ink); }
.lk-compare tbody td.col { text-align: center; }
.lk-compare tbody td.col.us { background: rgba(156,123,77,.04); }
.lk-cmp-yes, .lk-cmp-no { display: inline-grid; place-items: center; width: 30px; height: 30px; border-radius: 9999px; }
.lk-cmp-yes { background: rgba(126,96,56,.1); }
.lk-cmp-yes svg { width: 17px; height: 17px; stroke: var(--bronze-deep); }
.lk-cmp-no { background: #f2f2f2; }
.lk-cmp-no svg { width: 15px; height: 15px; stroke: var(--mute-soft); }
.lk-cmp-partial { font-family: var(--font-sans); font-size: 13px; color: var(--mute); font-weight: 500; }
.lk-compare tfoot td { font-family: var(--font-sans); padding: 22px 26px; background: var(--canvas-soft); }
.lk-compare-note { font-family: var(--font-sans); margin-top: 16px; font-size: 13px; color: var(--mute); }
@media (max-width: 720px) {
  .lk-compare thead th, .lk-compare tbody td { padding-left: 16px; padding-right: 16px; }
  .lk-compare thead .colhead .logo { display: none; }
  .lk-compare thead th.feat, .lk-compare tbody td.feat { font-size: 14px; }
  .lk-compare tbody td { font-size: 14px; }
}

/* ── DARK CONTACT SECTION ────────────────────────────────────────────────────── */
.lk-contact-sec { background: var(--charcoal); }
.lk-contact-sec .dk-eyebrow { color: var(--bronze); }
.lk-contact-sec .dk-eyebrow::before { background: var(--bronze); }
.lk-contact-sec .lk-h2 { color: var(--canvas); }
.lk-contact-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px,4vw,56px); align-items: stretch; margin-top: 44px; }
.lk-contact-info { display: flex; flex-direction: column; gap: 22px; }
.lk-cinfo-row { display: flex; gap: 16px; padding: 22px 0; border-bottom: 1px solid rgba(246,241,231,.1); }
.lk-cinfo-row:first-child { padding-top: 0; }
.lk-cinfo-row .ic { width: 44px; height: 44px; border-radius: var(--radius-md); background: rgba(246,241,231,.06); display: grid; place-items: center; flex-shrink: 0; }
.lk-cinfo-row .ic svg { width: 21px; height: 21px; stroke: var(--bronze); }
.lk-cinfo-row .ct h4 { font-family: var(--font-sans); color: var(--canvas); font-size: 12.5px; font-weight: 600; text-transform: uppercase; letter-spacing: 1.2px; margin-bottom: 7px; }
.lk-cinfo-row .ct p,
.lk-cinfo-row .ct a { font-family: var(--font-sans); font-size: 16px; color: rgba(246,241,231,.7); line-height: 1.5; text-decoration: none; }
.lk-cinfo-row .ct a:hover { color: var(--canvas); }
.lk-cinfo-row .ct .big { font-family: var(--font-sans); font-size: 22px; font-weight: 600; color: var(--canvas); letter-spacing: -0.01em; }
.lk-hours { width: 100%; border-collapse: collapse; margin-top: 4px; }
.lk-hours td { font-family: var(--font-sans); padding: 5px 0; font-size: 15px; color: rgba(246,241,231,.7); }
.lk-hours td:last-child { text-align: right; color: var(--canvas); font-weight: 500; }
.lk-hours tr.closed td:last-child { color: rgba(246,241,231,.35); font-weight: 400; }
.lk-contact-right { display: flex; flex-direction: column; gap: 20px; }
.lk-office-photo { border-radius: var(--radius-md); overflow: hidden; border: 1px solid rgba(246,241,231,.1); aspect-ratio: 16/10; }
.lk-office-photo img { width: 100%; height: 100%; object-fit: cover; }
.lk-map { border-radius: var(--radius-md); overflow: hidden; border: 1px solid rgba(246,241,231,.1); height: 280px; }
.lk-map iframe { width: 100%; height: 100%; border: 0; }
.lk-contact-cta { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 4px; }
@media (max-width: 880px) { .lk-contact-grid { grid-template-columns: 1fr; } }

/* ── CTA BAND ─────────────────────────────────────────────────────────────────── */
.lk-band { background: var(--canvas); padding: clamp(40px,6vw,72px) 0; }
.lk-band-inner { background: var(--charcoal); border-radius: 14px; padding: clamp(40px,6vw,72px); display: grid; grid-template-columns: 1.2fr .8fr; gap: 40px; align-items: center; overflow: hidden; position: relative; }
.lk-band-inner::after { content: ""; position: absolute; right: -80px; top: -80px; width: 320px; height: 320px; border-radius: 50%; background: radial-gradient(circle, rgba(156,123,77,.3), rgba(156,123,77,0)); pointer-events: none; }
.lk-band-inner h2 { font-family: var(--font-display); color: var(--canvas); font-size: clamp(28px,3.4vw,42px); margin-bottom: 14px; font-weight: 600; }
.lk-band-inner p { font-family: var(--font-sans); color: rgba(246,241,231,.65); font-size: 17px; line-height: 1.55; max-width: 440px; }
.lk-band-actions { display: flex; flex-direction: column; gap: 12px; align-items: flex-start; position: relative; z-index: 1; }
.lk-band-phone { font-family: var(--font-sans); display: inline-flex; align-items: center; gap: 10px; color: var(--canvas); font-size: 20px; font-weight: 600; text-decoration: none; }
.lk-band-phone svg { width: 20px; height: 20px; stroke: var(--bronze); }
@media (max-width: 760px) { .lk-band-inner { grid-template-columns: 1fr; } }

/* ── LIGHTBOX ─────────────────────────────────────────────────────────────────── */
.lk-lightbox { position: fixed; inset: 0; z-index: 100; background: rgba(43,42,47,.88); backdrop-filter: blur(8px); display: none; align-items: center; justify-content: center; padding: 5vw; }
.lk-lightbox.open { display: flex; }
.lk-lightbox .lb-inner { position: relative; max-width: 1000px; width: 100%; }
.lk-lightbox .lb-stage { border-radius: var(--radius-md); overflow: hidden; background: #000; box-shadow: var(--shadow-3); }
.lk-lightbox .lb-stage img, .lk-lightbox .lb-stage video { width: 100%; max-height: 78vh; object-fit: contain; display: block; background: #000; }
.lk-lightbox .lb-cap { color: var(--canvas); margin-top: 16px; display: flex; align-items: baseline; gap: 12px; }
.lk-lightbox .lb-cap b { font-family: var(--font-sans); font-size: 18px; font-weight: 600; }
.lk-lightbox .lb-cap span { font-family: var(--font-sans); font-size: 13.5px; color: rgba(246,241,231,.6); }
.lk-lightbox .lb-close { position: absolute; top: -46px; right: 0; width: 40px; height: 40px; border-radius: 50%; border: 1px solid rgba(246,241,231,.3); background: rgba(246,241,231,.1); display: grid; place-items: center; cursor: pointer; }
.lk-lightbox .lb-close svg { width: 18px; height: 18px; stroke: var(--canvas); }
.lk-lightbox .lb-close:hover { background: rgba(246,241,231,.2); }
