: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;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--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-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{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:28px;animation:fade-up .5s var(--ease) both}.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-header-actions{display:flex;gap:8px;flex-wrap:wrap}.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:18px;height:18px}.char-card-prof-icon svg{width:100%;height:100%}.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-create-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;flex-wrap:wrap}.char-create-back{border:1px solid var(--border);background:#ffffff0a;color:var(--text);border-radius:var(--radius-sm);padding:8px 12px;cursor:pointer}.char-create-steps{display:flex;gap:10px;flex-wrap:wrap}.char-create-step{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid var(--border);color:var(--text-muted);font-size:13px}.char-create-step.is-active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:var(--accent-soft)}.char-create-step.is-done{color:var(--accent-warm)}.char-create-step-num{width:22px;height:22px;display:grid;place-items:center;border-radius:50%;background:#ffffff0f;font-weight:700;font-size:12px}.char-create-main{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:20px;align-items:start}.char-create-panel,.char-create-preview-card{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-card);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);padding:24px}.char-create-title{margin:0 0 8px;font-size:1.5rem}.char-create-lead{margin:0 0 20px;color:var(--text-muted)}.char-gender-tabs{display:flex;gap:8px;margin-bottom:18px}.char-gender-tab{flex:1;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid var(--border);background:#ffffff08;color:var(--text-muted);cursor:pointer}.char-gender-tab.is-active{color:var(--text);border-color:color-mix(in srgb,var(--accent) 45%,var(--border));background:var(--accent-soft)}.char-appearance-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:10px}.char-appearance-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:10px;border:1px solid var(--border);border-radius:12px;background:#ffffff05;cursor:pointer;color:var(--text)}.char-appearance-item.is-active{border-color:var(--accent);box-shadow:0 0 0 1px color-mix(in srgb,var(--accent) 40%,transparent)}.char-appearance-sprite{image-rendering:pixelated}.char-appearance-fallback{width:48px;height:48px;display:grid;place-items:center;border-radius:10px;background:var(--accent-soft);font-weight:700}.char-appearance-name{font-size:11px;color:var(--text-muted);text-align:center}.char-profession-list{display:flex;flex-direction:column;gap:10px}.char-profession-card{display:flex;gap:14px;align-items:flex-start;padding:14px;border:1px solid var(--border);border-radius:14px;background:#ffffff05;cursor:pointer;text-align:left;color:var(--text)}.char-profession-card.is-active{border-color:var(--accent);background:var(--accent-soft)}.char-profession-icon{width:36px;height:36px;flex-shrink:0;color:var(--accent-warm)}.char-profession-icon svg{width:100%;height:100%}.char-profession-text{display:flex;flex-direction:column;gap:4px}.char-profession-text strong{font-size:1rem}.char-profession-text span{color:var(--text-muted);font-size:13px;line-height:1.45}.char-nickname-field small{color:var(--text-muted);font-size:12px}.char-create-footer{display:flex;justify-content:space-between;gap:12px;margin-top:24px}.char-create-preview-label{margin:0 0 10px;color:var(--text-muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.char-create-preview-stage{display:grid;place-items:center;min-height:180px;margin-bottom:16px;border-radius:14px;background:linear-gradient(180deg,rgba(255,255,255,.05),transparent)}.char-create-preview-info h3{margin:0 0 8px}.char-create-preview-info p{margin:0 0 6px;color:var(--text-muted);font-size:14px}.char-preview-prof{display:inline-flex;align-items:center;gap:6px}.char-preview-prof svg{width:16px;height:16px}.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}@media(max-width:900px){.char-create-main{grid-template-columns:1fr}.char-create-preview{order:-1}}
