/* ============================================
   РАЗДЕВАЛКА — night-beach velvet
   Display: Cormorant Garamond · UI: Golos Text
   ============================================ */

:root{
  --bg:#0a0710;
  --bg-2:#120b1c;
  --card:#181022;
  --line:rgba(255,224,240,.12);
  --txt:#f6eef6;
  --txt-mut:#a493ad;
  --rose:#ff5c8a;
  --rose-2:#ff8fb0;
  --gold:#ffd9a0;
  --ease:cubic-bezier(.22,.9,.28,1);
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:"Golos Text",sans-serif;
  background:var(--bg);
  color:var(--txt);
  overflow:hidden;
  -webkit-font-smoothing:antialiased;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
a{color:inherit;text-decoration:none}

/* ---------- age gate ---------- */
.gate{
  position:fixed;inset:0;z-index:50;
  display:grid;place-items:center;padding:20px;
  background:rgba(8,5,13,.9);backdrop-filter:blur(22px);
  transition:opacity .5s var(--ease),visibility .5s;
}
.gate.off{opacity:0;visibility:hidden}
.gate-card{
  max-width:440px;text-align:center;padding:clamp(28px,5vw,48px);
  background:linear-gradient(165deg,var(--card),var(--bg-2));
  border:1px solid var(--line);border-radius:28px;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8);
}
.gate-badge{
  width:74px;height:74px;margin:0 auto 20px;border-radius:50%;
  display:grid;place-items:center;
  font-weight:800;font-size:1.45rem;color:var(--bg);
  background:linear-gradient(135deg,var(--rose),var(--rose-2));
  box-shadow:0 14px 40px -10px rgba(255,92,138,.6);
}
.gate-card h1{font-family:"Cormorant Garamond",serif;font-weight:600;font-size:2rem;margin-bottom:10px}
.gate-card p{color:var(--txt-mut);font-size:.95rem;line-height:1.6;margin-bottom:26px}
.gate-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:14px 26px;border-radius:999px;font-weight:600;font-size:15px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.btn-primary{background:linear-gradient(115deg,var(--rose),var(--rose-2));color:var(--bg);
  box-shadow:0 14px 38px -12px rgba(255,92,138,.65)}
.btn-primary:hover{transform:translateY(-2px)}
.btn-ghost{border:1px solid var(--line);color:var(--txt-mut)}
.btn-ghost:hover{color:var(--txt);border-color:var(--txt-mut)}

/* ---------- stage ---------- */
.stage{position:relative;height:100svh;display:flex;flex-direction:column}
.bg-glow{
  position:absolute;inset:0;pointer-events:none;z-index:0;
  background:
    radial-gradient(50% 60% at 78% 20%,rgba(255,92,138,.14),transparent 60%),
    radial-gradient(45% 55% at 15% 85%,rgba(120,80,200,.16),transparent 60%);
}

.top{
  position:relative;z-index:3;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px clamp(18px,4vw,44px);
}
.brand{font-family:"Cormorant Garamond",serif;font-style:italic;font-weight:500;font-size:1.7rem;letter-spacing:.02em}
.brand span{color:var(--rose)}
.reset{
  font-size:13.5px;font-weight:600;color:var(--txt-mut);
  padding:10px 18px;border:1px solid var(--line);border-radius:999px;transition:.3s;
}
.reset:hover{color:var(--txt);border-color:var(--rose)}

/* ---------- scene ---------- */
.scene{
  position:relative;z-index:2;flex:1;min-height:0;
  display:flex;align-items:center;justify-content:center;
  gap:clamp(22px,4vw,64px);
  padding:0 clamp(16px,4vw,44px) 24px;
}

.frame{
  position:relative;height:100%;max-height:calc(100svh - 120px);
  aspect-ratio:9/16;border-radius:26px;overflow:hidden;
  background:var(--bg-2);
  box-shadow:
    0 0 0 1px var(--line),
    0 50px 110px -40px rgba(0,0,0,.9),
    0 0 90px -30px rgba(255,92,138,.35);
}
.poster,.vid{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
}
.vid{opacity:0;transition:opacity .35s ease}
.vid.on{opacity:1}
.frame-tint{
  position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,rgba(10,7,16,.18),transparent 18% 82%,rgba(10,7,16,.3));
}
.busy{
  position:absolute;inset:auto 0 18px 0;display:flex;justify-content:center;
}
.busy[hidden]{display:none}
.busy span{
  width:34px;height:34px;border-radius:50%;
  border:3px solid rgba(255,255,255,.25);border-top-color:var(--rose);
  animation:spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ---------- panel ---------- */
.panel{display:flex;flex-direction:column;gap:16px;min-width:230px}
.hint{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  font-size:clamp(1.3rem,2.4vw,1.8rem);color:var(--gold);
  min-height:1.4em;transition:opacity .3s;
}
.items{display:flex;flex-direction:column;gap:12px}
.item{
  position:relative;display:flex;align-items:center;gap:14px;
  padding:16px 20px;border-radius:18px;
  background:linear-gradient(165deg,var(--card),var(--bg-2));
  border:1px solid var(--line);
  font-size:16px;font-weight:600;color:var(--txt);
  transition:transform .3s var(--ease),border-color .3s,opacity .4s,box-shadow .3s;
}
.item:hover:not(:disabled){transform:translateX(6px);border-color:var(--rose);
  box-shadow:0 16px 40px -18px rgba(255,92,138,.5)}
.item:disabled{cursor:default}
.item .ic{font-size:1.5rem;line-height:1}
.item .done{
  margin-left:auto;color:var(--rose);font-weight:800;opacity:0;transform:scale(.4);
  transition:.4s var(--ease);
}
.item.off{opacity:.45;border-color:transparent}
.item.off .lb{text-decoration:line-through;color:var(--txt-mut)}
.item.off .done{opacity:1;transform:scale(1)}
.item.busy{pointer-events:none;opacity:.7}
.fine{font-size:11.5px;color:var(--txt-mut);letter-spacing:.04em}

/* ---------- finale ---------- */
.hint.fin{color:var(--rose-2)}

/* ---------- mobile ---------- */
@media (max-width:760px){
  body{overflow:auto}
  .stage{height:auto;min-height:100svh}
  .scene{flex-direction:column;gap:16px;padding-bottom:30px}
  .frame{width:min(100%,420px);height:auto;max-height:none;aspect-ratio:9/16}
  .panel{width:min(100%,420px);min-width:0}
  .items{flex-direction:row;gap:10px}
  .item{flex-direction:column;gap:8px;flex:1;padding:14px 8px;font-size:13.5px;text-align:center}
  .item .done{position:absolute;top:8px;right:10px;margin:0}
  .item:hover:not(:disabled){transform:none}
  .hint{text-align:center}
  .fine{text-align:center}
}
