/* ===========================================================
   MONITOR / SIGNAGE — Asociación cannábica
   Vídeo del producto a PANTALLA COMPLETA + rótulo mínimo.
   Un producto cada vez, auto-pasa en bucle. Fullscreen 16:9.
   =========================================================== */
:root{
  --bg:#080c08;
  --text:#f3efe3;
  --dim:#a7ad9c;
  --gold:#c9a44c;
  --serif:"Cormorant Garamond", Georgia, serif;
  --sans:"Manrope", system-ui, -apple-system, "Segoe UI", sans-serif;
}
*{ box-sizing:border-box; margin:0; padding:0; }
html,body{ height:100%; }
body{
  background:var(--bg); color:var(--text);
  font-family:var(--sans);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
body.idle{ cursor:none; }

.kiosk{ position:fixed; inset:0; overflow:hidden; background:var(--bg); }

/* ---- vídeo del producto a pantalla completa (dos capas para crossfade) ---- */
.pv{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
  object-fit:cover; object-position:center;
  transform:scale(1.04);            /* recorta cualquier barra negra del vídeo */
  opacity:0; transition:opacity 1.1s ease;
}
.pv.is-active{ opacity:1; }

/* ---- scrim para que el rótulo se lea sobre el vídeo ---- */
.scrim{
  position:absolute; inset:0; z-index:1; pointer-events:none;
  background:linear-gradient(180deg,
    rgba(4,6,4,.22) 0%, transparent 20%,
    transparent 52%, rgba(4,6,4,.72) 100%);
}

/* ---- rótulo mínimo: nombre + donativo ---- */
.caption{
  position:absolute; left:0; right:0; bottom:11vh; z-index:2;
  text-align:center; padding:0 4vw;
  transition:opacity .6s ease, transform .6s ease;
}
.caption.swapping{ opacity:0; transform:translateY(12px); }
.cap-eyebrow{
  font-size:clamp(.7rem,1.4vmin,1rem); font-weight:600;
  letter-spacing:.34em; text-transform:uppercase; color:var(--gold);
  margin-bottom:.7em;
}
.cap-name{
  font-family:var(--serif); font-weight:600;
  font-size:clamp(2.8rem,8vmin,6rem); line-height:1; letter-spacing:.01em;
  text-shadow:0 2px 24px rgba(0,0,0,.6);
}
.cap-price{
  font-family:var(--serif); font-weight:600; color:var(--gold);
  font-size:clamp(1.5rem,3.4vmin,2.6rem); margin-top:.35em;
  text-shadow:0 2px 18px rgba(0,0,0,.6);
}
.cap-price .u{ font-family:var(--sans); font-size:.5em; font-weight:600; color:var(--dim); }

/* ---- progreso ---- */
.progress{
  position:absolute; bottom:5vh; left:50%; transform:translateX(-50%); z-index:2;
  display:flex; gap:.7rem;
}
.dot{
  width:7px; height:7px; border-radius:50%;
  background:rgba(243,239,227,.30); transition:background .4s ease, width .4s ease;
}
.dot.active{ background:var(--gold); width:22px; border-radius:4px; }

/* ---- botón de pantalla completa (se oculta tras el primer toque) ---- */
.enter{
  position:absolute; z-index:5; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--sans); font-size:.8rem; font-weight:600;
  letter-spacing:.14em; text-transform:uppercase; color:var(--text);
  padding:.85em 1.6em; border-radius:100px; cursor:pointer;
  background:rgba(8,12,8,.5); border:1px solid rgba(201,164,76,.35);
  backdrop-filter:blur(6px);
  transition:opacity .4s ease, background .25s ease;
}
.enter:hover{ background:rgba(201,164,76,.16); }
.kiosk.started .enter{ opacity:0; pointer-events:none; }
