/* ============================================================
   PUZZLE GESER — style.css   |   Warm Midnight Luxury
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;1,300&family=Jost:wght@200;300;400;500&display=swap');

:root {
  --bg:         #111009;
  --bg2:        #1a1710;
  --bg3:        #211e14;
  --surface:    #1c1a11;
  --surface2:   #252110;
  --line:       rgba(210,190,140,0.11);
  --line2:      rgba(210,190,140,0.06);
  --gold:       #c8a45c;
  --gold-lt:    #e0c88a;
  --gold-dim:   rgba(200,164,92,0.16);
  --warm:       #ede0c8;
  --muted:      rgba(237,224,200,0.38);
  --faint:      rgba(237,224,200,0.12);
  --empty:      #0d0c08;
  --serif:      'Cormorant Garamond', Georgia, serif;
  --sans:       'Jost', sans-serif;
  --ease:       cubic-bezier(0.22,1,0.36,1);
}

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

html { height:100%; }

body {
  height:100%; min-height:100dvh;
  background:var(--bg);
  color:var(--warm);
  font-family:var(--sans);
  overflow:hidden;
  -webkit-tap-highlight-color:transparent;
  user-select:none;
}

/* ── Ambient orbs ── */
.bg-orbs { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }

.orb {
  position:absolute; border-radius:50%;
  filter:blur(90px);
  animation:orbDrift ease-in-out infinite alternate;
}
.orb-1 {
  width:50vw; height:50vw;
  background:radial-gradient(circle, rgba(160,110,40,0.13) 0%, transparent 70%);
  top:-15%; left:-15%; animation-duration:20s;
}
.orb-2 {
  width:38vw; height:38vw;
  background:radial-gradient(circle, rgba(90,70,30,0.10) 0%, transparent 70%);
  bottom:0; right:-8%; animation-duration:25s; animation-delay:-10s;
}
.orb-3 {
  width:30vw; height:30vw;
  background:radial-gradient(circle, rgba(200,164,92,0.07) 0%, transparent 70%);
  top:50%; left:50%; transform:translate(-50%,-50%);
  animation-duration:30s; animation-delay:-17s;
}
@keyframes orbDrift {
  from { transform:translate(0,0) scale(1); }
  to   { transform:translate(4%,6%) scale(1.08); }
}

/* ── Screens ── */
.screen {
  position:fixed; inset:0; z-index:1;
  display:flex; flex-direction:column;
  align-items:center;
  opacity:0; pointer-events:none;
  transition:opacity 0.38s var(--ease);
  padding:0 16px;
  overflow-y:auto; overflow-x:hidden;
}
.screen.active { opacity:1; pointer-events:all; }


/* ════════════════════════════════════
   MENU
════════════════════════════════════ */
#menu-screen {
  justify-content:flex-start;
  padding-top:52px; padding-bottom:48px;
}

.menu-header { text-align:center; margin-bottom:36px; }

.logo-mark {
  font-size:1.6rem; color:var(--gold); display:block;
  margin-bottom:10px;
  animation:markPulse 4s ease-in-out infinite;
}
@keyframes markPulse {
  0%,100% { opacity:.65; transform:scale(1); }
  50%     { opacity:1;   transform:scale(1.14); }
}

.logo-title {
  font-family:var(--serif);
  font-size:clamp(2rem,7vw,2.8rem);
  font-weight:300; font-style:italic;
  letter-spacing:0.04em; color:var(--warm);
  line-height:1; margin-bottom:8px;
}
.logo-tagline {
  font-size:0.65rem; font-weight:300;
  letter-spacing:0.28em; text-transform:uppercase;
  color:var(--muted);
}

.menu-cards {
  width:min(400px,100%);
  display:flex; flex-direction:column;
  gap:12px; margin-bottom:28px;
}

/* Card base */
.card {
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:18px;
  padding:20px 18px;
  position:relative; overflow:hidden;
}
.card::before {
  content:''; position:absolute;
  top:0; left:20px; right:20px; height:1px;
  background:linear-gradient(90deg,transparent,rgba(200,164,92,.22),transparent);
}

.card-eyebrow {
  display:block; font-size:0.62rem; font-weight:400;
  letter-spacing:0.28em; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px;
}

/* Grid selector */
.grid-selector { display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }

.gs-btn {
  background:var(--bg3); border:1px solid var(--line);
  border-radius:12px; padding:12px 4px 10px;
  cursor:pointer; text-align:center;
  display:flex; flex-direction:column; align-items:center; gap:3px;
  color:var(--warm);
  transition:all 0.22s var(--ease);
}
.gs-btn:active { transform:scale(0.93); }
.gs-btn.active {
  background:var(--gold-dim);
  border-color:rgba(200,164,92,0.45);
  box-shadow:0 0 18px rgba(200,164,92,0.10);
}
.gs-num {
  font-family:var(--serif); font-size:1.1rem;
  font-weight:400; line-height:1; color:var(--warm);
}
.gs-btn.active .gs-num { color:var(--gold-lt); }
.gs-tag {
  font-size:0.58rem; font-weight:300;
  letter-spacing:0.12em; color:var(--muted); text-transform:uppercase;
}

/* Audio card */
.card-audio { padding:0; }

.audio-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:16px 18px; cursor:pointer;
  transition:background 0.18s;
}
.audio-row:active { background:rgba(255,255,255,0.02); }
.audio-label { font-size:0.9rem; font-weight:300; letter-spacing:0.04em; margin-bottom:2px; }
.audio-sub   { font-size:0.65rem; font-weight:300; letter-spacing:0.14em; color:var(--muted); text-transform:uppercase; }

.card-divider { height:1px; background:var(--line2); margin:0 18px; }

.pill-toggle {
  width:44px; height:26px;
  background:var(--bg3); border:1px solid var(--line);
  border-radius:13px; position:relative;
  transition:all 0.3s var(--ease); flex-shrink:0;
}
.pill-toggle.on { background:var(--gold-dim); border-color:rgba(200,164,92,0.4); }
.pill-thumb {
  width:18px; height:18px;
  background:var(--muted); border-radius:50%;
  position:absolute; top:3px; left:3px;
  transition:all 0.3s var(--ease);
}
.pill-toggle.on .pill-thumb {
  background:var(--gold); left:23px;
  box-shadow:0 0 8px rgba(200,164,92,0.5);
}

/* Photo thumbs */
.thumb-row { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:10px; }
.thumb-img {
  width:50px; height:50px; border-radius:10px;
  object-fit:cover; border:1px solid var(--line);
  transition:transform 0.2s var(--ease);
}
.thumb-img:hover { transform:scale(1.06); }
.photo-note { font-size:0.68rem; font-weight:300; letter-spacing:0.1em; color:var(--muted); }

/* Play button */
.play-btn {
  width:min(400px,100%);
  background:linear-gradient(135deg,rgba(200,164,92,.14),rgba(140,100,45,.11));
  border:1px solid rgba(200,164,92,0.32);
  border-radius:16px; color:var(--gold-lt);
  font-family:var(--sans); font-size:0.88rem;
  font-weight:300; letter-spacing:0.25em; text-transform:uppercase;
  padding:18px 24px; cursor:pointer;
  display:flex; align-items:center; justify-content:center; gap:12px;
  transition:all 0.24s var(--ease);
}
.play-btn:hover {
  background:linear-gradient(135deg,rgba(200,164,92,.24),rgba(140,100,45,.18));
  border-color:rgba(200,164,92,0.55);
  box-shadow:0 8px 32px rgba(200,164,92,0.11);
  transform:translateY(-2px);
}
.play-btn:active { transform:translateY(0) scale(0.98); }
.play-icon { font-size:0.7rem; opacity:0.8; }


/* ════════════════════════════════════
   GAME
════════════════════════════════════ */
#game-screen {
  justify-content:flex-start;
  padding-top:14px; padding-bottom:16px;
  gap:10px; overflow:hidden;
}

.game-top {
  width:min(560px,100%);
  display:flex; align-items:center; gap:10px;
}

/* Icon buttons */
.icon-btn {
  width:40px; height:40px;
  background:var(--surface); border:1px solid var(--line);
  border-radius:12px; color:var(--muted);
  cursor:pointer; display:flex; align-items:center; justify-content:center;
  flex-shrink:0; transition:all 0.18s var(--ease);
}
.icon-btn:hover  { color:var(--gold); border-color:rgba(200,164,92,0.3); }
.icon-btn:active { transform:scale(0.91); }
.icon-btn.lit    { color:var(--gold); border-color:rgba(200,164,92,0.4); background:var(--gold-dim); }

/* Stats bar */
.game-stats {
  flex:1; display:flex; align-items:center; justify-content:center;
  background:var(--surface); border:1px solid var(--line);
  border-radius:12px; overflow:hidden;
}
.stat { flex:1; padding:8px 0; text-align:center; display:flex; flex-direction:column; gap:1px; }
.stat-n {
  font-family:var(--serif); font-size:1.1rem; font-weight:400;
  color:var(--gold-lt); line-height:1.1;
}
.stat-n.urgent { color:#d07060; animation:urgentPulse 0.6s ease-in-out infinite alternate; }
@keyframes urgentPulse { from{opacity:1;} to{opacity:0.35;} }
.stat-l { font-size:0.52rem; font-weight:300; letter-spacing:0.18em; text-transform:uppercase; color:var(--muted); }
.stat-sep { width:1px; height:26px; background:var(--line); }

.top-actions { display:flex; gap:6px; }

/* Hint overlay */
.hint-overlay {
  position:fixed; inset:0; z-index:50;
  background:rgba(10,9,6,0.90);
  backdrop-filter:blur(6px);
  display:flex; flex-direction:column;
  align-items:center; justify-content:center; gap:18px;
  opacity:0; pointer-events:none;
  transition:opacity 0.25s var(--ease);
}
.hint-overlay.show { opacity:1; pointer-events:all; }
.hint-overlay img {
  width:min(300px,80vw); height:min(300px,80vw);
  object-fit:cover; border-radius:16px;
  border:1px solid var(--line);
  box-shadow:0 24px 70px rgba(0,0,0,0.65);
}
.hint-label {
  font-size:0.68rem; font-weight:300;
  letter-spacing:0.22em; text-transform:uppercase; color:var(--muted);
}

/* ── PUZZLE BOARD ── */
#puzzle-board {
  display:grid;
  background:var(--empty);
  border-radius:14px;
  overflow:hidden;
  box-shadow:0 20px 60px rgba(0,0,0,0.55), 0 0 0 1px var(--line);
  flex-shrink:0;
  touch-action:none;
}

/* Each piece */
.piece {
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition:transform 0.12s var(--ease);
  touch-action:manipulation;
}
.piece:active { transform:scale(0.96); }

.piece img {
  display:block; width:100%; height:100%;
  pointer-events:none; -webkit-user-drag:none;
  /* smooth slide animation applied via JS inline transition */
}

/* Empty cell */
.piece.empty {
  background:var(--empty);
  cursor:default;
}
.piece.empty:active { transform:none; }

/* Slide animation */
.piece.sliding {
  transition: transform 0.18s var(--ease);
  z-index:5;
}

/* ── GAME BOTTOM ── */
.game-bottom {
  width:min(560px,100%);
  display:flex; flex-direction:column; gap:6px;
}

.progress-wrap {
  height:2px; background:var(--line2);
  border-radius:2px; overflow:hidden;
}
.progress-bar {
  height:100%;
  background:linear-gradient(90deg,rgba(200,164,92,0.3),var(--gold));
  border-radius:2px; width:0%;
  transition:width 0.5s var(--ease);
}

.bottom-row {
  display:flex; align-items:center;
  justify-content:space-between;
}

.progress-label {
  font-size:0.62rem; font-weight:300;
  letter-spacing:0.18em; text-transform:uppercase; color:var(--muted);
}

.target-wrap {
  display:flex; align-items:center; gap:8px;
}
.target-label {
  font-size:0.6rem; font-weight:300;
  letter-spacing:0.2em; text-transform:uppercase; color:var(--muted);
}
.target-img {
  width:48px; height:48px;
  border-radius:8px; object-fit:cover;
  border:1px solid var(--line);
  cursor:pointer;
  transition:transform 0.2s var(--ease), box-shadow 0.2s;
}
.target-img:hover {
  transform:scale(1.08);
  box-shadow:0 4px 16px rgba(0,0,0,0.4);
}


/* ════════════════════════════════════
   WIN
════════════════════════════════════ */
#win-screen {
  justify-content:center;
  padding-top:32px; padding-bottom:48px;
}

.win-inner {
  width:min(360px,100%);
  display:flex; flex-direction:column;
  align-items:center; text-align:center;
}

.win-ornament {
  font-size:2.2rem; color:var(--gold); margin-bottom:16px;
  animation:winOrn 2.2s ease-in-out infinite alternate;
}
@keyframes winOrn {
  from { transform:scale(1) rotate(-6deg); opacity:.65; }
  to   { transform:scale(1.18) rotate(6deg); opacity:1; }
}

.win-title {
  font-family:var(--serif);
  font-size:clamp(2.8rem,9vw,4rem);
  font-weight:300; font-style:italic;
  color:var(--warm); line-height:1; margin-bottom:6px;
}
.win-sub {
  font-size:0.66rem; font-weight:300;
  letter-spacing:0.26em; text-transform:uppercase;
  color:var(--muted); margin-bottom:28px;
}

.win-photo-wrap {
  width:min(190px,55vw); height:min(190px,55vw);
  border-radius:14px; overflow:hidden;
  border:1px solid var(--line);
  box-shadow:0 16px 50px rgba(0,0,0,0.55);
  margin-bottom:26px; flex-shrink:0;
  animation:winReveal 0.8s var(--ease) both;
}
@keyframes winReveal {
  from { transform:scale(0.82); opacity:0; }
  to   { transform:scale(1);    opacity:1; }
}
.win-photo { width:100%; height:100%; object-fit:cover; display:block; }

.win-row { display:flex; gap:12px; margin-bottom:28px; flex-wrap:wrap; justify-content:center; }

.win-stat {
  background:var(--surface); border:1px solid var(--line);
  border-radius:14px; padding:14px 20px;
  display:flex; flex-direction:column; gap:3px; min-width:80px;
}
.ws-n { font-family:var(--serif); font-size:1.5rem; font-weight:400; color:var(--gold-lt); }
.ws-l { font-size:0.56rem; font-weight:300; letter-spacing:0.2em; text-transform:uppercase; color:var(--muted); }

.win-btns { display:flex; gap:10px; width:100%; }

.win-btn {
  flex:1; background:var(--surface); border:1px solid var(--line);
  border-radius:14px; color:var(--muted);
  font-family:var(--sans); font-size:0.76rem; font-weight:300;
  letter-spacing:0.2em; text-transform:uppercase;
  padding:15px 12px; cursor:pointer;
  transition:all 0.22s var(--ease);
}
.win-btn:active { transform:scale(0.96); }
.win-btn:hover  { color:var(--warm); }
.win-btn.primary {
  background:var(--gold-dim);
  border-color:rgba(200,164,92,0.4); color:var(--gold-lt);
}
.win-btn.primary:hover {
  background:rgba(200,164,92,0.22);
  border-color:rgba(200,164,92,0.6);
  box-shadow:0 6px 24px rgba(200,164,92,0.12);
}

/* ── Confetti ── */
.cf {
  position:fixed; pointer-events:none; z-index:999;
  animation:cfFall linear forwards;
}
@keyframes cfFall {
  0%   { opacity:1;  transform:translateY(-10px) rotate(0deg); }
  100% { opacity:0;  transform:translateY(105vh) rotate(540deg); }
}

/* ── Scrollbar ── */
::-webkit-scrollbar { width:3px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--line); border-radius:2px; }
