/* ===== MODAL ===== */
.modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9000;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.5rem;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  overscroll-behavior: none;
}
.modal-overlay.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
[data-theme="dark"] .modal-overlay {
  background: rgba(0,0,0,.55);
}
.modal {
  background: var(--card-bg);
  border-radius: 20px;
  max-width: 700px;
  width: 100%;
  max-height: 85vh;
  overflow: hidden;
  position: relative;
  box-shadow: 0 25px 80px rgba(0,0,0,.3), 0 0 0 1px var(--border);
  transform: scale(0.9);
  display: flex;
  flex-direction: column;
  will-change: transform, opacity;
}
.modal__close {
  position: absolute;
  top: .75rem;
  right: .75rem;
  z-index: 10;
  width: 36px;
  height: 36px;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1.5px solid rgba(255, 255, 255, 0.15);
  border-radius: 50%;
  padding: 0;
  font-size: 0;
  color: transparent;
  transition: background .3s, transform .3s, border-color .3s;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.25);
}
.modal__close::before,
.modal__close::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 15px;
  height: 2px;
  background: #ffffff;
  border-radius: 1px;
}
.modal__close::before { transform: translate(-50%, -50%) rotate(45deg); }
.modal__close::after { transform: translate(-50%, -50%) rotate(-45deg); }
.modal__close:hover {
  background: var(--green-600);
  border-color: rgba(255, 255, 255, 0.3);
  transform: rotate(90deg) scale(1.05);
}
.modal__content {
  padding: 0 2rem 2rem;
  overflow-y: auto;
  overflow-x: hidden;
  flex: 1;
  min-height: 0;
  scrollbar-width: none;
  overscroll-behavior: contain;
}
.modal__content::-webkit-scrollbar { display: none; }

/* Body scroll lock */
body.modal-open,
html.modal-open {
  overflow: hidden;
}

/* ===== MODAL V2 ===== */

/* Gallery carousel */
.modal-v2-gallery {
  position: relative;
  height: clamp(220px, 32vh, 340px);
  overflow: hidden;
  width: calc(100% + 4rem);
  margin-left: -2rem;
  border-radius: 20px 20px 0 0;
}
.modal-v2-gallery__track {
  display: flex;
  height: 100%;
  transition: transform .45s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}
.modal-v2-gallery__slide {
  min-width: 100%;
  height: 100%;
  object-fit: cover;
  cursor: pointer;
  user-select: none;
  -webkit-user-drag: none;
}
.modal-v2-gallery__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 5;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.25);
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s, transform .25s, border-color .25s;
  padding: 0;
}
.modal-v2-gallery__arrow:hover {
  background: rgba(0,0,0,.55);
  border-color: rgba(255,255,255,.45);
  transform: translateY(-50%) scale(1.08);
}
.modal-v2-gallery__arrow--left { left: .75rem; }
.modal-v2-gallery__arrow--right { right: .75rem; }

.modal-v2-gallery__dots {
  position: absolute;
  bottom: .75rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: .4rem;
  z-index: 5;
}
.modal-v2-gallery__dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: rgba(255,255,255,.45);
  border: none;
  padding: 0;
  transition: background .25s, transform .25s;
  cursor: pointer;
}
.modal-v2-gallery__dot.active {
  background: #fff;
  transform: scale(1.25);
}

/* Hero overlay on gallery */
.modal-v2-hero {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 2.5rem 2rem 2.25rem;
  background: linear-gradient(to top, rgba(0,0,0,.7) 0%, rgba(0,0,0,.25) 60%, transparent 100%);
  z-index: 4;
  pointer-events: none;
}
.modal-v2-hero__name {
  font-size: 1.6rem;
  font-weight: 800;
  color: #fff;
  margin-bottom: .25rem;
  text-shadow: 0 1px 6px rgba(0,0,0,.3);
}
.modal-v2-hero__row {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-wrap: wrap;
}
.modal-v2-hero__badge {
  display: inline-block;
  background: rgba(255,255,255,.18);
  backdrop-filter: blur(6px);
  color: #fff;
  padding: .2rem .7rem;
  border-radius: 50px;
  font-size: .75rem;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,.2);
}
.modal-v2-hero__mode {
  display: inline-flex; align-items: center; gap: .3rem;
  background: linear-gradient(135deg, rgba(99,102,241,.75), rgba(139,92,246,.75));
  backdrop-filter: blur(6px);
  color: #fff;
  padding: .25rem .7rem;
  border-radius: 50px;
  font-size: .75rem;
  font-weight: 600;
  border: 1px solid rgba(255,255,255,.2);
}
.modal-v2-hero__mode svg { width: 13px; height: 13px; }
.modal-v2-hero__location {
  font-size: .85rem;
  color: rgba(255,255,255,.85);
  display: flex;
  align-items: center;
  gap: .3rem;
}
.modal-v2-hero__location svg { color: rgba(255,255,255,.7); }

/* Stats bar — clean, no card */
.modal-v2-stats {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 0 1rem;
  margin-bottom: .5rem;
  border-bottom: 1px solid var(--border);
}
.modal-v2-stats__item {
  display: flex;
  align-items: center;
  gap: .45rem;
  flex: 1;
  justify-content: center;
}
.modal-v2-stats__icon {
  color: var(--green-600);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.modal-v2-stats__icon svg { width: 18px; height: 18px; }
.modal-v2-stats__label {
  font-size: .62rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: var(--text-muted);
  line-height: 1.2;
}
.modal-v2-stats__value {
  font-size: .85rem;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
}
.modal-v2-stats__divider {
  width: 1px;
  height: 28px;
  background: var(--border);
  flex-shrink: 0;
}
[data-theme="dark"] .modal-v2-stats__icon {
  color: var(--green-400);
}

/* Section pattern — left accent bar */
.modal-v2-section {
  margin-bottom: 1.75rem;
}
.modal-v2-section__header {
  display: flex;
  align-items: center;
  gap: .5rem;
  margin-bottom: .65rem;
}
.modal-v2-section__header-icon {
  display: none;
}
.modal-v2-section__title {
  font-size: .95rem;
  font-weight: 700;
  color: var(--text);
  position: relative;
  padding-left: .75rem;
  margin-bottom: .65rem;
}
.modal-v2-section__title::before {
  content: '';
  position: absolute;
  left: 0;
  top: .1em;
  bottom: .1em;
  width: 3px;
  border-radius: 3px;
  background: linear-gradient(180deg, var(--green-400), var(--green-600));
}
.modal-v2-section__text {
  font-size: .9rem;
  color: var(--text-muted);
  line-height: 1.75;
}

/* Features / certifications — soft chips */
.modal-v2-certs {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}
.modal-v2-cert {
  font-size: .8rem;
  font-weight: 500;
  color: var(--text);
  background: var(--bg-alt);
  padding: .35rem .75rem;
  border-radius: 8px;
}
.modal-v2-cert::before {
  display: none;
}
.modal-v2-cert__check { display: none; }

/* Schedule — rows with alternating tint */
.modal-v2-schedule {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0;
  border-radius: 10px;
  overflow: hidden;
}
.modal-v2-schedule__item {
  display: contents;
}
.modal-v2-schedule__day {
  font-size: .82rem;
  font-weight: 600;
  color: var(--text);
  padding: .5rem .75rem;
  background: transparent;
}
.modal-v2-schedule__time {
  font-size: .82rem;
  font-weight: 400;
  color: var(--text-muted);
  padding: .5rem .75rem;
  text-align: right;
  background: transparent;
}
.modal-v2-schedule__item:nth-child(odd) .modal-v2-schedule__day,
.modal-v2-schedule__item:nth-child(odd) .modal-v2-schedule__time {
  background: var(--bg-alt);
}
/* Closed */
.modal-v2-schedule__item--off .modal-v2-schedule__day,
.modal-v2-schedule__item--off .modal-v2-schedule__time {
  color: var(--text-muted);
  opacity: .4;
}
/* Today */
.modal-v2-schedule__item--today .modal-v2-schedule__day,
.modal-v2-schedule__item--today .modal-v2-schedule__time {
  background: rgba(16,185,129,.08);
}
.modal-v2-schedule__item--today .modal-v2-schedule__day {
  color: var(--green-600);
  font-weight: 700;
}
.modal-v2-schedule__item--today .modal-v2-schedule__time {
  color: var(--green-600);
  font-weight: 600;
}
[data-theme="dark"] .modal-v2-schedule__item--today .modal-v2-schedule__day,
[data-theme="dark"] .modal-v2-schedule__item--today .modal-v2-schedule__time {
  background: rgba(52,211,153,.06);
}
[data-theme="dark"] .modal-v2-schedule__item--today .modal-v2-schedule__day {
  color: var(--green-400);
}
[data-theme="dark"] .modal-v2-schedule__item--today .modal-v2-schedule__time {
  color: var(--green-400);
}

/* Contact — side by side */
.modal-v2-contact {
  display: flex;
  gap: 1rem;
}
.modal-v2-contact__card {
  display: flex;
  align-items: center;
  gap: .5rem;
  text-decoration: none;
  color: var(--text);
  font-size: .85rem;
  transition: color .25s;
}
.modal-v2-contact__card:hover {
  color: var(--green-600);
}
[data-theme="dark"] .modal-v2-contact__card:hover {
  color: var(--green-400);
}
.modal-v2-contact__card-icon {
  color: var(--green-600);
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
[data-theme="dark"] .modal-v2-contact__card-icon {
  color: var(--green-400);
}
.modal-v2-contact__card-icon svg { width: 16px; height: 16px; }
.modal-v2-contact__card-label { display: none; }
.modal-v2-contact__card-value {
  font-size: .85rem;
  font-weight: 500;
  color: inherit;
}

/* Social media — inline with brand hover */
.modal-v2-socials {
  display: flex;
  gap: .85rem;
}
.modal-v2-social-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  text-decoration: none;
  color: var(--text-muted);
  font-size: .8rem;
  font-weight: 500;
  transition: color .25s;
}
.modal-v2-social-link[data-brand="instagram"]:hover { color: #E1306C; }
.modal-v2-social-link[data-brand="facebook"]:hover { color: #1877F2; }
.modal-v2-social-link[data-brand="tiktok"]:hover { color: #69C9D0; }
.modal-v2-social-link[data-brand="website"]:hover { color: var(--green-500); }
.modal-v2-social-link__icon {
  display: flex;
  align-items: center;
  color: inherit;
}
.modal-v2-social-link__icon svg { width: 17px; height: 17px; }
.modal-v2-social-link__label {
  font-size: .8rem;
  line-height: 1;
}

/* Map embed */
.modal-v2-map {
  border-radius: 12px;
  overflow: hidden;
  height: 280px;
}
.modal-v2-map iframe {
  display: block;
  border: 0;
}

/* ===== LIGHTBOX ===== */
.lightbox-overlay {
  position: fixed;
  inset: 0;
  z-index: 9500;
  background: rgba(0,0,0,.88);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity .3s, visibility .3s;
}
.lightbox-overlay.active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.lightbox__img {
  max-width: 90vw;
  max-height: 85vh;
  object-fit: contain;
  border-radius: 8px;
  user-select: none;
  -webkit-user-drag: none;
  transition: opacity .3s;
}
.lightbox__arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 52px;
  height: 52px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s, border-color .25s, transform .25s;
  padding: 0;
}
.lightbox__arrow:hover {
  background: rgba(255,255,255,.2);
  border-color: rgba(255,255,255,.4);
  transform: translateY(-50%) scale(1.06);
}
.lightbox__arrow--left { left: 1.5rem; }
.lightbox__arrow--right { right: 1.5rem; }

.lightbox__close {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,.2);
  background: rgba(255,255,255,.1);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .25s, transform .25s;
  padding: 0;
}
.lightbox__close:hover {
  background: rgba(255,255,255,.25);
  transform: rotate(90deg) scale(1.05);
}

.lightbox__counter {
  position: absolute;
  top: 1.25rem;
  left: 50%;
  transform: translateX(-50%);
  color: rgba(255,255,255,.7);
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: 1px;
  font-family: 'Outfit', sans-serif;
}

/* Dark mode */
[data-theme="dark"] .modal-v2-hero {
  background: linear-gradient(to top, rgba(0,0,0,.85) 0%, rgba(0,0,0,.35) 60%, transparent 100%);
}
[data-theme="dark"] .lightbox-overlay {
  background: rgba(0,0,0,.92);
}

/* Mobile */
@media (max-width: 768px) {
  .modal-v2-gallery {
    height: 260px;
    width: calc(100% + 2.5rem);
    margin-left: -1.25rem;
    border-radius: 0;
  }
  .modal-v2-gallery__arrow {
    width: 34px;
    height: 34px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .modal-v2-gallery__dots { display: none; }
  .modal-v2-hero__name { font-size: 1.3rem; }
  .modal-v2-stats {
    flex-direction: column;
    gap: .5rem;
    align-items: stretch;
    padding: 1rem 0 .75rem;
  }
  .modal-v2-stats__item { justify-content: flex-start; }
  .modal-v2-stats__divider {
    width: 100%;
    height: 1px;
  }
  .modal-v2-certs {
    grid-template-columns: 1fr;
  }
  .modal-v2-contact {
    flex-direction: column;
    gap: .25rem;
  }
  .lightbox__arrow {
    width: 40px;
    height: 40px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
  .lightbox__arrow--left { left: .75rem; }
  .lightbox__arrow--right { right: .75rem; }
  .lightbox__close {
    width: 38px;
    height: 38px;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }
}
