@import"https://fonts.googleapis.com/css2?family=Chakra+Petch:wght@400;600;700&family=Share+Tech+Mono&display=swap";:root{--cyan: #22e3ff;--magenta: #ff2e88;--line: #1d3a52;--dim: #4d6a85;--text: #cfe8ff;--bg-0: #04060c;--font-display: "Chakra Petch", sans-serif;--font-body: "Share Tech Mono", monospace}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{background:var(--bg-0);color:var(--text);font-family:var(--font-body)}.app{position:relative;height:100%;min-height:100vh;display:flex;flex-direction:column;background:radial-gradient(ellipse at 20% 0%,#10182b,#070a12 55%,#04060c);overflow:hidden}.scanlines{pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:5;background:repeating-linear-gradient(0deg,rgba(0,0,0,.18) 0px,rgba(0,0,0,.18) 1px,transparent 1px,transparent 3px);mix-blend-mode:multiply}.grain{pointer-events:none;position:absolute;top:0;right:0;bottom:0;left:0;z-index:4;opacity:.04;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='80' height='80'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}.icon-cyan{color:var(--cyan)}.icon-magenta{color:var(--magenta)}.icon-dim{color:var(--dim)}.header{position:relative;z-index:6;display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid var(--line);background:#080e1899;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.header-brand{display:flex;align-items:center;gap:12px}.title{font-family:var(--font-display);font-weight:700;font-size:20px;letter-spacing:2px;color:#eaf6ff}.subtitle{font-size:10px;color:var(--dim);letter-spacing:1px;margin-top:2px}.turn-box{display:flex;flex-direction:column;align-items:center;border:1px solid var(--line);padding:4px 12px;border-radius:4px;background:#22e3ff0d}.turn-label{color:var(--dim);font-size:11px}.turn-num{font-family:var(--font-display);font-size:22px;font-weight:700;color:var(--cyan);text-shadow:0 0 10px var(--cyan)}.body{position:relative;z-index:6;display:flex;flex:1;min-height:0;gap:14px;padding:14px}.chat-pane{flex:1;display:flex;flex-direction:column;min-width:0;border:1px solid var(--line);border-radius:6px;background:#060b148c}.log{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px}.sys-msg{text-align:center;font-size:10px;letter-spacing:1.5px;color:var(--dim);padding:4px 0;border-bottom:1px dashed var(--line)}.msg-row{display:flex}.msg-row--gm{justify-content:flex-start}.msg-row--player{justify-content:flex-end}.msg{max-width:82%;padding:10px 13px;font-size:13.5px;line-height:1.55}.msg--gm{border-radius:2px 10px 10px;background:#22e3ff12;border:1px solid rgba(34,227,255,.3);box-shadow:0 0 18px #22e3ff0f}.msg--player{border-radius:10px 2px 10px 10px;background:#ff2e8814;border:1px solid rgba(255,46,136,.3)}.msg-label{display:flex;align-items:center;gap:4px;font-size:9px;letter-spacing:1.5px;color:var(--dim);margin-bottom:5px}.thinking{font-size:11px;color:var(--cyan);letter-spacing:1px;opacity:.8}.input-bar{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}.input{flex:1;background:#0006;border:1px solid var(--line);border-radius:4px;padding:9px 12px;color:#dff1ff;font-family:var(--font-body);font-size:13px;outline:none}.input::placeholder{color:var(--dim)}.send-btn{display:flex;align-items:center;justify-content:center;width:44px;background:var(--cyan);color:var(--bg-0);border:none;border-radius:4px;cursor:pointer;transition:all .15s}.send-btn:hover:not(:disabled){box-shadow:0 0 14px var(--cyan);transform:translateY(-1px)}.send-btn:disabled{opacity:.4;cursor:default}.sidebar{width:290px;display:flex;flex-direction:column;gap:14px;overflow-y:auto}.card{border:1px solid var(--line);border-radius:6px;padding:14px;background:#080e1899}.card-head{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-size:12px;letter-spacing:1.5px;color:#bfe6f5;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--line)}.hp-row{display:flex;align-items:center;gap:8px;margin-bottom:14px}.hp-bar{flex:1;height:10px;background:#00000080;border:1px solid var(--line);border-radius:5px;overflow:hidden}.hp-bar__fill{height:100%;background:linear-gradient(90deg,#ff2e88,#ff7eb0);box-shadow:0 0 8px var(--magenta);transition:width .3s}.hp-text{font-size:12px;color:#ffd0e2;min-width:44px;text-align:right}.hp-btns{display:flex;flex-direction:column}.hp-btn{background:transparent;border:1px solid var(--line);color:var(--dim);cursor:pointer;line-height:0;padding:1px;border-radius:2px}.stat-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:14px}.stat{border:1px solid var(--line);border-radius:4px;padding:6px 8px;display:flex;align-items:center;justify-content:space-between;background:#00000040}.stat__key{font-size:10px;color:var(--dim);letter-spacing:1px}.stat__val{font-size:18px;font-family:var(--font-display);color:#eaf6ff}.stat__mod{font-size:11px;color:var(--cyan)}.inv-head{font-size:10px;letter-spacing:1.5px;color:var(--dim);display:flex;align-items:center;gap:5px;margin-bottom:8px}.inv-list{display:flex;flex-direction:column;gap:5px}.inv-item{font-size:12px;color:#aecadd;display:flex;align-items:center;gap:6px;padding:4px 0}.dice-input-row{display:flex;gap:6px}.roll-btn{width:44px;background:var(--cyan);color:var(--bg-0);border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.roll-btn:hover{box-shadow:0 0 14px var(--cyan);transform:translateY(-1px)}.dice-error{color:var(--magenta);font-size:11px;margin-top:4px}.presets{display:flex;gap:5px;flex-wrap:wrap;margin-top:8px}.preset{background:#22e3ff0f;border:1px solid var(--line);color:#9fd6e8;font-size:11px;padding:3px 8px;border-radius:3px;cursor:pointer;font-family:var(--font-body)}.dice-result{margin-top:12px;padding:12px;border:1px solid var(--line);border-radius:4px;text-align:center;background:#0000004d;transition:opacity .2s}.dice-total{font-family:var(--font-display);font-size:40px;font-weight:700;color:var(--cyan);text-shadow:0 0 16px var(--cyan);line-height:1}.dice-break{font-size:12px;color:var(--dim);margin-top:4px}.dice-placeholder{color:var(--dim);font-size:12px}.to-gm-btn{margin-top:10px;background:transparent;border:1px solid var(--magenta);color:var(--magenta);font-size:11px;padding:5px 10px;border-radius:3px;cursor:pointer;font-family:var(--font-body);letter-spacing:.5px}.hist-list{display:flex;flex-wrap:wrap;gap:5px;margin-top:10px}.hist-item{font-size:10px;color:var(--dim);border:1px solid var(--line);border-radius:2px;padding:2px 5px}.glitch{position:relative}.glitch:before,.glitch:after{content:attr(data-text);position:absolute;left:0;top:0;width:100%;overflow:hidden}.glitch:before{color:var(--magenta);animation:gl1 3s infinite linear alternate-reverse;clip-path:inset(0 0 60% 0)}.glitch:after{color:var(--cyan);animation:gl2 2.4s infinite linear alternate-reverse;clip-path:inset(55% 0 0 0)}@keyframes gl1{0%,40%{transform:translate(0)}42%{transform:translate(-2px)}44%,to{transform:translate(0)}}@keyframes gl2{0%,60%{transform:translate(0)}62%{transform:translate(2px)}64%,to{transform:translate(0)}}.dots:after{content:"";animation:dots 1.2s steps(4,end) infinite}@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}@media (max-width: 720px){html,body,#root{height:auto;min-height:100%}.app{height:auto;min-height:100vh;overflow:visible}.body{flex-direction:column;flex:0 0 auto}.chat-pane{flex:0 0 auto}.log{flex:0 0 auto;height:55vh}.sidebar{width:100%;flex-direction:row;flex-wrap:wrap;overflow:visible}.sidebar>.card{flex:1;min-width:240px}}.creation{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 50% 0%,#10182b,#070a12 55%,#04060c);overflow-y:auto}.creation-back{display:inline-flex;align-items:center;gap:5px;margin-bottom:16px}.creation-inner{position:relative;z-index:6;width:100%;max-width:760px}.creation-brand{display:flex;align-items:center;gap:12px;justify-content:center}.creation-title{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:2px;color:#eaf6ff}.creation-sub{text-align:center;color:var(--dim);font-size:13px;letter-spacing:1px;margin:8px 0 22px}.class-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.class-card{text-align:left;background:#080e1899;border:1px solid var(--line);border-radius:8px;padding:14px;cursor:pointer;color:var(--text);font-family:var(--font-body);transition:all .15s}.class-card:hover{border-color:var(--cyan);box-shadow:0 0 14px #22e3ff1f}.class-card--active{border-color:var(--cyan);box-shadow:0 0 20px #22e3ff40;background:#22e3ff12}.class-card__top{display:flex;align-items:baseline;justify-content:space-between}.class-card__name{font-family:var(--font-display);font-size:18px;color:#eaf6ff}.class-card__key{font-size:11px;color:var(--cyan);border:1px solid var(--line);border-radius:3px;padding:1px 6px}.class-card__tag{font-size:12px;color:#9fb8cc;margin:6px 0 10px;line-height:1.4}.class-card__stats{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.class-card__stat{font-size:11px;color:var(--dim);border:1px solid var(--line);border-radius:3px;padding:2px 6px}.class-card__stat em{color:var(--cyan);font-style:normal}.class-card__ability{font-size:11.5px;color:#c8b0e0;line-height:1.45;margin-bottom:8px}.class-card__hp{font-size:11px;color:#ffb0cc;letter-spacing:1px}.name-field{display:flex;gap:10px;margin-top:20px}.name-input{flex:1;background:#0006;border:1px solid var(--line);border-radius:4px;padding:11px 14px;color:#dff1ff;font-family:var(--font-body);font-size:14px;outline:none}.name-input:focus{border-color:var(--cyan)}.start-btn{background:var(--cyan);color:#04060c;border:none;border-radius:4px;padding:0 22px;font-family:var(--font-display);font-size:14px;font-weight:600;letter-spacing:1px;cursor:pointer;transition:all .15s;white-space:nowrap}.start-btn:hover:not(:disabled){box-shadow:0 0 16px var(--cyan)}.start-btn:disabled{background:var(--line);color:var(--dim);cursor:not-allowed}@media (max-width: 640px){.class-grid{grid-template-columns:1fr}.name-field{flex-direction:column}.start-btn{padding:12px}}.header-right{display:flex;align-items:center;gap:12px}.change-char{display:flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--line);color:var(--dim);font-size:11px;font-family:var(--font-body);padding:6px 10px;border-radius:4px;cursor:pointer;transition:all .15s}.change-char:hover{border-color:var(--cyan);color:var(--cyan)}.sheet-name-input{width:100%;background:#00000059;border:1px solid var(--line);border-radius:4px;padding:7px 10px;color:#eaf6ff;font-family:var(--font-display);font-size:16px;outline:none}.sheet-name-input:focus{border-color:var(--cyan)}.class-badge{display:inline-block;font-size:10px;letter-spacing:1px;color:var(--cyan);border:1px solid var(--line);border-radius:3px;padding:2px 7px;margin:8px 0}.ability-line{font-size:11px;color:#c8b0e0;line-height:1.45;margin-bottom:14px}.stat__btns{display:flex;flex-direction:column;margin-left:6px}.stat-btn{background:transparent;border:1px solid var(--line);color:var(--dim);cursor:pointer;line-height:0;padding:1px;border-radius:2px}.stat-btn:hover{border-color:var(--cyan);color:var(--cyan)}.inv-item{display:flex;align-items:center;justify-content:space-between}.inv-item__name{display:flex;align-items:center;gap:6px}.inv-remove{background:transparent;border:none;color:var(--dim);cursor:pointer;line-height:0;padding:2px;border-radius:2px;opacity:.5;transition:all .12s}.inv-remove:hover{color:var(--magenta);opacity:1}.inv-empty{font-size:11px;color:var(--dim);font-style:italic}.inv-add-row{display:flex;gap:6px;margin-top:10px}.inv-add-input{flex:1;background:#0006;border:1px solid var(--line);border-radius:4px;padding:6px 10px;color:#dff1ff;font-family:var(--font-body);font-size:12px;outline:none}.inv-add-input:focus{border-color:var(--cyan)}.inv-add-btn{width:36px;background:#22e3ff1a;border:1px solid var(--line);color:var(--cyan);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s}.inv-add-btn:hover{box-shadow:0 0 10px #22e3ff33}.check-prompt{display:flex;align-items:center;justify-content:space-between;gap:12px;margin:0 12px;padding:11px 14px;border:1px solid var(--magenta);border-radius:6px;background:#ff2e8814;box-shadow:0 0 16px #ff2e881f}.check-prompt__text{font-size:13px;color:#ffd0e2}.check-prompt__text b{color:var(--magenta)}.check-prompt__reason{font-size:11px;color:var(--dim);margin-top:2px}.check-roll-btn{display:flex;align-items:center;gap:6px;white-space:nowrap;background:var(--magenta);color:#04060c;border:none;border-radius:4px;padding:9px 14px;font-family:var(--font-display);font-size:13px;font-weight:600;cursor:pointer;transition:all .15s}.check-roll-btn:hover:not(:disabled){box-shadow:0 0 14px var(--magenta);transform:translateY(-1px)}.check-roll-btn:disabled{opacity:.4;cursor:not-allowed}.quest-banner{display:flex;align-items:center;gap:6px;font-size:11.5px;color:#ffe08a;border:1px solid rgba(255,224,138,.3);background:#ffe08a0f;border-radius:4px;padding:6px 9px;margin-bottom:12px;line-height:1.35}.check-prompt__info{flex:1;min-width:0}.sidebar{width:380px;gap:16px}.msg{font-size:15.5px;line-height:1.6;padding:12px 15px;max-width:92%}.msg-label{font-size:10.5px}.input{font-size:14.5px;padding:11px 14px}.send-btn{width:48px}.card{padding:16px}.card-head{font-size:13px;margin-bottom:14px;padding-bottom:10px;gap:8px}.sheet-name-input{font-size:18px;padding:8px 11px}.class-badge{font-size:12px;padding:3px 9px;margin-top:10px}.ability-line{font-size:13px;line-height:1.5;margin-bottom:16px}.quest-banner{font-size:13px;padding:8px 11px}.hp-row{margin-bottom:18px}.hp-bar{height:14px}.hp-text{font-size:14px;min-width:56px}.stat-grid{gap:10px;margin-bottom:18px}.stat{padding:9px 12px}.stat__key{font-size:12px}.stat__val{font-size:22px}.stat__mod{font-size:13px}.inv-head{font-size:12px;margin-bottom:10px}.inv-item{font-size:14px;padding:5px 0}.inv-item__name{gap:7px}.mod-hint{font-size:12px;color:var(--dim);text-align:center;margin-bottom:12px;letter-spacing:.5px}.mod-table{display:flex;flex-direction:column;gap:8px}.mod-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:12px;padding:8px 12px;border:1px solid var(--line);border-radius:4px;background:#00000040}.mod-row__stat{font-size:14px;color:#c8dceb;letter-spacing:1px}.mod-row__val{font-size:13px;color:var(--dim)}.mod-row__delta{font-family:var(--font-display);font-size:20px;font-weight:700;min-width:44px;text-align:right}.mod-row__delta--pos{color:var(--cyan);text-shadow:0 0 8px rgba(34,227,255,.4)}.mod-row__delta--neg{color:var(--magenta)}.mod-active{text-align:center;padding:8px 0 4px}.mod-active__label{font-size:11px;letter-spacing:1.5px;color:var(--magenta);margin-bottom:6px}.mod-active__stat{font-family:var(--font-display);font-size:26px;font-weight:700;color:#ffd0e2;letter-spacing:2px}.mod-active__formula{font-family:var(--font-display);font-size:32px;margin-top:10px;color:#eaf6ff}.mod-active__sign{color:var(--cyan);text-shadow:0 0 12px var(--cyan)}.mod-active__dc{font-size:12px;color:var(--dim);margin-top:8px;letter-spacing:1px}.sys-msg{font-size:13px;letter-spacing:.5px;padding:7px 12px;border-radius:4px;border-bottom:none;text-align:center;font-weight:600}.sys-msg--good{color:#5fffae;background:#5fffae14;border:1px solid rgba(95,255,174,.35);text-shadow:0 0 10px rgba(95,255,174,.4)}.sys-msg--bad{color:#ff7ea8;background:#ff2e881a;border:1px solid rgba(255,46,136,.4);text-shadow:0 0 10px rgba(255,46,136,.45)}.sys-msg--roll{color:#ffe08a;background:#ffe08a14;border:1px solid rgba(255,224,138,.35);text-shadow:0 0 8px rgba(255,224,138,.3)}.sys-msg--neutral{color:#9fb8cc;border:1px dashed var(--line)}@media (max-width: 1100px){.sidebar{width:320px}}@media (max-width: 900px){.body{flex-direction:column}.sidebar{width:auto}}.creation-inner{max-width:1100px}.creation-title{font-size:34px;letter-spacing:3px}.creation-sub{font-size:15px;margin:12px 0 30px}.class-grid{gap:18px}.class-card{padding:22px;border-radius:10px}.class-card__name{font-size:24px}.class-card__key{font-size:13px;padding:3px 9px}.class-card__tag{font-size:15px;line-height:1.5;margin:10px 0 14px}.class-card__stats{gap:8px;margin-bottom:14px}.class-card__stat{font-size:13px;padding:4px 9px}.class-card__ability{font-size:14px;line-height:1.5;margin-bottom:12px}.class-card__hp{font-size:13px}.name-field{margin-top:28px;gap:14px}.name-input{font-size:16px;padding:14px 18px}.start-btn{font-size:16px;padding:0 30px;letter-spacing:1.5px}@media (max-width: 880px){.creation-title{font-size:26px}.class-card{padding:18px}.class-card__name{font-size:20px}}.auth{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 50% 0%,#10182b,#070a12 55%,#04060c);overflow-y:auto}.auth-card{position:relative;z-index:6;width:100%;max-width:460px;background:#080e18b3;border:1px solid var(--line);border-radius:10px;padding:32px 30px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-brand{display:flex;align-items:center;gap:12px;justify-content:center}.auth-title{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:2.5px;color:#eaf6ff}.auth-sub{text-align:center;color:var(--dim);font-size:13px;letter-spacing:1px;margin:10px 0 24px}.auth-tabs{display:flex;gap:0;margin-bottom:22px;border:1px solid var(--line);border-radius:5px;overflow:hidden}.auth-tab{flex:1;background:transparent;border:none;color:var(--dim);font-family:var(--font-body);font-size:13px;padding:10px;cursor:pointer;letter-spacing:1px;transition:all .15s}.auth-tab:hover{color:#c8dceb}.auth-tab--active{background:#22e3ff1a;color:var(--cyan)}.auth-fields{display:flex;flex-direction:column;gap:4px}.auth-label{font-size:10.5px;letter-spacing:1.5px;color:var(--dim);margin-top:12px;margin-bottom:5px}.auth-input{background:#0006;border:1px solid var(--line);border-radius:4px;padding:11px 14px;color:#dff1ff;font-family:var(--font-body);font-size:14px;outline:none;transition:border .15s}.auth-input:focus{border-color:var(--cyan)}.auth-error{display:flex;align-items:flex-start;gap:8px;margin-top:16px;padding:10px 12px;background:#ff2e8814;border:1px solid rgba(255,46,136,.35);border-radius:4px;color:var(--pink);font-size:12.5px;line-height:1.4}.auth-error svg{flex-shrink:0;margin-top:1px}.auth-submit{display:flex;align-items:center;justify-content:center;width:100%;margin-top:22px;padding:13px;background:var(--cyan);color:#04060c;border:none;border-radius:4px;font-family:var(--font-display);font-size:15px;font-weight:700;letter-spacing:1.5px;cursor:pointer;transition:all .15s}.auth-submit:hover:not(:disabled){box-shadow:0 0 18px var(--cyan)}.auth-submit:disabled{background:var(--line);color:var(--dim);cursor:not-allowed}.auth-note{text-align:center;font-size:11px;color:var(--dim);margin-top:18px;font-style:italic}.menu{position:relative;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(ellipse at 50% 0%,#10182b,#070a12 55%,#04060c);overflow-y:auto}.menu-top{position:absolute;top:0;left:0;right:0;z-index:7;display:flex;align-items:center;justify-content:space-between;padding:14px 22px;border-bottom:1px solid var(--line);background:#080e1899;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.menu-user{font-size:13px;color:#c8dceb}.menu-user__label{color:var(--dim);letter-spacing:1px;font-size:11px}.menu-user__name{color:var(--cyan)}.menu-logout{display:flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--line);color:var(--dim);font-size:11px;font-family:var(--font-body);padding:6px 11px;border-radius:4px;cursor:pointer;transition:all .15s}.menu-logout:hover{border-color:var(--magenta);color:var(--magenta)}.menu-card{position:relative;z-index:6;width:100%;max-width:520px;background:#080e18b3;border:1px solid var(--line);border-radius:10px;padding:36px 30px}.menu-brand{display:flex;align-items:center;gap:14px;justify-content:center}.menu-title{font-family:var(--font-display);font-weight:700;font-size:30px;letter-spacing:3px;color:#eaf6ff}.menu-sub{text-align:center;color:var(--dim);font-size:12px;letter-spacing:1.5px;margin:12px 0 30px}.menu-actions{display:flex;flex-direction:column;gap:12px}.menu-btn{display:flex;align-items:center;gap:14px;text-align:left;padding:16px 18px;background:#080e1880;border:1px solid var(--line);border-radius:6px;color:var(--text);font-family:var(--font-body);cursor:pointer;transition:all .15s}.menu-btn:hover{border-color:var(--cyan);background:#22e3ff0f}.menu-btn--primary{margin-top:40px;border-color:var(--cyan);background:#22e3ff14;box-shadow:0 0 16px #22e3ff1a}.menu-btn__text{flex:1}.menu-btn__title{font-family:var(--font-display);font-size:17px;color:#eaf6ff;letter-spacing:1px}.menu-btn__hint{font-size:12px;color:var(--dim);margin-top:2px}.menu-join{display:flex;flex-direction:column}.menu-join__input{font-family:var(--font-display);font-size:18px;letter-spacing:3px;text-align:center}.menu-join__row{display:flex;gap:10px;margin-top:18px;align-items:center}.menu-back{display:flex;align-items:center;gap:5px;background:transparent;border:1px solid var(--line);color:var(--dim);font-size:12px;font-family:var(--font-body);padding:11px 14px;border-radius:4px;cursor:pointer}.menu-back:hover{border-color:var(--cyan);color:var(--cyan)}.menu-join__submit{flex:1;margin-top:0}.glitch:before,.glitch:after{content:none!important;display:none!important}.glitch{background:linear-gradient(90deg,#22e3ff,#6ee0ff 22%,#c89bff,#ff5fb3 78%,#ff2e88);background-size:200% 100%;background-position:0% 50%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 0 6px rgba(34,227,255,.55)) drop-shadow(0 0 14px rgba(200,155,255,.45)) drop-shadow(0 0 22px rgba(255,46,136,.35));animation:neon-flow 9s ease-in-out infinite}@keyframes neon-flow{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.class-card__name{font-family:var(--font-display);font-size:30px;font-weight:700;letter-spacing:2px;background:linear-gradient(100deg,#22e3ff,#6ee0ff 25%,#c89bff 55%,#ff5fb3 80%,#ff2e88);background-size:200% 100%;background-position:0% 50%;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:transparent;filter:drop-shadow(0 0 4px rgba(34,227,255,.4)) drop-shadow(0 0 10px rgba(255,46,136,.25));transition:filter .25s ease}.class-card--active .class-card__name{background-position:100% 50%;filter:drop-shadow(0 0 6px rgba(34,227,255,.7)) drop-shadow(0 0 14px rgba(200,155,255,.55)) drop-shadow(0 0 24px rgba(255,46,136,.5))}.class-card:hover .class-card__name{background-position:50% 50%}@media (max-width: 768px){.header{padding:10px 12px}.title{font-size:17px;letter-spacing:1.5px}.header-brand{gap:9px}.header-right{gap:8px}.turn-box{padding:3px 9px}.turn-label{font-size:10px}.turn-num{font-size:18px}.change-char{font-size:10.5px;padding:6px 9px}.body{gap:10px;padding:10px}.log{padding:14px;gap:11px}.msg{font-size:14.5px;padding:11px 13px;max-width:94%;line-height:1.55}.input-bar{gap:7px;padding:10px}.input{font-size:16px;padding:10px 13px}.send-btn{width:46px}.card{padding:13px}.card-head{font-size:12px;margin-bottom:11px;padding-bottom:8px}.sheet-name-input{font-size:16px;padding:7px 10px}.stat-grid{gap:8px;margin-bottom:14px}.stat{padding:7px 10px}.stat__val{font-size:20px}.mod-row{padding:7px 10px}.mod-row__delta{font-size:18px;min-width:40px}.mod-active__formula{font-size:28px}.mod-active__stat{font-size:22px}.check-prompt{padding:11px 13px;margin:0 10px}.auth-card{padding:26px 22px}.auth-title{font-size:23px;letter-spacing:2px}.menu-card{padding:28px 22px}.menu-title{font-size:25px;letter-spacing:2.5px}.creation{padding:18px}.creation-inner{max-width:100%}.creation-title{font-size:24px;letter-spacing:2px}}@media (max-width: 480px){.header{padding:8px 10px}.header-brand{gap:7px}.title{font-size:14px;letter-spacing:1px}.header-brand .icon-cyan{transform:scale(.85);transform-origin:center}.turn-box{padding:3px 8px}.turn-label{display:none}.turn-num{font-size:15px}.change-char{font-size:0;gap:0;padding:7px 9px}.change-char svg{width:15px;height:15px}.body{gap:8px;padding:8px}.chat-pane{border-radius:5px}.log{padding:11px;gap:9px}.msg{font-size:13.5px;padding:9px 11px;max-width:92%;line-height:1.5}.msg-label{font-size:9.5px;margin-bottom:4px}.input-bar{gap:6px;padding:8px}.input{font-size:16px;padding:9px 11px}.send-btn{width:42px}.sys-msg{font-size:11.5px;padding:6px 10px}.check-prompt{flex-wrap:wrap;margin:0 8px;padding:10px 12px;gap:9px}.check-prompt__info{flex-basis:100%}.check-prompt__text{font-size:12.5px}.check-prompt__reason{font-size:10.5px}.check-roll-btn{width:100%;justify-content:center;padding:10px;font-size:13px}.sidebar{gap:10px}.card{padding:11px;border-radius:5px}.card-head{font-size:11.5px;margin-bottom:10px;padding-bottom:7px;gap:6px}.sheet-name-input{font-size:16px;padding:7px 9px}.class-badge{font-size:10.5px;padding:2px 7px;margin-top:8px}.ability-line{font-size:12px;margin-bottom:12px}.quest-banner{font-size:11.5px;padding:7px 9px}.hp-row{margin-bottom:13px}.hp-bar{height:11px}.hp-text{font-size:12.5px;min-width:48px}.stat-grid{gap:6px;margin-bottom:12px}.stat{padding:6px 8px}.stat__key{font-size:10px}.stat__val{font-size:17px}.stat__mod{font-size:11px}.inv-head{font-size:11px;margin-bottom:7px}.inv-item{font-size:12.5px;padding:4px 0}.inv-add-input{font-size:14px;padding:5px 9px}.inv-add-btn{width:34px}.mod-hint{font-size:11px;margin-bottom:10px}.mod-row{padding:6px 9px;gap:9px}.mod-row__stat{font-size:13px}.mod-row__val{font-size:12px}.mod-row__delta{font-size:17px;min-width:36px}.mod-active__label{font-size:10px}.mod-active__stat{font-size:20px;letter-spacing:1.5px}.mod-active__formula{font-size:24px;margin-top:7px}.mod-active__dc{font-size:11px;margin-top:6px}.auth{padding:16px}.auth-card{padding:22px 18px;border-radius:8px}.auth-brand{gap:9px}.auth-title{font-size:20px;letter-spacing:1.5px}.auth-sub{font-size:12px;margin:9px 0 20px}.auth-tabs{margin-bottom:18px}.auth-tab{font-size:12px;padding:9px}.auth-label{font-size:10px;margin-top:11px;margin-bottom:4px}.auth-input{font-size:16px;padding:11px 13px}.auth-submit{padding:13px;font-size:14px;margin-top:20px}.auth-note{font-size:10.5px;margin-top:16px}.menu{padding:70px 14px 14px}.menu-top{padding:9px 12px}.menu-user{font-size:11px}.menu-user__label{font-size:10px;letter-spacing:.5px}.menu-logout{font-size:10px;padding:5px 8px;gap:4px}.menu-logout svg{width:12px;height:12px}.menu-card{padding:22px 18px;border-radius:8px}.menu-brand{gap:10px}.menu-title{font-size:22px;letter-spacing:2px}.menu-sub{font-size:11px;letter-spacing:1px;margin:10px 0 22px}.menu-actions{gap:10px}.menu-btn{padding:13px 14px;gap:11px}.menu-btn--primary{margin-top:28px}.menu-btn__title{font-size:15px;letter-spacing:.8px}.menu-btn__hint{font-size:11px}.menu-join__input{font-size:16px;letter-spacing:2px}.menu-join__row{gap:8px;margin-top:14px}.menu-back{padding:10px 12px;font-size:11.5px}.creation{padding:16px}.creation-brand{gap:9px}.creation-title{font-size:21px;letter-spacing:1.5px}.creation-sub{font-size:12.5px;margin:8px 0 18px}.class-grid{gap:11px}.class-card{padding:14px;border-radius:8px}.class-card__name{font-size:22px;letter-spacing:1.5px}.class-card__key{font-size:11.5px;padding:2px 7px}.class-card__tag{font-size:13px;margin:8px 0 11px}.class-card__stat{font-size:11.5px;padding:3px 7px}.class-card__ability{font-size:12.5px;margin-bottom:9px;line-height:1.45}.class-card__hp{font-size:11.5px}.name-field{margin-top:20px;gap:10px}.name-input{font-size:16px;padding:12px 14px}.start-btn{padding:13px;font-size:14px;letter-spacing:1px}}@media (max-width: 360px){.title{font-size:13px}.turn-num{font-size:14px}.header-right{gap:6px}.change-char{padding:6px 7px}.msg{font-size:13px;padding:8px 10px}.stat__val{font-size:16px}.mod-active__formula{font-size:22px}.auth-title,.menu-title,.creation-title{font-size:19px}.class-card__name{font-size:20px}}.log,.sidebar,.auth,.menu,.creation{-webkit-overflow-scrolling:touch}@media (max-width: 768px) and (pointer: coarse){.auth-submit,.start-btn,.menu-btn,.check-roll-btn,.send-btn,.roll-btn{min-height:42px}}.my-rooms{margin-top:24px;padding-top:18px;border-top:1px solid var(--line)}.my-rooms__title{font-size:11px;letter-spacing:1.5px;color:var(--dim);margin-bottom:10px}.my-rooms__list{display:flex;flex-direction:column;gap:6px}.my-rooms__item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#22e3ff0a;border:1px solid var(--line);border-radius:4px;color:var(--text);font-family:var(--font-body);cursor:pointer;transition:all .15s;text-align:left}.my-rooms__item:hover:not(:disabled){border-color:var(--cyan);background:#22e3ff14}.my-rooms__item:disabled{opacity:.4;cursor:not-allowed}.my-rooms__main{flex:1;min-width:0}.my-rooms__name{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-rooms__class{color:var(--dim)}.my-rooms__code{font-family:var(--font-display);font-size:11px;letter-spacing:1px;color:var(--cyan);margin-top:3px}.my-rooms__play{color:var(--cyan);flex-shrink:0;margin-left:10px}.my-rooms__row{display:flex;align-items:stretch;gap:6px}.my-rooms__row .my-rooms__item{flex:1}.my-rooms__owner{margin-left:8px;font-size:9px;letter-spacing:1px;color:var(--magenta);border:1px solid rgba(255,46,136,.4);border-radius:8px;padding:1px 6px}.my-rooms__delete{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:40px;background:#ff2e880f;border:1px solid var(--line);border-radius:4px;color:var(--dim);cursor:pointer;transition:all .15s}.my-rooms__delete:hover{border-color:var(--magenta);color:var(--magenta);background:#ff2e8824}.delete-modal__warn{margin:10px 0 14px;font-size:12px;line-height:1.5;color:var(--dim)}.delete-modal__confirm{background:var(--magenta)!important}.delete-modal__confirm:hover:not(:disabled){box-shadow:0 0 18px var(--magenta)!important}.room-code-pill{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background:#ff2e8814;border:1px solid rgba(255,46,136,.35);border-radius:12px;font-family:var(--font-display);font-size:11px;letter-spacing:1.5px;color:var(--pink);cursor:pointer;transition:background .15s}.room-code-pill:hover{background:#ff2e8829}.room-code-pill__label{font-size:9px;color:var(--dim);letter-spacing:1px}.players-list{display:flex;flex-direction:column;gap:5px}.player-item{display:flex;align-items:center;gap:8px;padding:6px 8px;background:#22e3ff0a;border-radius:3px;font-size:12.5px}.player-item__name{color:var(--text)}.player-item__class{color:var(--dim);font-size:11px}.player-item__you{color:var(--cyan);font-size:10px;letter-spacing:1px}.player-block{border:1px solid transparent;border-radius:3px}.player-block--active{border-color:#ff2e8880;box-shadow:0 0 8px #ff2e8833}.player-item--btn{width:100%;border:none;cursor:pointer;font-family:var(--font-body);transition:background .15s}.player-item--btn:hover:not(:disabled){background:#22e3ff17}.player-item--btn:disabled{cursor:default}.player-item__turn{color:var(--magenta);font-size:9px;letter-spacing:1px;border:1px solid rgba(255,46,136,.45);border-radius:8px;padding:1px 6px}.player-sheet{padding:8px 10px 10px;background:#22e3ff08;border-top:1px solid var(--line);font-size:11.5px}.player-sheet__hp{color:var(--magenta);margin-bottom:6px;font-size:11px}.player-sheet__stats{display:grid;grid-template-columns:repeat(4,1fr);gap:5px}.player-sheet__stat{display:flex;flex-direction:column;align-items:center;padding:4px 2px;background:#22e3ff0d;border-radius:3px}.player-sheet__stat-key{font-size:9px;color:var(--dim);letter-spacing:1px}.player-sheet__stat-val{font-size:13px;color:var(--text)}.player-sheet__stat-mod{font-size:10px;color:var(--cyan)}.player-sheet__quest{margin-top:7px;color:var(--cyan);font-size:11px}.player-sheet__inv{margin-top:6px;color:var(--dim);font-size:11px;line-height:1.5}.turn-notice{margin:0 0 8px;padding:7px 12px;background:#ff2e881f;border:1px solid rgba(255,46,136,.4);border-radius:4px;color:var(--magenta);font-size:12px;text-align:center}.turn-wait{margin:0 0 8px;padding:7px 12px;background:#22e3ff0f;border:1px solid var(--line);border-radius:4px;color:var(--dim);font-size:12px;text-align:center}.menu-join__back{margin-bottom:14px;align-self:flex-start}.public-rooms{margin-bottom:18px}.public-rooms__title{font-size:11px;letter-spacing:1.5px;color:var(--dim);margin-bottom:10px}.public-rooms__empty{padding:14px 10px;text-align:center;font-size:12px;color:var(--dim);font-style:italic}.public-rooms__list{display:flex;flex-direction:column;gap:6px;max-height:280px;overflow-y:auto;-webkit-overflow-scrolling:touch}.public-room{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:#22e3ff0a;border:1px solid var(--line);border-radius:4px;color:var(--text);font-family:var(--font-body);cursor:pointer;transition:all .15s;text-align:left}.public-room:hover{border-color:var(--cyan);background:#22e3ff14}.public-room--mine{border-color:#ff2e8859;background:#ff2e880a}.public-room--mine:hover{border-color:var(--pink);background:#ff2e8814}.public-room__main{flex:1;min-width:0}.public-room__name{display:flex;align-items:center;gap:6px;font-size:13.5px;color:var(--text);margin-bottom:4px}.public-room__lock{color:var(--pink);flex-shrink:0}.public-room__mine-tag{margin-left:6px;padding:1px 6px;background:#ff2e882e;border-radius:3px;font-family:var(--font-display);font-size:9px;letter-spacing:1px;color:var(--pink)}.public-room__meta{display:flex;flex-wrap:wrap;gap:5px;font-size:11px;color:var(--dim)}.public-room__code{font-family:var(--font-display);color:var(--cyan);letter-spacing:1px}.public-room__sep{opacity:.5}.public-room__play{color:var(--cyan);flex-shrink:0;margin-left:10px}.join-by-code{margin-top:18px;padding-top:16px;border-top:1px solid var(--line)}.join-by-code__title{display:flex;align-items:center;gap:5px;font-size:11px;letter-spacing:1.5px;color:var(--dim);margin-bottom:10px}.join-by-code__row{display:flex;gap:8px}.join-by-code__row .menu-join__input{flex:1;text-align:left}.join-by-code__submit{margin-top:0;width:auto;padding:0 18px;white-space:nowrap}.room-fields{margin-top:16px;padding:14px 14px 12px;background:#22e3ff08;border:1px solid var(--line);border-radius:4px;display:flex;flex-direction:column;gap:10px}.room-fields__hint{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--dim);line-height:1.4}.pwd-modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#04060cd9;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.pwd-modal{background:#0a0d18;border:1px solid var(--cyan);border-radius:6px;padding:22px;max-width:360px;width:100%;box-shadow:0 0 30px #22e3ff40}.pwd-modal__title{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-size:13px;letter-spacing:1.5px;color:var(--pink);margin-bottom:6px}.pwd-modal__sub{font-size:12px;color:var(--dim);margin-bottom:14px;word-break:break-word}.pwd-modal__row{display:flex;gap:8px;margin-top:16px}.pwd-modal__row .auth-submit{margin-top:0;flex:1}.pwd-modal__row .menu-back{flex-shrink:0}@media (max-width: 480px){.pwd-modal{padding:18px}.pwd-modal__title{font-size:12px}}
