/* ============================================================
   MULTISERVICIOS HISPANOS — SITE STYLES
   Every value references a token from tokens.css.
   Mobile-first; breakpoints at 640px and 1024px.
   ============================================================ */

/* ---------- RESET ---------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; }
[hidden] { display: none !important; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
}

body {
  font-family: var(--font-body);
  font-size: var(--fs-body);
  font-weight: var(--fw-reg);
  line-height: var(--lh-body);
  color: var(--text-primary);
  background: var(--bg-page);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

img, svg { display: block; max-width: 100%; }
a { color: inherit; }
button { font: inherit; color: inherit; cursor: pointer; }
ul { list-style: none; padding: 0; }

/* ---------- ACCESSIBILITY HELPERS ---------- */
.sr-only {
  position: absolute; width: 1px; height: 1px;
  padding: 0; margin: -1px; overflow: hidden;
  clip: rect(0 0 0 0); white-space: nowrap; border: 0;
}
.skip-link {
  position: absolute; left: var(--space-3); top: -100px;
  z-index: 200; background: var(--color-ink); color: var(--text-on-dark);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  text-decoration: none; transition: top var(--dur-fast) var(--ease);
}
.skip-link:focus { top: var(--space-3); }

:where(a, button, input, select, textarea, [tabindex]):focus-visible {
  outline: 3px solid var(--color-fuchsia);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}

/* ---------- SHARED ATOMS ---------- */
.eyebrow {
  font-family: var(--font-body);
  font-weight: var(--fw-semi);
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-label);
  text-transform: uppercase;
  color: var(--color-teal-deep);
  margin-bottom: var(--space-3);
}
.eyebrow--on-dark { color: var(--color-marigold); }

.section {
  padding: var(--space-section) var(--space-section-x);
}
.section__head {
  max-width: var(--max-content);
  margin: 0 auto var(--space-6);
  text-align: center;
}
.section__title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  color: var(--text-primary);
}
.section__title--on-dark { color: var(--text-on-dark); }
.section__lead {
  font-size: var(--fs-lead);
  color: var(--text-muted);
  max-width: var(--max-text);
  margin: var(--space-3) auto 0;
}
.subsection-title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: var(--fs-h3);
  text-align: center;
  margin: var(--space-7) 0 var(--space-4);
}

.section--dark {
  background: var(--bg-dark);
  color: var(--text-on-dark);
  position: relative;
  overflow: hidden;
}

/* ---------- BUTTONS ---------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2);
  font-weight: var(--fw-semi);
  font-size: var(--fs-body);
  padding: 0.85em 1.6em;
  border: 2px solid transparent;
  border-radius: var(--radius-pill);
  text-decoration: none;
  transition: transform var(--dur-fast) var(--ease),
              background-color var(--dur-fast) var(--ease),
              color var(--dur-fast) var(--ease),
              box-shadow var(--dur-fast) var(--ease);
  will-change: transform;
}
.btn--primary {
  background: var(--cta-bg); color: var(--cta-text);
  box-shadow: var(--shadow-sm);
}
.btn--primary:hover { background: #c01650; transform: translateY(-2px); box-shadow: var(--shadow-md); }
.btn--primary:active { transform: translateY(0); }
.btn--secondary {
  background: transparent; color: var(--color-teal-deep);
  border-color: var(--color-teal);
}
.btn--secondary:hover { background: var(--color-teal); color: #fff; transform: translateY(-2px); }
.btn--ghost {
  background: rgba(251,244,228,0.08); color: var(--text-on-dark);
  border-color: rgba(251,244,228,0.5);
}
.btn--ghost:hover { background: rgba(251,244,228,0.16); transform: translateY(-2px); }
.btn--block { width: 100%; }
.btn:disabled { opacity: 0.6; cursor: not-allowed; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .btn { transition: background-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease); }
  .btn:hover { transform: none; }
}

/* ============================================================
   LANGUAGE GATE
   ============================================================ */
.gate {
  position: fixed; inset: 0; z-index: 1000;
  background:
    radial-gradient(60% 60% at 20% 20%, rgba(14,139,139,0.55), transparent 70%),
    radial-gradient(55% 55% at 85% 80%, rgba(216,30,91,0.45), transparent 70%),
    var(--color-ink);
  display: flex; flex-direction: column; justify-content: space-between;
  color: var(--text-on-dark);
}
.gate[hidden] { display: none; }
.gate__weave { flex-shrink: 0; }
.gate__inner {
  flex: 1; display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; padding: var(--space-6) var(--space-4);
  gap: var(--space-3);
}
.gate__logo {
  width: clamp(72px, 16vw, 110px); height: auto;
  filter: drop-shadow(0 8px 24px rgba(0,0,0,0.4));
}
.gate__sub {
  font-family: var(--font-body);
  font-weight: var(--fw-semi);
  font-size: var(--fs-label);
  letter-spacing: var(--tracking-sub);
  text-transform: uppercase;
  color: var(--color-marigold);
  margin-top: var(--space-2);
}
.gate__title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: var(--fs-h2);
  line-height: var(--lh-snug);
  margin-top: var(--space-2);
  display: flex; flex-direction: column; align-items: center;
  gap: var(--space-2);
}
.gate__title-sep {
  color: var(--color-marigold);
  font-size: 0.6em; line-height: 1;
}
.gate__buttons {
  display: flex; flex-wrap: wrap; gap: var(--space-3);
  margin-top: var(--space-5); width: 100%;
  max-width: 460px; justify-content: center;
}
.gate__btn {
  flex: 1 1 180px;
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: 1.5rem;
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-lg);
  border: 2px solid rgba(251,244,228,0.25);
  background: rgba(251,244,228,0.06);
  color: var(--text-on-dark);
  transition: transform var(--dur-fast) var(--ease),
              background-color var(--dur-fast) var(--ease),
              border-color var(--dur-fast) var(--ease);
}
.gate__btn:hover {
  background: var(--cta-bg); border-color: var(--cta-bg);
  transform: translateY(-3px) scale(1.02);
}
.gate__btn[data-lang="es"]:hover { background: var(--color-teal); border-color: var(--color-teal); }
@media (prefers-reduced-motion: reduce) {
  .gate__btn:hover { transform: none; }
}
/* Gate entrance */
.gate__inner > * { opacity: 0; transform: translateY(12px); animation: gate-in var(--dur-med) var(--ease) forwards; }
.gate__inner > *:nth-child(1) { animation-delay: 0.05s; }
.gate__inner > *:nth-child(2) { animation-delay: 0.12s; }
.gate__inner > *:nth-child(3) { animation-delay: 0.19s; }
.gate__inner > *:nth-child(4) { animation-delay: 0.26s; }
@keyframes gate-in { to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) {
  .gate__inner > * { opacity: 1; transform: none; animation: none; }
}

/* ============================================================
   HEADER
   ============================================================ */
.header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(251,244,228,0.85);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border-subtle);
}
.header__inner {
  max-width: var(--max-content); margin: 0 auto;
  padding: var(--space-2) var(--space-section-x);
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3);
}
.header__brand {
  display: flex; align-items: center; gap: var(--space-2);
  text-decoration: none; color: var(--text-primary);
}
.header__logo { width: 42px; height: 42px; }
.header__wordmark { display: flex; flex-direction: column; line-height: 1; }
.header__word {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: 1.15rem; color: var(--color-teal-deep);
}
.header__sub {
  font-family: var(--font-body); font-weight: var(--fw-semi);
  font-size: 0.6rem; letter-spacing: var(--tracking-sub);
  text-transform: uppercase; color: var(--text-muted);
  margin-top: 2px;
}

.nav { display: flex; align-items: center; }
.nav__toggle {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; background: none; border: none;
}
.nav__toggle-bars { position: relative; width: 22px; height: 16px; }
.nav__toggle-bars span {
  position: absolute; left: 0; width: 100%; height: 2.4px;
  background: var(--color-ink); border-radius: 2px;
  transition: transform var(--dur-fast) var(--ease), opacity var(--dur-fast) var(--ease);
}
.nav__toggle-bars span:nth-child(1) { top: 0; }
.nav__toggle-bars span:nth-child(2) { top: 7px; }
.nav__toggle-bars span:nth-child(3) { top: 14px; }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars span:nth-child(2) { opacity: 0; }
.nav__toggle[aria-expanded="true"] .nav__toggle-bars span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.nav__list {
  display: flex; align-items: center; gap: var(--space-4);
}
.nav__list a {
  text-decoration: none; font-weight: var(--fw-med);
  color: var(--text-primary); padding: var(--space-1) 0;
  position: relative;
}
.nav__list a::after {
  content: ""; position: absolute; left: 0; bottom: -2px;
  width: 100%; height: 2px; background: var(--color-fuchsia);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--dur-fast) var(--ease);
}
.nav__list a:hover::after, .nav__list a:focus-visible::after { transform: scaleX(1); }

.lang-toggle {
  display: inline-flex; align-items: center; gap: 0.35em;
  background: transparent; border: 2px solid var(--color-teal);
  border-radius: var(--radius-pill);
  padding: 0.3em 0.85em; font-weight: var(--fw-semi);
  font-size: var(--fs-small); color: var(--color-teal-deep);
  transition: background-color var(--dur-fast) var(--ease);
}
.lang-toggle:hover { background: rgba(14,139,139,0.08); }
.lang-toggle__opt { opacity: 0.45; transition: opacity var(--dur-fast) var(--ease); }
.lang-toggle__opt.is-active { opacity: 1; color: var(--color-fuchsia); }
.lang-toggle__sep { opacity: 0.35; }

/* Mobile nav */
@media (max-width: 1023px) {
  .nav__list {
    position: fixed; top: 0; right: 0; z-index: 90;
    height: 100dvh; width: min(80vw, 320px);
    flex-direction: column; align-items: flex-start;
    justify-content: center; gap: var(--space-5);
    padding: var(--space-7) var(--space-6);
    background: var(--bg-surface);
    box-shadow: var(--shadow-lg);
    transform: translateX(100%);
    transition: transform var(--dur-med) var(--ease);
    visibility: hidden;
  }
  .nav__list.is-open { transform: translateX(0); visibility: visible; }
  .nav__list a { font-family: var(--font-display); font-weight: var(--fw-black); font-size: var(--fs-h3); }
  .nav { gap: var(--space-3); }
}
@media (min-width: 1024px) {
  .nav__toggle { display: none; }
}
@media (prefers-reduced-motion: reduce) {
  .nav__list { transition: none; }
  .nav__toggle-bars span { transition: none; }
}

/* Body scroll-lock helper (set by JS) */
body.is-locked { overflow: hidden; }

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative; overflow: hidden;
  background: var(--bg-page); color: var(--text-primary);
  padding: clamp(var(--space-7), 14vh, 9rem) var(--space-section-x);
  text-align: center;
}
.hero__glows { position: absolute; inset: 0; pointer-events: none; }
.glow {
  position: absolute; border-radius: 50%;
  filter: blur(80px); opacity: 0.55;
}
/* Teal leads (brand primary, structure); fuchsia is the single accent. */
.glow--teal { width: 52vw; height: 52vw; background: var(--color-teal); top: 18%; right: -14%; opacity: 0.55; }
.glow--fuchsia { width: 40vw; height: 40vw; background: var(--color-fuchsia); top: -12%; left: -10%; opacity: 0.42; }
.hero__inner {
  position: relative; z-index: 1;
  max-width: var(--max-content); margin: 0 auto;
  display: grid; gap: var(--space-6); align-items: center;
}
.hero__content { display: flex; flex-direction: column; align-items: center; }
.hero__logo { width: clamp(60px, 12vw, 84px); height: auto; margin-bottom: var(--space-4); }
.hero__title {
  font-family: var(--font-display);
  font-weight: var(--fw-black);
  font-size: var(--fs-hero);
  line-height: var(--lh-tight);
  letter-spacing: -0.01em;
  margin-bottom: var(--space-4);
}
.hero__body {
  font-size: var(--fs-lead);
  color: var(--text-muted);
  max-width: 54ch; margin-bottom: var(--space-5);
}
.hero__actions { display: flex; flex-wrap: wrap; gap: var(--space-3); justify-content: center; }

/* Family photo */
.hero__media {
  position: relative; margin: 0;
  width: 100%; max-width: 420px; margin-inline: auto;
  overflow: hidden;
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lg);
}
/* 4-strip frame overlaid on top of the photo — corners stay clean because
   overflow:hidden clips the photo flush to the container's border-radius */
.hero__media::before {
  content: '';
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    repeating-linear-gradient(90deg,
      var(--color-fuchsia) 0 16px, var(--color-marigold) 16px 28px,
      var(--color-teal) 28px 46px, var(--color-terracotta) 46px 58px)
      0 0 / 100% 5px no-repeat,
    repeating-linear-gradient(90deg,
      var(--color-fuchsia) 0 16px, var(--color-marigold) 16px 28px,
      var(--color-teal) 28px 46px, var(--color-terracotta) 46px 58px)
      0 100% / 100% 5px no-repeat,
    repeating-linear-gradient(0deg,
      var(--color-fuchsia) 0 16px, var(--color-marigold) 16px 28px,
      var(--color-teal) 28px 46px, var(--color-terracotta) 46px 58px)
      0 0 / 5px 100% no-repeat,
    repeating-linear-gradient(0deg,
      var(--color-fuchsia) 0 16px, var(--color-marigold) 16px 28px,
      var(--color-teal) 28px 46px, var(--color-terracotta) 46px 58px)
      100% 0 / 5px 100% no-repeat;
}
.hero__media::after { display: none; }
.hero__photo {
  position: relative; z-index: 1;
  width: 100%; height: auto; aspect-ratio: 4 / 5; object-fit: cover;
  object-position: center top;
  display: block;
}

/* Desktop: split layout, text left / photo right */
@media (min-width: 1024px) {
  .hero { text-align: left; }
  .hero__inner {
    grid-template-columns: 1.05fr 0.95fr;
    gap: var(--space-7);
  }
  .hero__content { align-items: flex-start; }
  .hero__actions { justify-content: flex-start; }
  .hero__media { order: 0; max-width: none; }
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
.reveal.is-visible { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) {
  .reveal { opacity: 1; transform: none; transition: none; }
}

/* ============================================================
   SERVICES — TABS
   ============================================================ */
.tabs { max-width: var(--max-content); margin: 0 auto; }
.tabs__list {
  display: flex; flex-wrap: wrap; justify-content: center;
  gap: var(--space-2);
  background: var(--bg-surface);
  padding: var(--space-1);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-sm);
  width: fit-content; max-width: 100%;
  margin: 0 auto var(--space-6);
}
.tab {
  border: none; background: transparent;
  font-weight: var(--fw-semi); font-size: var(--fs-body);
  color: var(--text-muted);
  padding: 0.7em 1.4em; border-radius: var(--radius-pill);
  white-space: nowrap;
  transition: background-color var(--dur-fast) var(--ease), color var(--dur-fast) var(--ease);
}
.tab:hover { color: var(--text-primary); }
.tab[aria-selected="true"] {
  background: var(--color-teal); color: #fff;
  box-shadow: var(--shadow-sm);
}
.tabs__panel { animation: panel-in var(--dur-med) var(--ease); }
.tabs__panel[hidden] { display: none; }
@keyframes panel-in { from { opacity: 0; transform: translateY(8px); } to { opacity: 1; transform: none; } }
@media (prefers-reduced-motion: reduce) { .tabs__panel { animation: none; } }

.panel__intro {
  font-size: var(--fs-lead); color: var(--text-muted);
  text-align: center; max-width: var(--max-text);
  margin: 0 auto var(--space-6);
}
.panel__teaser { text-align: center; margin-top: var(--space-5); }
.panel__teaser a { color: var(--color-teal-deep); font-weight: var(--fw-semi); }

/* Lessons layout */
.lessons__grid {
  display: grid; gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .lessons__grid { grid-template-columns: 1.3fr 1fr; align-items: start; }
}
.lessons__aside { display: grid; gap: var(--space-4); }

/* Price card + table */
.price-card {
  background: var(--bg-surface);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  border: 1px solid var(--border-subtle);
}
.price-card__title {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: var(--fs-h3); margin-bottom: var(--space-3);
}
.price-card__title--sub { margin-top: var(--space-5); }
.price-table { width: 100%; border-collapse: collapse; }
.price-table th {
  text-align: left; font-size: var(--fs-label);
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  color: var(--text-muted); font-weight: var(--fw-semi);
  padding-bottom: var(--space-2); border-bottom: 2px solid var(--border-subtle);
}
.price-table th:last-child, .price-table .price-table__price { text-align: right; }
.price-table td {
  padding: var(--space-3) 0;
  border-bottom: 1px solid var(--border-subtle);
}
.price-table tr:last-child td { border-bottom: none; }
.price-table__price {
  font-family: var(--font-display); font-weight: var(--fw-black);
  color: var(--color-fuchsia); white-space: nowrap;
}
.price-table__unit {
  display: block; font-family: var(--font-body);
  font-weight: var(--fw-reg); font-size: var(--fs-small);
  color: var(--text-muted);
}

/* Info cards (perks / discounts) */
.info-card { border-radius: var(--radius-lg); padding: var(--space-5); color: #fff; }
.info-card--teal { background: var(--color-teal); }
.info-card--marigold { background: var(--color-marigold); color: var(--color-ink); }
.info-card__title {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: var(--fs-h3); margin-bottom: var(--space-3);
}
.check-list { display: grid; gap: var(--space-2); }
.check-list li {
  position: relative; padding-left: 1.8em; line-height: var(--lh-snug);
}
.check-list li::before {
  content: ""; position: absolute; left: 0; top: 0.15em;
  width: 1.1em; height: 1.1em;
  background: currentColor;
  -webkit-mask: var(--check-mask) center / contain no-repeat;
  mask: var(--check-mask) center / contain no-repeat;
  opacity: 0.9;
}
:root { --check-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M20 6 9 17l-5-5'/%3E%3C/svg%3E"); }

/* Service list (lessons classes / icons) */
.service-list {
  display: grid; gap: var(--space-3);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .service-list { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .service-list { grid-template-columns: repeat(4, 1fr); } }
.service-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
  position: relative; overflow: hidden;
}
.service-card::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px;
  background: repeating-linear-gradient(180deg,
    var(--color-fuchsia) 0 12px, var(--color-marigold) 12px 24px,
    var(--color-teal) 24px 36px, var(--color-terracotta) 36px 48px);
  opacity: 0; transition: opacity var(--dur-fast) var(--ease);
}
.service-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.service-card:hover::before { opacity: 1; }
.service-card__icon { width: 44px; height: 44px; margin-bottom: var(--space-3); }
.service-card__name {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: var(--fs-h3); margin-bottom: var(--space-2);
}
.service-card__desc { color: var(--text-muted); font-size: var(--fs-small); }
.service-list--cards { justify-content: center; }
@media (min-width: 640px) { .service-list--cards { grid-template-columns: repeat(2, minmax(0, 320px)); } }
@media (min-width: 1024px) { .service-list--cards { grid-template-columns: repeat(3, minmax(0, 320px)); } }
.service-list--cards .service-card { display: flex; flex-direction: column; }
.service-card__cta { margin-top: var(--space-4); }
@media (prefers-reduced-motion: reduce) {
  .service-card:hover { transform: none; }
}

/* Photography packages */
.photo-grid {
  display: grid; gap: var(--space-4);
  grid-template-columns: 1fr;
}
@media (min-width: 640px) { .photo-grid { grid-template-columns: repeat(2, 1fr); } }
@media (min-width: 1024px) { .photo-grid { grid-template-columns: repeat(4, 1fr); } }
.pkg-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
  display: flex; flex-direction: column;
  transition: transform var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.pkg-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.pkg-card--highlight {
  border: 2px solid var(--color-fuchsia);
  box-shadow: var(--shadow-md);
  position: relative;
}
.pkg-card--highlight::after {
  content: attr(data-badge);
  position: absolute; top: 0; right: var(--space-4);
  transform: translateY(-50%);
  background: var(--color-fuchsia); color: #fff;
  font-size: var(--fs-label); font-weight: var(--fw-semi);
  letter-spacing: var(--tracking-label); text-transform: uppercase;
  padding: 0.4em 0.9em; border-radius: var(--radius-pill);
  white-space: nowrap;
}
.pkg-card__name {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: var(--fs-h3);
}
.pkg-card__price {
  font-family: var(--font-display); font-weight: var(--fw-black);
  font-size: 2rem; color: var(--color-teal-deep);
  margin: var(--space-2) 0 var(--space-4);
}
.pkg-card--highlight .pkg-card__price { color: var(--color-fuchsia); }
.pkg-card__list { display: grid; gap: var(--space-2); margin-bottom: var(--space-4); flex: 1; }
.pkg-card__list li {
  position: relative; padding-left: 1.6em; font-size: var(--fs-small);
  color: var(--text-muted); line-height: var(--lh-snug);
}
.pkg-card__list li::before {
  content: ""; position: absolute; left: 0; top: 0.1em;
  width: 1em; height: 1em; color: var(--color-teal);
  background: currentColor;
  -webkit-mask: var(--check-mask) center / contain no-repeat;
  mask: var(--check-mask) center / contain no-repeat;
}
@media (prefers-reduced-motion: reduce) { .pkg-card:hover { transform: none; } }

/* Event photography */
.event-card {
  margin-top: var(--space-4);
  background: var(--color-indigo); color: var(--text-on-dark);
  border-radius: var(--radius-lg); padding: var(--space-5);
  display: grid; gap: var(--space-3);
}
@media (min-width: 768px) {
  .event-card { grid-template-columns: 1fr 1.4fr; align-items: center; }
}
.event-card__head { display: flex; flex-direction: column; gap: var(--space-1); }
.event-card__name { font-family: var(--font-display); font-weight: var(--fw-black); font-size: var(--fs-h3); }
.event-card__price { font-family: var(--font-display); font-weight: var(--fw-black); font-size: 2rem; color: var(--color-marigold); }
.event-card__price span { font-size: var(--fs-small); font-family: var(--font-body); font-weight: var(--fw-reg); color: rgba(251,244,228,0.8); }
.event-card__list { display: grid; gap: var(--space-2); }
.event-card__list li { position: relative; padding-left: 1.6em; font-size: var(--fs-small); }
.event-card__list li::before {
  content: ""; position: absolute; left: 0; top: 0.1em;
  width: 1em; height: 1em; color: var(--color-marigold);
  background: currentColor;
  -webkit-mask: var(--check-mask) center / contain no-repeat;
  mask: var(--check-mask) center / contain no-repeat;
}

/* ============================================================
   LESSONS GALLERY
   ============================================================ */
.lessons-gallery {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(2, 1fr);
  max-width: var(--max-content);
  margin: 0 auto;
}
@media (min-width: 1024px) {
  .lessons-gallery { grid-template-columns: repeat(4, 1fr); gap: var(--space-4); }
}
.lessons-gallery__item {
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  aspect-ratio: 3 / 4;
  box-shadow: var(--shadow-md);
  background: var(--color-ink);
}
.lessons-gallery__img {
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
  transition: transform 0.4s var(--ease);
}
.lessons-gallery__item:hover .lessons-gallery__img {
  transform: scale(1.04);
}
@media (prefers-reduced-motion: reduce) {
  .lessons-gallery__item:hover .lessons-gallery__img { transform: none; }
}

/* ============================================================
   PORTFOLIO — PHOTOGRAPHY VIDEO REEL
   ============================================================ */
.gallery-video {
  max-width: var(--max-content);
  margin: 0 auto;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-md);
}
.gallery-video__reel {
  display: block;
  width: 100%;
  height: auto;
}

/* ============================================================
   CONTACT
   ============================================================ */
.contact__glows { position: absolute; inset: 0; pointer-events: none; }
.contact__inner {
  position: relative; z-index: 1;
  max-width: var(--max-content); margin: 0 auto;
  display: grid; gap: var(--space-6);
}
@media (min-width: 1024px) {
  .contact__inner { grid-template-columns: 1fr 1.1fr; align-items: start; gap: var(--space-7); }
}
.contact__lead { font-size: var(--fs-lead); color: rgba(251,244,228,0.86); margin: var(--space-3) 0 var(--space-5); max-width: 44ch; }
.contact__details { display: grid; gap: var(--space-4); }
.contact__details li { display: flex; flex-direction: column; gap: 2px; }
.contact__label {
  font-size: var(--fs-label); letter-spacing: var(--tracking-label);
  text-transform: uppercase; color: var(--color-marigold); font-weight: var(--fw-semi);
}
.contact__details a { color: var(--text-on-dark); text-decoration: none; font-size: var(--fs-lead); font-weight: var(--fw-med); }
.contact__details a:hover { text-decoration: underline; }

/* Form */
.contact-form {
  background: var(--bg-surface); color: var(--text-primary);
  border-radius: var(--radius-xl); padding: var(--space-6);
  box-shadow: var(--shadow-lg);
}
.field { margin-bottom: var(--space-4); }
.field label {
  display: block; font-weight: var(--fw-semi);
  font-size: var(--fs-small); margin-bottom: var(--space-2);
}
.field input, .field select, .field textarea {
  width: 100%; font: inherit; color: var(--text-primary);
  padding: 0.75em 0.9em;
  border: 1.5px solid var(--border-subtle);
  border-radius: var(--radius-md);
  background: var(--bg-page);
  transition: border-color var(--dur-fast) var(--ease), box-shadow var(--dur-fast) var(--ease);
}
.field textarea { resize: vertical; min-height: 120px; }
.field input:focus, .field select:focus, .field textarea:focus {
  outline: none; border-color: var(--color-teal);
  box-shadow: 0 0 0 3px rgba(14,139,139,0.18);
}
.field input[aria-invalid="true"], .field select[aria-invalid="true"], .field textarea[aria-invalid="true"] {
  border-color: var(--color-fuchsia);
}
.field__error {
  color: var(--color-fuchsia); font-size: var(--fs-small);
  font-weight: var(--fw-med); margin-top: var(--space-2);
}
.field__error[hidden] { display: none; }
.form-status {
  margin-top: var(--space-4); padding: var(--space-3);
  border-radius: var(--radius-md); font-weight: var(--fw-med);
  text-align: center;
}
.form-status[hidden] { display: none; }
.form-status--success { background: rgba(14,139,139,0.12); color: var(--color-teal-deep); }
.form-status--error { background: rgba(216,30,91,0.1); color: var(--color-fuchsia); }
.form-fallback { margin-top: var(--space-4); font-size: var(--fs-small); color: var(--text-muted); text-align: center; }
.form-fallback a { color: var(--color-teal-deep); font-weight: var(--fw-semi); }

/* ============================================================
   FOOTER
   ============================================================ */
.footer { background: var(--bg-dark); color: var(--text-on-dark); }
.footer__inner {
  max-width: var(--max-content); margin: 0 auto;
  padding: var(--space-7) var(--space-section-x);
  display: flex; flex-direction: column; align-items: center;
  text-align: center; gap: var(--space-3);
}
.footer__logo { width: 56px; height: 56px; }
.footer__tagline {
  font-family: var(--font-display); font-style: italic;
  font-weight: var(--fw-med); font-size: var(--fs-h3);
  color: var(--color-marigold);
}
.footer__contact { display: flex; flex-wrap: wrap; gap: var(--space-2) var(--space-4); justify-content: center; }
.footer__contact a { color: var(--text-on-dark); text-decoration: none; }
.footer__contact a:hover { text-decoration: underline; }
.footer__legal { font-size: var(--fs-small); color: rgba(251,244,228,0.6); margin-top: var(--space-2); }
