/* Site-level additions on top of hero-styles.css */

/* Rolagem suave + offset pra navbar fixa não cobrir a seção alvo */
html { scroll-behavior: smooth; }
[id] { scroll-margin-top: 96px; }

/* Trava qualquer estouro horizontal em telas pequenas.
   'clip' (não 'hidden') não cria contexto de scroll, então não quebra a navbar sticky. */
html, body { overflow-x: clip; max-width: 100%; }

/* Reveal-on-scroll */
.reveal {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.9s cubic-bezier(.16,1,.3,1), transform 0.9s cubic-bezier(.16,1,.3,1);
}
.reveal.in {
  opacity: 1;
  transform: translateY(0);
}
.reveal.delay-1 { transition-delay: 0.08s; }
.reveal.delay-2 { transition-delay: 0.16s; }
.reveal.delay-3 { transition-delay: 0.24s; }
.reveal.delay-4 { transition-delay: 0.32s; }
.reveal.delay-5 { transition-delay: 0.40s; }

/* Pulse dot */
.pulse-dot {
  position: relative;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #2f6bff;
  box-shadow: 0 0 12px #2f6bff;
}
.pulse-dot::after {
  content: "";
  position: absolute;
  inset: -6px;
  border-radius: 50%;
  border: 1.5px solid #2f6bff;
  animation: pulse-ring 1.8s ease-out infinite;
}
@keyframes pulse-ring {
  0% { transform: scale(0.6); opacity: 1; }
  100% { transform: scale(1.8); opacity: 0; }
}

/* Marquee */
.marquee {
  display: flex;
  overflow: hidden;
  mask-image: linear-gradient(to right, transparent, #000 8%, #000 92%, transparent);
}
.marquee-track {
  display: flex;
  gap: 48px;
  animation: marquee 32s linear infinite;
  white-space: nowrap;
  flex-shrink: 0;
}
@keyframes marquee {
  from { transform: translateX(0); }
  to { transform: translateX(-50%); }
}

/* Floating gentle bob */
.bob {
  animation: bob 6s ease-in-out infinite;
}
.bob-slow {
  animation: bob 9s ease-in-out infinite;
}
@keyframes bob {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-10px); }
}

/* Type tickers */
.live-tick {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(34, 197, 94, 0.12);
  border: 1px solid rgba(34, 197, 94, 0.3);
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  color: #4ade80;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}
.live-tick::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #22c55e;
  box-shadow: 0 0 8px #22c55e;
  animation: live-blink 1.6s ease-in-out infinite;
}
@keyframes live-blink {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* Caret typer */
.caret::after {
  content: "▍";
  margin-left: 2px;
  color: #2f6bff;
  animation: blink 0.9s steps(2) infinite;
}
@keyframes blink {
  50% { opacity: 0; }
}

/* Section anchor */
.section {
  position: relative;
  padding: 96px 0;
}

/* sparkline default */
.spark path {
  fill: none;
  stroke: #7aa8ff;
  stroke-width: 1.5;
}

/* Number counter */
.counter {
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum";
}

/* Section kicker (variante p/ headers em grid) — mesmo idioma do .lh-badge */
.divider-label {
  display: inline-flex;
  align-items: center;
  gap: 13px;
  margin-bottom: 22px;
}
.divider-label::before {
  content: "";
  width: 28px;
  height: 2px;
  border-radius: 2px;
  background: linear-gradient(90deg, rgba(47,107,255,0) 0%, #2f6bff 100%);
  flex: none;
}
.divider-label::after { content: none; }
.divider-label span {
  font-size: 11px;
  font-weight: 700;
  color: #8fb4ff;
  letter-spacing: 0.04em;
  text-transform: none;
  white-space: nowrap;
}

/* Tilted card */
.tilt-l { transform: rotate(-3deg); }
.tilt-r { transform: rotate(3deg); }

/* Nav glass */
.nav-glass {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(10, 25, 60, 0.55);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  transition: background 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}
/* Ao rolar: fundo mais sólido + sombra, dando profundidade sobre o conteúdo */
.nav-glass.nav-scrolled {
  background: rgba(6, 16, 40, 0.85);
  border-bottom-color: rgba(255, 255, 255, 0.12);
  box-shadow: 0 12px 34px -14px rgba(0, 0, 0, 0.7);
}

/* Section bg variants */
.bg-deeper {
  background: linear-gradient(180deg, #040f2a 0%, #001529 100%);
}

/* ---- Premium team card (glass + glow, vivo já parado) ---- */
.team-card {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  background: linear-gradient(160deg, rgba(40,68,128,0.45) 0%, rgba(18,34,70,0.40) 48%, rgba(11,23,48,0.50) 100%);
  backdrop-filter: blur(20px) saturate(1.4);
  -webkit-backdrop-filter: blur(20px) saturate(1.4);
  border: 1px solid rgba(122,168,255,0.22);
  box-shadow:
    0 30px 70px -28px rgba(0,0,0,0.85),
    inset 0 1px 0 rgba(255,255,255,0.14),
    0 0 40px -22px rgba(47,107,255,0.55);
  transition: transform 0.55s cubic-bezier(.16,1,.3,1), border-color 0.55s, box-shadow 0.55s;
}
/* Borda gradiente azul brilhante (sempre visível) */
.team-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1.5px;
  background: linear-gradient(150deg, rgba(122,168,255,0.9) 0%, rgba(47,107,255,0.35) 35%, transparent 60%, rgba(47,107,255,0.25) 100%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
  mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  mask-composite: exclude;
  pointer-events: none;
}
/* Glow azul no canto (sempre aceso, intensifica no hover) */
.team-card::after {
  content: "";
  position: absolute;
  top: -45%;
  right: -35%;
  width: 80%;
  height: 80%;
  background: radial-gradient(circle, rgba(47,107,255,0.28), transparent 70%);
  opacity: 0.6;
  transition: opacity 0.55s;
  pointer-events: none;
}
.team-card:hover {
  transform: translateY(-10px);
  border-color: rgba(122,168,255,0.6);
  box-shadow:
    0 45px 95px -28px rgba(0,0,0,0.9),
    inset 0 1px 0 rgba(255,255,255,0.18),
    0 0 80px -18px rgba(47,107,255,0.7);
}
.team-card:hover::after { opacity: 1; }

/* Foto com anel de luz (destaque sempre) */
.team-photo {
  position: relative;
  filter:
    drop-shadow(0 0 18px rgba(47,107,255,0.65))
    drop-shadow(0 14px 26px rgba(0,0,0,0.5));
  transition: transform 0.55s cubic-bezier(.16,1,.3,1), filter 0.55s;
}
.team-card:hover .team-photo {
  transform: scale(1.07);
  filter:
    drop-shadow(0 0 28px rgba(122,168,255,0.9))
    drop-shadow(0 14px 26px rgba(0,0,0,0.5));
}

/* ---- Grade da equipe: grid no desktop, carrossel deslizável no mobile ---- */
.team-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 24px;
}
@media (max-width: 860px) {
  .team-grid {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    gap: 16px;
    /* sangra até as bordas da tela pra dar sensação de carrossel */
    margin: 0 -18px;
    padding: 6px 18px 16px;
    -ms-overflow-style: none;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
  }
  .team-grid::-webkit-scrollbar { display: none; }
  .team-grid > .team-card {
    flex: 0 0 84%;
    scroll-snap-align: center;
  }
}

/* ---- Chips de contato (clicáveis, premium) ---- */
.contact-chip {
  display: inline-flex;
  align-items: center;
  gap: 11px;
  padding: 11px 20px 11px 12px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  border: 1px solid rgba(255,255,255,0.12);
  color: rgba(255,255,255,0.92);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  backdrop-filter: blur(8px);
  transition: transform 0.4s cubic-bezier(.16,1,.3,1), border-color 0.4s, background 0.4s, box-shadow 0.4s;
}
.contact-chip:hover {
  transform: translateY(-3px);
  border-color: rgba(47,107,255,0.6);
  background: rgba(47,107,255,0.12);
  box-shadow: 0 16px 36px -14px rgba(47,107,255,0.6);
}
.contact-chip-ico {
  width: 30px;
  height: 30px;
  border-radius: 9px;
  background: rgba(47,107,255,0.18);
  border: 1px solid rgba(47,107,255,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #7aa8ff;
  font-size: 13px;
  transition: background 0.4s, color 0.4s;
}
.contact-chip:hover .contact-chip-ico {
  background: #2f6bff;
  color: #fff;
}

.btn-arrow-anim {
  display: inline-flex; align-items: center; gap: 10px;
}
.btn-arrow-anim i { transition: transform 0.4s cubic-bezier(.16,1,.3,1); }
.btn-arrow-anim:hover i { transform: translateX(4px); }

/* Glowing key data card */
.kpi-card {
  position: relative;
  overflow: hidden;
}
.kpi-card::after {
  content: "";
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: conic-gradient(from 0deg, transparent 0deg, rgba(47,107,255,0.3) 40deg, transparent 80deg);
  animation: rotate-bg 8s linear infinite;
  opacity: 0;
  transition: opacity 0.5s;
}
.kpi-card:hover::after { opacity: 0.5; }
.kpi-card > * { position: relative; z-index: 1; }
@keyframes rotate-bg {
  to { transform: rotate(360deg); }
}

/* ============ RESPONSIVO (mobile/tablet) ============ */
@media (max-width: 860px) {
  /* Seções: menos respiro vertical e lateral */
  .section { padding-top: 56px !important; padding-bottom: 56px !important; }
  .section > div { padding-left: 18px !important; padding-right: 18px !important; }

  /* Qualquer grid de várias colunas vira 1 coluna */
  section [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }
  footer [style*="grid-template-columns"] { grid-template-columns: 1fr !important; }

  /* Títulos grandes encolhem pra caber na tela */
  section h2 { font-size: 32px !important; line-height: 1.12 !important; }
  section h3 { font-size: 20px !important; }

  /* Botões do hero/CTA: largura total, altura igual e texto que cabe em 1 linha.
     letter-spacing menor pra "Vamos conversar sobre seu hotel" não quebrar em
     telas comuns (>=360px); a seta vai dentro do <span>, então mesmo se quebrar
     ela acompanha a última palavra em vez de boiar na borda direita. */
  .lh-btn-primary, .lh-btn-outline {
    display: flex !important;
    width: 100% !important;
    max-width: 420px !important;
    min-height: 54px !important;
    padding: 14px 20px !important;
    box-sizing: border-box !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    white-space: normal !important;
    letter-spacing: 0.05em !important;
    line-height: 1.25 !important;
  }
  .lh-btn-primary > span, .lh-btn-outline > span { display: inline; }
  .lh-btn-primary .fa-arrow-right { margin-left: 6px; }

  /* Outline não pode parecer "fantasma" ao lado do botão sólido */
  .lh-btn-outline {
    border-color: rgba(255, 255, 255, 0.38) !important;
    background: rgba(255, 255, 255, 0.04) !important;
  }

  /* Rodapé empilhado */
  footer { padding-left: 18px !important; padding-right: 18px !important; }

  /* Só a bio vira alinhada à esquerda no mobile (nome/cargo seguem centralizados) */
  .team-card .team-bio { text-align: left !important; }

  /* FlowDiagram: a linha conectora + pulso são horizontais e ficam tortos
     quando os 4 passos empilham. Some no mobile. */
  .flow-rail { display: none !important; }

  /* ClosingCTA: o card grande tinha padding 72px 56px (estourava a largura).
     Só o card externo (filho direto), não os mini-cards internos. */
  #contato > div > .lh-card { padding: 40px 20px !important; }
}

/* Telas bem pequenas (celular em pé) */
@media (max-width: 600px) {
  /* Cards de estatística do Hero: empilha número e legenda em vez de lado a lado,
     senão o número grande espreme o texto num filete. */
  .lh-stage .kpi-card {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 8px !important;
  }
  .lh-stage .kpi-card .counter { font-size: 34px !important; }
}

@media (max-width: 480px) {
  section h2 { font-size: 27px !important; }
  .lh-stage { padding-bottom: 0 !important; }
  /* Números gigantes (88.5%) não cabem em telas de ~320px */
  section .counter { font-size: 56px !important; }
}

/* ===== Celular DEITADO (paisagem com pouca altura) =====
   Aqui a tela é larga mas baixíssima: o hero empilhado fica alto demais e
   o usuário precisa rolar muito. Compactamos fontes, margens, altura dos
   botões e o respiro da faixa de stats. max-height: 500px exclui tablets. */
@media (orientation: landscape) and (max-height: 500px) {
  #topo h1 {
    font-size: clamp(22px, 4.4vw, 30px) !important;
    margin-top: 8px !important;
    line-height: 1.05 !important;
  }
  /* "VIRA O JOGO" + traço (é o .delay-2 que NÃO é o h2 com brilho) */
  #topo .delay-2:not(.lh-shine) { margin: 10px 0 8px !important; }
  #topo .lh-shine { font-size: clamp(17px, 3vw, 22px) !important; }
  #topo p {
    font-size: 14px !important;
    margin-top: 12px !important;
    line-height: 1.4 !important;
  }
  /* container dos botões */
  #topo .delay-4 { margin-top: 16px !important; gap: 10px !important; }
  #topo .lh-btn-primary, #topo .lh-btn-outline {
    min-height: 42px !important;
    padding: 10px 18px !important;
  }
  /* faixa de stats: menos respiro vertical e cards mais baixos */
  #topo > div:last-child { padding-top: 18px !important; padding-bottom: 24px !important; }
  #topo .kpi-card { padding: 12px 16px !important; }
  #topo .kpi-card .counter { font-size: 30px !important; }
}

/* ===== Planos (cards) ===== */
.hide-scrollbar { -ms-overflow-style: none; scrollbar-width: none; }
.hide-scrollbar::-webkit-scrollbar { display: none; }

/* Dica de swipe (reutilizada por seções com carrossel no mobile) */
.pricing-swipe { display: none; }
@keyframes swipe-hint {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(5px); }
}
.pricing-swipe i { animation: swipe-hint 1.2s ease-in-out infinite; }
@media (max-width: 860px) {
  .pricing-swipe { display: flex; }
}

.plans-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 20px;
  align-items: stretch;
}
@media (max-width: 1080px) { .plans-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px)  { .plans-grid { grid-template-columns: minmax(0, 1fr); } }

.plan-card {
  --plan-accent: #2f6bff;
  position: relative;
  height: 100%;
  display: flex;
  flex-direction: column;
  padding: 30px 24px 26px;
  border-radius: 24px;
  background:
    radial-gradient(120% 80% at 50% 0%,
      color-mix(in srgb, var(--plan-accent) 9%, transparent) 0%, transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,0.045) 0%, rgba(255,255,255,0.015) 100%);
  border: 1px solid rgba(255,255,255,0.1);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.06),
    0 24px 50px -34px rgba(0,0,0,0.8);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transition: transform 0.32s cubic-bezier(0.22,1,0.36,1), border-color 0.32s ease, box-shadow 0.32s ease;
}
.plan-card:hover {
  transform: translateY(-7px);
  border-color: color-mix(in srgb, var(--plan-accent) 45%, rgba(255,255,255,0.1));
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.08),
    0 38px 70px -36px rgba(0,0,0,0.85);
}
.plan-card.is-popular {
  background:
    radial-gradient(120% 75% at 50% 0%,
      color-mix(in srgb, var(--plan-accent) 22%, transparent) 0%, transparent 62%),
    linear-gradient(180deg, rgba(255,255,255,0.06) 0%, rgba(255,255,255,0.02) 100%);
  border-color: color-mix(in srgb, var(--plan-accent) 70%, transparent);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.1),
    0 0 0 1px color-mix(in srgb, var(--plan-accent) 50%, transparent),
    0 0 50px -10px color-mix(in srgb, var(--plan-accent) 35%, transparent),
    0 34px 74px -30px color-mix(in srgb, var(--plan-accent) 45%, rgba(0,0,0,0.85));
}
.plan-card.is-popular:hover {
  transform: translateY(-7px);
  box-shadow:
    inset 0 1px 0 0 rgba(255,255,255,0.12),
    0 0 0 1px color-mix(in srgb, var(--plan-accent) 60%, transparent),
    0 0 60px -8px color-mix(in srgb, var(--plan-accent) 45%, transparent),
    0 42px 84px -32px color-mix(in srgb, var(--plan-accent) 50%, rgba(0,0,0,0.85));
}

.plan-flag {
  position: absolute;
  top: -12px; left: 50%; transform: translateX(-50%);
  padding: 6px 16px; border-radius: 999px;
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--plan-accent) 88%, #fff) 0%, var(--plan-accent) 100%);
  color: #fff;
  font-size: 9px; font-weight: 900; letter-spacing: 0.22em; text-transform: uppercase;
  white-space: nowrap;
  box-shadow: 0 10px 24px -8px color-mix(in srgb, var(--plan-accent) 85%, transparent);
}

.plan-cabin {
  display: inline-flex; align-items: center; gap: 8px;
  align-self: flex-start;
  padding: 6px 13px; border-radius: 10px;
  font-size: 12px; font-weight: 700; letter-spacing: 0.01em;
  color: var(--plan-accent);
  background: color-mix(in srgb, var(--plan-accent) 13%, transparent);
  border: 1px solid color-mix(in srgb, var(--plan-accent) 32%, transparent);
}
.plan-cabin i { font-size: 11px; opacity: 0.9; }

.plan-name {
  margin: 4px 0 10px;
  font-size: 34px; font-weight: 900; letter-spacing: -0.03em; line-height: 1;
  color: #fff;
}
.plan-desc {
  margin: 0;
  font-size: 15px; font-weight: 300; line-height: 1.45;
  color: rgba(255,255,255,0.62);
}

.plan-rule {
  display: block; height: 1px; margin: 22px 0 18px;
  background: linear-gradient(90deg,
    color-mix(in srgb, var(--plan-accent) 35%, transparent),
    rgba(255,255,255,0.06) 70%, transparent);
}

.plan-modules-label {
  font-size: 11px; font-weight: 800; letter-spacing: 0.22em; text-transform: uppercase;
  color: rgba(255,255,255,0.4);
}

.plan-modules {
  list-style: none; margin: 14px 0 0; padding: 0;
  display: flex; flex-direction: column; gap: 12px;
}
.plan-mod {
  display: flex; align-items: flex-start; gap: 11px;
  font-size: 14px; font-weight: 400; line-height: 1.35;
  color: rgba(255,255,255,0.86);
}
.plan-mod.off { color: rgba(255,255,255,0.32); }

.plan-box {
  flex: 0 0 auto;
  width: 19px; height: 19px; margin-top: 1px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 6px;
  border: 1.5px solid color-mix(in srgb, var(--plan-accent) 55%, transparent);
  background: color-mix(in srgb, var(--plan-accent) 14%, transparent);
}
.plan-box i { font-size: 10px; color: var(--plan-accent); }
.plan-mod.off .plan-box {
  border-color: rgba(255,255,255,0.16);
  background: transparent;
}

.plan-ideal {
  box-sizing: border-box;
  /* 'margin-top: auto' empurra a caixa + o botão para a base, deixando os
     cards simétricos mesmo com listas de módulos de tamanhos diferentes. */
  margin: auto 0 18px;
  min-height: 142px;
  padding: 16px;
  border-radius: 14px;
  background: rgba(0,0,0,0.22);
  border: 1px solid rgba(255,255,255,0.05);
  font-size: 13px; font-weight: 300; line-height: 1.5;
  color: rgba(255,255,255,0.6);
}
.plan-ideal strong {
  display: block; margin-bottom: 5px;
  font-size: 13px; font-weight: 700; color: #fff;
}

.plan-cta {
  margin-top: 0;
  display: flex; align-items: center; justify-content: center; gap: 9px;
  padding: 14px; border-radius: 14px;
  font-size: 15px; font-weight: 600; text-decoration: none;
  color: #fff;
  border: 1px solid rgba(255,255,255,0.18);
  background: rgba(255,255,255,0.02);
  transition: background 0.25s ease, border-color 0.25s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.plan-cta i { font-size: 12px; }
.plan-cta:hover {
  background: var(--plan-accent);
  border-color: var(--plan-accent);
  color: #fff;
  box-shadow: 0 14px 30px -12px color-mix(in srgb, var(--plan-accent) 80%, transparent);
}
.plan-card.is-popular .plan-cta {
  background: linear-gradient(180deg,
    color-mix(in srgb, var(--plan-accent) 92%, #fff) 0%, var(--plan-accent) 100%);
  border-color: var(--plan-accent);
  color: #fff;
  box-shadow: 0 16px 34px -14px color-mix(in srgb, var(--plan-accent) 85%, transparent);
}
.plan-card.is-popular .plan-cta:hover { transform: translateY(-2px); }

/* ===== Lightbox / zoom de imagens ===== */
.zoomable { cursor: zoom-in; transition: transform 0.25s ease, box-shadow 0.25s ease; }
.zoomable:hover { transform: scale(1.015); }

.lightbox {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: rgba(2, 8, 23, 0.88);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.28s ease;
  overflow: auto;
  overscroll-behavior: contain;
}
.lightbox.open { opacity: 1; pointer-events: auto; }
.lightbox img {
  max-width: 92vw;
  max-height: 88vh;
  border-radius: 16px;
  object-fit: contain;
  box-shadow: 0 40px 120px -20px rgba(0,0,0,0.85), 0 0 90px -30px rgba(47,107,255,0.6);
  transform: scale(0.92);
  transition: transform 0.3s cubic-bezier(.16,1,.3,1);
  cursor: zoom-in;
}
.lightbox.open img { transform: scale(1); }
.lightbox.zoomed { align-items: flex-start; justify-content: flex-start; }
.lightbox.zoomed img {
  max-width: none;
  max-height: none;
  width: auto;
  transform: scale(1);
  cursor: zoom-out;
}
.lightbox-close {
  position: fixed;
  top: 16px;
  right: 18px;
  z-index: 2001;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.18);
  color: #fff;
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s, transform 0.2s;
}
.lightbox-close:hover { background: rgba(255,255,255,0.16); transform: scale(1.05); }
.lightbox-hint {
  position: fixed;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  pointer-events: none;
}
