:root{--bg: #0f1720;--bg-elev: #18222e;--bg-elev-2: #243140;--fg: #e8eef5;--fg-dim: #95a4b6;--accent: #4ec9c9;--accent-press: #3aa9a9;--warn: #f0a060;--danger: #e25c5c;--good: #6dcf72;--radius: 12px;--radius-lg: 16px;--tap: 48px;--space-1: 6px;--space-2: 12px;--space-3: 18px;--space-4: 28px;--safe-top: env(safe-area-inset-top, 0px);--safe-bottom: env(safe-area-inset-bottom, 0px)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{margin:0;padding:0;height:100%;background:var(--bg);color:var(--fg);font:16px/1.45 system-ui,-apple-system,SF Pro Text,Roboto,sans-serif;overscroll-behavior:none}button{font-family:inherit}.app{display:flex;flex-direction:column;height:100%;padding-top:var(--safe-top);padding-bottom:var(--safe-bottom)}.topbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-3);background:var(--bg-elev);border-bottom:1px solid #00000033}.topbar h1{margin:0;font-size:22px;letter-spacing:.5px;color:var(--accent)}.player-tag{font-size:14px;color:var(--fg-dim);background:var(--bg-elev-2);padding:4px 10px;border-radius:999px}.content{flex:1;overflow-y:auto;padding:var(--space-3);-webkit-overflow-scrolling:touch}.centered{height:100%;display:flex;align-items:center;justify-content:center;color:var(--fg-dim)}.toast{position:fixed;left:50%;top:calc(var(--safe-top) + 64px);transform:translate(-50%);background:var(--danger);color:#fff;padding:10px 16px;border-radius:var(--radius);z-index:100;max-width:90vw;text-align:center;box-shadow:0 6px 24px #0006}.btn-primary,.btn-secondary,.mode-btn,button{min-height:var(--tap);padding:0 18px;border-radius:var(--radius);border:0;font-size:16px;font-weight:600;cursor:pointer;transition:transform .05s ease,background .15s ease}.btn-primary{background:var(--accent);color:#062020}.btn-primary:active{background:var(--accent-press);transform:scale(.98)}.btn-primary:disabled{background:#2c3a4a;color:#6a7888;cursor:not-allowed}.btn-secondary{background:var(--bg-elev-2);color:var(--fg)}.btn-secondary:active{background:#2e3d50;transform:scale(.98)}.app.app-titlescreen .content{padding:0;max-width:none}.title-screen{display:flex;flex-direction:column;height:100%;width:100%;background:var(--bg);position:relative}.title-art{flex:1;position:relative;overflow:hidden;background:linear-gradient(160deg,#0a1628,#1a3056 45%,#0a1f3a);min-height:280px}.title-art-img{width:100%;height:100%;object-fit:cover;object-position:center 30%;display:block;animation:title-fade-in .6s ease-out}.title-art-vignette{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background:linear-gradient(180deg,#0f172000,#0f172000 55%,#0f1720b3 90%,#0f1720f2)}.title-art-fallback{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;text-align:center;padding:var(--space-4)}.title-art-fallback-mark{font-size:clamp(72px,18vw,160px);font-weight:900;letter-spacing:6px;background:linear-gradient(135deg,var(--accent),#fff 60%,var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 6px 24px rgba(78,201,201,.3)}.title-art-fallback-tagline{font-size:clamp(14px,3.6vw,22px);color:var(--fg);letter-spacing:4px;text-transform:uppercase;font-weight:600;opacity:.9}.title-form{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3) var(--space-3) calc(var(--space-3) + var(--safe-bottom));background:linear-gradient(180deg,rgba(15,23,32,.85),var(--bg) 30%);margin-top:-40px;position:relative;z-index:2;animation:title-fade-up .55s ease-out .1s both}.title-form-label{font-size:12px;letter-spacing:1.5px;text-transform:uppercase;color:var(--fg-dim);font-weight:600}.title-form-input{min-height:var(--tap);font-size:18px;padding:0 14px;border-radius:var(--radius);border:1px solid #2d3a4a;background:var(--bg-elev);color:var(--fg);font-family:inherit}.title-form-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.title-form-submit{width:100%;font-size:17px;letter-spacing:.5px}@keyframes title-fade-in{0%{opacity:0;transform:scale(1.04)}to{opacity:1;transform:scale(1)}}@keyframes title-fade-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (min-width: 720px){.title-screen{max-width:720px;margin:0 auto;border-radius:var(--radius-lg)}.title-art{min-height:420px}.title-form{padding-bottom:var(--space-4)}}.name-prompt{display:flex;flex-direction:column;gap:var(--space-2);max-width:480px;margin:24px auto 0}.name-prompt label{font-size:14px;color:var(--fg-dim)}.name-prompt input{min-height:var(--tap);font-size:18px;padding:0 14px;border-radius:var(--radius);border:1px solid #2d3a4a;background:var(--bg-elev);color:var(--fg)}.name-prompt input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.lobby{display:flex;flex-direction:column;gap:var(--space-3)}.lobby h2{font-size:16px;text-transform:uppercase;letter-spacing:1px;color:var(--fg-dim);margin:0 0 var(--space-2)}.lobby h2 .count{background:var(--bg-elev-2);color:var(--fg);padding:2px 8px;border-radius:999px;margin-left:8px;font-size:13px}.card-create,.card-rooms{background:var(--bg-elev);border-radius:var(--radius-lg);padding:var(--space-3)}.mode-grid{display:grid;grid-template-columns:1fr;gap:var(--space-2)}.mode-btn{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;background:var(--bg-elev-2);color:var(--fg);text-align:left;padding:14px 18px;min-height:64px}.mode-btn small{display:block;font-size:13px;color:var(--fg-dim);font-weight:400;margin-top:2px}.mode-btn:active{background:#2e3d50}.empty{color:var(--fg-dim);margin:0}.room-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-2)}.room-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elev-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius);gap:var(--space-2)}.room-info{display:flex;flex-direction:column;gap:2px}.room-mode{font-weight:600}.room-meta{font-size:13px;color:var(--fg-dim)}.room-view{display:flex;flex-direction:column;gap:var(--space-3)}.room-view h2{margin:0}.player-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:var(--space-1)}.player-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elev);padding:12px var(--space-3);border-radius:var(--radius);gap:var(--space-2)}.player-row .name{font-weight:600;flex:1}.player-row .team{color:var(--fg-dim);font-size:13px}.ready--yes{color:var(--good);font-weight:600}.ready--no{color:var(--fg-dim)}.slot-empty{color:var(--fg-dim);font-style:italic;justify-content:center}.team-A{border-left:4px solid #4ec9c9}.team-B{border-left:4px solid #f0a060}.room-actions{display:flex}.room-actions>button{flex:1}.room-hint{color:var(--fg-dim);font-size:14px;text-align:center;margin:0}.game-view{display:flex;flex-direction:column;gap:var(--space-2);height:100%;position:relative}.opponents{display:flex;flex-direction:column;gap:8px}.opp-card{background:var(--bg-elev);border-radius:var(--radius);padding:10px var(--space-3)}.opp-card.eliminated{opacity:.45}.opp-line{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2)}.opp-name{font-weight:600}.opp-meta{display:flex;gap:var(--space-3);color:var(--fg-dim);font-size:13px;margin-top:2px}.opp-out{color:var(--danger);font-weight:700;letter-spacing:.5px}.strike-dots{display:inline-flex;gap:4px;align-items:center}.strike-dots .dot{width:12px;height:12px;border-radius:999px;border:1.5px solid var(--fg-dim);background:transparent;display:inline-block;transition:background .18s ease,border-color .18s ease}.strike-dots .dot.on{background:var(--danger);border-color:var(--danger)}.strike-dots .dot.just-on{animation:strike-pop .6s cubic-bezier(.22,1.4,.4,1)}.strike-dots.pulsed{animation:strike-shake .4s ease-out}@keyframes strike-pop{0%{transform:scale(.4);box-shadow:0 0 #e25c5cb3}40%{transform:scale(1.5);box-shadow:0 0 0 6px #e25c5c00}to{transform:scale(1);box-shadow:0 0 #e25c5c00}}@keyframes strike-shake{0%,to{transform:translate(0)}25%{transform:translate(-3px)}50%{transform:translate(3px)}75%{transform:translate(-2px)}}.turn-banner{background:var(--bg-elev);border-radius:var(--radius);padding:10px var(--space-3);display:flex;flex-direction:column;gap:2px;border-left:4px solid #2d3a4a;transition:border-color .2s ease,background .2s ease}.turn-banner.mine{background:linear-gradient(90deg,rgba(78,201,201,.18),var(--bg-elev) 60%);border-left-color:var(--accent);animation:banner-pulse 1.6s ease-in-out infinite}.turn-banner.tone-throw.mine{border-left-color:#6aa6ff;background:linear-gradient(90deg,rgba(106,166,255,.18),var(--bg-elev) 60%)}.turn-banner.tone-catch.mine{border-left-color:#6dcf72;background:linear-gradient(90deg,rgba(109,207,114,.18),var(--bg-elev) 60%)}.turn-banner.tone-scrum.mine{border-left-color:var(--warn);background:linear-gradient(90deg,rgba(240,160,96,.2),var(--bg-elev) 60%)}.turn-banner.tone-throw.opponent{border-left-color:#34547a}.turn-banner.tone-catch.opponent{border-left-color:#2f5a3c}.turn-banner.tone-scrum.opponent{border-left-color:#5a4426}.turn-banner.tone-resolve{border-left-color:var(--accent)}.turn-banner-heading{display:flex;align-items:center;gap:8px;font-weight:700;font-size:16px;letter-spacing:.2px;color:var(--fg)}.turn-banner-subtitle{color:var(--fg-dim);font-size:13px;line-height:1.3}.turn-banner-pip{width:8px;height:8px;border-radius:999px;background:var(--accent);display:inline-block;box-shadow:0 0 #4ec9c9b3;animation:pip-pulse 1.4s ease-in-out infinite}@keyframes pip-pulse{0%,to{box-shadow:0 0 #4ec9c9b3}50%{box-shadow:0 0 0 8px #4ec9c900}}@keyframes banner-pulse{0%,to{box-shadow:0 0 #4ec9c900}50%{box-shadow:0 0 16px #4ec9c92e}}.field{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);background:linear-gradient(180deg,#1a3a2a,#0f1f17);border-radius:var(--radius-lg);padding:var(--space-3);min-height:240px;position:relative;overflow:hidden;transition:background .4s ease}.field.field-flash-clean_catch{animation:field-flash-good .9s ease-out}.field.field-flash-bad_throw,.field.field-flash-both_miss{animation:field-flash-bad .9s ease-out}.field.field-flash-drop{animation:field-flash-warn .9s ease-out}@keyframes field-flash-good{0%{background:linear-gradient(180deg,#2c5e3a,#16331f)}50%{background:linear-gradient(180deg,#36784b,#1c4a2a)}to{background:linear-gradient(180deg,#1a3a2a,#0f1f17)}}@keyframes field-flash-bad{0%{background:linear-gradient(180deg,#5e2c2c,#331616)}50%{background:linear-gradient(180deg,#783636,#4a1c1c)}to{background:linear-gradient(180deg,#1a3a2a,#0f1f17)}}@keyframes field-flash-warn{0%{background:linear-gradient(180deg,#5e4a2c,#332916)}50%{background:linear-gradient(180deg,#7a5a32,#4a371c)}to{background:linear-gradient(180deg,#1a3a2a,#0f1f17)}}.lane{display:flex;align-items:center;justify-content:center;gap:var(--space-2);width:100%}.lane-arrow{font-size:28px;color:var(--fg-dim);font-weight:700;transition:color .25s ease,transform .25s ease}.lane-arrow-active{color:var(--accent);transform:translate(2px)}.card-slot{flex:0 0 auto;width:100px;min-height:132px;border-radius:var(--radius);display:flex;align-items:center;justify-content:center}.card-slot.empty{border:1px dashed #3c5060;background:#00000026;color:var(--fg-dim)}.card-slot.card-slot-pop{animation:slot-pop .36s cubic-bezier(.22,1.4,.4,1)}@keyframes slot-pop{0%{transform:translateY(20px) scale(.7);opacity:0}60%{transform:translateY(-3px) scale(1.06);opacity:1}to{transform:translateY(0) scale(1)}}.slot-label{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--fg-dim)}.outcome-banner{background:var(--bg-elev);border-radius:var(--radius);padding:12px var(--space-3);text-align:center;border:2px solid transparent;min-width:220px;box-shadow:0 8px 32px #0006;animation:outcome-rise .36s cubic-bezier(.22,1.4,.4,1)}@keyframes outcome-rise{0%{transform:translateY(16px) scale(.92);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.outcome-banner.outcome-clean_catch{border-color:var(--good)}.outcome-banner.outcome-drop{border-color:var(--warn)}.outcome-banner.outcome-bad_throw,.outcome-banner.outcome-both_miss{border-color:var(--danger)}.outcome-label{font-size:18px;font-weight:700;letter-spacing:.5px;margin-bottom:4px}.outcome-dice{display:flex;gap:var(--space-3);justify-content:center;color:var(--fg-dim);font-size:13px;margin-top:2px}.outcome-hint{margin-top:6px;font-size:11px;color:var(--fg-dim);text-transform:uppercase;letter-spacing:.5px}.next-up-toast{display:inline-flex;align-items:center;gap:8px;background:#4ec9c92e;color:var(--fg);border:1px solid rgba(78,201,201,.45);border-radius:999px;padding:8px 16px;font-size:14px;font-weight:600;letter-spacing:.3px;animation:next-up-in .3s ease-out,next-up-out .4s ease-in 1.2s forwards}.next-up-icon{color:var(--accent);font-weight:800;font-size:18px;line-height:1}@keyframes next-up-in{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes next-up-out{0%{transform:translateY(0);opacity:1}to{transform:translateY(-4px);opacity:0}}.waiting{display:inline-flex;align-items:center;gap:10px;background:#0006;color:var(--fg-dim);border-radius:999px;padding:8px 16px;font-size:14px}.spinner{width:14px;height:14px;border:2px solid #3c5060;border-top-color:var(--accent);border-radius:999px;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.hand{background:var(--bg-elev);border-radius:var(--radius-lg);padding:var(--space-2)}.hand-prompt{display:flex;flex-direction:column;gap:2px;padding:6px 10px 10px;text-align:center;font-size:12px;line-height:1.35;color:var(--fg)}.hand-prompt strong{font-weight:600}.hand-prompt-tip{font-weight:700;font-size:12px;letter-spacing:.3px;color:var(--fg)}.hand-prompt-sub{color:var(--fg-dim);font-size:11px}.hand-row{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;align-items:stretch}.card-skip{flex:0 0 86px;min-height:120px;padding:8px 10px;border-radius:var(--radius);border:2px dashed var(--fg-dim);background:transparent;color:var(--fg-dim);cursor:pointer;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;transition:transform .08s ease,border-color .15s ease,color .15s ease}.card-skip:active{transform:scale(.97);border-color:var(--fg);color:var(--fg)}.card-skip-label{font-weight:700;font-size:14px;letter-spacing:.5px}.card-skip-sub{font-size:10px;line-height:1.2;text-align:center}.card-back{flex:0 0 56px;height:84px;border-radius:8px;background:repeating-linear-gradient(45deg,#2b3e52 0,#2b3e52 6px,#243341 6px,#243341 12px);border:1px solid #1a2535}.card-face{flex:0 0 86px;min-height:120px;padding:0;border-radius:var(--radius);border:2px solid transparent;background:var(--bg-elev-2);color:var(--fg);text-align:left;cursor:pointer;transition:transform .08s ease,border-color .15s ease,opacity .15s ease;font-weight:500;min-width:0;font-size:13px}.card-face.playable{border-color:var(--accent)}.card-face.playable:active{transform:scale(1.04);border-color:var(--accent-press)}.card-face.disabled{opacity:.4;cursor:not-allowed;border-color:transparent}.card-face.card-leaving{animation:card-leave .32s ease-in forwards;pointer-events:none}@keyframes card-leave{0%{transform:translateY(0) scale(1);opacity:1}60%{transform:translateY(-22px) scale(1.08);opacity:.85}to{transform:translateY(-32px) scale(.7);opacity:0}}.card-face.card-entering{animation:card-enter .36s cubic-bezier(.22,1.2,.4,1)}@keyframes card-enter{0%{transform:translateY(18px) scale(.85);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}.card-face-inner{height:100%;padding:8px 10px;border-radius:calc(var(--radius) - 2px);display:flex;flex-direction:column;gap:4px;min-height:var(--tap)}.card-face-inner.compact{padding:6px 8px}.card-throw-tint{background:linear-gradient(160deg,#1d3a5c,#14283e)}.card-catch-tint{background:linear-gradient(160deg,#1d4a30,#112e1f)}.card-special-tint{background:linear-gradient(160deg,#5c4318,#3a2a0e)}.card-kind{font-size:10px;font-weight:700;letter-spacing:1px;color:var(--fg-dim)}.card-name{font-size:14px;font-weight:700;line-height:1.2;color:var(--fg)}.card-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:auto}.card-tag{font-size:10px;background:#00000059;color:var(--fg-dim);padding:2px 6px;border-radius:999px;letter-spacing:.3px}.me-bar{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elev);border-radius:var(--radius);padding:8px var(--space-3)}.me-name{font-weight:600;font-size:14px}.overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#080e16c7;display:flex;align-items:center;justify-content:center;z-index:10;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.overlay-card{background:var(--bg-elev);border-radius:var(--radius-lg);padding:var(--space-3);width:min(90%,420px);display:flex;flex-direction:column;gap:var(--space-2)}.overlay-card h3{margin:0;font-size:18px;color:var(--accent)}.overlay-sub{margin:0;color:var(--fg-dim);font-size:14px}.target-list{display:flex;flex-direction:column;gap:8px}.target-row{display:flex;align-items:center;justify-content:space-between;background:var(--bg-elev-2);color:var(--fg);padding:12px var(--space-3);border-radius:var(--radius)}.target-row:active{background:#2e3d50;transform:scale(.99)}.target-name{font-weight:600}.power-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:var(--space-1)}.power-btn{display:flex;flex-direction:column;align-items:flex-start;justify-content:center;gap:4px;background:var(--bg-elev-2);color:var(--fg);text-align:left;padding:12px 14px;min-height:88px;border-radius:var(--radius);border-left:4px solid transparent}.power-btn:active{background:#2e3d50;transform:scale(.98)}.power-btn-1{border-left-color:#4ec07a}.power-btn-2{border-left-color:#d4b94e}.power-btn-3{border-left-color:#d97a3a}.power-btn-4{border-left-color:#d44a4a}.power-btn-label{font-weight:700;font-size:16px}.power-btn-pips{display:inline-flex;gap:4px}.power-btn-pips .pip{width:10px;height:10px;border-radius:999px;background:#2a3a4f}.power-btn-pips .pip.on{background:var(--accent)}.power-btn-hint{font-size:12px;color:var(--fg-dim);font-weight:400}.power-indicator{position:absolute;top:10px;left:50%;transform:translate(-50%);display:inline-flex;align-items:center;gap:10px;background:#00000073;border:1px solid #2d4a3a;border-radius:999px;padding:4px 12px;font-size:12px;letter-spacing:.5px;text-transform:uppercase;color:var(--fg)}.power-indicator .power-label{font-weight:700}.power-indicator.power-1{border-color:#4ec07a}.power-indicator.power-2{border-color:#d4b94e}.power-indicator.power-3{border-color:#d97a3a}.power-indicator.power-4{border-color:#d44a4a}.power-pips{display:inline-flex;gap:3px}.power-pips .pip{width:7px;height:7px;border-radius:999px;background:#2a3a4f}.power-pips .pip.on{background:var(--accent)}.reflex-overlay{transition:background .12s ease-out}.reflex-overlay.flash-hit{background:#28c86459}.reflex-overlay.flash-miss{background:#dc3c3c59}.reflex-card{width:min(94%,460px);align-items:center;text-align:center}.reflex-card h3{text-align:center}.reflex-bar{position:relative;width:100%;height:28px;background:#1a2230;border:1px solid #2d3d52;border-radius:999px;overflow:hidden;margin:var(--space-1) 0}.reflex-zone{position:absolute;top:0;bottom:0;background:linear-gradient(180deg,#4ec07a73,#4ec07ad9);border-left:2px solid var(--good);border-right:2px solid var(--good)}.reflex-indicator{position:absolute;top:-2px;bottom:-2px;left:0;width:4px;background:var(--fg);box-shadow:0 0 8px #ffffffb3;border-radius:2px;will-change:transform;transform:translateZ(0)}.reflex-now{width:100%;font-size:18px;font-weight:800;letter-spacing:1px;padding:14px;text-transform:uppercase;transition:background .15s ease,transform .15s ease}.reflex-now-hit{background:var(--good)!important;color:#062020;animation:reflex-pop .36s ease-out}.reflex-now-miss{background:var(--danger)!important;color:#fff;animation:reflex-shake .36s ease-out}@keyframes reflex-pop{0%{transform:scale(1)}40%{transform:scale(1.06)}to{transform:scale(1)}}@keyframes reflex-shake{0%,to{transform:translate(0)}25%{transform:translate(-4px)}50%{transform:translate(4px)}75%{transform:translate(-2px)}}.reflex-passive{color:var(--fg-dim);font-size:12px;text-transform:uppercase;letter-spacing:1px;padding:10px 0}.outcome-meta{display:flex;gap:var(--space-3);justify-content:center;color:var(--fg-dim);font-size:13px;margin-top:2px}.card-inspector{position:fixed;top:0;right:0;bottom:0;left:0;background:#080e16c7;display:flex;align-items:center;justify-content:center;z-index:50;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);padding:var(--space-3)}.inspector-card{width:min(92%,360px);border-radius:var(--radius-lg);padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-1);border:2px solid #00000033;box-shadow:0 12px 36px #0000008c}.inspector-kind{font-size:11px;font-weight:700;letter-spacing:1px;color:var(--fg-dim)}.inspector-name{font-size:22px;font-weight:800;color:var(--fg);line-height:1.15}.inspector-tags{display:flex;flex-wrap:wrap;gap:4px;margin:6px 0 4px}.inspector-desc{margin:6px 0 var(--space-2);font-size:14px;color:var(--fg);line-height:1.4}.inspector-close{align-self:stretch}.game-over{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4)}.game-over-banner{text-align:center;background:var(--bg-elev);border-radius:var(--radius-lg);padding:var(--space-4);width:100%;border:2px solid transparent}.game-over-banner.won{border-color:var(--good)}.game-over-banner.lost{border-color:var(--fg-dim)}.game-over-banner h2{margin:0 0 var(--space-2);font-size:28px;color:var(--fg)}.game-over-banner p{margin:0;color:var(--fg-dim)}.game-over .btn-primary{width:100%;max-width:320px}@media (min-width: 720px){.content{max-width:720px;margin:0 auto;width:100%}.mode-grid{grid-template-columns:repeat(3,1fr)}.card-back{flex-basis:80px;height:120px}.card-face,.card-skip{flex-basis:110px;min-height:150px}.card-slot{width:130px;min-height:170px}}.dash-shell{display:flex;flex-direction:column;height:100%;background:var(--bg);color:var(--fg);overflow:hidden}.btn-danger{min-height:var(--tap);padding:0 18px;border-radius:var(--radius);border:0;font-size:16px;font-weight:600;cursor:pointer;background:var(--danger);color:#fff;transition:transform .05s ease,background .15s ease}.btn-danger:active{transform:scale(.98);background:#c54d4d}.btn-danger:disabled{background:#5a3a3a;color:#b0a0a0;cursor:not-allowed}.dash-loading{flex:1;display:flex;align-items:center;justify-content:center;color:var(--fg-dim);flex-direction:column;gap:12px;padding:var(--space-4);text-align:center}.dash-loading.dash-error strong{color:var(--danger);font-size:18px}.dash-loading p{margin:0;max-width:480px}.dash-header{display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:var(--bg-elev);border-bottom:1px solid #00000044;flex-shrink:0;gap:var(--space-3)}.dash-title{display:flex;align-items:baseline;gap:10px;font-size:18px;font-weight:600;letter-spacing:.3px}.dash-title-mark{color:var(--accent);letter-spacing:1.5px;font-weight:800}.dash-title-sep{color:var(--fg-dim)}.dash-title-name{color:var(--fg)}.dash-header-meta{display:flex;align-items:center;gap:var(--space-3);color:var(--fg-dim);font-size:14px}.dash-count{background:var(--bg-elev-2);padding:4px 10px;border-radius:999px;font-size:13px}.dash-link{color:var(--accent);text-decoration:none;font-size:14px}.dash-link:hover{text-decoration:underline}.dash-body{flex:1;display:grid;grid-template-columns:320px 1fr;min-height:0}.dash-sidebar{background:var(--bg-elev);border-right:1px solid #00000044;display:flex;flex-direction:column;min-height:0}.dash-sidebar-top{display:flex;flex-direction:column;gap:10px;padding:14px;border-bottom:1px solid #00000044}.dash-add{width:100%}.dash-search{width:100%;min-height:40px;padding:0 12px;border-radius:var(--radius);border:1px solid #2d3a4a;background:var(--bg);color:var(--fg);font-size:14px}.dash-search:focus{outline:2px solid var(--accent);border-color:var(--accent)}.dash-sidebar-scroll{flex:1;overflow-y:auto;padding:8px 8px 24px}.dash-group{margin-top:10px}.dash-group-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--fg-dim);margin:14px 8px 6px;display:flex;align-items:center;gap:8px}.dash-group-count{background:var(--bg-elev-2);color:var(--fg);padding:1px 7px;border-radius:999px;font-size:11px;font-weight:600;letter-spacing:0}.dash-group-empty{color:var(--fg-dim);font-size:13px;font-style:italic;margin:4px 8px 0}.dash-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:2px}.dash-list-item{width:100%;display:grid;grid-template-columns:48px 1fr auto;align-items:center;gap:10px;padding:10px 12px;background:transparent;color:var(--fg);border:1px solid transparent;border-radius:var(--radius);text-align:left;cursor:pointer;font-weight:500;font-size:14px;min-height:44px;transition:background .1s ease,border-color .1s ease}.dash-list-item:hover{background:var(--bg-elev-2)}.dash-list-item.selected{background:#4ec9c926;border-color:var(--accent)}.dash-list-mod{font-variant-numeric:tabular-nums;font-weight:700;font-size:13px;text-align:center;padding:3px 0;border-radius:6px;background:var(--bg-elev-2)}.dash-list-mod.mod-throw{color:#7ec0ff}.dash-list-mod.mod-catch{color:#8fe0a8}.dash-list-mod.mod-special{color:#f0c860}.dash-list-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-list-flag{color:var(--warn);font-style:italic;font-size:11px}.dash-list-copies{font-size:12px;color:var(--fg-dim);font-variant-numeric:tabular-nums}.dash-main{overflow-y:auto;padding:24px 32px 48px}.dash-empty{display:flex;align-items:center;justify-content:center;height:100%;color:var(--fg-dim);text-align:center;padding:48px}.dash-editor{display:grid;grid-template-columns:320px 1fr;gap:32px;align-items:start;max-width:1100px;margin:0 auto}.dash-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--fg-dim);margin:0 0 12px}.dash-preview-section{position:sticky;top:24px}.dash-preview-card{background:var(--bg-elev);border:2px solid var(--bg-elev-2);border-radius:var(--radius-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:0 8px 32px #00000059}.dash-preview-card.preview-throw{border-color:#2a4a72;background:linear-gradient(170deg,#1d3a5c 0%,var(--bg-elev) 60%)}.dash-preview-card.preview-catch{border-color:#2a5a3a;background:linear-gradient(170deg,#1d4a30 0%,var(--bg-elev) 60%)}.dash-preview-card.preview-special{border-color:#6a5028;background:linear-gradient(170deg,#5c4318 0%,var(--bg-elev) 60%)}.dash-preview-image{width:100%;aspect-ratio:4 / 3;background:#0000004d;overflow:hidden;display:flex;align-items:center;justify-content:center}.dash-preview-image img{width:100%;height:100%;object-fit:cover}.dash-preview-image-empty{color:var(--fg-dim);font-size:13px;font-style:italic;letter-spacing:.3px}.dash-preview-body{padding:14px 16px 18px;display:flex;flex-direction:column;gap:8px}.dash-preview-row{display:flex;align-items:center;justify-content:space-between}.dash-preview-kind{font-size:11px;font-weight:700;letter-spacing:1.5px;color:var(--fg-dim);text-transform:uppercase}.dash-preview-mod{font-size:22px;font-weight:800;font-variant-numeric:tabular-nums;padding:2px 12px;border-radius:8px;background:#0000004d}.dash-preview-mod.pos{color:var(--good)}.dash-preview-mod.neg{color:var(--danger)}.dash-preview-name{font-size:22px;font-weight:700;letter-spacing:.3px;color:var(--fg)}.dash-preview-tags{display:flex;gap:6px;flex-wrap:wrap;margin-top:2px}.dash-preview-tag{font-size:11px;background:#00000059;color:var(--accent);padding:3px 9px;border-radius:999px;letter-spacing:.3px}.dash-preview-desc{font-size:13px;color:var(--fg-dim);line-height:1.45;margin-top:4px}.dash-preview-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;color:var(--fg-dim);margin-top:8px;padding-top:10px;border-top:1px solid #00000044}.dash-form{display:flex;flex-direction:column;gap:16px;background:var(--bg-elev);padding:20px 24px 22px;border-radius:var(--radius-lg);border:1px solid #00000044}.dash-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.dash-field{display:flex;flex-direction:column;gap:6px}.dash-field-label{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--fg-dim);font-weight:600}.dash-input{width:100%;min-height:40px;padding:0 12px;border-radius:var(--radius);border:1px solid #2d3a4a;background:var(--bg);color:var(--fg);font-size:14px;font-family:inherit}.dash-input:focus{outline:2px solid var(--accent);border-color:var(--accent)}.dash-textarea{min-height:80px;padding:10px 12px;resize:vertical;line-height:1.45}.dash-tags{display:flex;flex-direction:column;gap:4px}.dash-tag-list{display:flex;flex-wrap:wrap;gap:6px;padding:8px 10px;background:var(--bg);border:1px solid #2d3a4a;border-radius:var(--radius);min-height:44px;align-items:center}.dash-tag-list:focus-within{outline:2px solid var(--accent);border-color:var(--accent)}.dash-tag-chip{display:inline-flex;align-items:center;gap:4px;background:#4ec9c92e;color:var(--accent);padding:3px 4px 3px 10px;border-radius:999px;font-size:13px}.dash-tag-remove{all:unset;cursor:pointer;width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;border-radius:999px;font-size:16px;line-height:1;color:var(--accent)}.dash-tag-remove:hover{background:#4ec9c940}.dash-tag-input{border:0;background:transparent;color:var(--fg);outline:none;font-size:14px;flex:1;min-width:90px;min-height:28px;font-family:inherit}.dash-tag-hint{font-size:11px;color:var(--fg-dim)}.dash-image{display:flex;gap:14px;align-items:flex-start}.dash-image-preview{width:140px;height:100px;background:var(--bg);border:1px solid #2d3a4a;border-radius:var(--radius);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.dash-image-preview img{width:100%;height:100%;object-fit:cover}.dash-image-empty{color:var(--fg-dim);font-size:12px;font-style:italic}.dash-image-actions{display:flex;flex-direction:column;gap:8px}.dash-image-actions button{min-height:36px;padding:0 14px;font-size:14px}.dash-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:4px;padding-top:14px;border-top:1px solid #00000044}.dash-save{min-width:160px}.dash-delete{margin-left:auto}.dash-confirm{display:inline-flex;align-items:center;gap:10px;margin-left:auto;background:#e25c5c1f;padding:8px 12px;border:1px solid var(--danger);border-radius:var(--radius);font-size:13px;color:var(--fg)}.dash-confirm button{min-height:36px;padding:0 14px;font-size:13px}.dash-error-msg{background:#e25c5c26;color:var(--danger);border:1px solid var(--danger);border-radius:var(--radius);padding:8px 12px;font-size:13px;margin-top:4px}@media (max-width: 880px){.dash-body{grid-template-columns:1fr}.dash-sidebar{border-right:0;border-bottom:1px solid #00000044;max-height:280px}.dash-editor{grid-template-columns:1fr}.dash-preview-section{position:static}.dash-main{padding:16px}}
