:root{--bg: #0a1214;--bg2: #0e191c;--panel: #122024;--panel2: #16282d;--line: #1f3a40;--ink: #e8e2d0;--ink-dim: #9aa89e;--ember: #ff7a36;--verdigris: #4fae8d;--gold: #ffd24d;--danger: #ff5d5d;--parchment: #e8dcb8;--parchment-ink: #3b2f1d;--resonant: #7ad7ff;font-size:16px}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{margin:0;height:100%;background:var(--bg);color:var(--ink);font-family:Segoe UI,system-ui,sans-serif;overflow:hidden;touch-action:manipulation;-webkit-user-select:none;user-select:none}#stage{position:fixed;inset:0;width:100%;height:100%;display:block}#ui{position:fixed;inset:0;pointer-events:none;display:flex;flex-direction:column}#ui>*{pointer-events:auto}button{font:inherit;color:inherit;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:10px 16px;cursor:pointer;min-height:44px}button:active{transform:translateY(1px)}button.primary{background:linear-gradient(180deg,#c8511f,#a23c12);border-color:#e06a2e;color:#fff4ea;font-weight:700;letter-spacing:.03em}button.ghost{background:transparent}button:disabled{opacity:.45;cursor:default}input{font:inherit;color:var(--ink);background:var(--bg2);border:1px solid var(--line);border-radius:10px;padding:10px 12px;min-height:44px;text-transform:uppercase}input::placeholder{color:var(--ink-dim);text-transform:none}.pixel{image-rendering:pixelated}.screen{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:20px;overflow-y:auto}.title-logo{font-size:clamp(40px,11vw,76px);font-weight:800;letter-spacing:.14em;background:linear-gradient(180deg,#ffd9a0,var(--ember) 55%,#8a2f0e);-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 0 28px rgba(255,122,54,.25);margin:0}.title-sub{color:var(--ink-dim);margin:-6px 0 14px;text-align:center;max-width:34ch}.stack{display:flex;flex-direction:column;gap:10px;width:min(340px,92vw)}.row{display:flex;gap:10px;align-items:center}.row>*{flex:1}.room-code{font-size:44px;font-weight:800;letter-spacing:.35em;padding-left:.35em;color:var(--gold)}.seat-card{display:flex;gap:12px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:12px;width:min(340px,92vw);text-align:left}.seat-card.me{border-color:var(--verdigris)}.seat-card .who{flex:1}.seat-card .who .nm{font-weight:700}.seat-card .who .ttl{color:var(--ink-dim);font-size:13px}.seat-card .who .pasv{color:var(--verdigris);font-size:12px;margin-top:4px}.portrait{width:64px;height:64px;flex:none}.hud{display:flex;flex-direction:column;height:100%;padding:max(6px,env(safe-area-inset-top)) 8px max(8px,env(safe-area-inset-bottom));gap:6px}.topbar{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--ink-dim)}.topbar .spacer{flex:1}.timerbar{position:relative;height:4px;border-radius:2px;background:var(--line);overflow:hidden;flex:1;max-width:130px}.timerbar>div{position:absolute;inset:0;background:var(--ember);transform-origin:left}.scene-label{text-align:center;color:#2c4a48;font-size:11px;letter-spacing:.3em;margin-top:6px}.enemies{display:flex;justify-content:center;align-items:flex-end;gap:10px;min-height:118px;flex:1}.enemy{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;border-radius:12px;position:relative;max-width:130px}.enemy .sprite{width:72px;height:72px}.enemy.boss .sprite{width:104px;height:104px}.enemy .nm{font-size:11px;color:var(--ink-dim);text-align:center;line-height:1.15}.enemy.dead{opacity:.18;filter:grayscale(1)}.hpbar{width:86px;height:8px;background:#2a1518;border-radius:4px;overflow:hidden;position:relative}.hpbar>.fill{position:absolute;inset:0;background:linear-gradient(180deg,#ff7a6a,#c43a35);transform-origin:left;transition:transform .25s ease-out}.hpbar>.lbl{position:absolute;inset:0;font-size:7px;line-height:8px;text-align:center;color:#ffe9e4}.intent{font-size:11px;background:var(--panel);border:1px solid var(--line);border-radius:8px;padding:2px 7px;white-space:nowrap}.intent.attack{border-color:#7a3a32;color:#ffb09c}.intent.invert{border-color:var(--gold);color:var(--gold)}.chips{display:flex;gap:4px;font-size:10px;flex-wrap:wrap;justify-content:center;min-height:14px}.chip{padding:1px 5px;border-radius:6px;background:var(--panel2);border:1px solid var(--line)}.chip.burn{color:#ffac72;border-color:#84412a}.chip.brittle{color:#b9e8ff;border-color:#3b6c84}.chip.dampen{color:#c9b8ff;border-color:#56448a}.chip.ward{color:#d7e3ea;border-color:#5a707d}.chip.veil{color:#bfe8d2;border-color:#3f7a62}.channel-wrap{position:relative;padding:4px 0 2px}.channel-label{font-size:10px;letter-spacing:.25em;color:var(--ink-dim);text-align:center;margin-bottom:3px}.channel-label .inverted{color:var(--gold);font-weight:700}.channel{display:flex;gap:6px;justify-content:flex-start;align-items:center;min-height:78px;padding:6px 10px;margin:0 auto;max-width:100%;overflow-x:auto;background:linear-gradient(180deg,#4fae8d12,#4fae8d05);border:1px dashed #2c4a44;border-radius:14px;scrollbar-width:none}.channel:empty:after{content:"pour elements here, in order";color:#3f5d57;font-size:12px;margin:auto}.card{position:relative;width:52px;height:66px;flex:none;border-radius:9px;background:var(--panel);border:2px solid var(--el, #555);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1px;cursor:pointer;transition:transform .12s ease-out,box-shadow .12s ease-out}.card .sym{font-size:21px;font-weight:800;color:var(--el, #ccc);line-height:1}.card .nm{font-size:8.5px;color:var(--ink-dim);letter-spacing:.04em}.card .cost{position:absolute;top:-7px;left:-7px;width:18px;height:18px;border-radius:50%;background:#0d1f2b;border:1px solid var(--line);color:var(--gold);font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center}.card.periodic .sym{text-shadow:0 0 9px var(--el)}.card.periodic:after{content:"";position:absolute;inset:2px;border-radius:6px;border:1px dotted color-mix(in srgb,var(--el) 55%,transparent);pointer-events:none}.card.owner-a{box-shadow:-3px 0 #c8511f}.card.owner-b{box-shadow:3px 0 #2e7ec0}.card.glow{animation:cardglow 1.1s ease-in-out infinite alternate}@keyframes cardglow{0%{box-shadow:0 0 4px 1px color-mix(in srgb,var(--gold) 45%,transparent)}to{box-shadow:0 0 13px 3px color-mix(in srgb,var(--gold) 80%,transparent)}}.card.suggested{animation:suggested .9s ease-in-out 2}@keyframes suggested{0%,to{transform:translateY(0)}50%{transform:translateY(-10px) scale(1.07)}}.card.dragging{opacity:.85;transform:scale(1.12);z-index:30}.card.disabled{opacity:.4}.casters{display:flex;gap:8px}.caster{flex:1;display:flex;gap:8px;align-items:center;background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:6px 8px}.caster.downed{filter:grayscale(.9);opacity:.65}.caster .sprite{width:44px;height:44px;flex:none}.caster .col{flex:1;min-width:0}.caster .nm{font-size:12px;font-weight:700;display:flex;justify-content:space-between;align-items:baseline}.caster .nm .you{font-size:9px;color:var(--verdigris)}.caster .hpbar{width:100%;height:10px;margin:3px 0}.caster .hpbar>.fill{background:linear-gradient(180deg,#67d18f,#2f8f55)}.caster .hpbar>.lbl{font-size:8px;line-height:10px}.energy{display:flex;gap:3px;align-items:center}.pip{width:9px;height:9px;border-radius:50%;background:#233;border:1px solid var(--line)}.pip.on{background:radial-gradient(circle at 35% 35%,#ffe9a8,var(--gold));border-color:var(--gold)}.blockchip{font-size:10px;color:#d7e3ea;background:#1c2f3a;border:1px solid #41606e;border-radius:6px;padding:0 5px;margin-left:5px}.hands{display:flex;flex-direction:column;gap:5px}.hand-head{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--ink-dim)}.hand{display:flex;gap:7px;overflow-x:auto;padding:8px 4px 10px;min-height:84px;scrollbar-width:none}.hand .card:active{transform:translateY(-6px)}.hand.partner{min-height:56px;padding:3px 4px}.hand.partner .card{width:36px;height:46px;pointer-events:none}.hand.partner .card .sym{font-size:15px}.hand.partner .card .nm,.hand.partner .card .cost{display:none}.actionbar{display:flex;gap:8px;align-items:center}.actionbar .lock{flex:1;font-size:17px}.actionbar .lock.locked{background:#234034;border-color:var(--verdigris);color:var(--verdigris)}.combo-banner{position:absolute;left:50%;top:30%;transform:translate(-50%,-50%);text-align:center;pointer-events:none;z-index:40;animation:bannerin .22s ease-out}.combo-banner .knm{font-size:clamp(26px,7vw,42px);font-weight:800;letter-spacing:.06em;color:var(--ink);text-shadow:0 0 18px rgba(255,122,54,.6)}.combo-banner.attack .knm{color:#ffb09c}.combo-banner.defense .knm{color:#a8d8ff}.combo-banner.technique .knm{color:#b8f0cf}.combo-banner .tag{font-size:12px;letter-spacing:.3em;color:var(--ink-dim)}.combo-banner .tag .res{color:var(--resonant)}@keyframes bannerin{0%{transform:translate(-50%,-50%) scale(.6);opacity:0}to{transform:translate(-50%,-50%) scale(1);opacity:1}}.float{position:absolute;font-weight:800;font-size:18px;pointer-events:none;z-index:45;animation:floatup 1s ease-out forwards;text-shadow:0 1px 3px rgba(0,0,0,.8)}@keyframes floatup{0%{transform:translateY(0);opacity:1}to{transform:translateY(-46px);opacity:0}}.shake{animation:shake .3s}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px,2px)}50%{transform:translate(4px,-2px)}75%{transform:translate(-3px,1px)}}.overlay{position:absolute;inset:0;background:#050a0cd1;display:flex;align-items:center;justify-content:center;z-index:60;padding:16px}.sheet{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:18px;width:min(420px,94vw);max-height:86vh;overflow-y:auto;display:flex;flex-direction:column;gap:12px}.sheet h2{margin:0;font-size:19px}.sheet .sub{color:var(--ink-dim);font-size:13px;margin:-6px 0 0}.tome-sheet{background:var(--parchment);color:var(--parchment-ink);border-color:#b9a87c;font-family:Georgia,Times New Roman,serif}.tome-sheet h2{font-variant:small-caps;letter-spacing:.08em}.tome-sheet .sub{color:#7a6a4a}.tome-entry{border-bottom:1px solid #cdbd93;padding:7px 0}.tome-entry .seq{display:inline-flex;gap:4px;margin-right:8px;vertical-align:middle}.tome-entry .nm{font-weight:700}.tome-entry .kind{font-size:11px;color:#8a7240;margin-left:6px;font-variant:small-caps}.tome-entry .fx{font-size:13px;color:#5d4d2e}.tome-entry .fl{font-size:12px;font-style:italic;color:#8a7a55}.tome-entry.new .nm:after{content:" • fresh ink";color:#a23c12;font-size:11px}.tome-entry.ghost{opacity:.75}.glyph{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:5px;border:1.5px solid var(--el, #777);color:var(--el, #777);font-size:12px;font-weight:800;background:#ffffff59}.glyph.unknown{border-style:dashed;color:#8a7a55;border-color:#b9a87c}.map-depths{display:flex;flex-direction:column-reverse;gap:6px}.map-row{display:flex;gap:8px;align-items:center;opacity:.45}.map-row.current{opacity:1}.map-row .d{width:30px;font-size:12px;color:var(--ink-dim)}.map-row .nodes{display:flex;gap:8px;flex:1}.map-row .nodes button{flex:1}.map-row .nodes .done{flex:1;text-align:center;padding:10px;color:var(--ink-dim);font-size:13px}.vein{display:flex;gap:12px;justify-content:center}.vein .pick{display:flex;flex-direction:column;gap:8px;align-items:center}.vein .to{font-size:11px;padding:6px 8px;min-height:34px}.results-banner{font-size:clamp(30px,9vw,52px);font-weight:800;letter-spacing:.1em}.results-banner.won{color:var(--gold);text-shadow:0 0 24px rgba(255,210,77,.5)}.results-banner.lost{color:var(--danger)}.toast{position:absolute;bottom:110px;left:50%;transform:translate(-50%);background:var(--panel2);border:1px solid var(--line);padding:8px 16px;border-radius:10px;z-index:80;font-size:14px;animation:toastin .18s ease-out}@keyframes toastin{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.netbar{position:absolute;top:0;left:0;right:0;background:#5a1d1d;color:#ffd9d0;text-align:center;font-size:13px;padding:5px;z-index:90}@media(prefers-reduced-motion:reduce){.shake,.card.suggested,.card.glow{animation:none!important}*{transition-duration:.01ms!important}}
