:root {
  --green: #9EB324;
  --black: #111111;
  --gray: #555555;
  --lgray: #999999;
  --border: #E8E8E8;
  --bg: #FFFFFF;
  --bg2: #F7F7F5;
  --font-d: 'DM Serif Display', Georgia, serif;
  --font-b: 'Nunito', system-ui, sans-serif;
  --nav-h: 70px;
  --gap: 8px;
  --cw: 348px;
  --ch: 510px;
}

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

/* El atributo [hidden] debe ocultar siempre, aunque la clase fije display:flex/grid */
[hidden] { display: none !important; }

/* overflow-x: clip (no 'hidden') para no romper position: sticky en los hijos */
html { scroll-behavior: smooth; overflow-x: clip; }

/* Protección básica de imágenes (frena al usuario casual) */
img {
  -webkit-user-drag: none;
  user-select: none;
  -webkit-user-select: none;
}

body {
  font-family: var(--font-b);
  background: var(--bg);
  color: var(--black);
  overflow-x: clip;
}

h2 {
  font-family: var(--font-d);
  font-weight: 400;
  font-size: clamp(2rem, 4vw, 3rem);
  color: var(--black);
  line-height: 1.2;
}

.container {
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 2rem;
}

section { padding: 90px 0; }

.sec-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .35em;
  text-transform: uppercase;
  color: var(--green);
  display: block;
  margin-bottom: .85rem;
}

.sec-bar {
  width: 36px;
  height: 2px;
  background: var(--green);
  margin: 1.25rem 0;
}

.btn-primary {
  display: inline-block;
  padding: 13px 34px;
  background: var(--green);
  color: #fff;
  font-family: var(--font-b);
  font-size: .87rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: background .2s, transform .2s;
}

.btn-primary:hover {
  background: #5aa020;
  transform: translateY(-2px);
}

.btn-outline {
  display: inline-block;
  padding: 13px 34px;
  background: transparent;
  color: var(--black);
  font-family: var(--font-b);
  font-size: .87rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-decoration: none;
  border: 2px solid var(--black);
  cursor: pointer;
  transition: all .2s;
}

.btn-outline:hover {
  background: var(--black);
  color: #fff;
}

/* ── NAV ── */
#nav {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1000;
  height: var(--nav-h);
  display: flex;
  align-items: center;
  transition: background .3s, box-shadow .3s;
}

#nav.sc {
  background: rgba(255,255,255,.97);
  backdrop-filter: blur(12px);
  box-shadow: 0 1px 0 var(--border);
}

.nav-in {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: 1160px;
  margin: 0 auto;
  padding: 0 2rem;
}

.logo {
  display: inline-flex;
  align-items: center;
  gap: 9px;
  text-decoration: none;
}

/* Logo imagen */
.logo-img {
  height: 38px;
  width: auto;
  display: block;
  /* Sombra suave para que el texto gris sea legible sobre el hero oscuro */
  filter: drop-shadow(0 1px 4px rgba(0,0,0,.55));
  transition: filter .3s;
}

/* Sobre fondo blanco no necesita sombra */
#nav.sc .logo-img { filter: none; }

.hero-logo-img {
  width: min(520px, 82vw);
  height: auto;
  display: block;
  margin: 0 auto 1.5rem;
  filter: drop-shadow(0 2px 10px rgba(0,0,0,.65));
}

/* Footer → logo original */
.footer-logo-img {
  height: 50px;
}

.logo-instants {
  font-family: var(--font-d);
  font-size: 1.5rem;
  color: var(--green);
  letter-spacing: .02em;
  line-height: 1;
}

.logo-cam {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
}

.logo-right {
  display: flex;
  flex-direction: column;
  line-height: 1.15;
}

.logo-foto {
  font-family: var(--font-b);
  font-size: .78rem;
  font-weight: 700;
  color: var(--black);
  letter-spacing: .06em;
  text-transform: uppercase;
}

.logo-name {
  font-family: var(--font-b);
  font-size: .6rem;
  font-weight: 500;
  color: var(--gray);
  letter-spacing: .08em;
}

.nav-links {
  display: flex;
  gap: 2.5rem;
  list-style: none;
}

.nav-links a {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.8);
  text-decoration: none;
  transition: color .2s;
}

#nav.sc .nav-links a { color: var(--gray); }
.nav-links a:hover { color: var(--green) !important; }

.nav-cta {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: rgba(255,255,255,.8) !important;
  text-decoration: none;
  transition: color .2s;
  padding-bottom: 2px;
  border-bottom: 1.5px solid rgba(255,255,255,.4);
}

#nav.sc .nav-cta {
  color: var(--black) !important;
  border-bottom-color: var(--black);
}

.nav-cta:hover {
  color: var(--green) !important;
  border-bottom-color: var(--green) !important;
}

/* ── HAMBURGUESA (oculto en escritorio) ── */
.nav-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 38px;
  height: 38px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  z-index: 1002;
}

.nav-burger span {
  display: block;
  width: 24px;
  height: 2px;
  background: rgba(255,255,255,.9);
  transition: transform .3s, opacity .3s, background .3s;
}

#nav.sc .nav-burger span { background: var(--black); }

/* Estado abierto → X (el color lo da #nav.sc al abrir, vía JS) */
.nav-burger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-burger.open span:nth-child(2) { opacity: 0; }
.nav-burger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ── MENÚ MÓVIL (panel desplegable) ── */
.mobile-menu {
  position: fixed;
  top: var(--nav-h);
  left: 0;
  right: 0;
  z-index: 1001;
  background: rgba(255,255,255,.98);
  backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  border-bottom: 1px solid var(--border);
  transform: translateY(-12px);
  opacity: 0;
  pointer-events: none;
  transition: transform .28s ease, opacity .28s ease;
}

.mobile-menu.open {
  transform: translateY(0);
  opacity: 1;
  pointer-events: all;
}

.mobile-menu a {
  padding: 1.05rem 2rem;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--gray);
  text-decoration: none;
  border-bottom: 1px solid var(--border);
  transition: color .2s, background .2s;
}

.mobile-menu a:last-child { border-bottom: none; }
.mobile-menu a:hover { color: var(--green); background: var(--bg2); }

/* ── HERO ── */
#hero {
  position: relative;
  height: 100vh;
  min-height: 640px;
  overflow: hidden;
  padding: 0;
  cursor: grab;
  touch-action: pan-y;
  user-select: none;
}

.slides { position: absolute; inset: 0; }

.slide {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 1.2s ease;
}

.slide.active { opacity: 1; }

/* Deslizamiento lateral (solo cambio manual: dedo, ratón o puntos) */
.slide.manual {
  opacity: 1;
  transition: transform .5s ease;
}

.slide-bg {
  position: absolute;
  inset: 0;
  background-size: cover;
  background-position: center;
}

/* Gradient placeholders — reemplazar por background-image con foto real */
.s1 { background: linear-gradient(145deg,#1a1208 0%,#3a2a10 35%,#6a4a20 65%,#9a7030 100%); }
.s2 { background: linear-gradient(145deg,#080e18 0%,#102035 35%,#1a3a5a 65%,#2a5a80 100%); }
.s3 { background: linear-gradient(145deg,#0e1208 0%,#1a2010 35%,#2a3a18 65%,#3a5a20 100%); }
.s4 { background: linear-gradient(145deg,#180810 0%,#2a1020 35%,#4a2040 65%,#6a3060 100%); }
.s5 { background: linear-gradient(145deg,#121010 0%,#241e18 35%,#3a3028 65%,#5a4840 100%); }

.slide-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.38);
}

.hero-content {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 2rem;
}

.hero-logo-lg {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 1.5rem;
}

.hero-instants {
  font-family: var(--font-d);
  font-size: clamp(3.5rem,9vw,7rem);
  color: var(--green);
  letter-spacing: .04em;
  line-height: 1;
}

.hero-cam-lg {
  width: clamp(50px,8vw,80px);
  height: clamp(50px,8vw,80px);
  flex-shrink: 0;
}

.hero-right-block {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}

.hero-foto-lg {
  font-family: var(--font-b);
  font-size: clamp(.8rem,2vw,1.2rem);
  font-weight: 700;
  color: #fff;
  letter-spacing: .14em;
  text-transform: uppercase;
  line-height: 1;
}

.hero-name-lg {
  font-family: var(--font-b);
  font-size: clamp(.6rem,1.2vw,.85rem);
  font-weight: 400;
  color: rgba(255,255,255,.55);
  letter-spacing: .12em;
  margin-top: 4px;
}

.hero-tagline {
  font-family: var(--font-d);
  font-style: italic;
  font-size: clamp(.95rem,2vw,1.35rem);
  color: rgba(255,255,255,.7);
  max-width: 500px;
  margin-bottom: 2.5rem;
  line-height: 1.6;
}

.hero-btns { display: flex; gap: 1rem; }

.slide-dots {
  position: absolute;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: .55rem;
}

.dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255,255,255,.35);
  border: none;
  cursor: pointer;
  transition: background .3s, transform .3s;
  padding: 0;
}

.dot.active {
  background: var(--green);
  transform: scale(1.3);
}

/* ── SOBRE ── */
#sobre {
  background: var(--bg);
  border-top: 1px solid var(--border);
}

.sobre-text { max-width: 720px; }

.sobre-text p {
  font-size: .97rem;
  color: var(--gray);
  line-height: 1.85;
  margin-bottom: 1.25rem;
  font-weight: 300;
}

.sobre-text p strong {
  color: var(--black);
  font-weight: 600;
}

/* ── SERVICIOS ── */
#servicios {
  background: var(--bg2);
  border-top: 1px solid var(--border);
}

.serv-head { margin-bottom: 3rem; }

.serv-grid {
  display: grid;
  grid-template-columns: repeat(3,1fr);
  gap: var(--gap);
}

.serv-card {
  position: relative;
  overflow: hidden;
  cursor: pointer;
  aspect-ratio: 3/4;
}

.serv-bg {
  position: absolute;
  inset: 0;
  transition: transform .5s ease;
}

.serv-bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.serv-card:hover .serv-bg { transform: scale(1.05); }

.serv-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top,rgba(0,0,0,.75) 0%,rgba(0,0,0,.1) 60%,transparent 100%);
  transition: background .35s;
}

.serv-card:hover .serv-overlay {
  background: linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.3) 70%,rgba(0,0,0,.1) 100%);
}

.serv-name {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 1.5rem 1.75rem;
  font-family: var(--font-d);
  font-size: 1.4rem;
  color: #fff;
  line-height: 1.2;
}

.serv-name span {
  display: block;
  font-family: var(--font-b);
  font-size: .75rem;
  font-weight: 600;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .35rem;
}

/* Service gradient backgrounds */
.sv1 { background: linear-gradient(145deg,#1a1208,#3a2810,#6a4820); }
.sv2 { background: linear-gradient(145deg,#101820,#182a38,#2a4a60); }
.sv3 { background: linear-gradient(145deg,#0e1808,#1a2c10,#2a4820); }
.sv4 { background: linear-gradient(145deg,#181010,#2c1a18,#4a2c28); }
.sv5 { background: linear-gradient(145deg,#101018,#181828,#282840); }
.sv6 { background: linear-gradient(145deg,#181412,#302820,#504038); }

/* ── GALERÍA ── */
#galeria {
  background: var(--bg);
  border-top: 1px solid var(--border);
}

.gal-head { margin-bottom: 2.5rem; }

.gal-tabs {
  display: flex;
  flex-wrap: nowrap;
  gap: 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 2rem;
  overflow-x: auto;
  overflow-y: hidden;
  touch-action: pan-x;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
}

.g-tab {
  padding: 10px 22px;
  border: none;
  background: none;
  font-family: var(--font-b);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: var(--lgray);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}

.g-tab.active {
  color: var(--black);
  border-bottom-color: var(--green);
}

.g-tab:hover { color: var(--black); }

.masonry {
  columns: 4;
  column-gap: var(--gap);
}

.m-photo {
  break-inside: avoid;
  margin-bottom: var(--gap);
  position: relative;
  overflow: hidden;
  cursor: pointer;
}

.m-photo.hidden { display: none; }

.m-photo-bg {
  width: 100%;
  display: block;
  transition: transform .45s ease;
}

.m-photo:hover .m-photo-bg { transform: scale(1.04); }

/* ── LIGHTBOX ── */
.lightbox {
  position: fixed;
  inset: 0;
  z-index: 100000;
  background: rgba(0,0,0,.88);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4vh 4vw;
  opacity: 0;
  pointer-events: none;
  transition: opacity .25s ease;
  touch-action: none;
  overscroll-behavior: contain;
}

.lightbox.open {
  opacity: 1;
  pointer-events: all;
}

.lightbox-img {
  max-width: min(900px, 92vw);
  max-height: 88vh;
  width: auto;
  height: auto;
  object-fit: contain;
  box-shadow: 0 20px 60px rgba(0,0,0,.5);
  transform: scale(.96);
  transition: transform .25s ease;
  touch-action: none;
  cursor: grab;
}

.lightbox.open .lightbox-img { transform: scale(1); }

.lightbox-close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 42px;
  height: 42px;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}

.lightbox-close:hover {
  background: var(--green);
  border-color: var(--green);
}

/* Photo aspect ratio helpers */
.ph { display: block; }
.r32 { aspect-ratio: 3/2; }
.r23 { aspect-ratio: 2/3; }
.r43 { aspect-ratio: 4/3; }
.r34 { aspect-ratio: 3/4; }
.r11 { aspect-ratio: 1/1; }

/* Gallery gradient placeholders */
.pc1  { background: linear-gradient(155deg,#1a1208,#4a3018,#8a5828); }
.pc2  { background: linear-gradient(155deg,#0a1520,#183050,#2858a0); }
.pc3  { background: linear-gradient(155deg,#0a1808,#1a3010,#306030); }
.pc4  { background: linear-gradient(155deg,#180808,#381818,#703030); }
.pc5  { background: linear-gradient(155deg,#101018,#202038,#404880); }
.pc6  { background: linear-gradient(155deg,#1a1008,#3a2818,#685038); }
.pc7  { background: linear-gradient(155deg,#081018,#102040,#1a3870); }
.pc8  { background: linear-gradient(155deg,#0a180a,#183018,#285828); }
.pc9  { background: linear-gradient(155deg,#180a0a,#301818,#602828); }
.pc10 { background: linear-gradient(155deg,#101010,#202020,#383838); }
.pc11 { background: linear-gradient(155deg,#180c08,#382014,#704028); }
.pc12 { background: linear-gradient(155deg,#080c18,#101c38,#183060); }
.pc13 { background: linear-gradient(155deg,#0c180c,#182c18,#285828); }
.pc14 { background: linear-gradient(155deg,#1a0c1a,#301a30,#603060); }
.pc15 { background: linear-gradient(155deg,#181008,#302018,#584030); }

/* ── CONTACTO ── */
#contacto {
  background: var(--bg2);
  border-top: 1px solid var(--border);
}

.ct-inner {
  max-width: 620px;
  margin: 0 auto;
  text-align: center;
}

.ct-inner h2 { margin-bottom: .75rem; }

.ct-inner p {
  font-size: .97rem;
  color: var(--gray);
  line-height: 1.75;
  margin-bottom: 2.5rem;
  font-weight: 300;
}

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  text-align: left;
}

.fg {
  display: flex;
  flex-direction: column;
  gap: .3rem;
  min-width: 0;
}

.fg.full { grid-column: 1/-1; }

label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--lgray);
}

input, select, textarea {
  padding: 13px 15px;
  border: 1.5px solid var(--border);
  font-family: var(--font-b);
  font-size: .9rem;
  color: var(--black);
  background: var(--bg);
  outline: none;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  line-height: 1.4;
  transition: border-color .2s;
}

input[type="date"] {
  -webkit-appearance: none;
  appearance: none;
  min-height: 49px;
}

input:focus, select:focus, textarea:focus { border-color: var(--green); }

textarea {
  resize: vertical;
  min-height: 110px;
}

.form-legal-row {
  display: flex;
  align-items: center;
  gap: 10px;
}

.form-legal-row input[type="checkbox"] {
  width: auto;
  accent-color: var(--green);
  flex-shrink: 0;
}

.form-legal-row a { color: var(--green); }

.form-btn {
  width: 100%;
  padding: 15px;
  background: var(--green);
  color: #fff;
  border: none;
  font-family: var(--font-b);
  font-size: .9rem;
  font-weight: 700;
  letter-spacing: .08em;
  cursor: pointer;
  transition: background .2s;
  margin-top: .25rem;
}

.form-btn:hover { background: #5aa020; }

/* ── FOOTER ── */
footer {
  background: var(--black);
  padding: 56px 0 32px;
}

.footer-in {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 2rem;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.footer-links {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  list-style: none;
}

.footer-links a {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  text-decoration: none;
  transition: color .2s;
}

.footer-links a:hover { color: var(--green); }

.footer-info {
  display: flex;
  flex-wrap: wrap;
  gap: 2.5rem 3rem;
  padding: 2.25rem 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

.footer-info-col {
  flex: 1;
  min-width: 220px;
}

.footer-info-label {
  display: block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .2em;
  text-transform: uppercase;
  color: var(--green);
  margin-bottom: .6rem;
}

.footer-info-col p {
  font-size: .85rem;
  font-weight: 300;
  line-height: 1.7;
  color: rgba(255,255,255,.55);
}

.footer-info-col a {
  display: inline-block;
  margin-top: .6rem;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.4);
  text-decoration: none;
  border-bottom: 1px solid rgba(255,255,255,.2);
  padding-bottom: 2px;
  transition: color .2s, border-color .2s;
}

.footer-info-col a:hover {
  color: var(--green);
  border-bottom-color: var(--green);
}

/* Teléfono / email del footer: texto legible, no botón */
.footer-contact a {
  display: inline;
  margin: 0;
  padding: 0;
  font-size: .85rem;
  font-weight: 300;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(255,255,255,.55);
  border-bottom: none;
  transition: color .2s;
}
.footer-contact a:hover { color: var(--green); border-bottom: none; }

.footer-bottom {
  padding-top: 1.5rem;
  display: flex;
  justify-content: space-between;
  font-size: .75rem;
  color: rgba(255,255,255,.2);
}

/* ── TOAST ── */
.toast {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%) translateY(16px);
  background: var(--black);
  color: #fff;
  padding: 11px 26px;
  font-size: .82rem;
  font-family: var(--font-b);
  opacity: 0;
  pointer-events: none;
  z-index: 9999;
  transition: all .3s;
  white-space: nowrap;
  border-left: 3px solid var(--green);
}

.toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

@keyframes sfl {
  0%, 100% { box-shadow: none }
  40%       { box-shadow: inset 0 0 0 2px rgba(158,179,36,.25) }
}
.sf { animation: sfl 1.4s ease; }

/* ── CHAT WIDGET ── */
#cw-btn {
  position: fixed;
  bottom: 26px;
  right: 26px;
  z-index: 99998;
  width: 54px;
  height: 54px;
  border-radius: 50%;
  background: var(--green);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 4px 18px rgba(158,179,36,.5);
  transition: transform .2s;
}

#cw-btn:hover { transform: scale(1.09); }

#cw-btn svg { width: 22px; height: 22px; fill: #fff; }

#cw-btn .ic-close { display: none; }
#cw-btn.open .ic-chat { display: none; }
#cw-btn.open .ic-close { display: block; }

#cw-badge {
  position: fixed;
  bottom: 90px;
  right: 22px;
  z-index: 99997;
  background: var(--black);
  color: #fff;
  font-family: var(--font-b);
  font-size: 11px;
  font-weight: 600;
  padding: 5px 12px;
  white-space: nowrap;
  border-left: 3px solid var(--green);
  animation: cwb 2.5s ease-in-out infinite;
  pointer-events: none;
  box-shadow: 0 2px 12px rgba(0,0,0,.15);
}

@keyframes cwb {
  0%, 100% { transform: translateY(0) }
  50%       { transform: translateY(-4px) }
}

#cw-win {
  position: fixed;
  bottom: 92px;
  right: 26px;
  z-index: 99997;
  width: var(--cw);
  height: var(--ch);
  background: #fff;
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transform: scale(.93) translateY(18px);
  opacity: 0;
  pointer-events: none;
  transform-origin: bottom right;
  transition: transform .26s cubic-bezier(.34,1.56,.64,1), opacity .2s;
  box-shadow: 0 12px 50px rgba(0,0,0,.14);
}

#cw-win.open {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}

#cw-head {
  background: var(--black);
  padding: 13px 15px;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}

#cw-av {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--green);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

#cw-av svg { width: 18px; height: 18px; fill: #fff; }

#cw-hname {
  font-family: var(--font-b);
  font-weight: 700;
  font-size: 13px;
  color: #fff;
}

#cw-hsub {
  font-family: var(--font-b);
  font-size: 10px;
  color: rgba(255,255,255,.4);
  margin-top: 1px;
}

#cw-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--green);
  margin-left: auto;
  box-shadow: 0 0 6px rgba(158,179,36,.8);
}

#cw-msgs {
  flex: 1;
  overflow-y: auto;
  padding: 13px 12px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  scroll-behavior: smooth;
  background: var(--bg2);
}

#cw-msgs::-webkit-scrollbar { width: 3px; }
#cw-msgs::-webkit-scrollbar-thumb { background: #ddd; }

.cw-m {
  display: flex;
  flex-direction: column;
  max-width: 88%;
  animation: cwf .2s ease;
}

.cw-m.user { align-self: flex-end; align-items: flex-end; }
.cw-m.bot  { align-self: flex-start; align-items: flex-start; }

@keyframes cwf {
  from { opacity: 0; transform: translateY(6px) }
  to   { opacity: 1; transform: none }
}

.cw-bbl {
  padding: 9px 13px;
  font-family: var(--font-b);
  font-size: 13px;
  line-height: 1.55;
  word-break: break-word;
}

.cw-m.user .cw-bbl { background: var(--black); color: #fff; }
.cw-m.bot  .cw-bbl { background: #fff; color: var(--black); border: 1px solid var(--border); }

.cw-time {
  font-size: 9px;
  color: var(--lgray);
  margin-top: 3px;
  padding: 0 2px;
}

.cw-navbtns {
  display: flex;
  flex-direction: column;
  gap: 5px;
  margin-top: 6px;
  width: 100%;
}

.cw-navbtn {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 8px 12px;
  background: #fff;
  border: 1.5px solid var(--border);
  font-family: var(--font-b);
  font-size: 12px;
  font-weight: 600;
  color: var(--black);
  cursor: pointer;
  text-align: left;
  transition: all .15s;
  width: 100%;
}

.cw-navbtn:hover { background: var(--green); color: #fff; border-color: var(--green); }

#cw-chips {
  padding: 6px 11px 3px;
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  background: var(--bg2);
  flex-shrink: 0;
}

.cw-chip {
  background: #fff;
  border: 1.5px solid var(--border);
  color: var(--black);
  font-family: var(--font-b);
  font-size: 11.5px;
  font-weight: 600;
  padding: 5px 11px;
  cursor: pointer;
  transition: all .15s;
  white-space: nowrap;
}

.cw-chip:hover { background: var(--green); color: #fff; border-color: var(--green); }

#cw-typing {
  display: none;
  align-self: flex-start;
  background: #fff;
  border: 1px solid var(--border);
  padding: 11px 15px;
  gap: 5px;
  align-items: center;
}

#cw-typing.on { display: flex; }

#cw-typing span {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  animation: cwt 1.2s infinite;
}

#cw-typing span:nth-child(2) { animation-delay: .2s }
#cw-typing span:nth-child(3) { animation-delay: .4s }

@keyframes cwt {
  0%, 60%, 100% { transform: translateY(0); opacity: .4 }
  30%            { transform: translateY(-5px); opacity: 1 }
}

#cw-ia {
  padding: 10px 11px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 7px;
  align-items: flex-end;
  background: #fff;
  flex-shrink: 0;
}

#cw-inp {
  flex: 1;
  border: 1.5px solid var(--border);
  padding: 9px 13px;
  font-family: var(--font-b);
  font-size: 13px;
  color: var(--black);
  background: var(--bg2);
  resize: none;
  outline: none;
  max-height: 100px;
  line-height: 1.4;
  transition: border-color .15s;
  overflow-y: hidden;
}

#cw-inp:focus { border-color: var(--green); }
#cw-inp::placeholder { color: var(--lgray); }

#cw-send {
  width: 35px;
  height: 35px;
  background: var(--green);
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .15s;
}

#cw-send:hover { background: #5aa020; }

#cw-send svg { width: 14px; height: 14px; fill: #fff; }
#cw-send:disabled { opacity: .4; cursor: default; }

#cw-brand {
  text-align: center;
  font-family: var(--font-b);
  font-size: 9.5px;
  color: var(--lgray);
  padding: 5px 0 7px;
  background: #fff;
}

/* ── RESPONSIVE ── */
@media (max-width: 960px) {
  .serv-grid { grid-template-columns: repeat(2,1fr); }
  .masonry { columns: 3; }
  .nav-links { display: none; }
  .nav-cta { display: none; }
  .nav-burger { display: flex; }

  .footer-in {
    flex-direction: column;
    gap: 1.5rem;
    text-align: center;
  }

  .footer-links {
    justify-content: center;
  }

  .footer-info {
    flex-direction: column;
    gap: 1.75rem;
    text-align: center;
  }
}

@media (max-width: 600px) {
  section { padding: 64px 0; }
  .container { padding: 0 1.25rem; }

  /* Servicios y galería en 2 columnas tipo Pinterest */
  .serv-grid { grid-template-columns: repeat(2,1fr); }
  .masonry { columns: 2; }

  /* Texto de servicios más compacto para tarjetas pequeñas */
  .serv-name { padding: .9rem 1rem; font-size: 1.05rem; }
  .serv-name span { font-size: .58rem; letter-spacing: .14em; margin-bottom: .25rem; }

  /* Hero más compacto en pantalla pequeña */
  #hero { min-height: 0; height: 88vh; }
  .hero-content { padding: 1.5rem; }
  .hero-logo-img { width: min(330px, 78vw); margin-bottom: 1rem; }
  .hero-tagline { font-size: .95rem; margin-bottom: 1.5rem; max-width: 300px; }

  .hero-btns { gap: .6rem; }
  .btn-primary, .btn-outline { padding: 11px 22px; font-size: .78rem; }

  /* Títulos de sección un poco menores */
  h2 { font-size: clamp(1.6rem, 7vw, 2rem); }

  .form-grid { grid-template-columns: 1fr; }

  .footer-bottom {
    flex-direction: column;
    gap: .4rem;
    text-align: center;
  }

  /* Chat a ancho seguro ya en móvil para evitar scroll horizontal */
  :root { --cw: calc(100vw - 18px); }
  #cw-win  { right: 9px; bottom: 84px; }
  #cw-btn  { right: 14px; bottom: 14px; }
  #cw-badge { right: 9px; bottom: 62px; }
}

/* ════════════════════════════════════════════════════════
   SUBPÁGINAS (Tienda · Galería privada)
   ════════════════════════════════════════════════════════ */

/* Cabecera de subpágina (debajo del nav sólido) */
.page-hero {
  padding: calc(var(--nav-h) + 3.5rem) 0 2.75rem;
  text-align: center;
  background: var(--bg2);
  border-bottom: 1px solid var(--border);
}
.page-hero h2 { margin: .3rem 0 .6rem; }
.page-hero p { color: var(--gray); max-width: 560px; margin: 0 auto; font-size: .95rem; }

/* Grupo de acciones a la derecha del nav */
.nav-actions { display: flex; align-items: center; gap: 1.4rem; }

/* Selector de idioma */
.lang-switch { display: flex; align-items: center; gap: 1px; }
.lang-btn {
  background: none;
  border: none;
  cursor: pointer;
  font-family: var(--font-b);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .06em;
  color: rgba(255,255,255,.6);
  padding: 4px 5px;
  transition: color .2s;
}
.lang-btn:hover { color: rgba(255,255,255,.95); }
.lang-btn.active { color: var(--green); }
#nav.sc .lang-btn { color: var(--lgray); }
#nav.sc .lang-btn:hover { color: var(--black); }
#nav.sc .lang-btn.active { color: var(--green); }

/* Enlace de la página actual en el nav */
.nav-links a.active-link { color: var(--green) !important; }
#nav.sc .nav-links a.active-link { color: var(--green); }

/* Botón de carrito en el nav */
.cart-toggle {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  color: rgba(255,255,255,.85);
  transition: color .2s;
}
#nav.sc .cart-toggle { color: var(--black); }
.cart-toggle:hover { color: var(--green); }
.cart-toggle svg { width: 23px; height: 23px; fill: none; stroke: currentColor; stroke-width: 1.7; }
.cart-count {
  position: absolute;
  top: -4px;
  right: -6px;
  min-width: 17px;
  height: 17px;
  padding: 0 4px;
  background: var(--green);
  color: #fff;
  font-family: var(--font-b);
  font-size: 10px;
  font-weight: 700;
  line-height: 17px;
  text-align: center;
  border-radius: 9px;
  transform: scale(0);
  transition: transform .2s ease;
}
.cart-count.show { transform: scale(1); }

/* ── TIENDA: filtros + catálogo ── */
.shop-tabs {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  gap: 0;
  border-bottom: 1px solid var(--border);
  margin: 0 0 2.5rem;
  overflow-x: auto;
  overflow-y: hidden;
  touch-action: pan-x;
  overscroll-behavior: contain;
}
.shop-tab {
  padding: 12px 24px;
  border: none;
  background: none;
  font-family: var(--font-b);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--lgray);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  white-space: nowrap;
  transition: color .2s, border-color .2s;
}
.shop-tab.active { color: var(--black); border-bottom-color: var(--green); }
.shop-tab:hover { color: var(--black); }

.shop-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem 1.75rem;
}
.shop-card {
  display: flex;
  flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--border);
  overflow: hidden;
  transition: box-shadow .25s, transform .25s;
}
.shop-card.hidden { display: none; }
.shop-card:hover { box-shadow: 0 14px 36px rgba(0,0,0,.10); transform: translateY(-3px); }
.shop-thumb-wrap {
  position: relative;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--bg2);
}
.shop-thumb { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s ease; }
.shop-card:hover img.shop-thumb { transform: scale(1.05); }
.shop-thumb.no-img { display: flex; align-items: center; justify-content: center; }
.shop-thumb.no-img span {
  font-size: .72rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--lgray);
}
/* Miniatura sin foto en el carrito: solo el bloque, sin texto */
.ci-thumb.no-img { display: flex; align-items: center; justify-content: center; }
.ci-thumb.no-img span { display: none; }
.shop-cat {
  position: absolute;
  top: 12px;
  left: 12px;
  background: rgba(255,255,255,.92);
  color: var(--gray);
  font-size: 9px;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  padding: 5px 10px;
}
.shop-body { display: flex; flex-direction: column; flex: 1; padding: 1.25rem 1.3rem 1.4rem; }
.shop-name { font-family: var(--font-d); font-size: 1.35rem; color: var(--black); line-height: 1.15; margin-bottom: .4rem; }
.shop-desc { font-size: .85rem; color: var(--gray); line-height: 1.5; flex: 1; }
.shop-foot { display: flex; align-items: center; justify-content: space-between; margin-top: 1.1rem; gap: 1rem; }
.shop-price { font-family: var(--font-b); font-size: 1.25rem; font-weight: 700; color: var(--black); white-space: nowrap; }
.shop-add {
  padding: 10px 20px;
  background: var(--green);
  color: #fff;
  font-family: var(--font-b);
  font-size: .75rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: background .2s, transform .15s;
}
.shop-add:hover { background: #87991c; }
.shop-add:active { transform: scale(.95); }
a.shop-add { text-decoration: none; text-align: center; }

/* Botón secundario (Consultar) */
.shop-add.ghost { background: none; color: var(--green); border: 1.5px solid var(--green); }
.shop-add.ghost:hover { background: var(--green); color: #fff; }

/* Precio "Consultar" */
.shop-price.quote { font-size: .95rem; font-weight: 600; color: var(--gray); }

/* Estado vacío de categoría */
.shop-empty { text-align: center; color: var(--lgray); padding: 3.5rem 1rem; font-size: .95rem; }

/* Pie de tarjeta apilado (vale regalo) */
.shop-foot-col { margin-top: 1.1rem; }
.shop-add.block { display: block; width: 100%; margin-top: 1rem; }

/* Campos del vale regalo */
.voucher-fields label {
  display: block;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gray);
  margin: .9rem 0 .3rem;
}
.voucher-fields label:first-child { margin-top: 0; }
.voucher-fields input { font-size: .9rem; }

/* ── Vista de evento (Fiestas Jávea) ── */
#eventView .event-head { margin: .5rem 0 2rem; }
#eventView .event-head h2 { margin: .3rem 0 .5rem; }
#eventView .event-head p { color: var(--gray); font-size: .95rem; }
.fg-opt { color: var(--lgray); font-weight: 400; text-transform: none; letter-spacing: 0; }
.event-filters {
  display: flex;
  flex: 1;
  gap: 1.25rem;
  margin-bottom: 0;
}
.event-filters .fg { flex: 0 1 240px; }
.event-empty {
  text-align: center;
  color: var(--lgray);
  font-size: .95rem;
  padding: 4rem 1.5rem;
  border: 1px dashed var(--border);
  background: var(--bg2);
}

/* Contenedor ancho (aprovecha más pantalla que .container) */
.container-wide {
  max-width: 1760px;
  margin: 0 auto;
  padding: 0 2.5rem;
}

/* Bloque de controles (filtros + columnas) fijo al hacer scroll */
.event-controls {
  position: sticky;
  top: var(--nav-h);
  z-index: 50;
  display: flex;
  align-items: flex-end;
  gap: 1.25rem;
  background: var(--bg);
  padding: 1.1rem 0;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid var(--border);
}
/* Selector de columnas: pequeño y siempre a la derecha */
.fg-cols { flex: 0 0 auto; width: 92px; }

/* Cuadrícula uniforme de fotos (densa, no tipo Pinterest) */
.event-grid {
  display: grid;
  grid-template-columns: repeat(var(--ev-cols, 6), minmax(0, 1fr));
  gap: 10px;
}
.event-photo {
  aspect-ratio: 1 / 1;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.event-photo:hover {
  transform: scale(1.04);
  box-shadow: 0 4px 14px rgba(0,0,0,.18);
}

/* ── Visor de fotos (ampliada, pequeña, con marca de agua + formulario) ── */
.ev-viewer {
  position: fixed;
  inset: 0;
  z-index: 100050;
  background: rgba(0,0,0,.9);
  display: flex;
  align-items: stretch;
  justify-content: center;
  padding: 0;
  user-select: none;
  -webkit-user-select: none;
}
.ev-content {
  display: flex;
  align-items: stretch;
  gap: 0;
  width: 100%;
  height: 100vh;
}
.ev-stage {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: .8rem;
}
.ev-photo-big {
  position: relative;
  display: inline-block;
  line-height: 0;
  max-width: min(540px, 48vw);
  max-height: 82vh;
  box-shadow: 0 20px 60px rgba(0,0,0,.55);
  overflow: hidden;
}
.ev-photo-img { display: block; width: auto; height: auto; max-width: min(540px, 48vw); max-height: 82vh; }
.ev-photo-color { width: min(540px, 48vw); aspect-ratio: 1 / 1; }
/* Marca de agua con el logo, repetida sobre la foto (disuade descargas/capturas) */
.ev-watermark {
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: url("../assets/images/logo/logo.png");
  background-repeat: repeat;
  background-size: 220px auto;   /* más grande/espaciada → no satura */
  opacity: .12;                  /* más ligera */
  filter: grayscale(1);          /* sin color */
}
.ev-counter {
  color: rgba(255,255,255,.8);
  font-family: var(--font-b);
  font-size: .82rem;
  letter-spacing: .1em;
}

/* Formulario de compra de la foto (35% del ancho, alto completo) */
.ev-form {
  width: 35vw;
  flex-shrink: 0;
  background: var(--bg);
  height: 100vh;
  overflow-y: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
/* Columna interior con ancho acotado: los selectores no se estiran a media pantalla */
.ev-form-inner { width: 100%; max-width: 440px; }
.ev-form-title {
  font-family: var(--font-d);
  font-size: 1.4rem;
  font-weight: 400;
  margin-bottom: 1.2rem;
}
.ev-form .fg { margin-bottom: 1rem; }
.ev-note {
  font-size: .82rem;
  color: var(--gray);
  background: var(--bg2);
  padding: .7rem .8rem;
  margin-bottom: 1rem;
}
.ev-price-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  padding-top: .4rem;
  margin-bottom: 1rem;
  border-top: 1px solid var(--border);
}
.ev-price-row > span:first-child {
  font-size: .75rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--gray);
}
.ev-price { font-family: var(--font-d); font-size: 1.6rem; color: var(--black); }

/* Selector de soportes (miniatura de color + nombre) */
.support-list { display: flex; flex-direction: column; gap: .5rem; }
.support-opt {
  display: flex;
  align-items: center;
  gap: .85rem;
  width: 100%;
  padding: .55rem .65rem;
  border: 1.5px solid var(--border);
  background: var(--bg);
  cursor: pointer;
  text-align: left;
  font-family: var(--font-b);
  font-size: .9rem;
  color: var(--black);
  transition: border-color .2s, background .2s;
}
.support-opt:hover { border-color: var(--green); }
.support-opt.active { border-color: var(--green); background: rgba(158,179,36,.1); }
.support-thumb { width: 56px; height: 56px; flex-shrink: 0; }

.ev-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 48px;
  height: 48px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,.12);
  border: 1px solid rgba(255,255,255,.3);
  border-radius: 50%;
  color: #fff;
  font-size: 28px;
  line-height: 1;
  cursor: pointer;
  transition: background .2s, border-color .2s;
}
.ev-prev { left: 16px; }
.ev-next { right: calc(35vw + 16px); }   /* junto al borde de la foto, no sobre el formulario */
.ev-nav:hover { background: var(--green); border-color: var(--green); }
.ev-close {
  position: absolute;
  top: 18px;
  right: 22px;
  width: 42px;
  height: 42px;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  transition: background .2s, border-color .2s;
  z-index: 2;
}
.ev-close:hover { background: var(--green); border-color: var(--green); }
/* Botón de carrito dentro del visor (la nav queda tapada) */
.ev-cart {
  position: absolute;
  top: 18px;
  right: 74px;
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  cursor: pointer;
  z-index: 2;
  transition: background .2s, border-color .2s;
}
.ev-cart:hover { background: var(--green); border-color: var(--green); }
.ev-cart svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.7; }
@media (max-width: 760px) {
  .ev-viewer { padding: 1rem; align-items: center; }
  .ev-content { flex-direction: column; align-items: center; height: auto; max-height: 92vh; overflow-y: auto; gap: 1rem; }
  .ev-stage { flex: none; }
  .ev-photo-big { max-width: min(340px, 80vw); max-height: 56vh; }
  .ev-photo-img { max-width: min(340px, 80vw); max-height: 56vh; }
  .ev-photo-color { width: min(340px, 80vw); }
  .ev-form { width: 100%; height: auto; padding: 0; }
  .ev-form-inner { max-width: 360px; }
  .ev-nav { width: 38px; height: 38px; font-size: 22px; }
  .ev-prev { left: 6px; }
  .ev-next { right: 6px; }
}

/* ── CARRITO (panel deslizante) ── */
.cart-overlay {
  position: fixed;
  inset: 0;
  z-index: 100060;   /* por encima del visor de foto (100050) */
  background: rgba(0,0,0,.5);
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
}
.cart-overlay.open { opacity: 1; pointer-events: all; }
.cart-panel {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100061;   /* por encima del visor de foto (100050) */
  width: min(420px, 100vw);
  height: 100%;
  background: var(--bg);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform .3s ease;
  box-shadow: -10px 0 40px rgba(0,0,0,.18);
}
.cart-panel.open { transform: translateX(0); }
.cart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 1.4rem 1.5rem;
  border-bottom: 1px solid var(--border);
}
.cart-head h3 { font-family: var(--font-d); font-size: 1.5rem; font-weight: 400; }
.cart-close {
  width: 36px; height: 36px;
  background: none; border: none; cursor: pointer;
  font-size: 20px; line-height: 1; color: var(--gray);
  transition: color .2s;
}
.cart-close:hover { color: var(--black); }

.cart-items { flex: 1; overflow-y: auto; padding: 1rem 1.5rem; }
.cart-empty { text-align: center; color: var(--lgray); padding: 3rem 1rem; font-size: .9rem; }
.cart-item { display: flex; gap: 1rem; padding: 1rem 0; border-bottom: 1px solid var(--border); }
.cart-item .ci-thumb { width: 66px; height: 66px; object-fit: cover; flex-shrink: 0; background: var(--bg2); }
.ci-info { flex: 1; min-width: 0; }
.ci-name { font-size: .9rem; font-weight: 600; color: var(--black); margin-bottom: .15rem; }
.ci-sub { font-size: .78rem; color: var(--lgray); margin-bottom: .2rem; }
.ci-price { font-size: .82rem; color: var(--gray); }
.ci-bottom { display: flex; align-items: center; justify-content: space-between; margin-top: .55rem; }
.qty { display: inline-flex; align-items: center; border: 1px solid var(--border); }
.qty button { width: 26px; height: 26px; background: none; border: none; cursor: pointer; font-size: 15px; color: var(--gray); line-height: 1; }
.qty button:hover { color: var(--green); }
.qty span { min-width: 26px; text-align: center; font-size: .85rem; font-weight: 600; }
.ci-remove { background: none; border: none; cursor: pointer; font-size: .72rem; letter-spacing: .08em; text-transform: uppercase; color: var(--lgray); }
.ci-remove:hover { color: #c0392b; }

.cart-foot { padding: 1.3rem 1.5rem; border-top: 1px solid var(--border); }
.cart-total { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 1rem; }
.cart-total .ct-label { font-size: .8rem; letter-spacing: .14em; text-transform: uppercase; color: var(--gray); }
.cart-total .ct-val { font-family: var(--font-d); font-size: 1.7rem; color: var(--black); }
.cart-btn {
  width: 100%;
  padding: 14px;
  background: var(--green);
  color: #fff;
  font-family: var(--font-b);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: background .2s;
}
.cart-btn:hover { background: #87991c; }
.cart-btn:disabled { background: var(--lgray); cursor: not-allowed; }
.cart-note { text-align: center; font-size: .72rem; color: var(--lgray); margin-top: .7rem; }

/* Vista de checkout (sustituye a la lista dentro del panel) */
.checkout-view { display: none; flex: 1; overflow-y: auto; padding: 1.3rem 1.5rem; }
.cart-panel.checkout .cart-items,
.cart-panel.checkout .cart-foot { display: none; }
.cart-panel.checkout .checkout-view { display: block; }
.checkout-back { background: none; border: none; cursor: pointer; color: var(--gray); font-size: .8rem; letter-spacing: .06em; margin-bottom: 1.1rem; padding: 0; }
.checkout-back:hover { color: var(--black); }
.checkout-view .fg { margin-bottom: 1rem; }
.checkout-summary { background: var(--bg2); padding: 1rem 1.1rem; margin-bottom: 1.3rem; font-size: .85rem; }
.checkout-summary .cs-row { display: flex; justify-content: space-between; padding: .25rem 0; color: var(--gray); }
.checkout-summary .cs-total { font-weight: 700; color: var(--black); border-top: 1px solid var(--border); margin-top: .4rem; padding-top: .5rem; }
.order-done { text-align: center; padding: 2.5rem 1rem; }
.order-done .od-check { width: 64px; height: 64px; margin: 0 auto 1.3rem; border-radius: 50%; background: var(--green); display: flex; align-items: center; justify-content: center; }
.order-done .od-check svg { width: 32px; height: 32px; stroke: #fff; stroke-width: 3; fill: none; }
.order-done h3 { font-family: var(--font-d); font-size: 1.6rem; font-weight: 400; margin-bottom: .6rem; }
.order-done p { color: var(--gray); font-size: .9rem; line-height: 1.55; }

/* ════════════════════════════════════════════════════════
   GALERÍA PRIVADA
   ════════════════════════════════════════════════════════ */

/* Pantalla de acceso (gate) */
.gate {
  position: fixed;
  inset: 0;
  z-index: 99998;
  background: var(--black);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 2rem;
}
.gate.hidden { display: none; }
.gate-card {
  width: 100%;
  max-width: 400px;
  text-align: center;
  background: var(--bg);
  padding: 3rem 2.5rem;
}
.gate-icon { width: 52px; height: 52px; margin: 0 auto 1.5rem; color: var(--green); }
.gate-icon svg { width: 100%; height: 100%; fill: none; stroke: currentColor; stroke-width: 1.6; }
.gate-card h1 { font-family: var(--font-d); font-size: 1.9rem; font-weight: 400; color: var(--black); margin-bottom: .5rem; }
.gate-card p { font-size: .88rem; color: var(--gray); margin-bottom: 1.8rem; line-height: 1.5; }
.gate-form input {
  text-align: center;
  letter-spacing: .12em;
  text-transform: uppercase;
  font-weight: 600;
}
.gate-btn {
  width: 100%;
  margin-top: .9rem;
  padding: 13px;
  background: var(--green);
  color: #fff;
  font-family: var(--font-b);
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  border: none;
  cursor: pointer;
  transition: background .2s;
}
.gate-btn:hover { background: #87991c; }
.gate-error {
  margin-top: 1rem;
  font-size: .82rem;
  color: #c0392b;
  min-height: 1.1rem;
  opacity: 0;
  transition: opacity .2s;
}
.gate-error.show { opacity: 1; }
.gate-help { margin-top: 1.6rem; font-size: .78rem; color: var(--lgray); }
.gate-help a { color: var(--green); text-decoration: none; }

/* ── TIENDA DESHABILITADA temporalmente ──
   Oculta todos los enlaces a la tienda (nav escritorio, menú móvil y footer).
   La página tienda.html se redirige a la home en el sitio desplegado (ver _redirects).
   Para REACTIVAR la tienda: borra esta regla y las líneas de tienda en _redirects. */
a[data-i18n="nav.shop"],
li:has(> a[data-i18n="nav.shop"]) { display: none !important; }

/* Contenedor del álbum (deja sitio al nav fijo) */
.album-wrap { padding: calc(var(--nav-h) + 3rem) 0 90px; }

/* Barra de herramientas del álbum */
.album-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  margin-bottom: 2rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid var(--border);
}
.album-meta .sec-label { margin-bottom: .4rem; }
.album-meta h2 { margin: 0; }
.album-tools { display: flex; align-items: center; gap: .75rem; flex-wrap: wrap; }
.album-chip {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: 9px 16px;
  border: 1px solid var(--border);
  background: var(--bg);
  font-family: var(--font-b);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--gray);
  cursor: pointer;
  transition: all .2s;
}
.album-chip:hover { border-color: var(--green); color: var(--black); }
.album-chip.active { background: var(--green); border-color: var(--green); color: #fff; }
.album-chip svg { width: 15px; height: 15px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.album-chip.active svg { fill: #fff; }
.album-chip.ghost { border: none; color: var(--lgray); }
.album-chip.ghost:hover { color: var(--black); }

/* Botón favorita sobre cada foto */
.fav-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 3;
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,.4);
  border: none;
  border-radius: 50%;
  cursor: pointer;
  opacity: 0;
  transform: scale(.85);
  transition: opacity .2s, transform .2s, background .2s;
}
.m-photo:hover .fav-btn,
.fav-btn.is-fav { opacity: 1; transform: scale(1); }
.fav-btn svg { width: 19px; height: 19px; fill: none; stroke: #fff; stroke-width: 1.8; transition: fill .2s, stroke .2s; }
.fav-btn:hover { background: rgba(0,0,0,.6); }
.fav-btn.is-fav { background: rgba(255,255,255,.92); }
.fav-btn.is-fav svg { fill: var(--green); stroke: var(--green); }

/* ── Valoración por estrellas ── */
/* En la miniatura */
.m-photo .rating {
  position: absolute;
  left: 50%;
  bottom: 8px;
  transform: translateX(-50%);
  z-index: 3;
  display: flex;
  gap: 1px;
  padding: 3px 7px;
  background: rgba(0,0,0,.5);
  border-radius: 14px;
  opacity: 0;
  transition: opacity .2s;
}
.m-photo:hover .rating,
.m-photo .rating.has { opacity: 1; }
.rating .star {
  display: inline-flex;
  background: none;
  border: none;
  padding: 0 1px;
  cursor: pointer;
  line-height: 0;
  color: rgba(255,255,255,.55);
  transition: color .15s;
}
.rating .star svg {
  width: 15px; height: 15px;
  fill: currentColor; stroke: currentColor;
  stroke-width: 1.6; stroke-linejoin: round; stroke-linecap: round;
}
.rating .star.on { color: #f4b400; }
.rating .star.remove { color: #e0584f; }

/* En el visor */
.ev-rating { display: flex; align-items: center; gap: .55rem; margin-bottom: 1.1rem; flex-wrap: wrap; }
.ev-rating-label { font-size: .68rem; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; color: var(--gray); }
.ev-rating .star {
  display: inline-flex; background: none; border: none; padding: 0; cursor: pointer;
  line-height: 0; color: #d8d8d4; transition: color .15s;
}
.ev-rating .star svg {
  width: 24px; height: 24px;
  fill: currentColor; stroke: currentColor;
  stroke-width: 1.5; stroke-linejoin: round; stroke-linecap: round;
}
.ev-rating .star.on { color: #f4b400; }
.ev-rating .star.remove { color: #e0584f; }

/* Botón "Favorita" en el visor */
.ev-fav {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  background: none;
  border: 1.5px solid var(--border);
  padding: 7px 14px;
  margin-bottom: 1.1rem;
  cursor: pointer;
  font-family: var(--font-b);
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--gray);
  transition: border-color .2s, background .2s, color .2s;
}
.ev-fav svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; }
.ev-fav:hover { border-color: var(--green); color: var(--black); }
.ev-fav.is-fav { border-color: var(--green); background: rgba(158,179,36,.1); color: var(--black); }
.ev-fav.is-fav svg { fill: var(--green); stroke: var(--green); }

/* Filtro por estrellas: widget de estrellas + operadores (> = <) */
.star-filter {
  display: flex;
  align-items: center;
  gap: .6rem;
  padding: 5px 12px;
  border: 1px solid var(--border);
  background: var(--bg);
}
.filter-stars { display: flex; gap: 1px; }
.filter-stars .star {
  display: inline-flex;
  background: none;
  border: none;
  padding: 0 1px;
  cursor: pointer;
  line-height: 0;
  color: var(--lgray);
  transition: color .15s;
}
.filter-stars .star svg {
  width: 17px; height: 17px;
  fill: currentColor; stroke: currentColor;
  stroke-width: 1.6; stroke-linejoin: round; stroke-linecap: round;
}
.filter-stars .star.on { color: #f4b400; }
.op-group { display: flex; gap: 2px; }
.op-btn {
  width: 26px; height: 26px;
  background: none;
  border: 1px solid var(--border);
  cursor: pointer;
  font-family: var(--font-b);
  font-size: .9rem;
  font-weight: 700;
  color: var(--gray);
  transition: background .15s, color .15s, border-color .15s;
}
.op-btn:hover { border-color: var(--green); color: var(--black); }
.op-btn.active { background: var(--green); border-color: var(--green); color: #fff; }

/* ── Previsualizador de favoritas (estilo Lightroom) ── */
.fav-survey {
  position: fixed;
  inset: 0;
  z-index: 100040;
  background: rgba(8,8,8,.96);
  display: grid;
  gap: 10px;
  padding: 60px 24px 24px;
}
.fav-survey[hidden] { display: none; }
.fav-survey img {
  width: 100%;
  height: 100%;
  min-width: 0;
  min-height: 0;
  object-fit: contain;
  user-select: none;
  -webkit-user-drag: none;
}
.fav-survey-close {
  position: absolute;
  top: 16px;
  right: 20px;
  width: 42px;
  height: 42px;
  background: rgba(0,0,0,.4);
  border: 1px solid rgba(255,255,255,.3);
  color: #fff;
  font-size: 18px;
  line-height: 1;
  cursor: pointer;
  z-index: 2;
  transition: background .2s, border-color .2s;
}
.fav-survey-close:hover { background: var(--green); border-color: var(--green); }
.fav-survey-title {
  position: absolute;
  top: 22px;
  left: 24px;
  color: rgba(255,255,255,.7);
  font-family: var(--font-b);
  font-size: .8rem;
  letter-spacing: .12em;
  text-transform: uppercase;
}

/* Aviso de modo demo */
.demo-note {
  background: #fff8e1;
  border: 1px solid #f0e0a0;
  color: #7a6010;
  font-size: .8rem;
  text-align: center;
  padding: .7rem 1rem;
  margin-bottom: 1.5rem;
}

/* ── RESPONSIVE subpáginas ── */
@media (max-width: 960px) {
  .shop-grid { grid-template-columns: repeat(2, 1fr); }
  .nav-actions { gap: 1rem; }
  .cart-toggle { display: inline-flex; }   /* el carrito sigue visible en móvil */
}
@media (max-width: 600px) {
  .page-hero { padding-top: calc(var(--nav-h) + 2rem); }
  .shop-grid { grid-template-columns: 1fr; gap: 1.5rem; }
  .cart-panel { width: 100vw; }
  .gate-card { padding: 2.25rem 1.5rem; }
  .album-bar { flex-direction: column; align-items: flex-start; }
  .event-controls { position: static; flex-direction: column; align-items: stretch; }
  .event-filters { flex-direction: column; }
  .event-filters .fg { flex: 1 1 auto; }
  .fg-cols { width: auto; }
}
