/* ── KLVIABLO MOBILE · TOUCH-FIRST UI LAYER ─────────────────────────────
 * Loaded by index.html. Activates when body has .is-touch (set by
 * klviablo-mobile.js after detecting touch device). Desktop is unaffected.
 * Also contains polish for loader / loot-flash / floor-clear / death summary
 * which are touch-or-not (used on both form factors).
 * ───────────────────────────────────────────────────────────────────── */

/* ── PWA / iOS standalone polish ────────────────────────────────────── */
html, body { -webkit-text-size-adjust: 100%; }
body.is-touch { user-select: none; -webkit-user-select: none; }

/* ── ZOOM-IN CANVAS ON PORTRAIT ─────────────────────────────────────────
 * Default CSS fits canvas to width (causes ~33% vertical fill on 390x844).
 * Portrait override: fit canvas to HEIGHT — width auto exceeds viewport,
 * #carea has overflow:hidden so it crops symmetrically. Hero is drawn
 * canvas-centered, so the visible region stays hero-centered.
 * Target was >75% of viewport; this hits ~96%. */
@media (orientation:portrait){
  #floor{
    width:auto !important; height:100% !important;
    max-width:none !important; max-height:100% !important;
    /* sprites stay crisp — pixelated already declared on base #floor */
  }
}

/* ── MOBILE CHROME COLLAPSE ─────────────────────────────────────────────
 * On touch portrait, ctrlbar (text hints) is replaced by action buttons.
 * Topbar is slimmed and most controls move into a floating menu. */
body.is-touch #ctrlbar { display:none !important; }
@media (orientation:portrait){
  body.is-touch #topbar{ height:28px; padding:0 6px; gap:4px; background:rgba(10,10,26,0.65); border-bottom:1px solid rgba(124,58,237,0.18); }
  body.is-touch #topbar .t { font-size:10px; letter-spacing:1.4px; }
  body.is-touch #topbar .hub { font-size:9px; padding:2px 6px; }
  /* attune + map buttons move into floating menu — hide topbar copies */
  body.is-touch #topbar #map-btn,
  body.is-touch #topbar #attune-btn { display:none; }
}

/* ── FLOATING MENU (top-right) ──────────────────────────────────────── */
.klv-fmenu{
  position:fixed; top:38px; right:8px; z-index:120;
  display:none; flex-direction:column; gap:8px;
  pointer-events:none;
}
body.is-touch .klv-fmenu{ display:flex; }
.klv-fbtn{
  pointer-events:auto;
  width:44px; height:44px; border-radius:50%;
  background:rgba(10,10,26,0.78);
  border:1px solid rgba(124,58,237,0.55);
  color:#c084fc; font-size:20px; line-height:1;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; padding:0;
  box-shadow:0 4px 14px rgba(0,0,0,0.45), inset 0 0 8px rgba(124,58,237,0.18);
  transition:transform .12s ease, background .12s ease;
}
.klv-fbtn:active{ transform:scale(0.92); background:rgba(124,58,237,0.35); }
.klv-fbtn.has-badge::after{
  content:''; position:absolute; top:6px; right:6px;
  width:8px; height:8px; border-radius:50%; background:#fbbf24;
  box-shadow:0 0 6px #fbbf24;
}

/* ── VIRTUAL JOYSTICK (bottom-left) ─────────────────────────────────── */
.klv-joy{
  position:fixed; left:18px; bottom:24px; z-index:115;
  width:120px; height:120px; border-radius:50%;
  background:rgba(15,10,30,0.42);
  border:2px solid rgba(124,58,237,0.42);
  display:none; touch-action:none;
  box-shadow:inset 0 0 18px rgba(124,58,237,0.18);
}
.klv-joy.active{ background:rgba(15,10,30,0.62); border-color:rgba(192,132,252,0.7); }
body.is-touch .klv-joy{ display:block; }
.klv-joy .knob{
  position:absolute; top:50%; left:50%;
  width:54px; height:54px; border-radius:50%;
  background:radial-gradient(circle at 35% 30%, #c084fc 0%, #7c3aed 60%, #3a1a5e 100%);
  border:2px solid rgba(255,255,255,0.18);
  box-shadow:0 4px 14px rgba(124,58,237,0.55), inset 0 0 10px rgba(255,255,255,0.18);
  transform:translate(-50%,-50%);
  pointer-events:none;
}

/* ── ACTION BUTTONS (bottom-right) ──────────────────────────────────── */
.klv-actions{
  position:fixed; right:14px; bottom:24px; z-index:115;
  display:none; flex-direction:column-reverse; align-items:center; gap:10px;
  pointer-events:none;
}
body.is-touch .klv-actions{ display:flex; }
.klv-act{
  pointer-events:auto;
  width:64px; height:64px; border-radius:50%;
  border:2px solid rgba(124,58,237,0.62);
  background:radial-gradient(circle at 35% 30%, rgba(124,58,237,0.42) 0%, rgba(10,10,26,0.92) 70%);
  color:#fbbf24; font-size:24px; font-weight:700;
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; padding:0;
  box-shadow:0 4px 18px rgba(0,0,0,0.55), inset 0 0 10px rgba(124,58,237,0.32);
  transition:transform .1s ease, box-shadow .1s ease;
  position:relative;
}
.klv-act:active{ transform:scale(0.9); box-shadow:0 2px 8px rgba(0,0,0,0.45), inset 0 0 14px rgba(192,132,252,0.55); }
.klv-act.primary{ width:78px; height:78px; font-size:30px; border-color:#dc2626; color:#fff;
  background:radial-gradient(circle at 35% 30%, rgba(220,38,38,0.55) 0%, rgba(20,5,8,0.95) 70%); }
.klv-act .cd{ position:absolute; bottom:-12px; font-size:9px; color:#94a3b8; letter-spacing:1px; }
.klv-act .ct{ position:absolute; top:2px; right:4px; font-size:9px; color:#fbbf24; font-weight:700; }

/* ── TUTORIAL OVERLAY (first-launch) ────────────────────────────────── */
.klv-tut{
  position:fixed; inset:0; z-index:600;
  background:rgba(5,5,15,0.92);
  display:none; flex-direction:column; align-items:center; justify-content:center;
  padding:24px; text-align:center; gap:14px;
  backdrop-filter:blur(4px); -webkit-backdrop-filter:blur(4px);
}
.klv-tut.open{ display:flex; }
.klv-tut .icn{ font-size:54px; line-height:1; filter:drop-shadow(0 0 12px rgba(124,58,237,0.6)); }
.klv-tut .ttl{ font-family:Cinzel,serif; font-size:18px; letter-spacing:4px; color:#c084fc; text-transform:uppercase; text-shadow:0 0 10px rgba(124,58,237,0.55); }
.klv-tut .bdy{ font-size:13px; color:#cbd5e1; line-height:1.55; max-width:320px; }
.klv-tut .dots{ display:flex; gap:6px; }
.klv-tut .dots i{ width:7px; height:7px; border-radius:50%; background:rgba(124,58,237,0.3); }
.klv-tut .dots i.on{ background:#c084fc; box-shadow:0 0 8px #c084fc; }
.klv-tut .row{ display:flex; gap:10px; margin-top:6px; }
.klv-tut button{ border:0; padding:10px 18px; border-radius:8px; font-family:Cinzel,serif; font-size:11px; letter-spacing:2px; text-transform:uppercase; font-weight:700; cursor:pointer; }
.klv-tut .next{ background:linear-gradient(90deg,#7c3aed,#f59e0b); color:#fff; }
.klv-tut .skip{ background:transparent; color:#94a3b8; border:1px solid rgba(124,58,237,0.4); }

/* ── SETTINGS PANEL ─────────────────────────────────────────────────── */
.klv-set{
  position:fixed; inset:0; z-index:550;
  background:rgba(5,5,15,0.95);
  display:none; flex-direction:column; padding:18px; gap:14px;
  overflow-y:auto;
}
.klv-set.open{ display:flex; }
.klv-set .hdr{ display:flex; justify-content:space-between; align-items:center; padding-bottom:8px; border-bottom:1px solid rgba(124,58,237,0.35); }
.klv-set .ttl{ font-family:Cinzel,serif; font-size:14px; color:#c084fc; letter-spacing:3px; text-transform:uppercase; }
.klv-set .x{ width:34px; height:34px; border-radius:8px; border:1px solid #7c3aed; background:rgba(124,58,237,0.2); color:#c084fc; font-size:16px; font-weight:700; cursor:pointer; }
.klv-set .row{ display:flex; flex-direction:column; gap:6px; padding:10px 0; border-bottom:1px dashed rgba(124,58,237,0.18); }
.klv-set .lab{ font-family:Cinzel,serif; font-size:11px; color:#c084fc; letter-spacing:2px; text-transform:uppercase; }
.klv-set .val{ font-size:10px; color:#fbbf24; font-weight:700; }
.klv-set input[type=range]{ width:100%; accent-color:#7c3aed; height:24px; }
.klv-set .tog{ display:inline-block; width:44px; height:24px; border-radius:12px; background:rgba(124,58,237,0.25); border:1px solid rgba(124,58,237,0.45); position:relative; cursor:pointer; }
.klv-set .tog::after{ content:''; position:absolute; top:1px; left:1px; width:20px; height:20px; border-radius:50%; background:#c084fc; transition:left .15s; }
.klv-set .tog.on{ background:rgba(124,58,237,0.55); }
.klv-set .tog.on::after{ left:21px; background:#fbbf24; }
.klv-set .note{ font-size:10px; color:#64748b; letter-spacing:1px; }

/* ── LOOT FLASH (rare+) ─────────────────────────────────────────────── */
@keyframes klv-flash{ 0%{opacity:0} 12%{opacity:0.55} 100%{opacity:0} }
.klv-flash{ position:fixed; inset:0; z-index:280; pointer-events:none; animation:klv-flash 0.55s ease-out forwards; }

.klv-lootcard{
  position:fixed; left:50%; top:36%; transform:translate(-50%,-50%) scale(0.6);
  z-index:285; pointer-events:none;
  background:linear-gradient(180deg, rgba(10,10,26,0.94) 0%, rgba(30,12,50,0.94) 100%);
  border:2px solid currentColor; border-radius:10px;
  padding:14px 22px; min-width:200px;
  text-align:center; font-family:Cinzel,serif;
  box-shadow:0 0 32px currentColor;
  opacity:0; animation:klv-lc 1.5s ease-out forwards;
}
@keyframes klv-lc{
  0%   { opacity:0; transform:translate(-50%,-50%) scale(0.6); }
  18%  { opacity:1; transform:translate(-50%,-50%) scale(1.08); }
  28%  { transform:translate(-50%,-50%) scale(1); }
  80%  { opacity:1; transform:translate(-50%,-50%) scale(1); }
  100% { opacity:0; transform:translate(-50%,-60%) scale(0.95); }
}
.klv-lootcard .r{ font-size:9px; letter-spacing:3px; text-transform:uppercase; opacity:0.85; margin-bottom:4px; }
.klv-lootcard .n{ font-size:14px; color:#fff; letter-spacing:2px; text-transform:uppercase; }

/* ── FLOOR CLEAR BANNER ─────────────────────────────────────────────── */
.klv-floorbanner{
  position:fixed; left:0; right:0; top:42%; z-index:270; pointer-events:none;
  text-align:center; font-family:Cinzel,serif;
  opacity:0; animation:klv-fb 2s ease-out forwards;
}
@keyframes klv-fb{
  0%   { opacity:0; transform:translateY(20px); }
  15%  { opacity:1; transform:translateY(0); }
  80%  { opacity:1; transform:translateY(0); }
  100% { opacity:0; transform:translateY(-12px); }
}
.klv-floorbanner .big{ font-size:38px; letter-spacing:10px; color:#fbbf24; text-transform:uppercase; text-shadow:0 0 18px rgba(251,191,36,0.7), 0 0 4px #000; }
.klv-floorbanner .sub{ font-size:11px; color:#c084fc; letter-spacing:6px; margin-top:6px; text-transform:uppercase; }

/* ── LOADER POLISH ──────────────────────────────────────────────────── */
.klv-loader-art{
  width:96px; height:120px; position:relative; margin-bottom:6px;
  filter:drop-shadow(0 0 14px rgba(124,58,237,0.55));
}
.klv-loader-art svg{ width:100%; height:100%; display:block; }
.klv-loader-art .door-l, .klv-loader-art .door-r{
  transition:transform .8s cubic-bezier(.5,.05,.6,.95);
  transform-origin: 50% 100%;
}
.klv-loader-art.open .door-l{ transform:perspective(120px) rotateY(-78deg) translateX(-2px); }
.klv-loader-art.open .door-r{ transform:perspective(120px) rotateY(78deg) translateX(2px); }
#loading .lt{ text-shadow:0 0 16px rgba(124,58,237,0.65); }
.klv-loader-tag{ font-size:10px; color:#94a3b8; letter-spacing:2px; max-width:280px; text-align:center; line-height:1.5; font-style:italic; }

/* ── DEATH SCREEN POLISH (extra) ────────────────────────────────────── */
.klv-death-summary{
  display:flex; flex-direction:column; gap:4px; padding:10px 14px;
  border:1px dashed rgba(124,58,237,0.45); border-radius:6px;
  background:rgba(10,10,26,0.6);
  font-size:11px; color:#cbd5e1; letter-spacing:1px;
  min-width:220px;
}
.klv-death-summary b{ color:#fbbf24; font-weight:700; }
.klv-death-cause{ font-size:12px; color:#dc2626; letter-spacing:2px; text-transform:uppercase; }

/* ── CLASS-SELECT RESUME BADGE ──────────────────────────────────────── */
.klv-class-card .resume-pill{
  position:absolute; top:6px; right:6px;
  font-size:8px; letter-spacing:1px; text-transform:uppercase;
  background:linear-gradient(90deg,#7c3aed,#f59e0b); color:#fff;
  padding:2px 6px; border-radius:3px; font-weight:700;
}
.klv-class-card{ position:relative; }
.klv-class-card.last-run{ box-shadow:0 0 0 1px rgba(251,191,36,0.65), 0 0 14px rgba(251,191,36,0.25); }

/* ── WALLET GATE COPY (commercial onboarding) ───────────────────────── */
.klv-gate-cta{
  font-size:11px; color:#fbbf24; letter-spacing:1.5px; text-transform:uppercase;
  border-top:1px dashed rgba(251,191,36,0.35); padding-top:10px;
  max-width:300px;
}
.klv-gate-cta b{ color:#c084fc; }
