:root{color-scheme:dark;--bg: #06070c;--bg-card: rgba(20, 24, 38, .78);--border: rgba(255, 255, 255, .085);--text: #f0f2f8;--text-muted: #8d95ab;--accent: #6b8cff;--accent-2: #a78bfa;--accent-warm: #f0b86e;--accent-soft: color-mix(in srgb, var(--accent) 14%, transparent);--accent-glow: color-mix(in srgb, var(--accent) 38%, transparent);--shadow-lg: 0 28px 90px rgba(0, 0, 0, .58);--radius-lg: 20px;--radius-sm: 8px;--font: "DM Sans", system-ui, -apple-system, "Segoe UI", sans-serif;--ease: cubic-bezier(.22, 1, .36, 1);--page-padding-x: 40px;--header-padding-y: 24px}*,*:before,*:after{box-sizing:border-box}html,body{margin:0;min-height:100%;min-height:100dvh;overflow-x:hidden;background:var(--bg);color:var(--text);font-family:var(--font);-webkit-font-smoothing:antialiased}button,input{font:inherit}*:focus-visible{outline:2px solid var(--accent);outline-offset:2px}button:focus:not(:focus-visible){outline:none}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.auth-page{position:relative;display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;overflow-x:hidden;overflow-y:auto}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:hidden}.auth-bg-glow{position:absolute;border-radius:50%;opacity:.45}.auth-bg-glow--1{width:520px;height:520px;top:-120px;left:-80px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 45%,transparent),transparent 70%)}.auth-bg-glow--2{width:480px;height:480px;bottom:-100px;right:-60px;background:radial-gradient(circle,color-mix(in srgb,var(--accent-2) 35%,transparent),transparent 70%)}.auth-bg-glow--warm{width:360px;height:360px;top:38%;left:42%;opacity:.22;background:radial-gradient(circle,color-mix(in srgb,var(--accent-warm) 40%,transparent),transparent 70%)}.auth-bg-grid{position:absolute;top:0;right:0;bottom:0;left:0;background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);background-size:32px 32px;-webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,black 20%,transparent 100%);mask-image:radial-gradient(ellipse 80% 70% at 50% 40%,black 20%,transparent 100%)}.auth-header{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;padding:var(--header-padding-y) var(--page-padding-x);padding-top:max(var(--header-padding-y),env(safe-area-inset-top,0px));padding-left:max(var(--page-padding-x),env(safe-area-inset-left,0px));padding-right:max(var(--page-padding-x),env(safe-area-inset-right,0px))}.auth-header-start{display:flex;align-items:center;gap:16px;min-width:0;flex:1 1 auto}.auth-header-end{display:flex;align-items:center;gap:10px;flex-shrink:0;min-width:0}.btn-site-switch,.btn-logout{display:inline-flex;align-items:center;justify-content:center;box-sizing:border-box;height:36px;padding:0 14px;margin:0;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:var(--text-muted);font-family:inherit;font-size:13px;font-weight:600;line-height:1;white-space:nowrap;transition:border-color .2s var(--ease),color .2s var(--ease),background .2s var(--ease)}.btn-site-switch{flex-shrink:1;min-width:0;max-width:min(220px,46vw);overflow:hidden;text-overflow:ellipsis;cursor:pointer;text-decoration:none}.btn-site-switch:hover{color:var(--text);border-color:#ffffff2e;background:#ffffff14}.btn-logout{flex-shrink:0;cursor:pointer}.btn-logout:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));color:var(--text);background:#ffffff0f}.auth-header--world{margin-bottom:8px}.auth-header-logo{display:flex;align-items:center}.auth-logo-badge{display:grid;place-items:center;width:48px;height:40px;border-radius:11px;background:linear-gradient(135deg,var(--accent),var(--accent-2));font-size:12px;font-weight:700;letter-spacing:.04em;color:#fff;box-shadow:0 8px 24px var(--accent-glow);-webkit-user-select:none;user-select:none}.auth-header-badge{flex-shrink:0;font-size:12px;font-weight:500;color:var(--text-muted);padding:6px 12px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.auth-header-user{display:flex;align-items:center;gap:12px}.auth-header-username{font-size:14px;color:var(--text-muted)}.auth-ghost-btn{border:1px solid var(--border);border-radius:999px;padding:8px 14px;background:#ffffff0a;color:var(--text-muted);font-size:13px;font-weight:600;cursor:pointer;text-decoration:none;display:inline-block;transition:border-color .2s var(--ease),color .2s var(--ease)}.auth-ghost-btn:hover{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));color:var(--text)}.auth-site-switch{max-width:min(200px,40vw);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.auth-main{position:relative;z-index:1;flex:1;display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);align-items:center;gap:clamp(24px,5vw,64px);width:100%;max-width:1080px;margin:0 auto;padding:16px var(--page-padding-x) 48px}.auth-showcase{animation:fade-up .7s var(--ease) both}.auth-showcase--player .auth-eyebrow{color:var(--accent-warm)}.auth-showcase-icon{display:grid;place-items:center;width:56px;height:56px;margin-bottom:20px;border-radius:16px;border:1px solid var(--border);background:#ffffff0a;color:var(--accent);box-shadow:0 12px 40px #00000040}.auth-showcase-icon svg{width:28px;height:28px}.auth-showcase-icon--player{color:var(--accent-warm);background:linear-gradient(135deg,color-mix(in srgb,var(--accent-warm) 18%,transparent),color-mix(in srgb,var(--accent) 10%,transparent))}.auth-eyebrow{margin:0 0 12px;font-size:12px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}.auth-title{margin:0 0 16px;font-family:var(--font);font-size:clamp(2rem,4.5vw,3rem);font-weight:700;line-height:1.08;letter-spacing:-.03em}.auth-title span{background:linear-gradient(135deg,var(--accent-warm) 0%,var(--accent) 45%,var(--accent-2) 100%);-webkit-background-clip:text;background-clip:text;color:transparent}.auth-subtitle{margin:0 0 24px;max-width:460px;font-size:16px;line-height:1.65;color:var(--text-muted)}.auth-features{margin:0;padding:0;list-style:none;display:grid;gap:10px}.auth-features li{position:relative;padding-left:22px;color:var(--text-muted);font-size:14px;line-height:1.5}.auth-features li:before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:2px;background:linear-gradient(135deg,var(--accent-warm),var(--accent))}.auth-panel{animation:fade-up .7s var(--ease) .1s both}.auth-card{position:relative;width:min(100%,420px);margin-left:auto;padding:28px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg)}.auth-card:before{content:"";position:absolute;inset:0 0 auto;height:3px;border-radius:var(--radius-lg) var(--radius-lg) 0 0;background:linear-gradient(90deg,var(--accent-warm),var(--accent),var(--accent-2));opacity:.85}.auth-tabs{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-bottom:20px;padding:4px;border-radius:12px;border:1px solid var(--border);background:#0003}.auth-tab{border:none;border-radius:9px;padding:10px 12px;background:transparent;color:var(--text-muted);font-size:14px;font-weight:600;cursor:pointer;transition:background .2s var(--ease),color .2s var(--ease),box-shadow .2s var(--ease)}.auth-tab.is-active{background:#ffffff14;color:var(--text);box-shadow:0 4px 14px #0003}.auth-card-head{margin-bottom:20px}.auth-card-head h2{margin:0 0 6px;font-size:24px;font-weight:700;letter-spacing:-.02em}.auth-card-head p{margin:0;color:var(--text-muted);font-size:14px;line-height:1.5}.auth-error{margin:0 0 16px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid color-mix(in srgb,#ff7b8d 35%,transparent);background:color-mix(in srgb,#ff7b8d 10%,transparent);color:#ff9aab;font-size:14px}.auth-form{display:grid;gap:14px}.auth-field{display:grid;gap:6px}.auth-field span{color:var(--text-muted);font-size:13px;font-weight:500}.auth-field input{width:100%;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#00000047;color:var(--text);transition:border-color .2s var(--ease),box-shadow .2s var(--ease)}.auth-field input::placeholder{color:color-mix(in srgb,var(--text-muted) 70%,transparent)}.auth-field input:hover:not(:disabled){border-color:color-mix(in srgb,var(--accent) 30%,var(--border))}.auth-field input:focus{outline:none;border-color:color-mix(in srgb,var(--accent) 55%,var(--border));box-shadow:0 0 0 3px var(--accent-soft)}.auth-submit{display:inline-flex;align-items:center;justify-content:center;gap:8px;margin-top:4px;border:none;border-radius:12px;padding:13px 18px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent-2) 65%,var(--accent)));color:#fff;font-weight:700;cursor:pointer;box-shadow:0 10px 28px var(--accent-glow);transition:transform .2s var(--ease),box-shadow .2s var(--ease),opacity .2s var(--ease)}.auth-submit--player{background:linear-gradient(135deg,var(--accent-warm),color-mix(in srgb,var(--accent) 70%,var(--accent-warm)));box-shadow:0 10px 28px color-mix(in srgb,var(--accent-warm) 35%,transparent)}.auth-submit:hover:not(:disabled){transform:translateY(-1px)}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-footer{position:relative;z-index:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:20px var(--page-padding-x) max(24px,env(safe-area-inset-bottom,0px));font-size:12px;color:var(--text-muted)}.auth-footer-dot{opacity:.45}.auth-world{position:relative;z-index:1;flex:1;display:grid;place-items:center;padding:24px var(--page-padding-x) 48px}.auth-world-card{position:relative;width:min(100%,560px);padding:40px 32px;border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);text-align:center;overflow:hidden;animation:fade-up .7s var(--ease) both}.auth-world-glow{position:absolute;inset:auto -20% -50% -20%;height:220px;background:radial-gradient(circle,color-mix(in srgb,var(--accent-warm) 30%,transparent),transparent 70%);pointer-events:none}.auth-world-title{position:relative;margin:0 0 14px;font-size:clamp(1.75rem,4vw,2.4rem);font-weight:700;letter-spacing:-.02em}.auth-world-lead{position:relative;margin:0 0 24px;color:var(--text-muted);line-height:1.65;font-size:16px}.auth-world-status{position:relative;display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text-muted);font-size:13px;font-weight:600}.auth-world-status-dot{width:8px;height:8px;border-radius:50%;background:var(--accent-warm);box-shadow:0 0 12px color-mix(in srgb,var(--accent-warm) 60%,transparent);animation:pulse-dot 2s ease-in-out infinite}@keyframes pulse-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.85)}}@media(max-width:900px){.auth-main{grid-template-columns:1fr;max-width:520px;padding-bottom:32px}.auth-showcase{text-align:center}.auth-showcase-icon,.auth-subtitle{margin-inline:auto}.auth-features{max-width:320px;margin-inline:auto;text-align:left}.auth-card{margin-inline:auto}}@media(max-width:640px){.auth-header,.auth-main,.auth-footer,.auth-world{padding-left:max(20px,env(safe-area-inset-left,0px));padding-right:max(20px,env(safe-area-inset-right,0px))}.auth-header-badge{display:none}.btn-site-switch,.btn-logout{height:34px;padding:0 12px;font-size:12px}.btn-site-switch{max-width:min(160px,38vw)}.auth-card,.auth-world-card{padding:22px 20px}}.char-page{min-height:100vh;min-height:100dvh}.char-page-inner{position:relative;z-index:1;flex:1;width:min(1200px,100%);margin:0 auto;padding:24px var(--page-padding-x) 48px}.char-loading,.char-empty-hint{color:var(--text-muted);text-align:center;padding:48px 16px}.char-header{margin-bottom:28px;animation:fade-up .5s var(--ease) both}.char-world-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:12px;flex-wrap:wrap}.char-header-badge{display:inline-block;margin-bottom:8px;font-size:12px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-warm)}.char-header-title{margin:0 0 6px;font-size:clamp(1.6rem,4vw,2.2rem);font-weight:700}.char-header-sub{margin:0;color:var(--text-muted)}.char-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:18px}.char-card{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);overflow:hidden;transition:transform .2s var(--ease),border-color .2s var(--ease),box-shadow .2s var(--ease);animation:fade-up .55s var(--ease) both}.char-card:hover{transform:translateY(-3px);border-color:color-mix(in srgb,var(--accent) 35%,var(--border));box-shadow:var(--shadow-lg)}.char-card-preview{position:relative;display:grid;place-items:center;min-height:160px;background:linear-gradient(180deg,rgba(255,255,255,.04),transparent)}.char-card-preview-glow{position:absolute;inset:auto 10% -30% 10%;height:80px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 35%,transparent),transparent 70%)}.char-card-preview-sprite,.char-preview-stack,.char-preview-layer{image-rendering:pixelated;image-rendering:crisp-edges}.char-create-hint{margin:12px 0 0;color:var(--text-muted);font-size:13px}.char-preview-base{margin:0;color:var(--text-muted);font-size:13px}.char-appearance-item.is-layered.is-active{box-shadow:0 0 0 2px var(--accent-warm)}.char-card-preview-placeholder,.char-preview-placeholder,.char-world-sprite--fallback{width:72px;height:72px;display:grid;place-items:center;border-radius:16px;background:var(--accent-soft);font-size:28px;font-weight:700}.char-card-level{position:absolute;top:12px;right:12px;padding:4px 10px;border-radius:999px;background:#00000073;border:1px solid var(--border);font-size:12px;font-weight:700}.char-card-body{padding:16px;display:flex;flex-direction:column;gap:10px}.char-card-name{margin:0;font-size:1.15rem}.char-card-meta{display:flex;align-items:center;gap:6px;margin:0;color:var(--text-muted);font-size:13px}.char-card-prof-icon{display:inline-flex;width:22px;height:22px;vertical-align:middle}.char-card-prof-icon .prof-icon{border-radius:6px;border:1px solid color-mix(in srgb,var(--accent-warm) 35%,var(--border));background:#00000040;box-shadow:none}.char-card-prof-icon .prof-icon img{width:85%;height:85%;filter:drop-shadow(0 1px 4px color-mix(in srgb,var(--accent-warm) 40%,transparent))}.char-card-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-muted)}.char-card-stats span{padding:4px 8px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border)}.char-card-play{margin-top:4px;padding:10px 14px;border:none;border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-weight:700;cursor:pointer}.char-card--create{align-items:center;justify-content:center;min-height:280px;cursor:pointer;border-style:dashed;background:#ffffff05;color:var(--text)}.char-card-create-icon{width:56px;height:56px;display:grid;place-items:center;border-radius:50%;border:1px solid var(--border);font-size:28px;color:var(--accent)}.char-card-create-title{margin:12px 0 4px}.char-card-create-hint{margin:0;color:var(--text-muted);font-size:13px}.char-page--create .char-page-inner{max-width:1180px}.cc-wizard{animation:fade-up .45s var(--ease) both}.cc-top{display:flex;align-items:flex-start;gap:20px;margin-bottom:20px}.cc-back{flex-shrink:0;display:inline-flex;align-items:center;gap:6px;padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#ffffff0a;color:var(--text-muted);cursor:pointer;transition:color .15s,border-color .15s,background .15s}.cc-back:hover:not(:disabled){color:var(--text);border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.cc-back:disabled{opacity:.5;cursor:not-allowed}.cc-eyebrow{margin:0 0 6px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--accent)}.cc-heading{margin:0 0 4px;font-size:clamp(1.5rem,3vw,2rem)}.cc-subheading{margin:0;color:var(--text-muted);font-size:15px}.cc-progress{height:4px;border-radius:999px;background:#ffffff0f;overflow:hidden;margin-bottom:18px}.cc-progress-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2));transition:width .35s var(--ease)}.cc-steps{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px;margin-bottom:22px}.cc-step{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:12px;border:1px solid transparent;color:var(--text-muted);font-size:13px}.cc-step.is-active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 40%,var(--border));background:var(--accent-soft)}.cc-step.is-done{color:var(--accent-warm)}.cc-step-dot{width:26px;height:26px;flex-shrink:0;display:grid;place-items:center;border-radius:50%;background:#ffffff0f;font-size:12px;font-weight:800}.cc-step.is-active .cc-step-dot{background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff}.cc-step.is-done .cc-step-dot{background:color-mix(in srgb,var(--accent-warm) 25%,transparent);color:var(--accent-warm)}.cc-step-label{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-layout{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,340px);gap:22px;align-items:start}.cc-panel{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:var(--shadow-lg);overflow:hidden}.cc-error{margin:20px 20px 0}.cc-panel-body{padding:24px;min-height:320px}.cc-section-desc{margin:0 0 18px;color:var(--text-muted);font-size:14px;line-height:1.55}.cc-section-label{display:block;margin:0 0 10px;font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.cc-gender-row{margin-bottom:22px}.cc-gender-tabs{display:grid;grid-template-columns:1fr 1fr;gap:10px}.cc-gender-tab{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border:1px solid var(--border);border-radius:12px;background:#ffffff08;color:var(--text-muted);cursor:pointer;transition:border-color .15s,background .15s,color .15s}.cc-gender-tab.is-active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 50%,var(--border));background:var(--accent-soft)}.cc-gender-icon{font-size:18px}.cc-tile-grid{display:grid;gap:12px}.cc-tile-grid--skin{grid-template-columns:repeat(auto-fill,minmax(108px,1fr))}.cc-tile-grid--appearance{grid-template-columns:repeat(auto-fill,minmax(92px,1fr));max-height:380px;overflow-y:auto}.cc-tile{display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px;border:1px solid var(--border);border-radius:14px;background:#ffffff05;color:var(--text);cursor:pointer;transition:transform .15s var(--ease),border-color .15s,box-shadow .15s}.cc-tile:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 35%,var(--border))}.cc-tile.is-active{border-color:var(--accent);background:var(--accent-soft);box-shadow:0 8px 28px color-mix(in srgb,var(--accent) 15%,transparent)}.cc-tile--layer.is-active{border-color:var(--accent-warm)}.cc-tile-frame{position:relative;display:grid;place-items:center;min-height:72px;width:100%}.cc-tile-sprite{image-rendering:pixelated;image-rendering:crisp-edges}.cc-tile-fallback{width:52px;height:52px;display:grid;place-items:center;border-radius:12px;background:var(--accent-soft);font-weight:800}.cc-tile-check{position:absolute;top:2px;right:2px;width:20px;height:20px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:11px;font-weight:800}.cc-tile-name{font-size:11px;color:var(--text-muted);text-align:center;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cc-empty{grid-column:1 / -1;padding:28px 16px;text-align:center;color:var(--text-muted);border:1px dashed var(--border);border-radius:14px}.cc-layer-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;padding:10px 14px;border-radius:10px;background:#ffffff08;border:1px solid var(--border)}.cc-layer-count{font-size:13px;color:var(--text-muted)}.cc-layer-count strong{color:var(--accent-warm)}.cc-link-btn{border:none;background:none;color:var(--accent);font-size:13px;font-weight:600;cursor:pointer}.cc-prof-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.cc-prof-card{position:relative;display:flex;gap:14px;padding:16px;border:1px solid var(--border);border-radius:16px;background:#ffffff05;cursor:pointer;text-align:left;color:var(--text);transition:transform .15s,border-color .15s,box-shadow .15s}.cc-prof-card:hover{transform:translateY(-2px)}.cc-prof-card.is-active{border-color:var(--accent);background:var(--accent-soft)}.cc-prof-icon{width:48px;height:48px;flex-shrink:0}.cc-prof-icon .prof-icon{width:100%;height:100%}.prof-icon{display:grid;place-items:center;width:100%;height:100%;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent) 28%,var(--border));background:radial-gradient(circle at 30% 20%,color-mix(in srgb,var(--accent) 18%,transparent),transparent 55%),linear-gradient(160deg,#ffffff12,#00000059);box-shadow:0 4px 14px #00000047,inset 0 1px #ffffff12;overflow:hidden}.prof-icon img{width:72%;height:72%;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges;filter:drop-shadow(0 2px 8px color-mix(in srgb,var(--accent) 45%,transparent))}.cc-prof-card.is-active .prof-icon{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 35%,transparent),0 6px 22px color-mix(in srgb,var(--accent) 22%,transparent)}.cc-chip .prof-icon{display:inline-flex;width:18px;height:18px;border:none;border-radius:4px;background:transparent;box-shadow:none}.cc-chip .prof-icon img{width:100%;height:100%;filter:none}.cc-prof-body{display:flex;flex-direction:column;gap:6px;min-width:0}.cc-prof-body span{color:var(--text-muted);font-size:13px;line-height:1.45}.cc-prof-check{position:absolute;top:12px;right:12px;width:24px;height:24px;display:grid;place-items:center;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;font-size:12px;font-weight:800}.cc-nick-field{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.cc-nick-input-wrap input{width:100%;padding:16px 56px 16px 18px;border:1px solid var(--border);border-radius:14px;background:#00000040;color:var(--text);font-size:1.15rem;font-weight:600}.cc-nick-input-wrap{position:relative}.cc-nick-counter{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:12px;color:var(--text-muted)}.cc-nick-status{min-height:20px;font-size:13px;font-weight:600}.cc-nick-status--idle{color:var(--text-muted);font-weight:500}.cc-nick-status--checking{color:var(--accent)}.cc-nick-status--available{color:#6ee7a8}.cc-nick-status--taken,.cc-nick-status--invalid{color:#f87171}.cc-nick-hint{color:var(--text-muted);font-size:12px}.cc-summary{padding:16px;border-radius:14px;border:1px solid var(--border);background:#ffffff05}.cc-summary-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}.cc-summary-list li{display:flex;justify-content:space-between;font-size:14px}.cc-summary-list span{color:var(--text-muted)}.cc-footer{display:flex;justify-content:space-between;gap:12px;padding:16px 24px;border-top:1px solid var(--border);background:#00000026}.cc-btn-primary{display:inline-flex;align-items:center;gap:8px;min-width:140px;justify-content:center}.cc-hero{position:sticky;top:24px}.cc-hero-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:linear-gradient(165deg,#1c2236f2,#0c0e16eb);box-shadow:var(--shadow-lg);overflow:hidden}.cc-hero-stage{position:relative;display:grid;place-items:center;min-height:260px;padding:24px}.cc-hero-glow{position:absolute;inset:auto 15% 8% 15%;height:90px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 40%,transparent),transparent 70%);pointer-events:none}.cc-hero-stage .char-preview-stack,.cc-hero-stage .char-preview-layer,.cc-hero-stage .char-preview-placeholder{position:relative;z-index:1;image-rendering:pixelated;image-rendering:crisp-edges}.cc-hero-info{padding:20px;border-top:1px solid var(--border)}.cc-hero-name{margin:0 0 12px;font-size:1.35rem;text-align:center}.cc-hero-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.cc-chip{display:inline-flex;align-items:center;gap:5px;padding:5px 10px;border-radius:999px;border:1px solid var(--border);font-size:12px;font-weight:600;color:var(--text-muted)}.cc-chip svg{width:14px;height:14px}.cc-chip .prof-icon{display:inline-flex}.cc-chip--accent{color:var(--accent);border-color:color-mix(in srgb,var(--accent) 35%,var(--border));background:var(--accent-soft)}.cc-chip--warm{color:var(--accent-warm)}.char-world-card{max-width:640px}.char-world-hero{display:grid;place-items:center;margin-bottom:16px}.char-world-stats{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:20px 0}.char-world-stats div{padding:10px;border-radius:10px;border:1px solid var(--border);background:#ffffff08}.char-world-stats span{display:block;font-size:11px;color:var(--text-muted);margin-bottom:4px}.char-world-location{display:grid;gap:8px;margin-bottom:16px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:#ffffff08}.char-world-location p{display:flex;justify-content:space-between;gap:12px;margin:0;font-size:14px}.char-world-location span{color:var(--text-muted)}.game-page--play{overflow:hidden;display:flex;flex-direction:column;height:100dvh;max-height:100dvh}.game-page--play .auth-header{position:relative;z-index:5;flex-shrink:0}.game-page--play .auth-footer{display:none}.game-stage{position:relative;flex:1;min-height:0;display:flex;flex-direction:column;padding:0 var(--page-padding-x) 12px}.game-viewport-wrap{position:relative;flex:1;min-height:0;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;background:#0a0c12;box-shadow:var(--shadow-lg)}.game-viewport,.game-map-host{position:absolute;top:0;right:0;bottom:0;left:0}.game-map-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.22) rgba(0,0,0,.15);background-color:#0a0c12;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:24px 24px;outline:none}.game-map-scroll::-webkit-scrollbar{width:8px;height:8px}.game-map-spacer{position:relative;flex-shrink:0}.game-map-canvas{position:absolute;top:0;left:0;z-index:1;display:block;pointer-events:none;image-rendering:pixelated;image-rendering:crisp-edges}.game-toast{position:absolute;left:50%;bottom:88px;transform:translate(-50%);z-index:4;padding:10px 16px;border-radius:12px;border:1px solid color-mix(in srgb,var(--accent-warm) 45%,var(--border));background:#10131ef0;color:var(--accent-warm);font-size:13px;pointer-events:none;animation:fade-up .25s var(--ease) both}.game-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:3}.game-overlay>*{pointer-events:auto}.game-overlay-top{position:absolute;top:14px;left:14px;right:14px;display:flex;align-items:center;gap:10px;flex-wrap:wrap}.game-back-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:#0c0e16d1;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text);cursor:pointer;font-size:13px;font-weight:600;transition:border-color .2s var(--ease),background .2s var(--ease)}.game-back-btn:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border));background:#141826eb}.game-location-chip{display:flex;flex-direction:column;gap:2px;padding:8px 14px;border-radius:12px;border:1px solid var(--border);background:#0c0e16c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);min-width:0;flex:1}.game-location-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-warm)}.game-location-chip strong{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-coords-chip{padding:8px 12px;border-radius:999px;border:1px solid var(--border);background:#0c0e16c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.game-player-panel{position:absolute;left:14px;bottom:14px;display:flex;gap:14px;align-items:center;max-width:min(360px,calc(100% - 28px));padding:12px 14px;border-radius:var(--radius-lg);border:1px solid var(--border);background:#10131ee0;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);box-shadow:0 16px 48px #00000073;animation:fade-up .45s var(--ease) both}.game-player-avatar{position:relative;flex-shrink:0;width:72px;height:72px;display:grid;place-items:center;border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.05),transparent);border:1px solid rgba(255,255,255,.06);overflow:hidden}.game-player-avatar-glow{position:absolute;inset:auto 8px -20px 8px;height:40px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 40%,transparent),transparent 70%);pointer-events:none}.game-player-avatar .char-preview-stack{image-rendering:pixelated;image-rendering:crisp-edges}.game-avatar-fallback{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft);color:var(--accent);font-weight:700;font-size:18px}.game-player-body{min-width:0;display:flex;flex-direction:column;gap:6px}.game-player-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.game-player-name{margin:0;font-size:1rem;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.game-player-level{font-size:12px;color:var(--text-muted);flex-shrink:0}.game-player-meta{margin:0;display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted)}.game-player-prof .prof-icon{display:inline-flex;width:18px;height:18px}.game-player-prof .prof-icon img{width:100%;height:100%;object-fit:contain}.game-player-bars{display:flex;gap:8px;flex-wrap:wrap}.game-stat-bar{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:999px;font-size:12px;border:1px solid var(--border);background:#ffffff08}.game-stat-bar span{color:var(--text-muted)}.game-stat-bar--hp strong{color:#8fd4a8}.game-stat-bar--mp strong{color:#8eb8ff}.game-controls-hint{position:absolute;right:14px;bottom:14px;padding:8px 12px;border-radius:12px;border:1px solid var(--border);background:#0c0e16c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:12px;color:var(--text-muted);line-height:1.4}.game-controls-hint kbd{display:inline-block;padding:1px 6px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;font-size:11px;color:var(--text)}.game-controls-dot{margin:0 4px;opacity:.5}.game-controls-transition{color:color-mix(in srgb,#b58cff 75%,var(--text-muted))}.game-loading,.game-error-card{margin:auto;padding:48px 24px;text-align:center;color:var(--text-muted)}.game-error-card h2{margin:0 0 12px;color:var(--text)}@media(max-width:760px){.game-stage{padding:0 10px 10px}.game-overlay-top{top:10px;left:10px;right:10px}.game-controls-hint{display:none}.game-player-panel{left:10px;right:10px;bottom:10px;max-width:none}}.game-page{min-height:100dvh;display:flex;flex-direction:column}.game-page .auth-header{flex-shrink:0}.game-main{flex:1;display:flex;flex-direction:column;min-height:0;padding:0 0 16px}.game-layout{flex:1;display:grid;grid-template-columns:240px 1fr;grid-template-rows:1fr auto;gap:12px;min-height:0;padding:0 var(--page-padding-x)}.game-hud{grid-row:1 / 3;padding:16px;border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);display:flex;flex-direction:column;gap:12px}.game-hud-top{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.game-hud-top strong{font-size:1.1rem}.game-hud-top span{color:var(--text-muted);font-size:13px}.game-hud-map{color:var(--text-muted);font-size:13px;line-height:1.4}.game-hud-stats{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--text-muted)}.game-hud-stats span{padding:4px 8px;border-radius:999px;background:#ffffff0a;border:1px solid var(--border)}.game-hud-hint{margin:auto 0 0;font-size:12px;color:var(--text-muted);line-height:1.45}.game-toolbar{display:flex;justify-content:flex-start}@media(max-width:900px){.game-layout{grid-template-columns:1fr;grid-template-rows:auto 1fr auto}.game-hud{grid-row:auto}}@media(max-width:900px){.cc-layout{grid-template-columns:1fr}.cc-hero{position:static;order:-1}.cc-steps{grid-template-columns:repeat(2,minmax(0,1fr))}.cc-step-label{display:none}}.world-screen{display:flex;flex-direction:column;height:100dvh;max-height:100dvh;overflow:hidden;background:var(--bg)}.world-loading,.world-error{margin:auto;padding:32px;text-align:center;color:var(--text-muted)}.world-error h2{margin:0 0 12px;color:var(--text)}.world-btn{padding:8px 14px;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text);cursor:pointer;font-size:13px;font-weight:600}.world-btn:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border))}.world-stage{flex:1;min-height:0;display:flex;flex-direction:column}.world-map-frame{position:relative;flex:1;min-height:0}.world-map-slot{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden;background:#090b10}.world-map-host{position:relative;width:100%;height:100%}.world-map-scroll{position:absolute;top:0;right:0;bottom:0;left:0;overflow:auto;outline:none;background:#090b10;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.2) transparent;-webkit-overflow-scrolling:touch}.world-map-spacer{flex-shrink:0}.world-map-canvas{position:absolute;top:0;left:0;pointer-events:none;image-rendering:pixelated;image-rendering:crisp-edges}.world-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:2}.world-overlay>*{pointer-events:auto}.world-overlay-top{position:absolute;top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left));right:max(10px,env(safe-area-inset-right));display:flex;align-items:center;gap:8px}.world-icon-btn{flex-shrink:0;width:40px;height:40px;display:grid;place-items:center;border-radius:12px;border:1px solid var(--border);background:#0c0e16e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text);cursor:pointer;font-size:16px;font-weight:700}.world-icon-btn--menu{margin-left:auto}.world-location{flex:1;min-width:0;padding:8px 12px;border-radius:12px;border:1px solid var(--border);background:#0c0e16e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.world-location-label{display:block;font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--accent-warm)}.world-location strong,.world-bar-map{display:block;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.world-hud{position:absolute;left:max(10px,env(safe-area-inset-left));bottom:max(10px,env(safe-area-inset-bottom));display:flex;align-items:center;gap:10px;max-width:min(280px,calc(100% - 130px));padding:8px 12px 8px 8px;border-radius:14px;border:1px solid var(--border);background:#0c0e16e6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);cursor:pointer;text-align:left;color:inherit;font:inherit}.world-hud-avatar{flex-shrink:0;width:44px;height:44px;display:grid;place-items:center;border-radius:10px;background:#ffffff0a;overflow:hidden}.world-hud-avatar .char-preview-stack{image-rendering:pixelated;image-rendering:crisp-edges}.world-hud-avatar-fallback{width:28px;height:28px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft);font-weight:700;font-size:14px}.world-hud-info{min-width:0;display:flex;flex-direction:column;gap:4px}.world-hud-name{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.world-hud-meta{display:flex;align-items:center;gap:4px;font-size:11px;color:var(--text-muted)}.world-hud-meta .prof-icon{width:14px;height:14px}.world-hud-bars{display:flex;flex-direction:column;gap:3px}.world-hud-bar{display:block;height:4px;border-radius:999px;background:#ffffff14;overflow:hidden}.world-hud-bar i{display:block;height:100%;border-radius:inherit;transition:width .2s var(--ease)}.world-hud-bar--hp i{background:linear-gradient(90deg,#b83232,#ff5c5c);box-shadow:0 0 8px #ff464673}.world-hud-bar--mp i{background:linear-gradient(90deg,#3d5fbf,#7ba4ff)}.world-skillbar{position:absolute;left:50%;bottom:max(12px,env(safe-area-inset-bottom));transform:translate(-50%);z-index:3;display:flex;gap:6px;padding:6px;border-radius:16px;border:1px solid var(--border);background:#0a0c14e6;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);box-shadow:0 12px 36px #0006;max-width:calc(100% - 200px);overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.world-skillbar::-webkit-scrollbar{display:none}.world-skill-slot{flex-shrink:0;position:relative;width:52px;height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:4px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:var(--text);cursor:pointer;transition:border-color .15s var(--ease),background .15s var(--ease),transform .12s var(--ease);-webkit-tap-highlight-color:transparent}.world-skill-slot.is-ready{border-color:color-mix(in srgb,var(--accent-warm) 40%,var(--border));background:color-mix(in srgb,var(--accent-warm) 8%,transparent)}.world-skill-slot.is-locked{opacity:.45;cursor:default}.world-skill-slot.is-flash{transform:scale(.94);border-color:var(--accent-warm);background:color-mix(in srgb,var(--accent-warm) 22%,transparent);box-shadow:0 0 16px color-mix(in srgb,var(--accent-warm) 45%,transparent)}.world-skill-slot:not(:disabled):active{transform:scale(.92)}.world-skill-key{position:absolute;top:3px;left:4px;padding:1px 4px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#00000059;font-size:9px;font-weight:800;line-height:1.2;font-family:inherit;color:var(--text-muted)}.world-skill-name{margin-top:8px;font-size:9px;font-weight:700;text-align:center;line-height:1.1;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.world-skill-cost{position:absolute;bottom:3px;right:4px;font-size:8px;font-weight:700;color:#8eb8ff}.world-toast-host{position:absolute;left:50%;bottom:calc(78px + env(safe-area-inset-bottom));transform:translate(-50%);z-index:4;padding:8px 14px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent-warm) 40%,var(--border));background:#0c0e16eb;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);font-size:12px;font-weight:600;color:var(--accent-warm);pointer-events:none;white-space:nowrap;animation:fade-up .2s var(--ease) both}.world-toast-host[hidden]{display:none}.world-dpad{position:absolute;right:max(10px,env(safe-area-inset-right));bottom:max(10px,env(safe-area-inset-bottom));display:grid;grid-template-columns:repeat(3,52px);grid-template-rows:repeat(3,52px);gap:4px;touch-action:manipulation;-webkit-user-select:none;user-select:none}.world-dpad-btn{display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:#0c0e16e0;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:var(--text);cursor:pointer;font-size:16px;line-height:1;-webkit-tap-highlight-color:transparent}.world-dpad-btn:active{background:#6b8cff40;border-color:color-mix(in srgb,var(--accent) 50%,var(--border))}.world-dpad-btn--up{grid-column:2;grid-row:1}.world-dpad-btn--left{grid-column:1;grid-row:2}.world-dpad-btn--center{grid-column:2;grid-row:2;font-size:10px;color:var(--accent-warm)}.world-dpad-btn--right{grid-column:3;grid-row:2}.world-dpad-btn--down{grid-column:2;grid-row:3}.world-desktop-hint{position:absolute;right:max(10px,env(safe-area-inset-right));bottom:max(10px,env(safe-area-inset-bottom));margin:0;padding:8px 12px;border-radius:12px;border:1px solid var(--border);background:#0c0e16c7;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);font-size:12px;color:var(--text-muted);display:none}@media(hover:none),(pointer:coarse){.world-dpad{display:grid}.world-desktop-hint{display:none}}.world-sheet-host{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20;pointer-events:none}.world-sheet-host.is-open{pointer-events:auto}.world-sheet-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#020308b8;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);opacity:0;transition:opacity .28s var(--ease)}.world-sheet-host.is-open .world-sheet-backdrop{opacity:1}.world-sheet{position:absolute;left:0;right:0;bottom:0;max-height:min(92dvh,760px);display:flex;flex-direction:column;border-radius:24px 24px 0 0;border:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));border-bottom:none;background:linear-gradient(180deg,#121624fa,#0a0c14fc);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);box-shadow:0 -24px 80px #0000008c,inset 0 1px #ffffff0d;transform:translateY(104%);transition:transform .34s var(--ease);padding-bottom:env(safe-area-inset-bottom);overflow:hidden}.world-sheet-host.is-open .world-sheet{transform:translateY(0)}.world-sheet-handle{flex-shrink:0;width:42px;height:4px;margin:10px auto 0;border-radius:999px;background:#ffffff29}.world-sheet-banner{position:relative;flex-shrink:0;padding:8px 16px 14px;border-bottom:1px solid rgba(255,255,255,.06);overflow:hidden}.world-sheet-banner-glow{position:absolute;inset:-40% -10% auto;height:140px;background:radial-gradient(circle at 20% 50%,color-mix(in srgb,var(--accent) 35%,transparent),transparent 55%),radial-gradient(circle at 80% 30%,color-mix(in srgb,var(--accent-2) 25%,transparent),transparent 50%);pointer-events:none}.world-sheet-close{position:absolute;top:10px;right:12px;z-index:2;width:36px;height:36px;display:grid;place-items:center;border:1px solid var(--border);border-radius:12px;background:#080a12bf;color:var(--text-muted);font-size:22px;line-height:1;cursor:pointer;transition:border-color .2s var(--ease),color .2s var(--ease)}.world-sheet-close:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border));color:var(--text)}.world-sheet-banner-main{position:relative;z-index:1;display:flex;gap:14px;align-items:flex-start;padding-right:44px}.world-sheet-avatar-wrap{position:relative;flex-shrink:0}.world-sheet-avatar-glow{position:absolute;inset:auto 4px -12px 4px;height:36px;background:radial-gradient(circle,color-mix(in srgb,var(--accent) 45%,transparent),transparent 70%);pointer-events:none}.world-sheet-avatar{width:76px;height:76px;display:grid;place-items:center;border-radius:18px;border:1px solid color-mix(in srgb,var(--accent) 30%,var(--border));background:linear-gradient(180deg,#ffffff0f,#ffffff05);overflow:hidden;box-shadow:0 12px 32px #00000059}.world-sheet-avatar .char-preview-stack{image-rendering:pixelated;image-rendering:crisp-edges}.world-sheet-avatar-fallback{width:40px;height:40px;display:grid;place-items:center;border-radius:50%;background:var(--accent-soft);font-weight:700;font-size:20px;color:var(--accent)}.world-sheet-level{position:absolute;right:-6px;bottom:-6px;padding:3px 8px;border-radius:999px;border:1px solid var(--border);background:#000000a6;font-size:11px;font-weight:700;color:var(--accent-warm)}.world-sheet-identity{flex:1;min-width:0}.world-sheet-eyebrow{display:block;font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--accent-warm)}.world-sheet-identity h2{margin:2px 0 6px;font-size:1.25rem;font-weight:700;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.world-sheet-prof-line{display:flex;align-items:center;gap:6px;margin:0 0 4px;font-size:13px;color:var(--text-muted)}.world-sheet-prof-line .prof-icon{width:18px;height:18px}.world-sheet-map-line{margin:0 0 8px;font-size:12px;color:color-mix(in srgb,var(--text-muted) 85%,var(--accent-2));white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.world-sheet-vitals{display:flex;flex-direction:column;gap:8px;margin-top:4px}.world-sheet-vitals--compact{gap:6px}.world-sheet-vital-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:4px;font-size:11px}.world-sheet-vital-label{font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-muted)}.world-sheet-vital-top strong{font-size:12px;font-variant-numeric:tabular-nums}.world-sheet-vital--hp .world-sheet-vital-top strong{color:#ff7b7b}.world-sheet-vital--mp .world-sheet-vital-top strong{color:#8eb8ff}.world-sheet-vital-track{height:8px;border-radius:999px;background:#ffffff12;overflow:hidden;box-shadow:inset 0 1px 2px #00000059}.world-sheet-vitals--compact .world-sheet-vital-track{height:6px}.world-sheet-vital-fill{height:100%;border-radius:inherit;transition:width .25s var(--ease)}.world-sheet-vital--hp .world-sheet-vital-fill{background:linear-gradient(90deg,#a82828,#f55 55%,#ff8a8a);box-shadow:0 0 12px #ff46468c}.world-sheet-vital--mp .world-sheet-vital-fill{background:linear-gradient(90deg,#2f4db8,#6b9cff);box-shadow:0 0 10px #6b9cff59}.world-sheet-layout{flex:1;min-height:0;display:flex;flex-direction:row;border-top:1px solid rgba(255,255,255,.05)}.world-sheet-skills-pane{flex-shrink:0;width:min(38%,168px);min-width:132px;display:flex;flex-direction:column;gap:10px;padding:12px 10px;border-right:1px solid rgba(255,255,255,.06);background:#00000026;overflow:auto;-webkit-overflow-scrolling:touch}.world-sheet-skills-head{display:flex;align-items:center;justify-content:space-between;gap:6px}.world-sheet-skills-head h3{margin:0;font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--accent-warm)}.world-sheet-skills-empty{padding:12px 8px;text-align:center;border-radius:12px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05}.world-sheet-skills-empty p{margin:0;font-size:12px;font-weight:700}.world-sheet-skills-empty span{display:block;margin-top:4px;font-size:10px;line-height:1.35;color:var(--text-muted)}.world-sheet-skills-hint{margin:0;font-size:10px;color:var(--text-muted);text-align:center}.world-sheet-skills-hint kbd{padding:1px 4px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#ffffff0d;font-size:9px;font-family:inherit}.world-sheet-skills-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;margin-top:auto}.world-sheet-skill-slot{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:52px;padding:6px 4px;border-radius:10px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05;color:inherit;font:inherit;cursor:pointer}.world-sheet-skill-slot kbd{padding:1px 5px;border-radius:4px;border:1px solid rgba(255,255,255,.12);background:#0000004d;font-size:9px;font-weight:800;font-family:inherit}.world-sheet-skill-slot span{font-size:9px;font-weight:700;text-align:center;line-height:1.15}.world-sheet-skill-slot.is-empty{opacity:.5;cursor:default}.world-sheet-skill-slot.is-ready{border-style:solid;border-color:color-mix(in srgb,var(--accent-warm) 35%,var(--border));background:color-mix(in srgb,var(--accent-warm) 8%,transparent)}.world-sheet-skill-slot.is-flash{border-color:var(--accent-warm);box-shadow:0 0 12px color-mix(in srgb,var(--accent-warm) 40%,transparent)}.world-sheet-sections{flex:1;min-width:0;display:flex;flex-direction:row;min-height:0}.world-sheet-rail{flex-shrink:0;display:flex;flex-direction:column;gap:6px;width:58px;padding:10px 6px;border-right:1px solid rgba(255,255,255,.06);background:#0000001f;overflow-y:auto;scrollbar-width:none}.world-sheet-rail::-webkit-scrollbar{display:none}.world-sheet-rail-btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;border:1px solid transparent;border-radius:12px;background:transparent;color:var(--text-muted);cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease)}.world-sheet-rail-btn.is-active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 35%,var(--border));background:color-mix(in srgb,var(--accent) 12%,transparent);box-shadow:0 6px 16px #0003}.world-sheet-rail-label{font-size:9px;font-weight:700;letter-spacing:.02em;line-height:1.1;text-align:center}.world-sheet-nav-icon{width:18px;height:18px;border-radius:6px;background:#ffffff14;position:relative}.world-sheet-rail-btn.is-active .world-sheet-nav-icon{background:color-mix(in srgb,var(--accent) 35%,transparent)}.world-sheet-nav-icon--stats:after,.world-sheet-nav-icon--profession:after,.world-sheet-nav-icon--equipment:after,.world-sheet-nav-icon--inventory:after{content:"";position:absolute;top:4px;right:4px;bottom:4px;left:4px;border-radius:2px;background:currentColor;opacity:.85}.world-sheet-nav-icon--stats:after{clip-path:polygon(50% 0,100% 100%,0 100%);top:3px;right:5px;bottom:4px;left:5px}.world-sheet-nav-icon--profession:after{border-radius:50%;top:3px;right:3px;bottom:3px;left:3px}.world-sheet-nav-icon--equipment:after{clip-path:polygon(15% 0,85% 0,100% 35%,100% 100%,0 100%,0 35%);top:2px;right:4px;bottom:3px;left:4px}.world-sheet-nav-icon--inventory:after{border-radius:3px;box-shadow:inset 0 -4px #00000040}.world-sheet-content{flex:1;min-width:0;min-height:0;overflow:auto;padding:12px 12px 16px;-webkit-overflow-scrolling:touch}.world-sheet-panel{display:flex;flex-direction:column;gap:12px;animation:fade-up .28s var(--ease) both}.world-sheet-card{padding:14px;border-radius:16px;border:1px solid var(--border);background:var(--bg-card);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.world-sheet-card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:10px}.world-sheet-card-head--solo{margin-bottom:0}.world-sheet-card-head h3{margin:0;font-size:.95rem;font-weight:700}.world-sheet-card-text{margin:0;font-size:13px;line-height:1.55;color:var(--text-muted)}.world-sheet-chip{flex-shrink:0;padding:4px 10px;border-radius:999px;border:1px solid color-mix(in srgb,var(--accent-warm) 35%,var(--border));background:color-mix(in srgb,var(--accent-warm) 10%,transparent);font-size:11px;font-weight:700;color:var(--accent-warm)}.world-sheet-chip--muted{border-color:var(--border);background:#ffffff0a;color:var(--text-muted)}.world-sheet-stat-list{display:flex;flex-direction:column;gap:8px}.world-sheet-stat-list--compact{margin-top:12px}.world-sheet-stat-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:12px;border:1px solid var(--border);background:#ffffff05;border-left-width:3px}.world-sheet-stat-row--rose{border-left-color:#ff6b6b}.world-sheet-stat-row--amber{border-left-color:var(--accent-warm)}.world-sheet-stat-row--mint{border-left-color:#6fd4a8}.world-sheet-stat-row--violet{border-left-color:var(--accent-2)}.world-sheet-stat-row--gold{border-left-color:#e8c468}.world-sheet-stat-name{font-size:13px;color:var(--text-muted)}.world-sheet-stat-value{font-size:1.05rem;font-weight:700;font-variant-numeric:tabular-nums}.world-sheet-xp{padding:14px;border-radius:16px;border:1px solid var(--border);background:#ffffff05}.world-sheet-xp-head{display:flex;justify-content:space-between;margin-bottom:8px;font-size:12px}.world-sheet-xp-head span{color:var(--text-muted);font-weight:700;text-transform:uppercase;letter-spacing:.06em}.world-sheet-xp-track{height:6px;border-radius:999px;background:#ffffff12;overflow:hidden}.world-sheet-xp-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,var(--accent),var(--accent-2))}.world-sheet-xp-hint{margin:8px 0 0;font-size:11px;color:var(--text-muted)}.world-sheet-class-card{position:relative;display:flex;gap:14px;align-items:center;padding:16px;border-radius:18px;border:1px solid color-mix(in srgb,var(--accent-2) 30%,var(--border));background:linear-gradient(135deg,#a78bfa14,#6b8cff0f);overflow:hidden}.world-sheet-class-glow{position:absolute;inset:auto 10% -40% 10%;height:80px;background:radial-gradient(circle,color-mix(in srgb,var(--accent-2) 35%,transparent),transparent 70%);pointer-events:none}.world-sheet-class-icon{position:relative;z-index:1;flex-shrink:0;width:56px;height:56px;display:grid;place-items:center;border-radius:14px;border:1px solid var(--border);background:#00000040}.world-sheet-class-icon .prof-icon{width:36px;height:36px}.world-sheet-class-body{position:relative;z-index:1;min-width:0}.world-sheet-class-body h3{margin:2px 0 4px;font-size:1.05rem}.world-sheet-class-body p{margin:0;font-size:13px;color:var(--text-muted)}.world-sheet-equip-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.world-sheet-equip-slot{display:flex;flex-direction:column;gap:4px;min-height:88px;padding:12px;border-radius:14px;border:1px dashed rgba(255,255,255,.12);background:#ffffff05;transition:border-color .2s var(--ease),background .2s var(--ease)}.world-sheet-equip-slot.is-filled{border-style:solid;border-color:color-mix(in srgb,var(--accent) 35%,var(--border));background:color-mix(in srgb,var(--accent) 8%,transparent)}.world-sheet-equip-icon{font-size:14px;opacity:.55}.world-sheet-equip-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.world-sheet-equip-value{margin-top:auto;font-size:13px;font-weight:600;line-height:1.3}.world-sheet-inv-slots{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:8px}.world-sheet-inv-cell{aspect-ratio:1;display:grid;place-items:center;padding:6px;border-radius:12px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05}.world-sheet-inv-cell.is-filled{border-style:solid;border-color:color-mix(in srgb,var(--accent-warm) 35%,var(--border));background:color-mix(in srgb,var(--accent-warm) 8%,transparent)}.world-sheet-inv-cell-name{font-size:10px;font-weight:600;text-align:center;line-height:1.2;overflow:hidden;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical}.world-sheet-empty{padding:28px 16px;text-align:center;border-radius:16px;border:1px dashed rgba(255,255,255,.1);background:#ffffff05}.world-sheet-empty--inline{padding:16px}.world-sheet-empty-icon{width:40px;height:40px;margin:0 auto 10px;border-radius:12px;border:1px dashed rgba(255,255,255,.14);background:#ffffff0a}.world-sheet-empty-icon--bag{position:relative}.world-sheet-empty-icon--bag:after{content:"";position:absolute;top:10px;right:11px;bottom:8px;left:11px;border:2px solid rgba(255,255,255,.25);border-radius:4px 4px 6px 6px}.world-sheet-empty p{margin:0;font-weight:700}.world-sheet-empty span{display:block;margin-top:6px;font-size:13px;color:var(--text-muted);line-height:1.45}.world-sheet-skill-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}.world-sheet-skill{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center;padding:12px 14px;border-radius:14px;border:1px solid var(--border);background:#ffffff08}.world-sheet-skill.is-locked{opacity:.72}.world-sheet-skill-badge{width:32px;height:32px;display:grid;place-items:center;border-radius:10px;background:#ffffff0f;font-size:12px;font-weight:800;color:var(--text-muted)}.world-sheet-skill-badge.is-active{background:color-mix(in srgb,var(--accent) 25%,transparent);color:var(--accent)}.world-sheet-skill strong{display:block;font-size:13px}.world-sheet-skill small{display:block;margin-top:2px;font-size:12px;color:var(--text-muted)}.world-sheet-skill-tag{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;padding:4px 8px;border-radius:999px;border:1px solid var(--border);color:var(--text-muted)}.world-sheet-skill:not(.is-locked) .world-sheet-skill-tag{border-color:color-mix(in srgb,var(--accent) 35%,var(--border));color:var(--accent)}@media(max-width:760px),(max-height:520px)and (hover:none),(max-height:520px)and (pointer:coarse){.world-sheet{max-height:min(94dvh,100%)}.world-sheet-banner{padding:6px 12px 10px}.world-sheet-banner-main{gap:10px;padding-right:40px;align-items:center}.world-sheet-avatar{width:58px;height:58px;border-radius:14px}.world-sheet-identity h2{font-size:1.05rem;margin-bottom:4px}.world-sheet-map-line{margin-bottom:6px;font-size:11px}.world-sheet-layout{flex-direction:column}.world-sheet-sections{flex:1;flex-direction:column;min-height:0;order:1}.world-sheet-rail{flex-direction:row;flex-shrink:0;width:100%;padding:6px 8px;gap:4px;border-right:none;border-bottom:1px solid rgba(255,255,255,.06);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.world-sheet-rail::-webkit-scrollbar{display:none}.world-sheet-rail-btn{flex:1 1 0;min-width:56px;padding:7px 4px}.world-sheet-rail-label{font-size:9px}.world-sheet-content{flex:1;min-height:0;padding:10px 12px 12px}.world-sheet-skills-pane{order:2;flex-shrink:0;width:100%;min-width:0;flex-direction:row;align-items:center;gap:8px;padding:8px 10px calc(8px + env(safe-area-inset-bottom));border-right:none;border-top:1px solid rgba(255,255,255,.06);overflow:visible}.world-sheet-skills-head{flex-shrink:0;flex-direction:column;align-items:flex-start;gap:2px}.world-sheet-skills-head h3{font-size:10px}.world-sheet-skills-head .world-sheet-chip,.world-sheet-skills-hint{display:none}.world-sheet-skills-grid{flex:1;min-width:0;grid-template-columns:repeat(6,minmax(0,1fr));gap:4px;margin-top:0}.world-sheet-skill-slot{min-height:44px;padding:4px 2px;border-radius:8px}.world-sheet-skill-slot span{font-size:8px}.world-sheet-equip-grid{grid-template-columns:1fr}.world-sheet-inv-slots{grid-template-columns:repeat(4,minmax(0,1fr))}}@media(min-width:761px)and (hover:hover)and (pointer:fine){.world-map-frame{margin:8px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.world-dpad{display:none}.world-desktop-hint{display:block}.world-skillbar{bottom:max(14px,env(safe-area-inset-bottom));max-width:min(420px,calc(100% - 48px))}.world-toast-host{bottom:calc(86px + env(safe-area-inset-bottom))}.world-hud{max-width:min(320px,calc(100% - 28px))}.world-sheet{left:auto;right:16px;bottom:16px;top:16px;width:min(520px,calc(100% - 32px));max-height:none;border-radius:var(--radius-lg);border-bottom:1px solid color-mix(in srgb,var(--accent) 22%,var(--border));transform:translate(calc(100% + 24px))}.world-sheet-handle{display:none}.world-sheet-rail-label{font-size:10px}.world-sheet-skills-pane{width:168px}.world-sheet-host.is-open .world-sheet{transform:translate(0)}}@media(max-height:520px)and (hover:none),(max-height:520px)and (pointer:coarse){.world-dpad{grid-template-columns:repeat(3,44px);grid-template-rows:repeat(3,44px);gap:3px;right:max(8px,env(safe-area-inset-right));bottom:max(8px,env(safe-area-inset-bottom))}.world-dpad-btn{border-radius:12px;font-size:14px}.world-hud{max-width:min(240px,calc(100% - 160px));padding:6px 10px 6px 6px}.world-skillbar{gap:4px;padding:4px;max-width:calc(100% - 130px)}.world-skill-slot{width:44px;height:44px}.world-toast-host{bottom:calc(68px + env(safe-area-inset-bottom));font-size:11px}.world-hud-avatar{width:36px;height:36px}.world-overlay-top{top:max(6px,env(safe-area-inset-top))}.world-icon-btn{width:34px;height:34px}.world-sheet{max-height:min(98dvh,100%)}.world-sheet-handle{margin:6px auto 0}.world-sheet-banner{padding:4px 12px 8px}.world-sheet-avatar{width:48px;height:48px;border-radius:12px}.world-sheet-level{font-size:9px;padding:2px 6px}.world-sheet-map-line{display:none}.world-sheet-prof-line{font-size:11px;margin-bottom:2px}.world-sheet-vitals--compact{gap:4px}.world-sheet-vitals--compact .world-sheet-vital-track{height:5px}.world-sheet-rail-btn{min-width:48px;padding:5px 2px}.world-sheet-skill-slot{min-height:38px}}@media(max-width:760px){.world-hud{max-width:calc(100% - 190px)}.world-overlay-top{gap:6px}.world-icon-btn{width:36px;height:36px;font-size:14px}}@media(max-width:400px){.world-dpad{grid-template-columns:repeat(3,46px);grid-template-rows:repeat(3,46px)}.world-hud-name{font-size:12px}.world-sheet-rail-label{font-size:8px}.world-sheet-rail-btn{min-width:50px}.world-sheet-inv-slots{grid-template-columns:repeat(3,minmax(0,1fr))}}
