:root{--bg-deep: #0f0f1e;--bg-mid: #1a1a2e;--bg-soft: #232347;--bg-card: #2a2a4a;--border: #3d3d5c;--border-strong: #5b5b80;--text: #e8e8f4;--text-dim: #9090b0;--text-mute: #6a6a8a;--accent: #ffb454;--accent-deep: #d97706;--gold: #fcd34d;--hp-good: #22c55e;--hp-mid: #facc15;--hp-low: #ef4444;--damage: #ff5050;--heal: #4ade80;--shield: #60a5fa;--mana: #a78bfa;--type-attack: #b91c1c;--type-attack-2: #ef4444;--type-defense: #1e40af;--type-defense-2: #3b82f6;--type-heal: #15803d;--type-heal-2: #22c55e;--type-skill: #6b21a8;--type-skill-2: #a855f7;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .6);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 14px}*{box-sizing:border-box}html,body,#root{height:100%;margin:0;padding:0}body{background:radial-gradient(1200px 600px at 50% -200px,#2a1f4a 0%,transparent 70%),radial-gradient(900px 500px at 100% 100%,#1a2f4a 0%,transparent 70%),var(--bg-deep);color:var(--text);font-family:Helvetica Neue,Segoe UI,PingFang SC,Microsoft YaHei,sans-serif;font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased;-webkit-user-select:none;user-select:none;overflow:hidden}button{font-family:inherit}.app-root{position:relative;width:100vw;height:100vh;overflow:hidden}.screen{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--border-strong);background:var(--bg-card);color:var(--text);border-radius:var(--radius-md);cursor:pointer;transition:transform .06s ease,background .18s ease,border-color .18s ease,box-shadow .18s ease;font-weight:600;letter-spacing:.5px;white-space:nowrap}.btn:hover:not(:disabled){background:var(--bg-soft);border-color:var(--accent)}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-md{padding:9px 18px;font-size:14px}.btn-lg{padding:14px 32px;font-size:17px}.btn-primary{background:linear-gradient(180deg,var(--accent) 0%,var(--accent-deep) 100%);border-color:var(--accent);color:#1a0e00;text-shadow:0 1px 0 rgba(255,255,255,.2);box-shadow:0 2px 8px #ffb45440}.btn-primary:hover:not(:disabled){background:linear-gradient(180deg,#ffc26a,#f08a16);border-color:var(--gold);box-shadow:0 4px 14px #ffb45466}.btn-secondary{background:var(--bg-soft);border-color:var(--border-strong)}.btn-ghost{background:transparent;border-color:var(--border);color:var(--text-dim)}.btn-ghost:hover:not(:disabled){color:var(--text)}.btn-danger{background:linear-gradient(180deg,#b91c1c,#7f1d1d);border-color:#b91c1c;color:#fff}.btn-danger:hover:not(:disabled){background:linear-gradient(180deg,#dc2626,#991b1b)}.menu-screen{align-items:center;justify-content:center}.menu-card{width:min(440px,92vw);padding:36px 32px;background:#1a1a2ed9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:stretch;gap:14px;text-align:center}.menu-title{margin:0 0 4px;display:flex;flex-direction:column;align-items:center;gap:4px}.menu-title-cn{font-size:56px;font-weight:900;letter-spacing:16px;background:linear-gradient(180deg,var(--gold),var(--accent-deep));-webkit-background-clip:text;background-clip:text;color:transparent;text-shadow:0 4px 24px rgba(255,180,84,.25);padding-left:16px}.menu-title-en{font-size:14px;letter-spacing:12px;color:var(--text-dim);padding-left:12px}.menu-subtitle{margin:0 0 12px;color:var(--text-dim);font-size:14px}.rules-panel{text-align:left;background:#0f0f1e99;border:1px solid var(--border);border-radius:var(--radius-md);padding:12px 16px;font-size:13px;color:var(--text-dim);max-height:320px;overflow-y:auto}.rules-panel h3{color:var(--accent);font-size:13px;margin:10px 0 4px}.rules-panel ul,.rules-panel ol{margin:4px 0 8px;padding-left:20px}.matchmaking-screen{align-items:center;justify-content:center}.match-card{width:min(420px,92vw);padding:36px 32px;text-align:center;background:#1a1a2ed9;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:16px}.match-spinner{position:relative;width:96px;height:96px;display:flex;align-items:center;justify-content:center}.spinner-ring{position:absolute;top:0;right:0;bottom:0;left:0;border:3px solid rgba(255,180,84,.18);border-top-color:var(--accent);border-radius:50%;animation:spin 1.4s linear infinite}.spinner-emoji{font-size:38px;animation:bob 1.6s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bob{0%,to{transform:translateY(-2px) rotate(-8deg)}50%{transform:translateY(2px) rotate(8deg)}}.match-title{font-size:22px;margin:0;display:inline-flex;align-items:baseline}.dots span{display:inline-block;animation:blink 1.4s infinite}.dots span:nth-child(2){animation-delay:.2s}.dots span:nth-child(3){animation-delay:.4s}@keyframes blink{0%,to{opacity:.2}50%{opacity:1}}.match-position{font-size:15px;color:var(--text-dim)}.match-position strong{color:var(--accent);font-size:18px;margin-left:4px}.match-tip{margin:0;font-size:12px;color:var(--text-mute)}.muted{color:var(--text-mute)}.game-screen{display:grid;grid-template-rows:minmax(150px,auto) 1fr minmax(280px,auto);gap:8px;padding:10px 14px}.game-loading{align-items:center;justify-content:center}.loading-text{color:var(--text-dim);font-size:18px}.board-area{border-radius:var(--radius-md);padding:10px 14px;background:#0f0f1e8c;border:1px solid var(--border);position:relative}.opponent-area{border-color:#ef444440;background:linear-gradient(180deg,#50141e59,#0f0f1e80)}.my-area{border-color:#60a5fa40;background:linear-gradient(180deg,#0f0f1e80,#14285066);display:flex;flex-direction:column;gap:8px}.middle-area{display:grid;grid-template-columns:1fr 220px;gap:10px;padding:0;background:transparent;border:none}.turn-banner{display:flex;align-items:center;justify-content:center;background:#0f0f1e8c;border:1px solid var(--border);border-radius:var(--radius-md);font-size:18px;font-weight:700;letter-spacing:2px}.turn-banner-yours{color:var(--gold);text-shadow:0 0 20px rgba(252,211,77,.5);animation:pulse 2s ease-in-out infinite}.turn-banner-theirs{color:var(--text-dim)}@keyframes pulse{0%,to{transform:scale(1);opacity:.9}50%{transform:scale(1.04);opacity:1}}.hand-row{display:flex;flex-direction:row;justify-content:center;align-items:flex-end;gap:6px;min-height:180px;padding:0 8px;flex-wrap:nowrap}.hand-slot{display:flex;align-items:flex-end;justify-content:center;transition:transform .18s ease}.hand-slot:hover{transform:translateY(-10px);z-index:5}.action-bar{display:flex;justify-content:center;gap:14px;padding-top:4px}.player-info{display:flex;flex-direction:column;gap:6px}.player-info.is-current{outline:1px solid rgba(252,211,77,.45);outline-offset:-1px;border-radius:var(--radius-md)}.player-info-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.player-name{display:inline-flex;align-items:baseline;gap:8px;font-weight:700;font-size:16px}.player-sub{color:var(--text-dim);font-weight:400;font-size:12px}.turn-pill{background:var(--gold);color:#1a0e00;font-size:11px;font-weight:700;padding:2px 8px;border-radius:10px;letter-spacing:1px;margin-left:6px}.counts{display:flex;gap:12px;font-size:13px;color:var(--text-dim)}.hp-bar-wrapper{position:relative}.hp-bar{position:relative;height:22px;background:#1a1a2e;border:1px solid var(--border);border-radius:11px;overflow:hidden;transition:box-shadow .2s ease}.hp-bar-fill{position:absolute;top:0;left:0;bottom:0;background:linear-gradient(180deg,var(--hp-good) 0%,#15803d 100%);transition:width .4s cubic-bezier(.22,1,.36,1)}.hp-bar-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.6);letter-spacing:1px}.hp-flash-damage{animation:hp-flash-red .6s ease;box-shadow:0 0 16px #ff505099}.hp-flash-heal{animation:hp-flash-green .6s ease;box-shadow:0 0 16px #4ade8099}@keyframes hp-flash-red{0%{background:#ff505099}to{background:#1a1a2e}}@keyframes hp-flash-green{0%{background:#4ade8099}to{background:#1a1a2e}}.float-layer{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;overflow:visible}.float-num{position:absolute;left:50%;top:0;transform:translate(-50%);font-size:26px;font-weight:900;text-shadow:0 0 6px rgba(0,0,0,.8),0 2px 4px rgba(0,0,0,.6);animation:float-up 1.4s ease-out forwards;white-space:nowrap}.float-damage{color:#ff6464}.float-heal{color:var(--heal)}.float-shield{color:var(--shield)}@keyframes float-up{0%{transform:translate(-50%,8px) scale(.6);opacity:0}20%{transform:translate(-50%,-8px) scale(1.2);opacity:1}to{transform:translate(-50%,-60px) scale(1);opacity:0}}.stats-row{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-start}.stat-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:12px;font-size:13px;font-weight:600;background:#0f0f1e99;border:1px solid var(--border)}.stat-shield{color:var(--shield);border-color:#60a5fa66}.stat-mana{color:var(--mana);border-color:#a78bfa66}.stat-enrage{color:#fb923c;border-color:#fb923c80;animation:pulse 1.6s infinite}.stat-debuff{color:#94a3b8}.opponent-hand-row{display:flex;gap:4px;justify-content:center;margin-top:4px}.empty-hand{color:var(--text-mute);font-size:12px;font-style:italic}.card{width:110px;height:160px;border-radius:10px;border:2px solid var(--border-strong);background:var(--bg-card);padding:8px 6px;display:flex;flex-direction:column;align-items:center;justify-content:space-between;position:relative;cursor:pointer;transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;box-shadow:var(--shadow-md);outline:none;flex:0 0 auto}.card:focus-visible{box-shadow:0 0 0 3px var(--gold),var(--shadow-md)}.card-small{width:72px;height:100px;padding:4px 3px}.card-attack{background:linear-gradient(160deg,var(--type-attack-2) 0%,var(--type-attack) 100%);border-color:#fca5a5}.card-defense{background:linear-gradient(160deg,var(--type-defense-2) 0%,var(--type-defense) 100%);border-color:#93c5fd}.card-heal{background:linear-gradient(160deg,var(--type-heal-2) 0%,var(--type-heal) 100%);border-color:#86efac}.card-skill{background:linear-gradient(160deg,var(--type-skill-2) 0%,var(--type-skill) 100%);border-color:#d8b4fe}.card-disabled{filter:grayscale(.85) brightness(.55);cursor:not-allowed;pointer-events:none}.card-enrage{box-shadow:0 0 18px #fb923cb3,var(--shadow-md)}.card-playing{animation:play-card .5s ease forwards;pointer-events:none}@keyframes play-card{0%{transform:translateY(0) scale(1);opacity:1}60%{transform:translateY(-180px) scale(1.2);opacity:1}to{transform:translateY(-260px) scale(.4);opacity:0}}.card-cost{position:absolute;top:-8px;left:-8px;width:30px;height:30px;border-radius:50%;background:radial-gradient(circle at 30% 30%,#c4b5fd,var(--mana) 70%);border:2px solid #fff;display:flex;align-items:center;justify-content:center;font-weight:900;font-size:14px;color:#1a0030;box-shadow:0 2px 6px #00000080}.card-cost-gem{display:none}.card-cost-num{line-height:1}.card-emoji{font-size:32px;line-height:1;margin-top:8px}.card-name{font-size:16px;font-weight:800;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.7);letter-spacing:1px}.card-effect{font-size:12px;color:#fffffff2;text-align:center;padding:0 2px;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.6)}.card-type-label{font-size:10px;color:#ffffffb3;letter-spacing:2px;text-transform:uppercase}.card-back{background:repeating-linear-gradient(45deg,#1e1e3a,#1e1e3a 6px,#2a2a4a 6px,#2a2a4a 12px);border-color:var(--border-strong);width:36px;height:50px;padding:0;cursor:default}.card-back-pattern{font-size:18px;color:var(--accent);margin:auto;text-shadow:0 0 4px rgba(0,0,0,.6)}.card-back-count{position:absolute;bottom:2px;right:4px;font-size:10px;color:#fff;background:#0009;padding:1px 4px;border-radius:6px}.combat-log{display:flex;flex-direction:column;background:#0f0f1ea6;border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;height:100%;min-height:0}.combat-log-header{display:flex;align-items:center;justify-content:space-between;padding:6px 12px;background:#00000059;border-bottom:1px solid var(--border);font-size:13px;font-weight:700;color:var(--text-dim)}.combat-log-meta{display:flex;gap:12px}.time-warning{color:var(--damage);animation:pulse 1s ease-in-out infinite}.combat-log-body{flex:1;overflow-y:auto;padding:6px 10px;font-size:12.5px;line-height:1.6}.log-entry{padding:1px 0;color:var(--text-dim)}.log-system{color:var(--text-mute);font-style:italic}.log-damage{color:#ff8a8a}.log-heal{color:#86efac}.log-shield{color:#93c5fd}.log-skill{color:#d8b4fe}.log-turn{color:var(--gold);font-weight:600}.combat-log-body::-webkit-scrollbar{width:6px}.combat-log-body::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}.conn-indicator{position:fixed;bottom:8px;right:10px;display:inline-flex;align-items:center;gap:6px;background:#0000008c;padding:4px 9px;border-radius:12px;font-size:11.5px;color:var(--text-dim);z-index:100;pointer-events:none}.conn-dot{width:8px;height:8px;border-radius:50%;display:inline-block}.conn-green{background:#22c55e;box-shadow:0 0 6px #22c55e}.conn-yellow{background:#facc15;box-shadow:0 0 6px #facc15;animation:pulse 1.2s infinite}.conn-red{background:#ef4444;box-shadow:0 0 6px #ef4444}.conn-label{letter-spacing:1px}.error-toast{position:fixed;top:16px;left:50%;transform:translate(-50%);background:linear-gradient(180deg,#b91c1c,#7f1d1d);color:#fff;border-radius:var(--radius-md);padding:10px 16px;display:flex;align-items:center;gap:12px;font-size:14px;font-weight:600;cursor:pointer;z-index:200;box-shadow:var(--shadow-lg);animation:toast-in .3s ease;max-width:90vw}@keyframes toast-in{0%{transform:translate(-50%,-16px);opacity:0}to{transform:translate(-50%);opacity:1}}.error-toast-close{background:transparent;border:none;color:#ffffffd9;cursor:pointer;font-size:14px;padding:0 2px}.game-over-screen{align-items:center;justify-content:center}.game-over-card{width:min(440px,92vw);padding:36px 28px;background:#1a1a2ee0;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.game-over-screen.is-win .game-over-card{border-color:var(--gold);box-shadow:0 0 40px #fcd34d4d,var(--shadow-lg)}.game-over-screen.is-lose .game-over-card{border-color:#ef444499}.game-over-emoji{font-size:70px;line-height:1;animation:float-bob 2s ease-in-out infinite}@keyframes float-bob{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.game-over-title{margin:0;font-size:38px;letter-spacing:6px}.game-over-screen.is-win .game-over-title{color:var(--gold);text-shadow:0 0 24px rgba(252,211,77,.5)}.game-over-screen.is-lose .game-over-title{color:#ef4444}.game-over-screen.is-draw .game-over-title{color:var(--text)}.game-over-sub{margin:0;color:var(--text-dim);font-size:15px}.game-over-reason{margin:0;color:var(--text-mute);font-size:12px;font-style:italic}.game-over-stats{display:flex;gap:30px;margin:8px 0 4px}.gostat{display:flex;flex-direction:column;align-items:center;gap:2px}.gostat-label{color:var(--text-mute);font-size:11px;letter-spacing:2px;text-transform:uppercase}.gostat-value{color:var(--accent);font-size:26px;font-weight:800}.game-over-actions{display:flex;flex-direction:column;gap:8px;width:100%;margin-top:8px}.disconnected-screen{align-items:center;justify-content:center}.disconnected-card{width:min(420px,92vw);padding:36px 28px;background:#1a1a2ee0;border:1px solid rgba(250,204,21,.4);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:14px;text-align:center}.disconnect-icon{font-size:56px;animation:shake 1.6s ease-in-out infinite}@keyframes shake{0%,to{transform:rotate(-6deg)}50%{transform:rotate(6deg)}}.disconnect-title{margin:0;font-size:26px;color:var(--gold);letter-spacing:4px}.disconnect-sub{margin:0;color:var(--text-dim);font-size:14px}.countdown-wrap{position:relative;width:140px;height:140px;display:flex;align-items:center;justify-content:center}.countdown-ring{position:absolute;top:0;right:0;bottom:0;left:0}.ring-bg{stroke:#ffffff14}.ring-fg{stroke:var(--gold);transition:stroke-dashoffset 1s linear;filter:drop-shadow(0 0 6px rgba(252,211,77,.6))}.countdown-num{position:relative;font-size:44px;font-weight:900;color:var(--gold);line-height:1}.countdown-label{position:absolute;bottom:24px;font-size:11px;color:var(--text-mute);letter-spacing:4px}@media (max-width: 720px){.menu-title-cn{font-size:44px}.game-screen{padding:6px 8px;grid-template-rows:minmax(140px,auto) 1fr minmax(260px,auto)}.middle-area{grid-template-columns:1fr}.turn-banner{display:none}.card{width:86px;height:130px;padding:6px 4px}.card-emoji{font-size:24px}.card-name{font-size:13px}}
