/* ============================================================================
   WORLD — 3D world overlay UI (prefix: wld-)
   Dark, premium night theme. Adapted from the AGOS map UI, recoloured for the
   Redweb world (red/gold accents) and extended with dialogue + quest boxes.
   ========================================================================== */
:root{
  --wld-bg:#06070A; --wld-text:#F4F4F2; --wld-muted:#8A8A93; --wld-line:#23232a;
  --wld-red:#E5354B; --wld-gold:#E8B04B; --wld-violet:#8B5CF6; --wld-cyan:#46d6e0;
  --wld-font:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
[hidden]{display:none !important}
html,body{margin:0;height:100%;overflow:hidden;background:var(--wld-bg);color:var(--wld-text);font-family:var(--wld-font)}
.wld-canvas{position:fixed;inset:0;z-index:0;
  /* custom world cursor (hidden automatically while looking via pointer lock) */
  cursor:url('/uploads/DARKFILES/upload-private/1/data/1739270244-mous-32x32.png') 4 2, auto}
.wld-canvas canvas{display:block;cursor:inherit}

/* Account level / EXP */
.wld-level{position:fixed;top:0;left:0;right:0;z-index:24;background:rgba(9,8,13,.9);
  border-bottom:1px solid rgba(232,176,75,.35);box-shadow:0 4px 18px rgba(0,0,0,.45);
  backdrop-filter:blur(8px);pointer-events:none}
.wld-level__text{height:31px;display:flex;align-items:center;justify-content:center;gap:12px;padding:0 14px;
  color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.06em;text-transform:uppercase;
  text-shadow:0 1px 4px #000}
.wld-level__text strong{color:#ffd37b}
.wld-level__next{color:#b8b8c2;font-size:.65rem;font-weight:500;text-transform:none;letter-spacing:.02em}
.wld-level__track{height:7px;background:rgba(255,255,255,.08);overflow:hidden}
.wld-level__fill{width:0;height:100%;background:linear-gradient(90deg,#a84b08,#e58100,#ffc45c);
  box-shadow:0 0 10px rgba(229,129,0,.7);transition:width .45s ease}
.wld-has-level .wld-stats,.wld-has-level .wld-minimap{top:54px}
.wld-exp-reward{position:fixed;left:50%;top:21%;z-index:55;transform:translate(-50%,-12px) scale(.92);
  color:#ffd36b;font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;font-size:clamp(1.5rem,4vw,2.5rem);
  font-weight:400;letter-spacing:.04em;text-shadow:0 2px 4px #000,0 0 18px rgba(229,129,0,.9);
  opacity:0;pointer-events:none}
.wld-exp-reward.is-on{animation:wld-exp-reward 1.8s ease-out both}
@keyframes wld-exp-reward{
  0%{opacity:0;transform:translate(-50%,12px) scale(.78)}
  18%{opacity:1;transform:translate(-50%,0) scale(1.08)}
  72%{opacity:1;transform:translate(-50%,-12px) scale(1)}
  100%{opacity:0;transform:translate(-50%,-35px) scale(.96)}
}

.wld-damage-loss{position:fixed;left:50%;top:29%;z-index:59;transform:translate(-50%,-12px) scale(.9);
  color:#ff313d;font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;
  font-size:clamp(1.8rem,5vw,3.2rem);font-weight:400;letter-spacing:.05em;
  text-shadow:0 2px 4px #000,0 0 8px #ff0019,0 0 24px rgba(255,0,25,.95);
  opacity:0;pointer-events:none}
.wld-damage-loss.is-on{animation:wld-damage-loss 1.7s ease-out both}
@keyframes wld-damage-loss{
  0%{opacity:0;transform:translate(-50%,18px) scale(.65)}
  12%{opacity:1;transform:translate(-50%,0) scale(1.22)}
  25%{transform:translate(calc(-50% - 5px),-3px) scale(1.04)}
  32%{transform:translate(calc(-50% + 4px),-5px) scale(1.08)}
  70%{opacity:1;transform:translate(-50%,-18px) scale(1)}
  100%{opacity:0;transform:translate(-50%,-52px) scale(.94)}
}

/* Spirit reward popup — same motion as the EXP popup, sits below it, green */
.wld-spirit-reward{position:fixed;left:50%;top:29%;z-index:55;transform:translate(-50%,-12px) scale(.92);
  color:#7CF6A8;font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;font-size:clamp(1.5rem,4vw,2.5rem);
  font-weight:400;letter-spacing:.04em;text-shadow:0 2px 4px #000,0 0 18px rgba(34,197,94,.9);
  opacity:0;pointer-events:none}
.wld-spirit-reward.is-on{animation:wld-spirit-reward 1.9s ease-out both}
@keyframes wld-spirit-reward{
  0%{opacity:0;transform:translate(-50%,12px) scale(.78)}
  18%{opacity:1;transform:translate(-50%,0) scale(1.1)}
  72%{opacity:1;transform:translate(-50%,-14px) scale(1)}
  100%{opacity:0;transform:translate(-50%,-40px) scale(.96)}
}

/* Short status toast (e.g. "komm morgen wieder", "erneut versuchen") */
.wld-toast{position:fixed;left:50%;top:38%;z-index:55;transform:translate(-50%,0);
  background:rgba(10,11,15,.88);border:1px solid var(--wld-gold);border-radius:999px;
  padding:9px 20px;color:#fff;font-size:.92rem;opacity:0;pointer-events:none;white-space:nowrap}
.wld-toast.is-on{animation:wld-toast 2.6s ease-out both}
@keyframes wld-toast{
  0%{opacity:0;transform:translate(-50%,8px)}
  10%{opacity:1;transform:translate(-50%,0)}
  85%{opacity:1;transform:translate(-50%,0)}
  100%{opacity:0;transform:translate(-50%,-6px)}
}

/* Overlays (intro / fallback / loading) */
.wld-overlay{position:fixed;inset:0;z-index:30;display:flex;align-items:center;justify-content:center;
  background:rgba(4,5,8,.8);backdrop-filter:blur(8px);padding:20px}
#wld-intro{background:#080000 url('/world/assets/loading-screen.png') center center/cover no-repeat;backdrop-filter:none}
#wld-intro::before{content:"";position:absolute;inset:0;background:rgba(8,0,0,.32)}
.wld-panel{max-width:560px;width:100%;background:rgba(16,17,22,.93);border:1px solid var(--wld-line);
  position:relative;z-index:1;border-radius:18px;padding:34px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.wld-kicker{color:var(--wld-gold);letter-spacing:.18em;text-transform:uppercase;font-size:.72rem;font-weight:700;margin:0 0 12px}
.wld-title{font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin:0 0 14px}
.wld-lead{color:#cfcfd4;line-height:1.6;margin:0 0 22px}
.wld-actions{display:flex;gap:10px;flex-wrap:wrap}
.wld-hint{color:var(--wld-muted);font-size:.85rem;margin:16px 0 0}

/* Buttons */
.wld-btn{display:inline-block;cursor:pointer;border:1px solid var(--wld-line);background:rgba(255,255,255,.04);
  color:var(--wld-text);font:inherit;font-weight:600;padding:13px 22px;border-radius:999px;text-decoration:none;
  transition:transform .15s,box-shadow .15s,background .15s}
.wld-btn:hover{transform:translateY(-2px)}
.wld-btn--primary{background:var(--wld-red);color:#fff;border-color:var(--wld-red)}
.wld-btn--primary:hover{box-shadow:0 12px 30px rgba(229,53,75,.34)}

/* Help (bottom-left) */
.wld-help{display:none !important;position:fixed;left:16px;bottom:16px;z-index:20;background:rgba(10,11,15,.7);border:1px solid var(--wld-line);
  border-radius:12px;padding:9px 14px;font-size:.78rem;color:var(--wld-muted);backdrop-filter:blur(6px);max-width:92vw}
.wld-help strong{color:var(--wld-text)}

/* Reticle */
.wld-reticle{position:fixed;left:50%;top:50%;width:6px;height:6px;margin:-3px 0 0 -3px;border-radius:50%;
  background:rgba(255,255,255,.7);z-index:15;pointer-events:none;display:none}
.wld-reticle.is-on{display:block}

/* Interaction prompt */
.wld-prompt{position:fixed;left:50%;bottom:72px;transform:translateX(-50%);z-index:18;
  background:rgba(10,11,15,.85);border:1px solid var(--wld-gold);border-radius:999px;padding:8px 18px;
  font-size:.85rem;display:none}
.wld-prompt.is-on{display:block}
.wld-prompt b{color:var(--wld-gold)}
.wld-touch-controls{display:none;position:fixed;inset:0;z-index:17;pointer-events:none;
  touch-action:none;user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}
.wld-touch-controls.is-on{display:block}
.wld-touch-look{position:absolute;top:0;right:0;width:62%;height:100%;pointer-events:auto;touch-action:none}
.wld-touch-stick{position:absolute;left:max(24px,env(safe-area-inset-left));bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px));
  width:132px;height:132px;border-radius:50%;pointer-events:auto;touch-action:none;
  border:2px solid rgba(255,255,255,.2);background:radial-gradient(circle,rgba(255,255,255,.1),rgba(8,9,14,.42));
  box-shadow:inset 0 0 30px rgba(0,0,0,.4),0 8px 30px rgba(0,0,0,.35);backdrop-filter:blur(3px)}
.wld-touch-stick::before,.wld-touch-stick::after{content:"";position:absolute;background:rgba(255,255,255,.1);pointer-events:none}
.wld-touch-stick::before{left:50%;top:12%;bottom:12%;width:1px}
.wld-touch-stick::after{top:50%;left:12%;right:12%;height:1px}
.wld-touch-stick__knob{position:absolute;left:50%;top:50%;width:58px;height:58px;margin:-29px 0 0 -29px;
  border-radius:50%;border:2px solid rgba(255,255,255,.42);
  background:radial-gradient(circle at 35% 30%,rgba(255,255,255,.35),rgba(139,92,246,.68));
  box-shadow:0 5px 18px rgba(0,0,0,.45),0 0 18px rgba(139,92,246,.25);will-change:transform}
.wld-touch-btn{position:absolute;display:flex;align-items:center;justify-content:center;pointer-events:auto;touch-action:none;
  padding:0;border-radius:50%;color:#fff;border:2px solid rgba(255,255,255,.34);font-family:var(--wld-font);
  text-shadow:0 2px 5px #000;box-shadow:0 7px 24px rgba(0,0,0,.4);backdrop-filter:blur(4px)}
.wld-touch-btn:active{transform:scale(.92);filter:brightness(1.3)}
.wld-touch-btn--action{right:max(24px,env(safe-area-inset-right));bottom:max(24px,env(safe-area-inset-bottom));
  width:84px;height:84px;background:radial-gradient(circle at 35% 30%,#8a75ff,#6b24b6 58%,#281044);
  font-size:2.2rem;box-shadow:0 0 26px rgba(181,44,255,.38),0 7px 24px rgba(0,0,0,.4)}
.wld-touch-btn--action{bottom:max(228px,calc(env(safe-area-inset-bottom) + 228px))}
.wld-touch-btn--jump{right:max(35px,calc(env(safe-area-inset-right) + 35px));
  bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px));width:62px;height:62px;
  background:rgba(27,30,42,.75);font-size:1.9rem}

/* ── Stats HUD (top-left): health + mana ───────────────────────────────── */
.wld-stats{position:fixed;top:16px;left:16px;z-index:21;display:flex;flex-direction:column;gap:9px;
  background:rgba(10,11,15,.72);border:1px solid var(--wld-line);border-radius:12px;
  padding:11px 13px;backdrop-filter:blur(6px);min-width:230px}
.wld-player-card{padding:0 0 7px;border-bottom:1px solid rgba(255,255,255,.09)}
.wld-stats__body{display:flex;align-items:center;gap:11px}
.wld-stats__bars{display:flex;flex:1;min-width:0;flex-direction:column;gap:9px}
.wld-player-card__avatar{width:54px;height:54px;flex:0 0 54px;border-radius:50%;object-fit:cover;
  border:2px solid rgba(232,176,75,.75);box-shadow:0 0 16px rgba(139,92,246,.28);background:#161722}
.wld-player-card__avatar--fallback{display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:1rem;font-weight:800;background:linear-gradient(135deg,var(--wld-violet),#422075)}
.wld-player-card__name{display:block;min-width:0;max-width:230px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;
  color:#fff;font-size:.92rem;font-weight:800;letter-spacing:.02em;text-shadow:0 1px 8px rgba(0,0,0,.8)}
.wld-stat{display:flex;align-items:center;gap:9px}
.wld-stat__icon{width:18px;text-align:center;font-size:.95rem;line-height:1}
.wld-stat--hp .wld-stat__icon{color:#ff5b5b}
.wld-stat--mp .wld-stat__icon{color:#c08bff}
.wld-stat__bar{position:relative;flex:1;height:16px;background:#15161d;border:1px solid rgba(255,255,255,.07);border-radius:999px;overflow:hidden}
.wld-stat__bar>div{position:absolute;inset:0 auto 0 0;height:100%;width:100%;border-radius:999px;transition:width .18s linear}
.wld-stat--hp .wld-stat__bar>div{background:linear-gradient(90deg,#7a0a0a,#ff5b5b)}
.wld-stat--mp .wld-stat__bar>div{background:linear-gradient(90deg,#3d7bff,#8B5CF6)}
.wld-stat__text{position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;
  color:#fff;font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;font-size:.68rem;font-weight:400;
  letter-spacing:.04em;line-height:1;text-align:center;font-variant-numeric:tabular-nums;
  text-shadow:0 1px 2px #000,0 0 3px rgba(0,0,0,.9);pointer-events:none}

/* ── Quest box (top-right) ─────────────────────────────────────────────── */
.wld-minimap{position:fixed;top:16px;right:16px;z-index:22;width:120px;height:120px;border-radius:50%;
  padding:2px;background:rgba(7,9,15,.86);border:2px solid rgba(232,176,75,.72);
  box-shadow:0 10px 32px rgba(0,0,0,.5),0 0 20px rgba(139,92,246,.18);overflow:hidden}
.wld-minimap canvas{display:block;width:116px;height:116px;border-radius:50%}
.wld-minimap__north{position:absolute;top:6px;left:50%;transform:translateX(-50%);z-index:2;color:#fff;
  font:700 .65rem var(--wld-font);text-shadow:0 1px 4px #000;pointer-events:none}

/* Inventory */
.wld-inventory{position:fixed;right:24px;bottom:52px;z-index:46;width:min(520px,calc(100vw - 32px));
  max-height:min(650px,calc(100vh - 32px));overflow:hidden;background:rgba(10,11,17,.97);
  border:1px solid rgba(232,176,75,.55);border-radius:15px;box-shadow:0 24px 70px rgba(0,0,0,.72);
  backdrop-filter:blur(12px);color:#fff}
.wld-inventory__header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;
  background:linear-gradient(90deg,rgba(232,176,75,.2),rgba(139,92,246,.16));border-bottom:1px solid rgba(255,255,255,.1);
  font-weight:800;letter-spacing:.06em;cursor:move;touch-action:none}
.wld-inventory__close{width:30px;height:30px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.1);
  color:#fff;font-size:1.35rem;line-height:1;cursor:pointer}
.wld-inventory__content{max-height:min(510px,calc(100vh - 150px));overflow:auto;padding:14px}
.wld-inventory__grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
.wld-inventory-item{position:relative;display:flex;min-width:0;flex-direction:column;align-items:center;gap:3px;
  padding:10px 6px 8px;border:1px solid rgba(255,255,255,.1);border-radius:10px;
  background:linear-gradient(145deg,rgba(255,255,255,.075),rgba(255,255,255,.025))}
.wld-inventory-item.is-empty{opacity:.36;filter:grayscale(.45)}
.wld-inventory-item img{width:66px;height:66px;object-fit:contain;filter:drop-shadow(0 4px 7px rgba(0,0,0,.55))}
.wld-inventory-item__count{position:absolute;top:5px;right:6px;min-width:24px;padding:2px 6px;border-radius:999px;
  background:#7b35c8;border:1px solid rgba(255,255,255,.55);font-size:.72rem;text-align:center}
.wld-inventory-item__name{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.73rem;font-weight:700}
.wld-inventory-item small{color:var(--wld-muted);font-size:.62rem}
.wld-inventory__spirit{display:flex;align-items:center;gap:8px;margin-top:14px;padding:9px 11px;
  border:1px solid rgba(232,176,75,.4);border-radius:10px;background:rgba(232,176,75,.09);
  color:#f2d695;font-size:.82rem}
.wld-inventory__spirit strong{margin-left:auto;color:#fff2bd;font-size:.95rem;font-variant-numeric:tabular-nums}
.wld-inventory__coin{position:relative;width:20px;height:20px;flex:0 0 20px;border:2px solid #fff0a8;border-radius:50%;
  background:radial-gradient(circle at 35% 30%,#fff2a3 0 13%,#e8b04b 35%,#a76516 78%);
  box-shadow:0 0 8px rgba(232,176,75,.5),inset 0 0 0 2px rgba(116,65,10,.35)}
.wld-inventory__coin::after{content:"S";position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  color:#74410a;font-size:.65rem;font-weight:900;line-height:1}
.wld-inventory__loading,.wld-inventory__error{padding:35px 12px;text-align:center;color:var(--wld-muted)}
.wld-inventory__full-link{display:block;padding:10px 14px;border-top:1px solid rgba(255,255,255,.08);
  color:var(--wld-gold);font-size:.75rem;text-align:center;text-decoration:none}
.wld-inventory__full-link:hover{color:#fff}
.wld-quest{background:rgba(255,255,255,.03);border:1px solid var(--wld-line);border-left:3px solid var(--wld-gold);
  border-radius:12px;padding:12px 15px}
.wld-quest.is-done{border-left-color:#2f9e44}
.wld-quest__label{font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--wld-muted);margin-bottom:4px}
.wld-quest__title{font-size:1rem;font-weight:700;margin:0 0 6px}
.wld-quest__desc{font-size:.82rem;color:#cfcfd4;line-height:1.45;margin:0 0 8px}
.wld-quest__state{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.06em;
  color:var(--wld-gold);background:rgba(232,176,75,.12);border-radius:999px;padding:3px 10px}
.wld-quest__state.is-done{color:#43d17a;background:rgba(47,158,68,.16)}
.wld-quest__empty{color:var(--wld-muted);font-size:.85rem;text-align:center;padding:18px 8px;margin:0}
.wld-questlog__grid{display:grid;grid-template-columns:minmax(260px,360px) minmax(0,1fr);gap:18px;height:100%;min-height:0}
.wld-questlog__current{min-width:0}
.wld-questlog__all{min-width:0;display:flex;flex-direction:column;gap:14px;min-height:0}
.wld-questlog__toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;padding-bottom:12px;
  border-bottom:1px solid rgba(255,255,255,.09)}
.wld-questlog__eyebrow{font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:var(--wld-muted);margin-bottom:3px}
.wld-questlog__toolbar h2{margin:0;font-size:1.45rem;line-height:1.1}
.wld-questlog__summary{flex:0 0 auto;color:#f2d695;font-size:.82rem;font-weight:800;white-space:nowrap}
.wld-questlog__toolbar{flex:0 0 auto}
.wld-questlog__chapters{flex:1 1 0;display:flex;flex-direction:column;gap:13px;overflow-y:auto;overflow-x:hidden;
  padding-right:4px;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.wld-questlog__loading{padding:28px 12px;text-align:center;color:var(--wld-muted);font-size:.9rem}
.wld-quest-chapter{flex:0 0 auto;border:1px solid rgba(255,255,255,.09);border-left:3px solid var(--chapter-color);
  border-radius:10px;background:rgba(255,255,255,.035);overflow:hidden}
.wld-quest-chapter__head{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:11px 13px;
  width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer;user-select:none;
  background:linear-gradient(90deg,color-mix(in srgb,var(--chapter-color) 20%,transparent),rgba(255,255,255,.02));
  border:0;border-bottom:1px solid rgba(255,255,255,.07)}
.wld-quest-chapter__head:hover{background:linear-gradient(90deg,color-mix(in srgb,var(--chapter-color) 30%,transparent),rgba(255,255,255,.05))}
.wld-quest-chapter__head h3{margin:0;font-size:.95rem;flex:1 1 auto;min-width:0}
.wld-quest-chapter__count{color:#fff7d7;font-size:.76rem;font-weight:800;flex:0 0 auto}
.wld-quest-chapter__chevron{flex:0 0 auto;color:#fff7d7;font-size:.8rem;line-height:1;transition:transform .18s ease}
.wld-quest-chapter.is-collapsed .wld-quest-chapter__chevron{transform:rotate(-90deg)}
.wld-quest-chapter.is-collapsed .wld-quest-chapter__list{display:none}
.wld-quest-chapter__list{display:flex;flex-direction:column}
.wld-quest-row{display:grid;grid-template-columns:30px minmax(0,1fr) auto;align-items:center;gap:11px;padding:10px 12px;
  border-top:1px solid rgba(255,255,255,.055)}
.wld-quest-row:first-child{border-top:0}
.wld-quest-row__marker{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.08);color:#ddd;font-size:.72rem;font-weight:900}
.wld-quest-row.is-done .wld-quest-row__marker{background:rgba(47,158,68,.2);color:#43d17a}
.wld-quest-row__body{min-width:0;display:flex;flex-direction:column;gap:3px}
.wld-quest-row__body strong{font-size:.84rem;line-height:1.2;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.wld-quest-row__body small{color:var(--wld-muted);font-size:.72rem;line-height:1.35;display:-webkit-box;
  -webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.wld-quest-row__state{padding:3px 9px;border-radius:999px;background:rgba(232,176,75,.12);color:#e8b04b;
  font-size:.66rem;font-weight:800;white-space:nowrap}
.wld-quest-row.is-done .wld-quest-row__state{background:rgba(47,158,68,.16);color:#43d17a}
@media (max-width:760px){
  .wld-questlog{inset:8px}
  .wld-questlog .wld-popup__body{padding:12px}
  .wld-questlog__grid{grid-template-columns:1fr;grid-template-rows:auto minmax(0,1fr);gap:12px}
  .wld-questlog__toolbar{align-items:flex-start;flex-direction:column;gap:7px}
  .wld-questlog__summary{white-space:normal}
  .wld-quest-row{grid-template-columns:28px minmax(0,1fr);align-items:flex-start}
  .wld-quest-row__state{grid-column:2;justify-self:start}
}

/* ── Bottom action bar ─────────────────────────────────────────────────── */
/* Floating round icon chips — NO solid bar background (no black balken). */
.wld-bottombar{position:fixed;left:50%;bottom:0;transform:translateX(-50%);z-index:27;
  display:flex;align-items:center;gap:10px;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
  background:none;border:0;box-shadow:none}
.wld-bar-btn{display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;padding:0;border:1px solid var(--wld-line);border-radius:50%;
  background:rgba(10,11,15,.72);color:var(--wld-text);font:inherit;cursor:pointer;
  backdrop-filter:blur(6px);box-shadow:0 4px 14px rgba(0,0,0,.4);
  transition:transform .12s,background .12s,box-shadow .12s}
.wld-bar-btn:hover,.wld-bar-btn.is-open{background:rgba(255,255,255,.12);transform:translateY(-2px)}
.wld-bar-btn__icon{font-size:1.25rem;line-height:1}
.wld-bar-btn__label{display:none}
.wld-bar-btn.has-quest{border-color:var(--wld-gold);box-shadow:0 0 12px rgba(232,176,75,.4)}
.wld-bar-btn--portal{color:#dffcff;border-color:rgba(65,225,255,.72);
  background:radial-gradient(circle at 50% 50%,rgba(196,91,255,.72),rgba(20,127,187,.8) 48%,rgba(5,15,31,.9) 74%);
  box-shadow:0 0 9px rgba(75,220,255,.7),inset 0 0 10px rgba(255,255,255,.28);
  animation:wld-portal-button 1.7s ease-in-out infinite}
.wld-bar-btn--portal .wld-bar-btn__icon{font-size:1.55rem;text-shadow:0 0 8px #9ff,0 0 14px #b65cff}
.wld-bar-btn--spell{background:radial-gradient(circle at 35% 30%,#8a75ff,#6b24b6 70%);
  border-color:rgba(181,44,255,.5);box-shadow:0 0 16px rgba(181,44,255,.35)}
.wld-bar-btn--spell .wld-bar-btn__icon{color:#fff}
.wld-bar-btn--spell:active{transform:scale(.94);filter:brightness(1.2)}
@keyframes wld-portal-button{
  0%,100%{filter:brightness(.9);transform:translateY(0) scale(.96)}
  50%{filter:brightness(1.35);transform:translateY(-2px) scale(1.06)}
}

/* Portal glitch uses composite layers only: no additional Three.js pass. */
.wld-portal-fx{position:fixed;inset:0;z-index:80;overflow:hidden;
  pointer-events:none;visibility:hidden;opacity:0;background:rgba(66,22,120,.06)}
.wld-portal-fx>span{position:absolute;inset:-8%;opacity:0;mix-blend-mode:screen}
.wld-portal-fx__bars{background-size:100% 100%}
.wld-portal-fx__bars--violet{background:
  linear-gradient(0deg,transparent 0 7%,rgba(180,55,255,.82) 7% 16%,transparent 16% 27%,
    rgba(118,38,255,.74) 27% 39%,transparent 39% 53%,rgba(226,91,255,.88) 53% 68%,
    transparent 68% 82%,rgba(105,34,224,.75) 82% 92%,transparent 92%)}
.wld-portal-fx__bars--blue{background:
  linear-gradient(0deg,transparent 0 13%,rgba(129,214,255,.88) 13% 24%,transparent 24% 34%,
    rgba(154,226,255,.8) 34% 49%,transparent 49% 63%,rgba(106,197,255,.9) 63% 76%,
    transparent 76% 87%,rgba(184,231,255,.78) 87% 96%,transparent 96%)}
.wld-portal-fx__bars--cyan{background:
  repeating-linear-gradient(0deg,transparent 0 18px,rgba(31,234,255,.38) 18px 31px,
    transparent 31px 68px)}
.wld-portal-fx__flash{background:
  linear-gradient(0deg,transparent 0 18%,rgba(129,214,255,.62) 18% 32%,transparent 32% 46%,
    rgba(182,57,255,.72) 46% 66%,transparent 66% 79%,rgba(216,239,255,.5) 79% 88%,transparent 88%),
  radial-gradient(ellipse at center,rgba(170,222,255,.25),rgba(120,40,220,.18) 48%,rgba(13,5,32,.7))}
body.wld-portal-active .wld-portal-fx{visibility:visible;animation:wld-portal-intensity 3s linear both}
body.wld-portal-active .wld-canvas{transform-origin:center;
  animation:wld-portal-zoom 3s linear both;will-change:transform}
body.wld-portal-active #wld-canvas canvas{transform-origin:center;
  animation:wld-portal-canvas-loop .32s steps(2,end) infinite;will-change:transform,filter}
body.wld-portal-active .wld-portal-fx__bars--violet{animation:wld-portal-violet-loop .34s steps(2,end) infinite}
body.wld-portal-active .wld-portal-fx__bars--blue{animation:wld-portal-blue-loop .29s steps(2,end) infinite}
body.wld-portal-active .wld-portal-fx__bars--cyan{animation:wld-portal-cyan-loop .23s steps(3,end) infinite}
body.wld-portal-active .wld-portal-fx__flash{animation:wld-portal-flash-loop .31s steps(2,end) infinite}
@keyframes wld-portal-zoom{
  0%{transform:scale(1)}
  100%{transform:scale(2.2)}
}
@keyframes wld-portal-canvas-loop{
  0%{transform:translate(0,0) scale(1);filter:contrast(1.15) saturate(1.3)}
  18%{transform:translate(-18px,4px) scale(1.035,.975) skewX(2deg);
    filter:brightness(1.18) contrast(1.65) saturate(2.1) hue-rotate(28deg)}
  37%{transform:translate(24px,-6px) scale(.975,1.04) skewX(-3deg);
    filter:contrast(2) saturate(2.8) hue-rotate(88deg)}
  56%{transform:translate(-32px,8px) scale(1.055,.955) skewX(5deg);
    filter:brightness(1.4) contrast(2.3) saturate(3.2) hue-rotate(155deg)}
  74%{transform:translate(29px,-5px) scale(.96,1.06) skewX(-5deg);
    filter:contrast(2.15) saturate(3) hue-rotate(235deg)}
  88%{transform:translate(-13px,3px) scale(1.025,.98) skewX(2deg);
    filter:brightness(1.25) contrast(1.8) saturate(2.4) hue-rotate(305deg)}
  100%{transform:translate(0,0) scale(1);filter:contrast(1.25) saturate(1.5)}
}
@keyframes wld-portal-intensity{
  0%{opacity:.08}
  30%{opacity:.28}
  62%{opacity:.62}
  84%{opacity:.88}
  100%{opacity:1}
}
@keyframes wld-portal-violet-loop{
  0%,100%{opacity:.12;transform:translateX(18px) scaleX(1.04)}
  22%{opacity:.95;transform:translateX(-62px) scaleX(1.22)}
  48%{opacity:.2;transform:translateX(35px) scaleX(.94)}
  72%{opacity:1;transform:translateX(86px) scaleX(1.3)}
}
@keyframes wld-portal-blue-loop{
  0%,100%{opacity:.18;transform:translateX(-22px) scaleX(1.06)}
  25%{opacity:1;transform:translateX(72px) scaleX(1.26)}
  53%{opacity:.16;transform:translateX(-39px) scaleX(.92)}
  79%{opacity:.92;transform:translateX(-96px) scaleX(1.35)}
}
@keyframes wld-portal-cyan-loop{
  0%,100%{opacity:.08;transform:translateY(-22px)}
  24%{opacity:.76;transform:translateY(34px)}
  51%{opacity:.18;transform:translateY(-48px)}
  77%{opacity:.9;transform:translateY(61px)}
}
@keyframes wld-portal-flash-loop{
  0%,100%{opacity:.04;transform:translateX(0)}
  17%{opacity:.75;transform:translateX(-42px)}
  36%{opacity:.12;transform:translateX(57px)}
  58%{opacity:.94;transform:translateX(-76px)}
  81%{opacity:.22;transform:translateX(91px)}
}

/* ── Generic pop-up window (questlog + settings) ───────────────────────── */
.wld-popup{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);z-index:47;
  width:min(420px,calc(100vw - 32px));max-height:min(70vh,560px);
  display:flex;flex-direction:column;overflow:hidden;color:#fff;
  background:rgba(10,11,17,.97);border:1px solid rgba(232,176,75,.5);border-radius:15px;
  box-shadow:0 24px 70px rgba(0,0,0,.72);backdrop-filter:blur(12px)}
.wld-popup__header{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;
  background:linear-gradient(90deg,rgba(232,176,75,.2),rgba(139,92,246,.16));
  border-bottom:1px solid rgba(255,255,255,.1);font-weight:800;letter-spacing:.06em;cursor:move;touch-action:none}
.wld-popup__close{width:30px;height:30px;padding:0;border:0;border-radius:50%;background:rgba(255,255,255,.1);
  color:#fff;font-size:1.35rem;line-height:1;cursor:pointer}
.wld-popup__body{padding:16px;overflow:auto}
.wld-questlog{inset:18px;left:18px;top:18px;right:18px;bottom:18px;transform:none;width:auto;max-height:none;
  border-radius:12px;z-index:58}
.wld-questlog .wld-popup__header{cursor:default}
.wld-questlog .wld-popup__body{flex:1;min-height:0;overflow:hidden;padding:18px}

/* Settings: landing menu → sound sub-view */
.wld-settings__menu{display:flex;flex-direction:column;gap:10px}
.wld-settings__menu .wld-btn{text-align:center}
.wld-settings__sound{display:flex;flex-direction:column;gap:18px}
.wld-settings__back{align-self:flex-start;padding:0;border:0;background:none;color:var(--wld-gold);
  font:inherit;font-size:.82rem;font-weight:600;cursor:pointer}
.wld-setting{display:flex;flex-direction:column;gap:7px}
.wld-setting__label{display:flex;justify-content:space-between;font-size:.85rem;font-weight:600}
.wld-setting__label output{color:var(--wld-gold);font-variant-numeric:tabular-nums}
.wld-setting__slider{width:100%;accent-color:var(--wld-violet);cursor:pointer}
.wld-setting__hint{color:var(--wld-muted);font-size:.7rem}

/* Graphics quality sub-view */
.wld-settings__graphics{display:flex;flex-direction:column;gap:14px}
.wld-gfx-options{display:flex;flex-direction:column;gap:10px}
.wld-gfx-opt{text-align:left;line-height:1.25}
.wld-gfx-opt small{display:block;color:var(--wld-muted);font-size:.68rem;font-weight:400;margin-top:2px}
.wld-gfx-opt.is-active{border-color:var(--wld-gold);background:rgba(212,175,55,.14);color:#fff}
.wld-gfx-opt.is-active small{color:rgba(255,255,255,.7)}

/* Keyboard-shortcuts sub-view */
.wld-settings__keys{display:flex;flex-direction:column;gap:12px}
.wld-keys-list{display:flex;flex-direction:column;gap:8px;max-height:46vh;overflow-y:auto;padding-right:4px}
.wld-key-row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.wld-key-row__label{font-size:.84rem;font-weight:600}
.wld-key-row__slots{display:flex;align-items:center;gap:6px}
.wld-key-slot{min-width:64px;padding:5px 9px;border:1px solid var(--wld-line);border-radius:7px;
  background:rgba(255,255,255,.05);color:#fff;font:inherit;font-size:.76rem;font-weight:600;cursor:pointer;text-align:center}
.wld-key-slot:hover{border-color:var(--wld-gold)}
.wld-key-slot--add{min-width:34px;color:var(--wld-gold);font-size:1rem;line-height:1}
.wld-key-slot.is-capturing{border-color:var(--wld-violet);background:rgba(139,92,246,.2);color:#fff;animation:wld-keys-pulse 1s ease-in-out infinite}
.wld-key-clear{width:24px;height:24px;border:0;border-radius:6px;background:rgba(229,53,75,.18);
  color:#ff9bab;font:inherit;font-size:.9rem;line-height:1;cursor:pointer}
.wld-key-clear:hover{background:rgba(229,53,75,.34);color:#fff}
@keyframes wld-keys-pulse{0%,100%{opacity:1}50%{opacity:.55}}

/* Pause / ESC menu */
.wld-pause{z-index:50}
.wld-pause__actions{display:flex;flex-direction:column;gap:10px;margin-top:8px}
.wld-pause__actions .wld-btn{text-align:center}

/* ── Dialogue box (bottom-centre) ──────────────────────────────────────── */
.wld-dialogue{position:fixed;left:50%;bottom:54px;transform:translateX(-50%);z-index:25;width:min(760px,92vw);
  background:rgba(12,13,18,.94);border:1px solid var(--wld-line);border-radius:16px;
  padding:20px 24px 16px;box-shadow:0 24px 60px rgba(0,0,0,.55);cursor:pointer}
.wld-dialogue__speaker{color:var(--wld-red);font-weight:800;letter-spacing:.04em;font-size:.95rem;margin-bottom:8px}
.wld-dialogue__text{color:#ececef;line-height:1.6;font-size:1.05rem;min-height:3.2em}
.wld-dialogue__hint{text-align:right;color:var(--wld-muted);font-size:.78rem;margin-top:8px}
/* Dialogue choice menu (Meyra's Archivar etc.) */
.wld-dialogue__choices{display:flex;flex-direction:column;gap:8px;margin-top:12px}
.wld-dialogue__choice{display:flex;align-items:center;gap:10px;width:100%;text-align:left;cursor:pointer;
  border:1px solid rgba(232,176,75,.4);background:rgba(255,255,255,.04);color:#ececef;
  border-radius:11px;padding:11px 14px;font:inherit;font-size:.98rem;transition:transform .12s,background .12s,border-color .12s}
.wld-dialogue__choice:hover{background:rgba(232,176,75,.16);border-color:var(--wld-gold);transform:translateY(-1px)}
.wld-dialogue__choice-key{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto;
  width:22px;height:22px;border-radius:6px;background:var(--wld-gold);color:#10110a;font-weight:800;font-size:.82rem}

/* ── Archivar editor (Meyra: edit & save profile / AGOS) ───────────────────── */
.wld-archivist{width:min(460px,calc(100vw - 32px));z-index:48}
.wld-archivist__body{display:flex;flex-direction:column;gap:14px}
.wld-archivist__fields{display:flex;flex-direction:column;gap:13px}
.wld-archivist__field{display:flex;flex-direction:column;gap:5px}
.wld-archivist__label{font-size:.82rem;font-weight:700;letter-spacing:.02em;color:var(--wld-gold)}
.wld-archivist__input{width:100%;box-sizing:border-box;background:rgba(255,255,255,.05);color:#fff;
  border:1px solid rgba(255,255,255,.16);border-radius:9px;padding:9px 11px;font:inherit;font-size:.95rem}
.wld-archivist__input:focus{outline:none;border-color:var(--wld-gold);background:rgba(255,255,255,.08)}
textarea.wld-archivist__input{resize:vertical;min-height:64px;line-height:1.5}
.wld-archivist__note{color:var(--wld-muted);font-size:.72rem}
.wld-archivist__empty{color:var(--wld-muted);font-size:.92rem;line-height:1.55}
.wld-archivist__status{font-size:.85rem;font-weight:600}
.wld-archivist__status[data-kind="error"]{color:var(--wld-red)}
.wld-archivist__status[data-kind="success"]{color:#56d364}
.wld-archivist__status[data-kind="info"]{color:var(--wld-muted)}
.wld-archivist__actions{display:flex;gap:10px;justify-content:flex-end}
.wld-btn[disabled]{opacity:.5;cursor:not-allowed;transform:none}

/* ── Death screen ──────────────────────────────────────────────────────── */
.wld-death{position:fixed;inset:0;z-index:60;
  background:#080000 url('/world/assets/loading-screen.png') center center/cover no-repeat;
  display:flex;align-items:center;justify-content:center;
  opacity:0;transition:opacity .4s ease;pointer-events:none}
.wld-death::before{content:"";position:absolute;inset:0;background:rgba(0,0,0,.58)}
.wld-death.is-on{opacity:1}
.wld-death.is-fadeout{transition:opacity .8s ease;opacity:0}
.wld-death__text{position:relative;z-index:1;color:#ff6b6b;font-weight:800;letter-spacing:.04em;text-align:center;
  font-size:clamp(2.2rem,8vw,4.5rem);text-shadow:0 0 30px rgba(255,80,80,.5);
  opacity:0;transform:scale(.96);transition:opacity .6s ease,transform .6s ease}
.wld-death.is-on .wld-death__text{opacity:1;transform:scale(1)}

/* Loading */
.wld-loading{position:fixed;inset:0;z-index:40;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;
  background:#080000 url('/world/assets/loading-screen.png') center center/cover no-repeat;overflow:hidden}
.wld-loading::before{content:"";position:absolute;inset:0;background:rgba(8,0,0,.18)}
.wld-loading::after{content:"";position:absolute;inset:-5%;z-index:0;pointer-events:none;opacity:0;
  background:
    linear-gradient(90deg,rgba(177,55,255,.48),transparent 18%,transparent 78%,rgba(115,57,255,.42)),
    repeating-linear-gradient(0deg,transparent 0 7px,rgba(204,142,255,.16) 7px 10px,transparent 10px 31px);
  mix-blend-mode:screen;animation:wld-loading-violet-flicker 6s steps(1,end) infinite}
.wld-loading>*{position:relative;z-index:1}    /* keep text + spinner above the dim overlay */
/* loading text — same display font as the in-game "+1 EXP" popup */
.wld-loading__lead,.wld-loading__title,.wld-loading__sub{
  font-family:Impact,Haettenschweiler,"Arial Narrow Bold",sans-serif;font-weight:400;color:#ffd36b;
  text-shadow:0 2px 4px #000,0 0 18px rgba(229,129,0,.9);text-align:center;line-height:1}
.wld-loading__lead{font-size:clamp(1.15rem,3.4vw,1.75rem);letter-spacing:.04em}
.wld-loading__title{font-size:clamp(1.7rem,5vw,2.8rem);letter-spacing:.1em;margin-top:2px}
.wld-loading__sub{font-size:clamp(.85rem,2.5vw,1.4rem);letter-spacing:.4em;margin-top:-8px;opacity:.92}
.wld-loading__progress{width:min(420px,72vw);height:10px;border-radius:999px;overflow:hidden;
  background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);
  box-shadow:0 2px 10px rgba(0,0,0,.55),0 0 18px rgba(139,92,246,.26)}
.wld-loading__progress span{display:block;width:0;height:100%;border-radius:inherit;
  background:linear-gradient(90deg,#6d28d9,#a855f7,#f0abfc);
  box-shadow:0 0 18px rgba(192,132,252,.8);transition:width .35s ease}
.wld-loading__status{width:min(520px,82vw);min-height:16px;color:#fff;font-size:.72rem;font-weight:600;
  text-align:center;letter-spacing:.03em;text-shadow:0 1px 4px #000}
.wld-loading__log{width:min(520px,82vw);min-height:42px;color:rgba(255,255,255,.82);
  font:11px/1.35 "Consolas",ui-monospace,monospace;text-align:center;text-shadow:0 1px 3px #000;white-space:pre-line}
.wld-spinner{position:relative;z-index:1;width:42px;height:42px;border-radius:50%;
  border:4px solid rgba(255,255,255,.35);border-top-color:var(--wld-red);
  box-shadow:0 0 22px rgba(229,53,75,.72);animation:wld-spin .8s linear infinite}
@keyframes wld-spin{to{transform:rotate(360deg)}}
@keyframes wld-loading-violet-flicker{
  0%,88%,100%{opacity:0;transform:translate3d(0,0,0) scale(1)}
  89%{opacity:.75;transform:translate3d(-7px,3px,0) scale(1.015)}
  90%{opacity:.18;transform:translate3d(5px,-2px,0) scale(1.006)}
  91%{opacity:.62;transform:translate3d(2px,5px,0) scale(1.012)}
  92%{opacity:0}
}

/* Mobile */
.wld-mobile-only{display:none}
@media (max-width:820px){
  .wld-mobile-only{display:block}
  .wld-help{display:none !important}
  .wld-level{padding-top:env(safe-area-inset-top)}
  .wld-level__text{height:36px;gap:6px;padding:0 7px;font-size:.6rem;letter-spacing:.025em}
  .wld-level__next{display:none}
  .wld-level__track{height:6px}
  .wld-stats{top:max(8px,env(safe-area-inset-top));left:max(8px,env(safe-area-inset-left));
    min-width:205px;padding:8px 10px;transform:scale(.9);transform-origin:top left}
  .wld-minimap{top:max(8px,env(safe-area-inset-top));right:max(8px,env(safe-area-inset-right));
    width:87px;height:87px}
  .wld-has-level .wld-stats,.wld-has-level .wld-minimap{
    top:max(56px,calc(env(safe-area-inset-top) + 50px))}
  .wld-minimap canvas{width:83px;height:83px}
  .wld-inventory{left:10px;right:auto;top:70px;bottom:auto;width:calc(100vw - 20px);max-height:calc(100vh - 90px)}
  .wld-inventory__content{max-height:calc(100vh - 185px)}
  .wld-inventory__grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .wld-inventory-item img{width:54px;height:54px}
  .wld-popup{width:calc(100vw - 20px)}
  .wld-dialogue{bottom:max(56px,calc(env(safe-area-inset-bottom) + 56px));width:94vw;padding:15px 17px 12px}
  .wld-dialogue__text{font-size:.95rem}
  .wld-prompt{bottom:max(96px,calc(env(safe-area-inset-bottom) + 96px))}
  /* compact icon chips + lift the touch pads just above them */
  .wld-bottombar{gap:8px;padding:6px 8px calc(6px + env(safe-area-inset-bottom))}
  .wld-bar-btn{width:38px;height:38px}
  .wld-bar-btn__icon{font-size:1.1rem}
  .wld-touch-stick{bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px))}
  .wld-touch-btn--action{bottom:max(228px,calc(env(safe-area-inset-bottom) + 228px))}
  .wld-touch-btn--jump{bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px))}
}
@media (max-width:620px) and (orientation:portrait){
  .wld-touch-stick{width:116px;height:116px;bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px))}
  .wld-touch-stick__knob{width:52px;height:52px;margin:-26px 0 0 -26px}
  .wld-touch-btn--action{width:76px;height:76px;bottom:max(228px,calc(env(safe-area-inset-bottom) + 228px))}
  .wld-touch-btn--jump{right:max(31px,calc(env(safe-area-inset-right) + 31px));
    bottom:max(140px,calc(env(safe-area-inset-bottom) + 140px))}
}
/* Smartphone in LANDSCAPE (short viewport): compact, thumb-friendly touch HUD.
   Move (left stick) and cast (right action button) stay on opposite sides and use
   independent pointers, so running + shooting at the same time is always possible. */
@media (orientation:landscape) and (max-height:500px){
  /* life bar: hide the profile picture + username on small phone displays */
  .wld-player-card,
  .wld-player-card__avatar{display:none}
  .wld-stats{min-width:0}
  /* left movement pad: 25% smaller and a bit lower */
  .wld-touch-stick{width:99px;height:99px;
    bottom:max(80px,calc(env(safe-area-inset-bottom) + 80px))}
  .wld-touch-stick__knob{width:44px;height:44px;margin:-22px 0 0 -22px}
  /* right: jump + cast side by side (horizontal) and a bit lower */
  .wld-touch-btn--action{right:max(24px,env(safe-area-inset-right));
    bottom:max(80px,calc(env(safe-area-inset-bottom) + 80px))}
  .wld-touch-btn--jump{right:max(122px,calc(env(safe-area-inset-right) + 122px));
    bottom:max(80px,calc(env(safe-area-inset-bottom) + 80px))}
}

/* Damage feedback: short RGB split, scanline tear and cyberpunk flicker. */
.wld-damage-fx{--wld-hit-x:7px;--wld-hit-x-neg:-7px;--wld-hit-x-half:3.5px;
  --wld-hit-x-neg-half:-3.2px;--wld-hit-y:-1px;--wld-hit-y-neg:1px;
  position:fixed;inset:0;z-index:58;
  overflow:hidden;pointer-events:none;opacity:0;visibility:hidden}
.wld-damage-fx>span{position:absolute;inset:-4%}
.wld-damage-fx__chroma{mix-blend-mode:screen;opacity:0}
.wld-damage-fx__chroma--red{
  background:
    linear-gradient(90deg,rgba(255,0,26,.82),transparent 19%,transparent 76%,rgba(255,0,45,.72)),
    linear-gradient(0deg,transparent 0 31%,rgba(255,12,35,.48) 31% 42%,transparent 42% 73%,
      rgba(145,0,18,.55) 73% 81%,transparent 81%);
  transform:translateX(var(--wld-hit-x))}
.wld-damage-fx__chroma--cyan{
  background:linear-gradient(90deg,rgba(0,214,255,.22),transparent 22%,transparent 88%,rgba(0,214,255,.25));
  transform:translateX(var(--wld-hit-x-neg))}
.wld-damage-fx__scanlines{
  background:repeating-linear-gradient(0deg,rgba(0,0,0,.34) 0 2px,transparent 2px 5px);
  mix-blend-mode:multiply;opacity:0}
.wld-damage-fx__flash{
  background:
    linear-gradient(transparent 0 18%,rgba(255,20,83,.3) 18% 23%,transparent 23% 61%,
      rgba(255,0,30,.52) 61% 68%,transparent 68%),
    radial-gradient(circle at 50% 50%,rgba(130,0,8,.12) 10%,rgba(255,0,35,.32) 58%,rgba(95,0,15,.82) 100%);
  mix-blend-mode:screen;opacity:0}
.wld-damage-fx.is-on{visibility:visible;animation:wld-damage-visibility .82s steps(1,end) both}
.wld-damage-fx.is-on .wld-damage-fx__chroma--red{animation:wld-damage-red .82s steps(2,end) both}
.wld-damage-fx.is-on .wld-damage-fx__chroma--cyan{animation:wld-damage-cyan .82s steps(2,end) both}
.wld-damage-fx.is-on .wld-damage-fx__scanlines{animation:wld-damage-scan .82s steps(3,end) both}
.wld-damage-fx.is-on .wld-damage-fx__flash{animation:wld-damage-flash .82s steps(2,end) both}
body.wld-damage-active .wld-canvas{animation:wld-damage-shake .82s steps(2,end) both}
body.wld-damage-active .wld-canvas canvas{animation:wld-damage-color .82s steps(2,end) both}
@keyframes wld-damage-visibility{
  0%,12%,27%,43%,61%,76%{opacity:1} 7%,21%,36%,54%,70%,100%{opacity:0}
}
@keyframes wld-damage-red{
  0%{opacity:1;transform:translate(var(--wld-hit-x),var(--wld-hit-y))}
  35%{opacity:.78;transform:translate(var(--wld-hit-x-neg-half),4px)}
  68%{opacity:.48;transform:translate(4px,-2px)} 100%{opacity:0}
}
@keyframes wld-damage-cyan{
  0%{opacity:.82;transform:translate(var(--wld-hit-x-neg),var(--wld-hit-y-neg))}
  34%{opacity:.5;transform:translate(var(--wld-hit-x-half),-2px)}
  72%{opacity:.18;transform:translate(-2px,1px)} 100%{opacity:0}
}
@keyframes wld-damage-scan{
  0%{opacity:.75;transform:translateY(-5px)} 48%{opacity:.42;transform:translateY(4px)} 100%{opacity:0}
}
@keyframes wld-damage-flash{
  0%{opacity:1;transform:translateY(var(--wld-hit-y))}
  24%{opacity:.62;transform:translateY(10px)} 55%{opacity:.9;transform:translateY(-6px)} 100%{opacity:0}
}
@keyframes wld-damage-shake{
  0%{transform:translate(var(--wld-hit-x),var(--wld-hit-y))}
  18%{transform:translate(-9px,4px)} 38%{transform:translate(7px,-4px)}
  58%{transform:translate(-5px,3px)} 78%{transform:translate(2px,-1px)} 100%{transform:none}
}
@keyframes wld-damage-color{
  0%{filter:sepia(.35) contrast(1.7) saturate(2.8) hue-rotate(-18deg)}
  30%{filter:sepia(.22) contrast(1.4) saturate(2.2) hue-rotate(-8deg)}
  68%{filter:contrast(1.18) saturate(1.55)} 100%{filter:none}
}

/* Portal reuses the exact damage-flicker mechanism and timing. Only its palette
   and the continuously increasing 150% zoom differ. */
.wld-portal-damage-fx{z-index:80}
.wld-portal-damage-fx__violet{background:
  linear-gradient(90deg,rgba(184,64,255,.86),transparent 20%,transparent 72%,rgba(139,58,255,.78)),
  linear-gradient(0deg,transparent 0 18%,rgba(184,64,255,.62) 18% 34%,transparent 34% 57%,
    rgba(124,43,230,.72) 57% 74%,transparent 74%)}
.wld-portal-damage-fx__blue{background:
  linear-gradient(90deg,rgba(144,216,255,.78),transparent 24%,transparent 68%,rgba(177,231,255,.88)),
  linear-gradient(0deg,transparent 0 29%,rgba(137,211,255,.68) 29% 47%,transparent 47% 69%,
    rgba(190,235,255,.72) 69% 85%,transparent 85%)}
.wld-portal-damage-fx__scanlines{background:
  repeating-linear-gradient(0deg,rgba(76,20,130,.42) 0 7px,transparent 7px 18px,
    rgba(126,211,255,.32) 18px 31px,transparent 31px 54px)}
.wld-portal-damage-fx__flash{background:
  linear-gradient(transparent 0 14%,rgba(151,217,255,.62) 14% 29%,transparent 29% 48%,
    rgba(184,64,255,.7) 48% 67%,transparent 67% 78%,rgba(197,236,255,.58) 78% 91%,transparent 91%),
  radial-gradient(circle at 50% 50%,rgba(154,220,255,.18),rgba(153,51,232,.38) 60%,rgba(35,8,70,.78))}
.wld-portal-damage-fx.is-on{visibility:visible;animation:wld-portal-intensity 3s linear both}
.wld-portal-damage-fx.is-on .wld-portal-damage-fx__violet{
  animation:wld-damage-red .82s steps(2,end) infinite}
.wld-portal-damage-fx.is-on .wld-portal-damage-fx__blue{
  animation:wld-damage-cyan .82s steps(2,end) infinite}
.wld-portal-damage-fx.is-on .wld-portal-damage-fx__scanlines{
  animation:wld-damage-scan .82s steps(3,end) infinite}
.wld-portal-damage-fx.is-on .wld-portal-damage-fx__flash{
  animation:wld-damage-flash .82s steps(2,end) infinite}
body.wld-portal-active .wld-canvas{transform-origin:center;
  animation:wld-portal-zoom 3s linear both}
body.wld-portal-active .wld-canvas canvas{transform-origin:center;
  animation:wld-portal-damage-canvas .82s steps(2,end) infinite}
@keyframes wld-portal-damage-canvas{
  0%{transform:translate(var(--wld-hit-x),var(--wld-hit-y));
    filter:contrast(1.5) saturate(2.2) hue-rotate(25deg)}
  18%{transform:translate(-16px,6px) skewX(2deg);
    filter:brightness(1.2) contrast(1.8) saturate(2.7) hue-rotate(68deg)}
  38%{transform:translate(14px,-6px) skewX(-3deg);
    filter:contrast(2.1) saturate(3.1) hue-rotate(128deg)}
  58%{transform:translate(-11px,5px) skewX(3deg);
    filter:brightness(1.35) contrast(2.3) saturate(3.4) hue-rotate(206deg)}
  78%{transform:translate(7px,-3px) skewX(-2deg);
    filter:contrast(1.9) saturate(2.8) hue-rotate(282deg)}
  100%{transform:none;filter:contrast(1.35) saturate(1.8) hue-rotate(330deg)}
}
@media (prefers-reduced-motion:reduce){
  body.wld-damage-active .wld-canvas,
  body.wld-damage-active .wld-canvas canvas{animation:none}
  .wld-damage-fx.is-on{animation:wld-damage-reduced .28s ease-out both}
  .wld-damage-fx.is-on .wld-damage-fx__chroma,
  .wld-damage-fx.is-on .wld-damage-fx__scanlines,
  .wld-damage-fx.is-on .wld-damage-fx__flash{animation:none;opacity:.28}
}
@keyframes wld-damage-reduced{from{opacity:1} to{opacity:0}}

/* BETA version label — bottom-left, bold Impact, always on top, never blocks input. */
.wld-version{position:fixed;left:14px;bottom:10px;z-index:90;pointer-events:none;user-select:none;
  font-family:Impact,Haettenschweiler,"Franklin Gothic Bold","Arial Narrow Bold",sans-serif;
  font-weight:700;font-size:clamp(1.05rem,2.6vw,1.5rem);letter-spacing:.06em;line-height:1;
  color:#fff;text-shadow:0 2px 5px rgba(0,0,0,.9),0 0 2px rgba(0,0,0,.95)}

/* ── Admin-Bereich + Quest-Editor (nur user.id 1) ──────────────────────────── */
.wld-btn--admin{border-color:var(--wld-gold);color:var(--wld-gold)}
.wld-btn--admin:hover{box-shadow:0 12px 30px rgba(232,176,75,.25)}
.wld-settings__admin{display:flex;flex-direction:column;gap:10px}
.wld-settings__admin .wld-btn{text-align:center}

.wld-qadmin{position:fixed;inset:0;z-index:90;display:flex;flex-direction:column;
  background:rgba(6,7,10,.97);color:var(--wld-text);font-family:var(--wld-font)}
.wld-qadmin[hidden]{display:none}
.wld-qadmin__bar{display:flex;align-items:center;gap:14px;padding:14px 18px;
  border-bottom:1px solid var(--wld-line);background:rgba(16,17,22,.95)}
.wld-qadmin__title{font-size:1.05rem;font-weight:800;letter-spacing:.02em}
.wld-qadmin__status{flex:1;font-size:.85rem;color:var(--wld-muted)}
.wld-qadmin__status.is-error{color:var(--wld-red)}
.wld-qadmin__close{cursor:pointer;background:none;border:none;color:var(--wld-text);
  font-size:1.7rem;line-height:1;padding:0 6px}
.wld-qadmin__body{flex:1;display:flex;min-height:0}
.wld-qadmin__list{width:260px;flex-shrink:0;border-right:1px solid var(--wld-line);
  overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.wld-qadmin__item{display:flex;flex-direction:column;gap:2px;text-align:left;cursor:pointer;
  border:1px solid var(--wld-line);background:rgba(255,255,255,.03);color:var(--wld-text);
  border-radius:10px;padding:10px 12px;font:inherit}
.wld-qadmin__item:hover{background:rgba(255,255,255,.06)}
.wld-qadmin__item.is-active{border-color:var(--wld-gold);background:rgba(232,176,75,.10)}
.wld-qadmin__item-title{font-weight:700;font-size:.92rem}
.wld-qadmin__item-id{font-size:.72rem;color:var(--wld-muted)}
.wld-qadmin__add{margin-top:auto;text-align:center}
.wld-qadmin__empty,.wld-qadmin__hint{color:var(--wld-muted);font-size:.88rem;padding:8px}
.wld-qadmin__edit{flex:1;overflow-y:auto;padding:18px 22px}
.wld-qa-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px 18px;max-width:860px}
.wld-qa-field{display:flex;flex-direction:column;gap:5px;font-size:.82rem;color:var(--wld-muted)}
.wld-qa-field--full{grid-column:1/-1}
.wld-qa-field input,.wld-qa-field select,.wld-qa-field textarea{
  font:inherit;color:var(--wld-text);background:rgba(255,255,255,.04);
  border:1px solid var(--wld-line);border-radius:9px;padding:9px 11px}
.wld-qa-field input:focus,.wld-qa-field select:focus,.wld-qa-field textarea:focus{
  outline:none;border-color:var(--wld-gold)}
.wld-qa-field textarea{resize:vertical}
.wld-qa-check{display:flex;align-items:center;gap:8px;color:var(--wld-text);font-size:.9rem}
.wld-qa-check input{width:auto}
.wld-qa-sub{display:flex;flex-direction:column;gap:10px;border:1px dashed var(--wld-line);
  border-radius:10px;padding:12px}
.wld-qa-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.wld-qa-here{align-self:flex-start;padding:9px 16px}
.wld-qa-actions{margin-top:18px;max-width:860px}
.wld-qa-delete{border-color:var(--wld-red);color:var(--wld-red)}
.wld-qa-delete:hover{background:rgba(229,53,75,.12)}
@media (max-width:720px){
  .wld-qadmin__body{flex-direction:column}
  .wld-qadmin__list{width:auto;max-height:34vh;border-right:none;border-bottom:1px solid var(--wld-line)}
  .wld-qa-grid{grid-template-columns:1fr}
  .wld-qa-row{grid-template-columns:1fr 1fr}
}

/* ── "Quest annehmen" popup ────────────────────────────────────────────────── */
.wld-questoffer{z-index:56}
.wld-questoffer__panel{max-width:460px;text-align:left}
.wld-questoffer__title{margin:0 0 10px;font-size:1.5rem;font-weight:800;color:var(--wld-gold)}
.wld-questoffer__desc{margin:0 0 18px;color:var(--wld-text);line-height:1.5;font-size:.95rem}
.wld-questoffer__meta{display:flex;flex-direction:column;gap:10px;margin:0 0 22px;
  border-top:1px solid var(--wld-line);padding-top:16px}
.wld-questoffer__meta>div{display:flex;justify-content:space-between;gap:14px;align-items:baseline}
.wld-questoffer__meta dt{color:var(--wld-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.08em}
.wld-questoffer__meta dd{margin:0;text-align:right;font-weight:600;font-size:.92rem}
.wld-questoffer__actions{display:flex;gap:12px}
.wld-questoffer__actions .wld-btn{flex:1;text-align:center}
