:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--surface: rgba(255, 255, 255, .88);--surface-strong: rgba(255, 255, 255, .96);--ink: #1f2937;--muted: #5b7083;--grid-line: rgba(95, 129, 150, .14);--frame: #d7e8ee;--zone-text: #163240;--zone-head: linear-gradient(180deg, #f6d6c8 0%, #efc4b6 100%);--zone-neck: linear-gradient(180deg, #f4d5c8 0%, #edc1b0 100%);--zone-shoulder: linear-gradient(180deg, #d8e8eb 0%, #c3d7dc 100%);--zone-chest: linear-gradient(180deg, #f3b3a5 0%, #e79887 100%);--zone-upper-arm: linear-gradient(180deg, #d9e6ea 0%, #c2d6dd 100%);--zone-lower-arm: linear-gradient(180deg, #d6e3e8 0%, #bfd0d8 100%);--zone-hand: linear-gradient(180deg, #e6c0b0 0%, #dba898 100%);--zone-abdomen: linear-gradient(180deg, #f1c7ae 0%, #e8ae91 100%);color-scheme:light;color:#2c3e50;background-color:#f0f7fa;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh;background:radial-gradient(circle at top,rgba(245,180,159,.2),transparent 30%),linear-gradient(135deg,#e0f2fe,#fff 52%,#f8ede7)}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center;width:100%}h1{font-size:3.2em;line-height:1.1;margin-bottom:2rem;color:#0284c7}h2{color:#0369a1}button{border-radius:8px;border:1px solid transparent;padding:.8em 2em;font-size:1.2rem;font-weight:600;font-family:inherit;background-color:#0284c7;cursor:pointer;transition:all .25s ease;margin:10px;color:#fff;box-shadow:0 4px 6px #0284c733}button:hover{background-color:#0369a1;transform:translateY(-2px);box-shadow:0 6px 12px #0284c74d}button:active{transform:translateY(0)}button:disabled{opacity:.5;cursor:not-allowed;transform:none}input{padding:12px 20px;font-size:1.5rem;margin:20px 0;border-radius:8px;border:2px solid #bae6fd;background:#fff;color:#0f172a;text-align:center;text-transform:uppercase;width:100%;box-sizing:border-box;letter-spacing:2px;transition:all .25s ease;box-shadow:inset 0 2px 4px #00000005}input:focus{outline:none;border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e933}input::placeholder{color:#94a3b8}.panel{background:var(--surface-strong);padding:3rem;border-radius:16px;max-width:450px;margin:0 auto;box-shadow:0 10px 30px #0ea5e91a;border:1px solid #e0f2fe}.player-list{list-style-type:none;padding:0;text-align:left;max-width:350px;margin:20px auto}.player-item{padding:15px 20px;margin:10px 0;background:#f8fafc;border-radius:8px;display:flex;justify-content:space-between;align-items:center;font-size:1.1rem;border-left:4px solid #cbd5e1;color:#334155;animation:slideIn .3s ease;box-shadow:0 2px 4px #00000005}.player-item.is-me{border-left-color:#10b981;background:#ecfdf5;font-weight:500;color:#065f46}.player-item.is-host:after{content:"🏥";font-size:1.2rem}.error{color:#ef4444;margin-top:10px;min-height:24px;font-weight:500}.room-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:1px solid #e2e8f0}.room-code-display{font-size:3rem;letter-spacing:5px;font-weight:800;color:#0ea5e9;margin:10px 0;text-shadow:0 2px 4px rgba(14,165,233,.1)}.game-shell{width:min(100%,1180px);margin:0 auto;padding:2.25rem;border-radius:28px;background:linear-gradient(180deg,#ffffffeb,#f7fbfce6);box-shadow:0 24px 60px #22495e24;border:1px solid rgba(215,232,238,.95)}.game-heading{display:flex;justify-content:center;margin-bottom:1.75rem}.game-heading h1{margin:0}.game-kicker{margin:0 0 .25rem;text-transform:uppercase;letter-spacing:.24em;font-size:.78rem;font-weight:700;color:#7b9aac}.game-subtitle{margin:.75rem 0 0;color:var(--muted);font-size:1rem}.game-phase-card{margin:0 auto;max-width:760px;padding:1.5rem;border-radius:20px;border:1px solid #d7e8ee;background:#ffffffd9;box-shadow:0 12px 28px #395f741a}.game-phase-card.wide{max-width:920px}.game-phase-card h2{margin:0 0 .25rem;color:#0c75ad}.game-phase-card p{margin:.3rem 0;color:#456275}.loading-pulse{width:74px;height:74px;border-radius:50%;margin:0 auto .8rem;background:radial-gradient(circle,#9fd3e6,#56abd0 55%,#1790c7);box-shadow:0 0 #1790c766;animation:pulse 1.5s infinite}.countdown-badge{margin:1rem auto 0;width:fit-content;padding:.4rem .9rem;border-radius:999px;font-weight:800;color:#0b5f8e;background:#b0e0f599;border:1px solid rgba(109,188,225,.7)}.role-grid{margin-top:1rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.9rem}.role-card{margin:0;width:100%;min-height:130px;display:flex;align-items:stretch;gap:.8rem;padding:.85rem;border-radius:16px;border:1px solid #cfe3eb;background:#f8fcfd;box-shadow:none;color:#173a4d;text-align:left}.role-card:hover{transform:none;box-shadow:0 8px 20px #507b9224;border-color:#8cc4dd;background:#f2f9fc}.role-card.selected{border-color:#3c99c4;background:#eaf6fb;box-shadow:0 10px 22px #237ca733}.role-art{width:96px;min-width:96px;min-height:96px;border-radius:12px;background:linear-gradient(180deg,#ddeef4,#c5e1ec);display:flex;align-items:center;justify-content:center;font-size:2rem;overflow:hidden}.role-art-image{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.role-content{display:flex;flex-direction:column;justify-content:space-between}.role-title-row{display:flex;justify-content:space-between;align-items:center;gap:.6rem}.role-title-row h3{margin:0;font-size:1.02rem}.role-tag{font-size:.68rem;letter-spacing:.06em;text-transform:uppercase;font-weight:700;color:#2e6f8f;background:#d7eefa;border-radius:999px;padding:.18rem .52rem}.role-content p{margin-top:.45rem;font-size:.88rem;line-height:1.25}.role-skills{margin:.5rem 0 0;padding:0;list-style:none;display:grid;grid-template-columns:1fr;gap:.22rem}.role-skills li{display:flex;justify-content:space-between;gap:.4rem;font-size:.78rem;color:#355b71}.role-skills strong{color:#0f5f88}.status-copy{margin-top:.95rem;font-size:.96rem;font-weight:600;color:#2a5f7c}.origin-layout{display:grid;grid-template-columns:minmax(0,1fr) 360px;gap:1rem;align-items:start}.origin-main{min-width:0}.phase-header-row{display:flex;justify-content:space-between;align-items:center;gap:.8rem;margin-bottom:.6rem}.phase-header-row h2{margin:0;color:#0c75ad}.phase-header-row p{margin:.25rem 0 0;color:#456275}.avatar-pill{display:inline-flex;align-items:center;gap:.45rem;padding:.36rem .7rem;border-radius:999px;background:#edf7fb;border:1px solid #cbe4ef;color:#215875;font-weight:700}.avatar-icon{font-size:1.25rem;line-height:1;display:inline-flex;align-items:center;justify-content:center}.avatar-pill-image{width:32px;height:32px;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.avatar-image-placeholder{width:100%;height:100%;border-radius:10px;border:1px solid rgba(124,163,181,.45);background:radial-gradient(circle at 50% 34%,rgba(173,201,214,.95) 0 18%,transparent 19%),radial-gradient(circle at 50% 74%,rgba(173,201,214,.95) 0 28%,transparent 29%),linear-gradient(180deg,#ecf6fafa,#dcecf4f2)}.avatar-image-placeholder.small{width:32px;height:32px;border-radius:8px}.avatar-image-placeholder.tiny{width:18px;height:18px;border-radius:6px}.warning-copy{margin:.35rem 0 .7rem;color:#9c4f2c;font-weight:600}.origin-panel{position:sticky;top:1rem;border-radius:18px;border:1px solid #cfe3eb;background:#ffffffe0;padding:1.1rem;box-shadow:0 8px 20px #4e71831f}.origin-panel h3{margin:0;color:#0f6b9b}.origin-panel p{margin:.4rem 0 .75rem;color:#4a677b;font-size:.9rem}.tile-matrix{display:grid;gap:.55rem}.tile-button{margin:0;border-radius:12px;border:1px solid #d0e3ec;background:#f6fbfe;box-shadow:none;color:#20546d;min-height:56px;padding:.65rem .45rem;font-size:.92rem;font-weight:700}.tile-button:hover{transform:none;background:#eaf6fc;box-shadow:none}.tile-button.selected{border-color:#228dc2;background:#dff1fb;color:#0e4e70;font-weight:800}.body-zone{border:none}.body-zone:disabled{cursor:not-allowed}.zone-dimmed{opacity:.24;filter:grayscale(.35)}.zone-active{outline:2px solid #1a98cc;outline-offset:-2px}.waiting-copy{margin-bottom:0}.game-error{margin-top:.9rem}.game-shell-active{width:min(100%,calc(100vw - 2.25rem));max-width:100%;padding:1.5rem}.battle-shell{display:flex;flex-direction:column;gap:1rem}.battle-topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem}.dice-box-wrap{position:relative}.dice-box-trigger{margin:0;padding:.55rem .95rem;border-radius:999px;border:1px solid #e9b6be;background:linear-gradient(180deg,#fff2f4,#ffe8ec);color:#8d2f3f;font-weight:700;box-shadow:0 8px 16px #9d3a4c24}.dice-box-menu{position:absolute;top:calc(100% + .5rem);left:0;z-index:6;width:240px;padding:.8rem;border-radius:16px;border:1px solid #edb6c1;background:linear-gradient(180deg,#fff7f8,#ffeef1);box-shadow:0 14px 28px #6f263829;text-align:left}.dice-box-menu h3{margin:0;color:#8f3042}.dice-box-menu p{margin:.35rem 0 .65rem;color:#8a4a59;font-size:.88rem}.dice-options{display:grid;grid-template-columns:1fr;gap:.35rem;margin-bottom:.65rem}.dice-option-row{display:flex;justify-content:space-between;align-items:center;font-weight:700;color:#8d2f3f}.dice-counter{display:inline-flex;align-items:center;gap:.35rem}.dice-counter button{margin:0;min-width:28px;min-height:28px;padding:0;border-radius:8px;border:1px solid #d59ead;background:#fff;color:#8a3041;box-shadow:none}.dice-counter strong{min-width:1.2rem;text-align:center}.dice-roll-button{width:100%;margin:0;padding:.55rem .7rem;border-radius:10px;border:1px solid #cc6f85;background:linear-gradient(180deg,#e44767,#bf3152);color:#fff7f8;box-shadow:none}.dice-roll-button:disabled{opacity:.45;cursor:not-allowed}.dice-total-copy{margin:.5rem 0 0;font-weight:700;color:#7c2536}.team-hp-card{flex:1;display:flex;align-items:center;gap:.9rem;padding:.9rem 1rem;border-radius:18px;background:linear-gradient(180deg,#fff7f7fa,#ffeeeef0);border:1px solid #f2c7c7}.hp-heart{font-size:1.65rem;color:#d9304a}.hp-heart.warning{animation:heartbeat-slow 1.6s infinite}.hp-heart.critical{animation:heartbeat-fast .7s infinite}.hp-copy{flex:1;min-width:0}.hp-label{margin:0 0 .35rem;font-size:.78rem;text-transform:uppercase;letter-spacing:.12em;color:#9a5460}.hp-track{width:100%;height:14px;border-radius:999px;overflow:hidden;background:#9a54602e}.hp-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#f05a6c,#d9304a)}.hp-value{font-size:1rem;color:#8e293b}.battle-room-chip{padding:.55rem .85rem;border-radius:999px;background:#edf7fb;border:1px solid #cce7f0;color:#215875;font-weight:700;white-space:nowrap}.battle-layout{display:grid;grid-template-columns:minmax(0,1.95fr) 180px minmax(480px,1.2fr);gap:1rem;align-items:stretch;min-height:720px}.battle-map-panel,.skills-rail,.info-panel{border-radius:22px;border:1px solid #efb9c2;background:#fffafbed;box-shadow:0 12px 26px #8f31451c}.battle-map-panel{padding:1rem}.skills-rail,.info-panel{padding:.8rem}.panel-section-heading{display:flex;justify-content:space-between;align-items:baseline;gap:.8rem;margin-bottom:.8rem;text-align:left}.panel-section-heading.compact{justify-content:center}.panel-section-heading h2{margin:0}.panel-section-heading p{margin:0;color:#557083}.battle-map{display:grid;width:100%;aspect-ratio:22 / 18;border-radius:18px;overflow:hidden;background:linear-gradient(180deg,#fbfdfd,#f1f8fa);border:1px solid #d7e8ee}.combat-tile{position:relative;min-width:0;min-height:0;border:1px solid rgba(95,129,150,.11);display:flex;align-items:center;justify-content:center}.combat-tile.is-void{background:#d2e0e72e;border-color:#5f81960f}.combat-tile.is-obscured{background:#162936db;border-color:#142531e6}.combat-tile.is-visible.zone-head,.combat-tile.is-visible.zone-neck,.combat-tile.is-visible.zone-shoulder-left,.combat-tile.is-visible.zone-shoulder-right,.combat-tile.is-visible.zone-chest,.combat-tile.is-visible.zone-upper-arm-left,.combat-tile.is-visible.zone-upper-arm-right,.combat-tile.is-visible.zone-lower-arm-left,.combat-tile.is-visible.zone-lower-arm-right,.combat-tile.is-visible.zone-hand-left,.combat-tile.is-visible.zone-hand-right,.combat-tile.is-visible.zone-abdomen{filter:saturate(.92) brightness(.98)}.combat-tile.is-move-target{box-shadow:inset 0 0 0 2px #22c55ed9;background-color:#22c55e26!important}.turn-bar{display:flex;align-items:center;gap:.75rem;padding:.65rem 1rem;border-radius:18px;border:1px solid #d4e8ef;background:linear-gradient(90deg,#eef7fb,#f5fbfd);flex-wrap:wrap}.turn-bar.pathogen_turn{border-color:#efb9c2;background:linear-gradient(90deg,#fff2f4,#fff8fa)}.turn-phase-label{font-weight:800;font-size:.95rem;color:#1e5f7a;flex:1}.turn-bar.pathogen_turn .turn-phase-label{color:#8a2f3f}.turn-roll-result{font-size:.92rem;color:#2d6e8a;font-weight:600}.turn-bar.pathogen_turn .turn-roll-result{color:#8a3544}.moves-done{color:#6b8e6b;font-weight:700}.turn-waiting-copy{font-size:.88rem;color:#7a9aaa;font-style:italic}.turn-action-btn{margin:0;padding:.42rem .85rem;border-radius:12px;font-weight:700;font-size:.88rem;box-shadow:none}.turn-action-btn.roll-btn{border:1px solid #8dc9e0;background:linear-gradient(180deg,#d6f0fa,#b8e4f5);color:#1b5e78}.turn-action-btn.end-btn{border:1px solid #a8d4a8;background:linear-gradient(180deg,#d4f0d4,#b8e4b8);color:#265e26}.combat-occupant-stack{display:flex;align-items:center;gap:.2rem}.combat-occupant{width:24px;height:24px;border-radius:8px;background:#ffffffe0;border:1px solid rgba(255,255,255,.95);display:inline-flex;align-items:center;justify-content:center;overflow:hidden;font-size:.9rem}.combat-occupant.is-self{box-shadow:0 0 0 2px #0284c780}.combat-occupant-image{width:100%;height:100%;object-fit:contain;image-rendering:pixelated;image-rendering:crisp-edges}.occupant-count{font-size:.7rem;font-weight:800;color:#fff;background:#0c2230bf;border-radius:999px;padding:.08rem .28rem}.skills-rail{display:flex;flex-direction:column}.skills-rail-list{display:flex;flex-direction:column;gap:.55rem}.skill-stat-card{border-radius:14px;padding:.8rem .65rem;background:linear-gradient(180deg,#fff4f6,#ffe9ee);border:1px solid #efbdc8;display:flex;flex-direction:column;gap:.35rem;text-align:center}.skill-stat-name{font-size:.85rem;color:#7f2f3e;font-weight:700}.skill-stat-level{font-size:1rem;color:#a3384d}.info-panel{display:flex;flex-direction:column;text-align:left;gap:.65rem}.repertoire-heading{margin:0;color:#8a2f3f}.info-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.45rem;margin-bottom:.85rem}.info-tab{margin:0;padding:.7rem .5rem;font-size:.95rem;border-radius:14px;border:1px solid #ebc5ce;background:#fff4f6;color:#89404f;box-shadow:none}.info-tab:hover{transform:none;box-shadow:none;background:#ffeef2}.info-tab.active{background:#ffe9ee;border-color:#eaa6b6;color:#973347}.info-body{border-radius:18px;border:1px solid #efc4cd;background:linear-gradient(180deg,#fffbfcfa,#fff2f6f7);padding:1rem;flex:1}.info-body h3{margin:0 0 .6rem;color:#933246}.notebook-body{display:flex;flex-direction:column;gap:.85rem}.notebook-section{margin-top:.3rem;border-radius:16px;border:1px solid #3a0a14;background:#0e0002d9;padding:.85rem}.notebook-section>h3{margin:0 0 .55rem;color:#ff8fa0}.info-body p{margin:.35rem 0;color:#774854}.info-list{margin:0 0 .8rem;padding-left:1rem;color:#6e3f4d}.info-list li{margin-bottom:.4rem}.repertoire-subtitle{margin:0;font-size:.9rem;color:#94515f}.repertoire-bookmarks{display:flex;gap:.45rem;flex-wrap:wrap}.bookmark-tab{margin:0;padding:.42rem .62rem;border-radius:12px 12px 0 0;border:1px solid #e8aebb;border-bottom-color:#d38294;background:linear-gradient(180deg,#ffe9ee,#ffdbe3);color:#8b3041;font-weight:700;box-shadow:none}.bookmark-tab.active{background:linear-gradient(180deg,#ffdde6,#ffcfdc);color:#7b1f30}.repertoire-notebook{border-radius:18px;border:1px solid #eebfcc;padding:1rem;background:repeating-linear-gradient(180deg,#fff8fa 0,#fff8fa 30px,#ffeef2 30px,#ffeef2 31px);box-shadow:inset 0 0 0 1px #ffffffbf}.repertoire-notebook h3,.repertoire-notebook h4{margin:0 0 .5rem;color:#852c3c}.repertoire-type{margin:0 0 .6rem;text-transform:uppercase;letter-spacing:.1em;font-size:.74rem;color:#a35262}.cross-check-panel{border-radius:16px;border:1px solid #efc4cd;background:linear-gradient(180deg,#fff8faf2,#ffeff4f2);padding:.85rem}.cross-check-panel h3{margin:0;color:#8d2f40}.cross-check-panel p{margin:.35rem 0 .65rem;color:#8b5360;font-size:.86rem}.cross-check-list{display:flex;flex-direction:column;gap:.5rem}.cross-check-item{display:flex;justify-content:space-between;align-items:center;gap:.7rem;border-radius:12px;border:1px solid #e7b6c2;background:#fff7f9;padding:.5rem .6rem;width:100%;margin:0}.cross-check-label-wrap{display:inline-flex;align-items:center;gap:.45rem}.cross-check-final-box{width:20px;height:20px;border-radius:4px;border:1px solid #c56f84;display:inline-flex;align-items:center;justify-content:center;color:#9f3048;font-size:.9rem;font-weight:800;line-height:1}.cross-check-name{color:#7f3343;font-weight:700}.cross-check-item.circled{border-radius:999px;border-width:2px;border-color:#bb415f}.cross-check-item.crossed .cross-check-name,.cross-check-item.crossed .cross-check-final-box{text-decoration:line-through;text-decoration-thickness:2px;text-decoration-color:#8e2e41}.cross-check-item.checked{border-color:#ff6b8a;box-shadow:inset 0 0 0 1px #ff6b8a47}.cross-check-state-label{text-transform:capitalize;font-size:.76rem;color:#7a3040}.body-grid-frame{display:flex;justify-content:center;overflow-x:auto;padding:1rem;border-radius:24px;background:linear-gradient(180deg,#ebf4f6b8,#f9fcfdf2);border:1px solid var(--frame)}.body-grid{width:704px;min-width:704px;height:576px;display:grid;grid-template-columns:repeat(11,64px);grid-template-rows:repeat(9,64px);gap:0;position:relative;border-radius:26px;padding:0;background:linear-gradient(var(--grid-line) 1px,transparent 1px),linear-gradient(90deg,var(--grid-line) 1px,transparent 1px),linear-gradient(180deg,#fbfdfd,#f3f8f8);background-size:64px 64px,64px 64px,100% 100%;box-shadow:inset 0 0 0 1px #d7e8eef2,0 12px 24px #48687a1a}.body-zone{margin:4px;border-radius:22px;border:1px solid rgba(255,255,255,.85);display:flex;flex-direction:column;justify-content:space-between;align-items:flex-start;padding:.8rem .9rem;text-align:left;color:var(--zone-text);box-shadow:inset 0 1px #ffffff73,0 10px 18px #475c691f;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.zone-code{display:inline-flex;align-items:center;justify-content:center;min-width:2.5rem;padding:.18rem .55rem;border-radius:999px;background:#ffffff8c;font-size:.82rem;font-weight:800;letter-spacing:.08em}.zone-name{font-size:.96rem;font-weight:700;line-height:1.1;text-wrap:balance}.zone-head,.zone-neck,.zone-hand-left,.zone-hand-right{align-items:center;text-align:center}.zone-head{background:var(--zone-head)}.zone-neck{background:var(--zone-neck)}.zone-shoulder-left,.zone-shoulder-right{background:var(--zone-shoulder)}.zone-chest{background:var(--zone-chest)}.zone-upper-arm-left,.zone-upper-arm-right{background:var(--zone-upper-arm)}.zone-lower-arm-left,.zone-lower-arm-right{background:var(--zone-lower-arm)}.zone-hand-left,.zone-hand-right{background:var(--zone-hand)}.zone-abdomen{background:var(--zone-abdomen)}@media (max-width: 900px){#root{padding:1rem}.game-shell{padding:1.25rem}.body-grid-frame{justify-content:flex-start}.role-grid,.origin-layout{grid-template-columns:1fr}.origin-panel{position:static}.battle-topbar{flex-direction:column;align-items:stretch}.dice-box-wrap{width:100%}.dice-box-menu{position:static;width:100%}.battle-layout{grid-template-columns:1fr;min-height:auto}}@media (max-width: 560px){.panel{padding:2rem 1.25rem}h1{font-size:2.5em}.zone-name{font-size:.82rem}.role-art{width:72px;min-width:72px}.phase-header-row{flex-direction:column;align-items:flex-start}.info-tabs{grid-template-columns:1fr}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%{box-shadow:0 0 #1790c76b;transform:scale(1)}70%{box-shadow:0 0 0 16px #1790c700;transform:scale(1.03)}to{box-shadow:0 0 #1790c700;transform:scale(1)}}@keyframes heartbeat-slow{0%,to{opacity:.85;transform:scale(1)}50%{opacity:.35;transform:scale(1.08)}}@keyframes heartbeat-fast{0%,to{opacity:1;transform:scale(1)}50%{opacity:.2;transform:scale(1.16)}}:root{color-scheme:dark}html,body,#root{width:100%;max-width:100%;overflow-x:hidden}*{transition:background-color .35s ease,border-color .35s ease,color .35s ease}body{display:block;min-width:0;margin:0;background:radial-gradient(circle at 50% 20%,rgba(61,0,16,.35),transparent 45%),radial-gradient(circle at 20% 80%,rgba(37,0,10,.25),transparent 50%),#0e0002;color:#ff8fa0}#root{margin:0;padding:0;box-sizing:border-box;max-width:100%}.app-scene{position:relative;width:100%;box-sizing:border-box;min-height:calc(100vh - 2rem);display:flex;align-items:center;justify-content:center;padding:.5rem;isolation:isolate}.ambient-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:0;overflow:hidden}.app-scene>*:not(.ambient-layer){position:relative;z-index:1}.scene-lobby{animation:lobbyPulse 4s ease-in-out infinite}.scene-lobby:before,.scene-lobby:after{content:"";position:absolute;top:0;bottom:0;width:16vw;min-width:120px;pointer-events:none;z-index:0;background:radial-gradient(ellipse at center,rgba(61,0,16,.55),rgba(26,5,8,.15) 65%,transparent 70%);filter:blur(8px)}.scene-lobby:before{left:-6vw}.scene-lobby:after{right:-6vw}.rbc-disc{position:absolute;width:clamp(24px,3vw,44px);aspect-ratio:1;border-radius:999px;background:radial-gradient(circle at center,#99001833 0,#99001833 28%,#c0112bbf 29%,#c0112bbf 72%,#6e0612d1 73%);opacity:.65;animation:rbcDrift linear infinite}.rbc-1{top:12%;left:-8%;animation-duration:23s;animation-delay:-3s;opacity:.52}.rbc-2{top:28%;left:-12%;animation-duration:31s;animation-delay:-11s;opacity:.75}.rbc-3{top:48%;left:-6%;animation-duration:38s;animation-delay:-5s;opacity:.88}.rbc-4{top:66%;left:-10%;animation-duration:27s;animation-delay:-15s;opacity:.6}.rbc-5{top:82%;left:-14%;animation-duration:34s;animation-delay:-7s;opacity:.78}.scene-game .plasma-particle{position:absolute;width:3px;height:3px;border-radius:999px;background:#e51c3ce6;box-shadow:0 0 8px #e51c3c73;animation:plasmaDrift linear infinite}.plasma-1{left:6%;bottom:-2%;animation-duration:7s;animation-delay:-1s}.plasma-2{left:14%;bottom:-3%;animation-duration:9s;animation-delay:-4s}.plasma-3{left:21%;bottom:-4%;animation-duration:8s;animation-delay:-6s}.plasma-4{left:29%;bottom:-5%;animation-duration:11s;animation-delay:-2s}.plasma-5{left:36%;bottom:-1%;animation-duration:10s;animation-delay:-7s}.plasma-6{left:44%;bottom:-3%;animation-duration:8s;animation-delay:-5s}.plasma-7{left:52%;bottom:-2%;animation-duration:9s;animation-delay:-8s}.plasma-8{left:60%;bottom:-4%;animation-duration:12s;animation-delay:-3s}.plasma-9{left:68%;bottom:-3%;animation-duration:10s;animation-delay:-9s}.plasma-10{left:75%;bottom:-2%;animation-duration:9s;animation-delay:-5s}.plasma-11{left:82%;bottom:-1%;animation-duration:11s;animation-delay:-7s}.plasma-12{left:88%;bottom:-3%;animation-duration:8s;animation-delay:-2s}.plasma-13{left:93%;bottom:-2%;animation-duration:10s;animation-delay:-6s}.plasma-14{left:97%;bottom:-5%;animation-duration:12s;animation-delay:-4s}h1,h2,h3,h4,strong,.hp-value,.turn-phase-label{color:#ff8fa0}p,li,span,.status-copy,.game-subtitle,.panel-section-heading p,.turn-waiting-copy{color:#7a3040}button{background:#8b0017;color:#ff8fa0;border:1px solid #3a0a14;box-shadow:inset 0 0 16px #c0112b33}button:hover{background:#c0112b;border-color:#ff6b8a;transform:none;box-shadow:inset 0 0 18px #ff6b8a47}input{background:#0e0002d9;border:1px solid #3a0a14;color:#ff8fa0;box-shadow:inset 0 0 10px #3d001073}input::placeholder{color:#7a3040}.panel,.game-shell,.game-phase-card,.origin-panel,.battle-map-panel,.skills-rail,.info-panel,.info-body,.repertoire-notebook,.cross-check-panel,.dice-box-menu,.tile-button,.role-card,.player-item,.turn-bar,.team-hp-card{background:#0e0002d9!important;border-color:#3a0a14!important;box-shadow:0 0 24px #3d001040}.room-code-display{color:#ff6b8a;text-shadow:0 0 14px rgba(192,17,43,.5)}.player-list{gap:.7rem}.player-item{border-radius:18px;border:1px solid rgba(192,17,43,.4)!important;background:#1a0508!important}.player-name-row{display:flex;justify-content:space-between;align-items:center;gap:.75rem;color:#ff8fa0}.player-status{display:block;margin-top:.2rem;font-size:.78rem;font-style:italic;color:#7a3040}.ready-dot{width:9px;height:9px;border-radius:999px;background:#c0112b;box-shadow:0 0 10px #c0112bcc;animation:readyPulse 1.8s ease-in-out infinite}.lobby-waiting-copy{font-size:.84rem;font-style:italic;margin-top:.7rem;color:#7a3040}.deploy-btn{background:#8b0017!important;color:#ff8fa0!important;box-shadow:inset 0 0 14px #c0112b59!important}.battle-topbar{align-items:stretch}.battle-meta{display:inline-flex;align-items:center;gap:.5rem}.battle-timer-chip,.battle-room-chip{border-radius:999px;border:1px solid #3a0a14;background:#1a0508e6!important;color:#ff8fa0!important;font-weight:700;padding:.55rem .82rem}.battle-timer-chip{animation:readyPulse 1.5s ease-in-out infinite}.hp-label{color:#7a3040}.hp-label.secondary{margin-top:.45rem}.hp-track,.charge-track{width:100%;height:12px;border-radius:999px;overflow:hidden;background:#1a0508;border:1px solid #3a0a14}.hp-fill{background:linear-gradient(90deg,#c0112b,#e51c3c)}.charge-track{margin-top:.2rem}.charge-fill{height:100%;border-radius:inherit;background:linear-gradient(90deg,#8b0017,#ff6b8a)}.battle-map{background:radial-gradient(circle at 20% 25%,rgba(26,5,8,.78) 0 16px,transparent 17px),radial-gradient(circle at 75% 30%,rgba(18,0,4,.85) 0 18px,transparent 19px),radial-gradient(circle at 35% 70%,rgba(26,5,8,.76) 0 15px,transparent 16px),repeating-linear-gradient(120deg,#3d001047 0,#3d001047 10px,#0e000233 10px,#0e000233 20px),linear-gradient(180deg,#120004,#1a0508);border-color:#3a0a14}.combat-tile{border-color:#3a0a1480}.combat-tile.is-obscured{background:#080001d1}.info-tab,.bookmark-tab,.cross-check-actions button,.dice-counter button,.turn-action-btn{background:#1a0508f0!important;border-color:#3a0a14!important;color:#ff8fa0!important}.info-tab.active,.bookmark-tab.active{border-color:#ff6b8a!important;color:#ff8fa0!important}.battle-shell.threat-active:before,.battle-shell.low-health:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:20px}.battle-shell{position:relative}.battle-shell.threat-active:before{box-shadow:inset 0 0 80px #e51c3c47;animation:threatPulse 1.5s ease-in-out infinite}.battle-shell.low-health:after{background:#e51c3c26;animation:lowHealthFlash 2.2s linear infinite}@keyframes lobbyPulse{0%,to{box-shadow:inset 0 0 #3d00101a}50%{box-shadow:inset 0 0 80px #3d001047}}@keyframes rbcDrift{0%{transform:translate(-8vw) rotate(0)}to{transform:translate(120vw,-28vh) rotate(360deg)}}@keyframes plasmaDrift{0%{transform:translateY(0) translate(0);opacity:.35}20%{opacity:.9}to{transform:translateY(-110vh) translate(-8px);opacity:0}}@keyframes readyPulse{0%,to{opacity:.65;box-shadow:0 0 4px #c0112b73}50%{opacity:1;box-shadow:0 0 14px #ff6b8a8c}}@keyframes threatPulse{0%,to{opacity:.35}50%{opacity:.8}}@keyframes lowHealthFlash{0%{opacity:.15}9%{opacity:0}to{opacity:0}}.body-grid-frame{background:radial-gradient(circle at 50% 40%,rgba(61,0,16,.22),transparent 62%),linear-gradient(180deg,#140104f2,#0e0002eb);border-color:#3a0a14}.body-grid{background:linear-gradient(rgba(122,48,64,.22) 1px,transparent 1px),linear-gradient(90deg,rgba(122,48,64,.22) 1px,transparent 1px),radial-gradient(circle at 20% 30%,rgba(61,0,16,.25),transparent 35%),radial-gradient(circle at 78% 68%,rgba(26,5,8,.24),transparent 42%),linear-gradient(180deg,#140003,#0e0002);background-size:64px 64px,64px 64px,100% 100%,100% 100%,100% 100%;box-shadow:inset 0 0 0 1px #3a0a14f2,0 10px 22px #3d001059}.body-zone{border:1px solid rgba(58,10,20,.75);box-shadow:inset 0 1px #ff8fa01f,0 8px 16px #3d00102e}.zone-dimmed{opacity:.36;filter:saturate(.75)}.zone-active{outline:2px solid rgba(255,107,138,.72);outline-offset:-2px;box-shadow:0 0 0 1px #ff6b8a59,0 0 18px #ff6b8a33}.tile-button{min-height:56px;background:#0e0002e6!important;border:1px solid #3a0a14!important}.tile-button:hover{border-color:#ff6b8a!important;background:#1a0508eb!important}.tile-button.selected{border-color:#ff6b8a!important;background:#3d001099!important;box-shadow:inset 0 0 0 1px #ff6b8a73}
