@import "https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;600;800&family=Inter:wght@400;500;700&display=swap";:root{--bg-dark:#0a0b10;--bg-panel:#161823;--bg-card:#202231;--text-main:#f0f0f0;--text-muted:#8b8d99;--primary:#ff2a5f;--primary-hover:#ff4d79;--secondary:#00d2ff;--color-pink:#ff6b9d;--color-blue:#4da6ff;--color-red:#ff4d4d;--color-green:#2ecc71;--color-orange:#f39c12;--color-free:#9b59b6;--glass-bg:#16182399;--glass-border:#ffffff1a;--glass-shadow:0 8px 32px 0 #0000005e;--font-heading:"Outfit", sans-serif;--font-body:"Inter", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background-color:var(--bg-dark);color:var(--text-main);background-image:radial-gradient(circle at 15%,#ff2a5f14,#0000 25%),radial-gradient(circle at 85% 30%,#00d2ff14,#0000 25%);min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-family:var(--font-heading)}.app-container{flex-direction:column;min-height:100vh;display:flex}.app-view-switch{z-index:1200;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#0a0b10d1;border:1px solid #ffffff24;border-radius:8px;gap:6px;padding:5px;display:flex;position:fixed;top:12px;left:50%;transform:translate(-50%);box-shadow:0 10px 28px #00000052}.app-view-switch button{min-height:34px;color:var(--text-muted);font-family:var(--font-heading);cursor:pointer;background:0 0;border:0;border-radius:6px;align-items:center;gap:7px;padding:0 12px;font-size:.86rem;font-weight:900;display:inline-flex}.app-view-switch button.active{color:var(--text-main);background:#00d2ff29}.app-view-switch button:hover{color:var(--text-main)}.bot-speed-select{min-height:34px;color:var(--text-main);font-family:var(--font-heading);cursor:pointer;background:#ffffff14;border:0;border-radius:6px;outline:none;padding:0 9px;font-size:.82rem;font-weight:900}.bot-speed-select:disabled{cursor:not-allowed;opacity:.45}.bot-speed-select:focus-visible{outline-offset:2px;outline:2px solid #00d2ff80}.bot-status-chip{z-index:1190;color:#d8f8ff;height:30px;font-family:var(--font-heading);pointer-events:none;background:#001422c7;border:1px solid #00d2ff61;border-radius:7px;align-items:center;gap:7px;padding:0 11px;font-size:.78rem;font-weight:900;display:inline-flex;position:fixed;top:58px;left:50%;transform:translate(-50%);box-shadow:0 8px 22px #0000004d}.bot-status-chip svg{color:var(--secondary)}.glass-panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);border:1px solid var(--glass-border);box-shadow:var(--glass-shadow);border-radius:16px}.btn{font-family:var(--font-heading);cursor:pointer;text-transform:uppercase;letter-spacing:1px;border:none;border-radius:8px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;transition:all .2s}.btn-primary{background:linear-gradient(135deg, var(--primary), #d91c4a);color:#fff;box-shadow:0 4px 15px #ff2a5f66}.btn-primary:hover{background:linear-gradient(135deg, var(--primary-hover), #ff2a5f);transform:translateY(-2px);box-shadow:0 6px 20px #ff2a5f99}.btn-secondary{background:linear-gradient(135deg, var(--secondary), #09f);color:#fff;box-shadow:0 4px 15px #00d2ff66}.btn-secondary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #00d2ff99}.btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none;transform:none}.card-wrapper{perspective:1000px;cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:12px;flex-shrink:0;width:160px;height:240px;transition:transform .3s;position:relative}.card-wrapper.exhausted{opacity:.8;transform:rotate(90deg)scale(.9)}.card-facedown{background:linear-gradient(135deg,#161823 0%,#0a0b10 100%);border:2px solid #ff2a5f66;justify-content:center;align-items:center;display:flex;box-shadow:inset 0 0 20px #ff2a5f33,0 4px 10px #00000080}.card-back-pattern{font-family:var(--font-heading);color:#ff2a5f99;text-align:center;letter-spacing:2px;text-shadow:0 0 10px #ff2a5f66;font-size:1.2rem;font-weight:800;transform:rotate(-45deg)}.card-faceup{background:var(--bg-card);border:2px solid var(--card-accent);flex-direction:column;display:flex;overflow:hidden;box-shadow:0 4px 10px #0006}.card-faceup.center-member-card{border-color:#ffd166;box-shadow:0 0 0 2px #ffd1663d,0 8px 22px #ffd16633}.card-faceup.center-member-card:after{content:"CENTER";z-index:2;color:#251504;letter-spacing:0;background:#ffd166eb;border-radius:4px;padding:3px 7px;font-size:.62rem;font-weight:900;position:absolute;bottom:8px;left:8px}.card-faceup:before{content:"";background:linear-gradient(180deg, var(--card-accent) 0%, transparent 40%);opacity:.15;pointer-events:none;height:100%;position:absolute;top:0;left:0;right:0}.card-inner{z-index:1;flex-direction:column;height:100%;padding:8px;display:flex;position:relative}.card-header{justify-content:space-between;align-items:flex-start;margin-bottom:8px;display:flex}.card-name{font-family:var(--font-heading);color:var(--text-main);text-shadow:0 1px 3px #000c;font-size:.85rem;font-weight:700;line-height:1.1}.card-cost{background:var(--card-accent);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:.8rem;font-weight:700;display:flex;box-shadow:0 2px 5px #00000080}.card-rank-badge{color:gold;background:#0009;border:1px solid gold;border-radius:4px;padding:2px 6px;font-size:.7rem;font-weight:700;position:absolute;top:36px;right:8px}.card-image-placeholder{background:#0000004d;border:1px solid #ffffff1a;border-radius:6px;flex:1;justify-content:center;align-items:center;margin-bottom:8px;display:flex;position:relative;overflow:hidden}.card-type-label{color:#ffffff80;font-size:.75rem;font-family:var(--font-heading);text-transform:uppercase;letter-spacing:1px}.card-member-image{object-fit:cover;width:100%;height:100%;display:block}.card-body{background:#0006;border:1px solid #ffffff0d;border-radius:6px;height:90px;padding:6px;font-size:.7rem;overflow-y:auto}.card-body::-webkit-scrollbar{width:4px}.card-body::-webkit-scrollbar-thumb{background:#fff3;border-radius:2px}.card-trait{color:#ddd;margin-bottom:4px}.card-trait strong{color:var(--card-accent)}.card-effect{color:#aaa;margin-top:4px;font-style:italic;line-height:1.3}.game-board{background-image:radial-gradient(circle,#1e0a32cc,#0a0514);flex-direction:column;justify-content:space-between;height:100vh;padding:20px;display:flex}.player-area{background:#0000004d;border:1px solid #fff3;border-radius:12px;flex-direction:column;flex:1;gap:10px;padding:15px;display:flex;position:relative}.opponent-area{transform:rotate(180deg)}.play-area-row{gap:15px;width:100%;display:flex}.top-row{justify-content:flex-start;min-height:140px}.deck-zone{gap:10px;display:flex}.song-area,.action-area{border:1px dashed #ffffff4d;border-radius:8px;gap:10px;min-width:200px;min-height:140px;padding:10px;display:flex}.action-area{padding-top:34px;position:relative}.song-area:before{content:"SONG AREA";color:#fff3;pointer-events:none;font-weight:700;position:absolute}.action-area:before{content:"ACTION AREA";color:#fff3;pointer-events:none;font-weight:700;position:absolute}.action-zone-count{z-index:2;color:#ffd18a;min-width:72px;font-family:var(--font-heading);text-align:center;white-space:nowrap;background:#f39c122e;border:1px solid #f39c1280;border-radius:6px;padding:4px 8px;font-size:.68rem;font-weight:900;line-height:1;position:absolute;top:7px;right:8px;box-shadow:0 0 10px #f39c1229}.action-zone-count.full{color:#ffb4c5;background:#ff2a5f2e;border-color:#ff2a5f9e;box-shadow:0 0 12px #ff2a5f33}.action-card-slot{outline:none;flex:0 0 160px;display:flex;position:relative}.action-card-slot:focus-visible{outline-offset:3px;border-radius:12px;outline:2px solid #00d2ffb3}.action-zone-reason{z-index:3;color:#b9efff;font-family:var(--font-heading);text-align:center;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;background:#080c14d1;border:1px solid #00d2ff6b;border-radius:6px;padding:4px 6px;font-size:.62rem;font-weight:900;line-height:1;position:absolute;bottom:8px;left:8px;right:8px;overflow:hidden}.action-zone-slot-ghost{opacity:.72;background:linear-gradient(135deg,#ffffff14,#ffffff05),#00000029;border:1px dashed #ffffff3d;border-radius:8px;flex:0 0 48px;align-self:flex-start;width:48px;height:72px;margin-top:8px;box-shadow:inset 0 0 0 1px #00d2ff0d}.action-zone-slot-ghost:before{content:"";background:#ffffff29;border-radius:50%;width:16px;height:16px;margin:27px auto 0;display:block;box-shadow:0 0 12px #00d2ff1f}.stage-zone{background:#ffffff0d;border-radius:8px;gap:10px;min-height:180px;padding:10px;display:flex;position:relative}.stage-card-wrapper{z-index:1;flex-direction:column;flex:0 0 160px;align-items:center;gap:6px;width:160px;display:flex;position:relative}.stage-card-wrapper.center-member-slot{filter:drop-shadow(0 0 12px #ffd16661)}.stage-center-btn{color:#ffe6a3;cursor:pointer;background:#ffd16629;border:1px solid #ffd16680;border-radius:6px;width:100%;height:26px;font-size:.72rem;font-weight:800}.stage-center-btn:hover:not(:disabled){background:#ffd16647}.stage-center-btn:disabled{opacity:.62;cursor:not-allowed}.stage-zone:before{content:"MEMBER AREA";color:#fff3;pointer-events:none;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.energy-row{justify-content:space-between;min-height:140px;display:flex}.energy-zone{background:#ff2a5f1a;border-radius:8px;flex:1;gap:10px;min-height:140px;padding:10px;display:flex;position:relative}.energy-zone-full{background:#ff2a5f29;border:1px solid #ff2a5f80;box-shadow:inset 0 0 0 1px #ffd16624,0 0 18px #ff2a5f1f}.energy-zone-near-full{background:#f39c121f;border:1px solid #f39c126b;box-shadow:inset 0 0 0 1px #f39c1214}.energy-zone:before{content:"ENERGY AREA";color:#fff3;pointer-events:none;font-weight:700;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.play-deck-zone{justify-content:center;align-items:center;width:120px;display:flex}.hand-zone{justify-content:center;width:100%;padding:10px 0 40px;display:flex;position:relative}.hand-card-wrapper{margin-bottom:-32px;margin-left:-40px;padding-bottom:32px;transition:transform .3s;position:relative}.hand-card-wrapper:first-child{margin-left:0}.hand-card-wrapper:hover{z-index:10;transform:translateY(-20px)}.hand-zone.debug-hands{padding-bottom:58px}.hand-zone.debug-hands .hand-card-wrapper{margin-bottom:-20px;padding-bottom:42px}.hand-zone.debug-hands .hand-card-wrapper:hover{transform:translateY(-10px)}.card-actions{opacity:0;pointer-events:none;white-space:nowrap;gap:4px;transition:opacity .2s;display:flex;position:absolute;bottom:2px;left:50%;transform:translate(-50%)}.hand-card-wrapper:hover .card-actions,.hand-zone.debug-hands .card-actions{opacity:1;pointer-events:auto}.action-btn{cursor:pointer;border:none;border-radius:4px;padding:5px 10px;font-size:.8rem;font-weight:700}.action-btn:disabled{opacity:.5;cursor:not-allowed}.play-btn{background:var(--secondary);color:#fff}.energy-btn{background:var(--primary);color:#fff}.center-area{justify-content:center;align-items:center;gap:40px;margin:10px 0;padding:20px;display:flex}.center-slot{flex-direction:column;align-items:center;gap:10px;display:flex}.center-slot h4{color:var(--text-muted);text-transform:uppercase;letter-spacing:2px;font-size:.9rem}.empty-slot-placeholder{color:#ffffff4d;text-transform:uppercase;border:2px dashed #fff3;border-radius:12px;justify-content:center;align-items:center;width:160px;height:240px;font-weight:700;display:flex}.player-info{justify-content:space-between;align-items:center;width:100%;padding:0 20px;display:flex}.score-badge{background:linear-gradient(135deg,#ff2a5f33,#00d2ff33);border:1px solid #ffffff1a;border-radius:20px;padding:5px 15px;font-weight:700}.alert-final-round{color:#ff2a5f;text-transform:uppercase;text-shadow:0 0 10px #ff2a5f80;margin-bottom:10px;font-size:1.5rem;font-weight:900;animation:1s infinite alternate pulse}.game-over-banner{text-align:center;background:#000c;border:2px solid #00d2ff;border-radius:12px;padding:20px 40px;box-shadow:0 0 20px #00d2ff66}.game-over-banner h3{color:#fff;margin-bottom:10px;font-size:2rem}.game-over-banner p{color:#00d2ff;font-size:1.2rem}@keyframes pulse{0%{opacity:.8;transform:scale(1)}to{opacity:1;transform:scale(1.05)}}.game-log{z-index:100;width:320px;max-height:200px;padding:12px;font-size:.8rem;position:fixed;bottom:10px;right:10px;overflow-y:auto}.log-entry.bot-log-entry{color:#d8f8ff;background:#00d2ff14;border-left:3px solid #00d2ffc7;padding-left:7px}.debug-panel{z-index:120;flex-wrap:wrap;align-items:center;gap:6px;max-width:calc(100vw - 20px);padding:8px;display:flex;position:fixed;top:10px;left:10px}.debug-panel-label{color:var(--text-muted);text-transform:uppercase;font-size:.72rem;font-weight:800}.debug-collapse-btn{width:30px;height:30px;color:var(--text-main);cursor:pointer;background:#ffffff14;border:1px solid #ffffff29;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.debug-collapse-btn:hover,.debug-collapse-btn:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff24;outline:2px solid #00d2ff6b}.debug-panel-collapsed{width:auto}.debug-picker{flex:0 0 172px;width:172px;position:relative}.debug-picker input{width:100%;height:30px;color:var(--text-main);background:#ffffff14;border:1px solid #ffffff29;border-radius:6px;outline:none;padding:6px 9px;font-size:.72rem;font-weight:800}.debug-picker input::placeholder{color:#ffffff7a}.debug-picker input:focus,.debug-picker input:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff1f;outline:2px solid #00d2ff75}.debug-picker input:disabled{opacity:.45;cursor:not-allowed}.debug-picker-menu{background:#0c111ef7;border:1px solid #ffffff24;border-radius:8px;flex-direction:column;gap:4px;width:236px;max-width:calc(100vw - 24px);padding:8px;display:flex;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 18px 40px #00000059}.debug-picker-menu button{min-height:30px;color:var(--text-main);cursor:pointer;text-align:left;background:#ffffff0d;border:1px solid #0000;border-radius:6px;justify-content:space-between;align-items:center;gap:12px;padding:6px 8px;font-size:.72rem;font-weight:800;display:flex}.debug-picker-menu button.active,.debug-picker-menu button:hover:not(:disabled),.debug-picker-menu button:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff24;outline:2px solid #00d2ff6b}.debug-picker-menu button span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.debug-picker-menu button strong{color:var(--text-muted);text-transform:uppercase;flex:none;font-size:.64rem}.debug-picker-empty{min-height:30px;color:var(--text-muted);padding:8px;font-size:.72rem;font-weight:800}.debug-recents{align-items:center;gap:4px;max-width:190px;display:flex;overflow:hidden}.debug-recents button{min-width:0;height:30px;color:var(--text-main);cursor:pointer;text-overflow:ellipsis;white-space:nowrap;background:#ffffff0d;border:1px solid #ffffff24;border-radius:6px;flex:0 58px;padding:6px 8px;font-size:.68rem;font-weight:800;overflow:hidden}.debug-recents button.active,.debug-recents button:hover:not(:disabled),.debug-recents button:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff24;outline:2px solid #00d2ff6b}.debug-recents button:disabled{opacity:.45;cursor:not-allowed}.debug-groups{display:contents}.debug-group{position:relative}.debug-group summary{min-width:76px;color:var(--text-main);cursor:pointer;background:#ffffff14;border:1px solid #ffffff29;border-radius:6px;outline:none;padding:6px 10px;font-size:.72rem;font-weight:800;list-style:none}.debug-group summary::-webkit-details-marker{display:none}.debug-group summary:after{content:"v";color:var(--text-muted);margin-left:8px}.debug-group[open] summary{border-color:var(--secondary);background:#00d2ff24}.debug-group.active summary{color:#fff3bd;background:#ffd96624;border-color:#ffd966b8}.debug-group summary:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff24;outline:2px solid #00d2ff75}.debug-group-menu{background:#0c111ef5;border:1px solid #ffffff24;border-radius:8px;grid-template-columns:repeat(2,minmax(76px,1fr));gap:6px;width:max-content;max-width:calc(100vw - 24px);padding:8px;display:grid;position:absolute;top:calc(100% + 6px);left:0;box-shadow:0 18px 40px #00000059}.debug-group button{min-width:64px;color:var(--text-main);cursor:pointer;background:#ffffff14;border:1px solid #ffffff29;border-radius:6px;flex:none;padding:6px 8px;font-size:.72rem;font-weight:800}.debug-group button:hover:not(:disabled),.debug-group button:focus-visible{border-color:var(--secondary);outline-offset:2px;background:#00d2ff24;outline:2px solid #00d2ff6b}.debug-group button.active{color:#fff3bd;background:#ffd96629;border-color:#ffd966b8}.debug-group button:disabled{opacity:.45;cursor:not-allowed}.debug-readout{z-index:320;width:min(340px,100vw - 20px);padding:10px;position:fixed;top:58px;left:10px}.debug-readout-compact{top:58px}.debug-readout-head{justify-content:space-between;align-items:center;gap:10px;margin-bottom:8px;display:flex}.debug-readout-head span{color:var(--text-main);text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;font-size:.78rem;font-weight:900;overflow:hidden}.debug-readout-head strong{color:var(--secondary);flex:none;font-size:.76rem}.debug-run-btn{width:100%;height:28px;color:var(--text-main);cursor:pointer;background:#00d2ff1f;border:1px solid #00d2ff59;border-radius:6px;margin-bottom:8px;font-size:.72rem;font-weight:900}.debug-run-btn:hover:not(:disabled){background:#00d2ff33}.debug-run-btn:disabled{opacity:.45;cursor:not-allowed}.debug-check-list{gap:6px;display:grid}.debug-check{min-width:0;color:var(--text-muted);align-items:center;gap:7px;font-size:.72rem;line-height:1.2;display:flex}.debug-check span:last-child{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.debug-check-dot{background:#ffffff47;border-radius:50%;flex:0 0 8px;width:8px;height:8px}.debug-check.passed{color:#bdf5cf}.debug-check.passed .debug-check-dot{background:#2ecc71;box-shadow:0 0 8px #2ecc718c}@media (width<=760px){.debug-panel{align-items:flex-start;row-gap:6px;width:calc(100vw - 20px)}.debug-panel-label{flex:none;height:30px;line-height:30px}.debug-picker{flex:154px;width:auto;min-width:148px}.debug-recents{flex:160px;max-width:none}.debug-recents button{flex-basis:54px}.debug-groups{flex-wrap:wrap;flex:100%;gap:6px;min-width:0;display:flex}.debug-group summary{min-width:68px;padding-inline:8px}.debug-readout{top:102px}.debug-readout-compact{top:58px}}@media (width<=480px){.debug-picker{flex-basis:calc(100% - 64px);order:1}.debug-recents{flex:100%;order:2}.debug-groups{scrollbar-width:thin;flex-wrap:nowrap;order:3;padding-bottom:2px;overflow:auto visible}.debug-groups::-webkit-scrollbar{height:5px}.debug-groups::-webkit-scrollbar-thumb{background:#ffffff38;border-radius:999px}.debug-group{flex:none}.debug-group summary{white-space:nowrap}.debug-group-menu{z-index:125;grid-template-columns:repeat(3,minmax(0,1fr));width:auto;max-width:none;max-height:min(48vh,340px);position:fixed;top:128px;left:10px;right:10px;overflow-y:auto}.debug-group button{text-overflow:ellipsis;min-width:0;min-height:34px;overflow:hidden}.debug-picker-menu{z-index:125;width:auto;max-height:min(48vh,340px);right:0;overflow-y:auto}.debug-readout{top:136px}.debug-readout-compact{top:58px}}.log-entry{color:#ccc;border-bottom:1px solid #ffffff0d;padding:4px 0}.log-entry:last-child{color:#fff;border-bottom:none}.energy-count{color:var(--color-orange);align-self:center;margin-left:8px;font-size:.85rem;font-weight:700}.energy-count.full{color:#ffd18a;text-shadow:0 0 8px #f39c1247}.energy-count.near-full{color:#ffd18a}.energy-zone-full-badge,.energy-zone-near-full-badge{z-index:2;color:#ffe6a3;font-family:var(--font-heading);text-transform:uppercase;white-space:nowrap;background:#ffd1662e;border:1px solid #ffd1668f;border-radius:6px;padding:4px 8px;font-size:.66rem;font-weight:900;line-height:1;position:absolute;top:8px;right:8px}.energy-zone-near-full-badge{color:#ffd18a;background:#f39c1229;border-color:#f39c1280}.deck-count{color:var(--text-muted);font-size:1.1rem;font-weight:700}.empty-slot-placeholder.small{width:auto;height:auto;min-height:80px;padding:10px 20px;font-size:.75rem}.game-controls{align-items:center;gap:12px;display:flex}.phase-chip{color:#aef2c8;font-family:var(--font-heading);text-transform:uppercase;background:#2ecc712e;border-radius:999px;padding:8px 12px;font-size:.78rem;font-weight:800}.phase-panel{justify-content:space-between;align-items:center;gap:16px;width:min(720px,100%);display:flex}.phase-heading{flex-direction:column;gap:4px;display:flex}.phase-heading span{color:var(--secondary);font-family:var(--font-heading);text-transform:uppercase;font-size:1.05rem;font-weight:800}.phase-heading strong{color:var(--text-muted);font-size:.82rem}.standby-options{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.standby-hint{width:100%;color:var(--text-muted);text-align:right;font-size:.76rem}.song-requirements{background:#00000047;border:1px solid #ffffff1f;border-radius:8px;width:300px;padding:10px}.song-requirements.ready{border-color:#2ecc7199}.song-requirements.blocked{border-color:#ff2a5f59}.song-requirements-title{color:var(--text-main);font-family:var(--font-heading);text-transform:uppercase;letter-spacing:0;margin-bottom:8px;font-size:.82rem;font-weight:800}.requirement-pills{flex-wrap:wrap;gap:6px;margin-bottom:8px;display:flex}.requirement-pill{color:#fff;text-align:center;background:#ffffff1a;border-radius:999px;min-width:54px;padding:4px 7px;font-size:.72rem;font-weight:700}.requirement-pill.color-pink{background:#ff6b9d57}.requirement-pill.color-blue{background:#4da6ff57}.requirement-pill.color-red{background:#ff4d4d57}.requirement-pill.color-green{background:#2ecc7157}.requirement-pill.color-orange{background:#f39c1257}.requirement-pill.color-free{background:#9b59b65c}.requirement-meta{color:var(--text-muted);flex-wrap:wrap;gap:8px;font-size:.72rem;display:flex}.requirement-state{color:var(--text-main);margin-top:6px;font-size:.76rem;line-height:1.25}.game-over-banner button{margin-top:12px}.pending-overlay{z-index:300;background:#05060cb8;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.pending-dialog{flex-direction:column;gap:16px;width:min(960px,100%);max-height:min(760px,92vh);padding:20px;display:flex;overflow:hidden}.pending-dialog-compact{width:min(560px,100%)}.pending-header h3{margin-bottom:6px;font-size:1.4rem}.pending-header p{color:var(--text-muted);line-height:1.4}.pending-choice-grid{grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:14px;padding:2px 4px 8px 2px;display:grid;overflow-y:auto}.pending-choice{min-width:0;color:var(--text-main);cursor:pointer;background:#ffffff0f;border:1px solid #ffffff24;border-radius:8px;flex-direction:column;align-items:center;gap:8px;padding:10px;display:flex}.pending-choice:hover{border-color:var(--secondary);background:#00d2ff1f}.pending-choice>span{width:100%;color:var(--secondary);text-align:center;font-size:.78rem;font-weight:700}.pending-choice .card-wrapper{width:150px;height:225px}.pending-empty{color:var(--text-muted);text-align:center;border:1px dashed #ffffff29;border-radius:8px;padding:28px}.payment-choice-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.payment-choice{min-width:0;min-height:112px;color:var(--text-main);cursor:pointer;background:#ffffff12;border:1px solid #ffffff24;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:16px;display:flex}.payment-choice:hover{border-color:var(--secondary);background:#00d2ff1f}.payment-choice span{text-transform:uppercase;font-size:.82rem;font-weight:900}.payment-choice strong{color:var(--secondary);font-size:1.25rem}.pending-actions{justify-content:flex-end;align-items:center;gap:12px;display:flex}.pending-action-note{color:var(--text-muted);margin-right:auto;font-size:.78rem;line-height:1.3}.janken-status{grid-template-columns:repeat(2,1fr);gap:10px;display:grid}.janken-player{background:#ffffff0f;border:1px solid #ffffff1f;border-radius:8px;justify-content:space-between;align-items:center;gap:10px;min-width:0;padding:12px;display:flex}.janken-player.active{background:#00d2ff1f;border-color:#00d2ffb3}.janken-player span,.janken-player strong{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.janken-player span{color:var(--text-main);font-weight:800}.janken-player strong{color:var(--secondary);text-transform:uppercase;font-size:.78rem}.janken-move-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.janken-move{min-width:0;min-height:118px;color:var(--text-main);cursor:pointer;background:#ffffff12;border:1px solid #ffffff24;border-radius:8px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:14px 10px;font-weight:800;display:flex}.janken-move:hover{border-color:var(--primary);background:#ff2a5f24}.janken-mark{color:#fff;width:44px;height:44px;font-family:var(--font-heading);background:linear-gradient(135deg,#ff2a5fdb,#00d2ffb8);border-radius:50%;place-items:center;font-size:1.2rem;display:grid}.deck-builder{background:linear-gradient(#0a0b10b8,#0a0b10fa),radial-gradient(circle at 20% 12%,#ff2a5f1f,#0000 28%),radial-gradient(circle at 88% 26%,#2ecc711a,#0000 24%);min-height:100vh;padding:66px 18px 18px}.deck-builder-header{justify-content:space-between;align-items:center;gap:16px;max-width:1500px;margin:0 auto 14px;display:flex}.deck-builder-header h1{letter-spacing:0;font-size:1.55rem}.deck-builder-stats,.deck-builder-actions,.deck-filter-strip,.deck-card-meta,.deck-breakdown{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.deck-builder-stats span,.deck-breakdown span,.pool-count,.deck-save-state{color:var(--text-muted);background:#ffffff0e;border:1px solid #ffffff1a;border-radius:6px;padding:5px 8px;font-size:.78rem;font-weight:700}.deck-builder-actions{justify-content:flex-end}.deck-rule-panel{background:#161823b8;border:1px solid #ffffff1f;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:stretch;gap:12px;max-width:1500px;margin:0 auto 14px;padding:10px;display:grid}.deck-rule-panel.valid{border-color:#2ecc7161}.deck-rule-panel.invalid{border-color:#ffbc4252}.deck-rule-summary,.deck-rule-item{align-items:center;gap:8px;display:flex}.deck-rule-summary{min-width:160px;color:var(--text-main);font-family:var(--font-heading);background:#ffffff0e;border-radius:7px;padding:10px;font-size:.92rem;font-weight:900}.deck-rule-panel.valid .deck-rule-summary svg,.deck-rule-item.pass svg{color:var(--color-green)}.deck-rule-panel.invalid .deck-rule-summary svg,.deck-rule-item.warn svg{color:#ffbc42}.deck-rule-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:8px;display:grid}.deck-rule-item{background:#ffffff0b;border:1px solid #ffffff16;border-radius:7px;min-width:0;padding:9px}.deck-rule-item div{min-width:0}.deck-rule-item strong,.deck-rule-item span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.deck-rule-item strong{color:var(--text-main);font-size:.75rem}.deck-rule-item span{color:var(--text-muted);margin-top:3px;font-size:.68rem}.deck-icon-btn,.deck-card-controls button,.deck-selected-controls button{color:var(--text-main);cursor:pointer;background:#ffffff13;border:1px solid #ffffff1f;border-radius:6px;justify-content:center;align-items:center;display:inline-flex}.deck-icon-btn{width:38px;height:38px}.deck-icon-btn:hover,.deck-card-controls button:hover:not(:disabled),.deck-selected-controls button:hover{background:#00d2ff29;border-color:#00d2ff85}.deck-icon-btn.play:not(:disabled){color:#dfffe8;border-color:#2ecc7161}.deck-icon-btn.play:hover:not(:disabled){background:#2ecc712e;border-color:#2ecc719e}.deck-icon-btn.meta{color:#ffe7ad;border-color:#ffbc4257}.deck-icon-btn.meta:hover{background:#ffbc4229;border-color:#ffbc42ad}.deck-icon-btn:disabled{cursor:not-allowed;opacity:.38}.deck-icon-btn.danger:hover{background:#ff2a5f29;border-color:#ff2a5f9e}.deck-builder-layout{grid-template-columns:minmax(0,1fr) minmax(320px,420px);gap:14px;max-width:1500px;margin:0 auto;display:grid}.deck-panel{background:#161823c7;border:1px solid #ffffff1c;border-radius:8px;min-height:0;box-shadow:0 12px 34px #00000047}.card-pool-panel{padding:12px}.deck-toolbar{grid-template-columns:minmax(220px,1fr) auto;gap:10px;margin-bottom:10px;display:grid}.deck-search,.deck-filter-strip{background:#0000003d;border:1px solid #ffffff1f;border-radius:8px;min-height:42px}.deck-search{align-items:center;gap:9px;padding:0 12px;display:flex}.deck-search input,.deck-filter-strip select{color:var(--text-main);font:inherit;border:0;outline:0}.deck-search input{background:0 0;width:100%}.deck-filter-strip{padding:0 8px}.deck-filter-strip select{background:#ffffff14;border-radius:6px;max-width:150px;padding:7px 8px}.pool-count{margin-bottom:10px;display:inline-flex}.card-pool-list,.deck-list{flex-direction:column;gap:8px;display:flex;overflow:auto}.card-pool-list{max-height:calc(100vh - 160px);padding-right:4px}.deck-card-row,.deck-selected-row{background:#ffffff0b;border:1px solid #ffffff16;border-radius:8px;align-items:center;gap:10px;display:grid}.deck-card-row{grid-template-columns:54px minmax(0,1fr) 98px;min-height:70px;padding:8px}.deck-card-thumb{border:2px solid var(--thumb-accent);background:#00000047;border-radius:7px;width:48px;height:54px;overflow:hidden}.deck-card-thumb img{object-fit:cover;width:100%;height:100%;display:block}.deck-card-thumb span{height:100%;color:var(--text-muted);font-family:var(--font-heading);place-items:center;font-weight:900;display:grid}.deck-card-main{min-width:0}.deck-card-main h2{color:var(--text-main);text-overflow:ellipsis;white-space:nowrap;font-size:.96rem;line-height:1.15;overflow:hidden}.deck-card-meta{margin-top:6px}.deck-card-meta span{color:var(--text-muted);font-size:.72rem}.deck-card-meta span:not(:last-child):after{content:"/";color:#ffffff3d;margin-left:8px}.deck-card-controls,.deck-selected-controls{grid-template-columns:28px 32px 28px;justify-content:end;align-items:center;gap:4px;display:grid}.deck-card-controls button,.deck-selected-controls button{width:28px;height:28px}.deck-card-controls button:disabled{cursor:not-allowed;opacity:.35}.deck-card-controls span,.deck-selected-controls span{color:var(--text-main);font-family:var(--font-heading);text-align:center;font-weight:900}.deck-list-panel{flex-direction:column;padding:12px;display:flex}.deck-list-header{justify-content:space-between;align-items:baseline;gap:12px;margin-bottom:10px;display:flex}.deck-list-header h2{font-size:1.05rem}.deck-list-header span{color:var(--text-muted);font-size:.8rem;font-weight:800}.deck-breakdown{margin-bottom:12px}.deck-list{max-height:calc(100vh - 190px);padding-right:4px}.deck-selected-row{grid-template-columns:minmax(0,1fr) 94px;padding:9px}.deck-selected-row strong,.deck-selected-row span{text-overflow:ellipsis;white-space:nowrap;display:block;overflow:hidden}.deck-selected-row strong{font-size:.86rem}.deck-selected-row span{color:var(--text-muted);margin-top:3px;font-size:.72rem}.empty-deck{min-height:180px;color:var(--text-muted);border:1px dashed #ffffff1f;border-radius:8px;place-items:center;font-weight:800;display:grid}@media (width<=980px){.deck-builder{padding:62px 12px 12px}.deck-builder-header,.deck-toolbar{grid-template-columns:1fr}.deck-builder-header{display:grid}.deck-builder-actions{justify-content:flex-start}.deck-builder-layout,.deck-rule-panel,.deck-rule-grid{grid-template-columns:1fr}.card-pool-list,.deck-list{max-height:none}}@media (width<=560px){.deck-card-row{grid-template-columns:48px minmax(0,1fr)}.deck-card-controls{grid-column:1/-1;grid-template-columns:40px 1fr 40px;justify-content:stretch}.deck-card-controls button{width:40px}.deck-filter-strip select{flex:92px;min-width:0}}
