/* ═══════════════════════════════════════════════════════════
   Los Polos — Virtuális Üzlet PUBLIKUS FX-réteg (additív UI).
   Társfájl: js/iroda_public_fx.js. A motort (js/iroda.js) NEM érinti.
   ═══════════════════════════════════════════════════════════ */
:root{
  --fx-lp:#D89D4C; --fx-lp-d:#B87D2E; --fx-bg:#0F0F14; --fx-bg2:#1A1A24;
  --fx-br:#2A2A38; --fx-tx:#F0DCC0; --fx-t2:#C8B89C;
}

/* ── Lebegő eszköztár (jobb-fent, a fejléc alatt) ── */
.fx-toolbar{
  position:fixed; top:64px; right:12px; z-index:540;
  display:flex; flex-direction:column; gap:8px; align-items:flex-end;
}
.fx-btn{
  background:var(--fx-bg2); color:var(--fx-lp); border:1px solid var(--fx-br);
  width:42px; height:42px; border-radius:50%; cursor:pointer; font-size:18px;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 10px rgba(0,0,0,.5); transition:transform .15s, background .15s, color .15s;
  font-family:inherit; line-height:1; padding:0;
}
.fx-btn:hover{ background:var(--fx-lp); color:var(--fx-bg); transform:scale(1.08); }
.fx-btn:active{ transform:scale(.94); }
.fx-btn.fx-on{ background:var(--fx-lp); color:var(--fx-bg); border-color:var(--fx-lp-d); }

/* ── Nézőszám + élő stat badge (bal-fent) ── */
.fx-live{
  position:fixed; top:64px; left:12px; z-index:540;
  display:flex; flex-direction:column; gap:6px; align-items:flex-start;
  pointer-events:none;
}
.fx-chip{
  background:rgba(15,15,20,.85); color:var(--fx-tx); border:1px solid var(--fx-br);
  border-radius:20px; padding:5px 12px; font-size:12px; font-weight:600;
  box-shadow:0 2px 10px rgba(0,0,0,.45); display:flex; align-items:center; gap:6px;
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
  font-family:'Segoe UI',system-ui,sans-serif;
}
.fx-chip .fx-dot{ width:8px; height:8px; border-radius:50%; background:#4ade80; box-shadow:0 0 8px #4ade80; animation:fxBlink 1.6s infinite; }
@keyframes fxBlink{ 0%,100%{opacity:1} 50%{opacity:.45} }
.fx-chip b{ color:var(--fx-lp); }

/* ── Apokalipszis-intenzitás csúszka (alul-közép) ── */
.fx-apo-slider{
  position:fixed; left:50%; bottom:96px; transform:translateX(-50%);
  z-index:545; background:rgba(15,15,20,.9); border:1px solid var(--fx-br);
  border-radius:24px; padding:8px 16px; display:flex; align-items:center; gap:10px;
  box-shadow:0 4px 16px rgba(0,0,0,.5); font-size:12px; color:var(--fx-t2);
  font-family:'Segoe UI',system-ui,sans-serif; max-width:92vw;
}
.fx-apo-slider input[type=range]{ width:170px; accent-color:#dc2626; }
.fx-apo-slider .fx-apo-val{ min-width:38px; text-align:right; color:#ff7a3a; font-weight:800; }

/* ── Modál (kerék, üdvözlés, gyűjtemény, tutorial) ── */
.fx-modal{
  position:fixed; inset:0; z-index:9998; display:none;
  align-items:center; justify-content:center; padding:16px;
  background:rgba(0,0,0,.62); backdrop-filter:blur(3px); -webkit-backdrop-filter:blur(3px);
}
.fx-modal.open{ display:flex; }
.fx-card{
  background:var(--fx-bg2); border:1px solid var(--fx-lp-d); border-radius:16px;
  padding:22px; width:100%; max-width:420px; color:var(--fx-tx);
  box-shadow:0 18px 60px rgba(0,0,0,.7); font-family:'Segoe UI',system-ui,sans-serif;
  text-align:center; position:relative;
}
.fx-card h3{ color:var(--fx-lp); font-size:18px; margin:0 0 10px; font-weight:800; }
.fx-card p{ font-size:13px; color:var(--fx-t2); line-height:1.5; margin:0 0 14px; }
.fx-card .fx-close{ position:absolute; top:10px; right:12px; background:none; border:none; color:var(--fx-t2); font-size:20px; cursor:pointer; line-height:1; }
.fx-cta{
  background:linear-gradient(90deg,var(--fx-lp-d),var(--fx-lp)); color:var(--fx-bg);
  border:none; border-radius:10px; padding:11px 18px; font-weight:800; font-size:14px;
  cursor:pointer; font-family:inherit; text-decoration:none; display:inline-block;
}
.fx-cta:hover{ filter:brightness(1.08); }
.fx-coupon{
  font-family:ui-monospace,monospace; font-size:22px; font-weight:800; letter-spacing:3px;
  color:#fff; background:rgba(216,157,76,.15); border:1px dashed var(--fx-lp);
  border-radius:10px; padding:12px; margin:10px 0;
}

/* ── Szerencsekerék ── */
.fx-wheel-wrap{ position:relative; width:240px; height:240px; margin:6px auto 14px; }
.fx-wheel{ width:240px; height:240px; border-radius:50%; border:4px solid var(--fx-lp-d); box-shadow:0 0 24px rgba(216,157,76,.4); transition:transform 4s cubic-bezier(.17,.67,.12,1); }
.fx-wheel-pin{ position:absolute; top:-6px; left:50%; transform:translateX(-50%); font-size:26px; z-index:2; filter:drop-shadow(0 2px 3px rgba(0,0,0,.6)); }

/* ── Köszönő üzenet input ── */
.fx-input{ width:100%; box-sizing:border-box; background:var(--fx-bg); border:1px solid var(--fx-br); border-radius:10px; padding:10px 12px; color:var(--fx-tx); font-size:14px; font-family:inherit; margin-bottom:12px; }

/* ── Gyűjtemény rács ── */
.fx-collect-grid{ display:grid; grid-template-columns:repeat(5,1fr); gap:8px; margin:8px 0 14px; }
.fx-collect-cell{ aspect-ratio:1; border:1px solid var(--fx-br); border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:26px; background:var(--fx-bg); opacity:.28; }
.fx-collect-cell.got{ opacity:1; border-color:var(--fx-lp); background:rgba(216,157,76,.12); }

/* ── Tutorial buborékok ── */
.fx-tut{ position:fixed; z-index:9997; background:var(--fx-bg2); color:var(--fx-tx); border:1px solid var(--fx-lp); border-radius:12px; padding:14px 16px; max-width:280px; font-family:'Segoe UI',system-ui,sans-serif; font-size:13px; box-shadow:0 10px 30px rgba(0,0,0,.6); }
.fx-tut b{ color:var(--fx-lp); }
.fx-tut .fx-tut-row{ display:flex; justify-content:space-between; align-items:center; margin-top:12px; gap:10px; }
.fx-tut .fx-skip{ background:none; border:none; color:var(--fx-t2); cursor:pointer; font-size:12px; font-family:inherit; }

/* ── Toast / floaters ── */
.fx-flash{
  position:fixed; left:50%; bottom:150px; transform:translateX(-50%) translateY(20px);
  background:rgba(15,15,20,.96); color:var(--fx-tx); border:1px solid var(--fx-lp);
  border-radius:10px; padding:10px 16px; font-size:13px; z-index:600; opacity:0;
  transition:opacity .3s, transform .3s; pointer-events:none; font-family:'Segoe UI',system-ui,sans-serif;
  box-shadow:0 6px 22px rgba(0,0,0,.6); max-width:90vw; text-align:center;
}
.fx-flash.show{ opacity:1; transform:translateX(-50%) translateY(0); }

/* ── Téma: CRT retro ── */
body.fx-theme-crt::after{
  content:''; position:fixed; inset:0; z-index:9000; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.16) 0, rgba(0,0,0,.16) 1px, transparent 1px, transparent 3px);
  mix-blend-mode:multiply;
}
body.fx-theme-crt #iroda-canvas{ filter:saturate(1.25) contrast(1.08); }
/* ── Téma: világos (lágy) ── */
body.fx-theme-light{ background:#f4ece0 !important; color:#3D2800 !important; }
body.fx-theme-light .iroda-public-fejlec{ background:rgba(255,248,240,.92) !important; }

/* ── Reduced motion: minden saját animációnk leáll ── */
@media (prefers-reduced-motion: reduce){
  .fx-chip .fx-dot{ animation:none; }
}
body.fx-reduced-motion .iroda-canvas-wrap{ animation:none !important; }
body.fx-reduced-motion .fx-chip .fx-dot,
body.fx-reduced-motion .badge{ animation:none !important; }

/* ── Mobil ── */
@media (max-width:640px){
  .fx-toolbar{ top:auto; bottom:150px; right:10px; }
  .fx-btn{ width:38px; height:38px; font-size:16px; }
  .fx-live{ top:58px; left:8px; }
  .fx-chip{ font-size:11px; padding:4px 9px; }
  .fx-apo-slider input[type=range]{ width:120px; }
}
