:root{color-scheme:dark;--bg0: #041a13;--bg1: #0b4b35;--panel: rgba(255, 255, 255, .08);--panel-border: rgba(255, 255, 255, .14);--ink: #f8fafc;--muted: rgba(248, 250, 252, .72);--shadow: rgba(0, 0, 0, .55);--cardRadius: 12px;--pileCardW: 120px;--pileCardH: 168px;--handCardW: 80px;--handCardH: 112px;--uno-red: #ed1c24;--uno-red-dark: #b71c1c;--uno-yellow: #ffde00;--uno-yellow-dark: #f9a825;--uno-green: #00a651;--uno-green-dark: #1b5e20;--uno-blue: #0072bc;--uno-blue-dark: #0d47a1;--uno-black: #1a1a1a}*{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Hiragino Kaku Gothic ProN,Noto Sans JP,sans-serif;color:var(--ink);background:radial-gradient(circle at 50% 20%,rgba(255,255,255,.07) 0%,transparent 55%),radial-gradient(circle at 12% 110%,rgba(255,216,122,.08) 0%,transparent 50%),radial-gradient(circle at 88% -12%,rgba(122,255,216,.06) 0%,transparent 52%),linear-gradient(180deg,var(--bg1),var(--bg0));min-height:100vh}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;pointer-events:none;opacity:.08;background:repeating-linear-gradient(45deg,rgba(255,255,255,.12) 0px,rgba(255,255,255,.12) 1px,transparent 1px,transparent 9px)}input,select,button{font:inherit}input,select{border:1px solid rgba(255,255,255,.12);border-radius:12px;padding:10px 12px;background:#ffffffeb;color:#0f172a}button{border:none;border-radius:12px;padding:10px 16px;cursor:pointer;font-weight:600;transition:transform .15s cubic-bezier(.34,1.56,.64,1),filter .15s ease,box-shadow .15s ease,background .15s ease}button:disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.5;transform:none}button:hover:not(:disabled){transform:translateY(-2px)}button:active:not(:disabled){transform:translateY(0) scale(.98)}.primary{background:linear-gradient(180deg,#ffd56a,#f59e0b);color:#1a1200;font-weight:900;letter-spacing:.02em;box-shadow:0 4px 12px #f59e0b4d,0 2px 4px #0003}.primary:hover:not(:disabled){box-shadow:0 6px 20px #f59e0b66,0 4px 8px #0003}.secondary{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:var(--ink)}.secondary:hover:not(:disabled){background:#ffffff26}.danger{background:linear-gradient(180deg,#f87171,#dc2626);color:#fff;font-weight:900;box-shadow:0 4px 12px #dc26264d,0 2px 4px #0003}.danger:hover:not(:disabled){box-shadow:0 6px 20px #dc262666,0 4px 8px #0003}.ghost{background:transparent;color:var(--ink);border:1px solid rgba(255,255,255,.15)}.ghost:hover:not(:disabled){background:#ffffff14}.big{padding:14px 24px;font-size:1.05rem;border-radius:14px}.muted{color:var(--muted)}.app-shell{max-width:1400px;margin:0 auto;padding:14px 14px 140px}.screen{animation:screenIn .17s ease-out}@keyframes screenIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.top-bar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;padding:0 4px}.brand{display:flex;align-items:center;gap:12px}.top-bar h1{margin:0;font-size:1.5rem;font-weight:900;letter-spacing:.02em;background:linear-gradient(180deg,var(--uno-yellow),var(--uno-red));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.room-pill{padding:6px 12px;border-radius:999px;background:#ffffff1a;border:1px solid rgba(255,255,255,.15);font-size:.8rem;font-weight:600;color:#fffc;letter-spacing:.03em}.top-actions{display:flex;align-items:center;gap:10px}.status-pill{padding:6px 12px;border-radius:999px;background:#ffffff14;border:2px solid rgba(255,255,255,.15);font-size:.8rem;font-weight:600;color:#fffc;transition:border-color .2s ease}.status-idle{border-color:#ffffff26}.status-connecting{border-color:var(--uno-yellow);animation:statusPulse 1s ease-in-out infinite}@keyframes statusPulse{0%,to{opacity:1}50%{opacity:.6}}.status-connected{border-color:var(--uno-green);color:var(--uno-green)}.status-error{border-color:var(--uno-red);color:var(--uno-red)}.row-buttons{display:flex;gap:12px;flex-wrap:wrap}.home-screen{max-width:480px;margin:40px auto 0;display:grid;gap:20px}.home-hero{text-align:center;padding:20px}.home-hero h2{margin:0;font-size:1.5rem;font-weight:900;letter-spacing:.02em;background:linear-gradient(180deg,#fff,#fffc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-hero p{margin:10px 0 0;font-size:.95rem}.panel{background:#0006;border:1px solid rgba(255,255,255,.12);border-radius:20px;box-shadow:0 16px 48px #0006,inset 0 1px #ffffff0d;padding:20px;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.form-panel{display:grid;gap:16px}label{display:grid;gap:8px;font-size:.9rem;font-weight:600;color:#fffc}input,select{border:2px solid rgba(255,255,255,.15);border-radius:12px;padding:12px 14px;background:#fffffff2;color:#1a1a1a;font-size:1rem;transition:border-color .15s ease,box-shadow .15s ease}input:focus,select:focus{outline:none;border-color:var(--uno-yellow);box-shadow:0 0 0 3px #ffde0033}.segmented{display:grid;grid-template-columns:1fr 1fr;border-radius:12px;overflow:hidden;border:2px solid rgba(255,255,255,.15);background:#0000004d}.seg{background:transparent;color:#ffffffb3;border-radius:0;padding:12px 16px;font-weight:600;transition:all .15s ease}.seg:hover:not(.on){background:#ffffff0d;transform:none}.seg.on{background:linear-gradient(180deg,var(--uno-yellow),var(--uno-yellow-dark));color:#1a1a1a;font-weight:900}.table-stage{border-radius:24px;border:2px solid rgba(255,255,255,.1);background:radial-gradient(ellipse at 50% 30%,rgba(0,80,50,.6) 0%,transparent 60%),radial-gradient(ellipse at 50% 100%,rgba(0,0,0,.5) 0%,transparent 50%),linear-gradient(180deg,#003c28f2,#002d1efa,#001e14);box-shadow:0 24px 64px #00000080,inset 0 1px #ffffff1a;padding:20px}.lobby-hero{display:grid;gap:12px;align-items:center;justify-items:center;margin-bottom:20px;padding:16px}.lobby-roomcode{font-weight:900;font-size:2.5rem;letter-spacing:.1em;text-shadow:0 4px 12px rgba(0,0,0,.3);background:linear-gradient(180deg,#fff,#ffffffd9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.lobby-actions,.lobby-meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.lobby-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.lobby-grid .panel h3{margin:0 0 14px;font-size:1rem;font-weight:700;color:#ffffffe6}.player-list{display:grid;gap:10px}.player-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;transition:background .15s ease}.player-line:hover{background:#ffffff14}.player-line-main{display:flex;align-items:center;gap:10px}.player-name{font-weight:700;font-size:1rem}.player-line-sub{display:flex;align-items:center;gap:8px}.config-panel{display:grid;gap:14px}.config-panel label{font-size:.85rem}.config-panel select,.config-panel input{padding:10px 12px;font-size:.95rem}.config-panel button{margin-top:8px}.config-readonly{display:grid;gap:10px}.readonly-line{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 12px;border-radius:10px;border:1px solid rgba(255,255,255,.08);background:#ffffff08;font-size:.9rem}.readonly-line .muted{font-weight:500}.hint{margin:8px 0 0;font-size:.85rem;opacity:.7}.badge{display:inline-flex;align-items:center;justify-content:center;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700;letter-spacing:.03em;border:1px solid rgba(255,255,255,.15);background:#ffffff14;color:#ffffffe6;text-transform:uppercase}.badge.muted{color:#fff9;background:#ffffff0d}.table-grid{display:grid;grid-template-areas:"top top top" "left center right" "bottom bottom bottom";grid-template-columns:1fr minmax(320px,560px) 1fr;grid-template-rows:auto 1fr auto;gap:12px;align-items:center;min-height:min(72vh,760px)}.seat-area{display:flex;align-items:center;justify-content:center}.top-area{grid-area:top}.left-area{grid-area:left}.right-area{grid-area:right}.bottom-area{grid-area:bottom}.center-area{grid-area:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:4px 0 0}.seat{min-width:180px;max-width:280px;padding:14px 16px;border-radius:16px;border:2px solid rgba(255,255,255,.15);background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 8px 24px #0000004d;display:grid;gap:10px;position:relative;transition:all .2s ease}.seat.turn{border-color:var(--uno-yellow);box-shadow:0 0 0 3px #ffde004d,0 8px 24px #0000004d;animation:turnGlow 1.5s ease-in-out infinite}@keyframes turnGlow{0%,to{box-shadow:0 0 0 3px #ffde004d,0 8px 24px #0000004d}50%{box-shadow:0 0 0 5px #ffde0033,0 0 30px #ffde0033,0 8px 24px #0000004d}}.seat.me{border-color:var(--uno-green)}.seat.uno{border-color:var(--uno-red);animation:unoAlert .5s ease-in-out infinite}@keyframes unoAlert{0%,to{border-color:var(--uno-red)}50%{border-color:#ed1c2466}}.seat-name{display:flex;align-items:center;gap:8px;justify-content:center;flex-wrap:wrap}.seat-name-text{font-weight:900;font-size:1.05rem}.seat-meta{display:flex;gap:8px;justify-content:center;align-items:center}.badge.count{background:#ffd56a33;border-color:#ffd56a66;color:#ffd56a;font-size:.85rem;padding:4px 10px}.seat-action{justify-self:center;padding:10px 16px;border-radius:999px;background:var(--uno-red);color:#fff;font-weight:900;font-size:.9rem;border:none;cursor:pointer;animation:unoButtonPulse 1s ease-in-out infinite}@keyframes unoButtonPulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}.seat-empty{opacity:0;pointer-events:none}.spectator-strip{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;padding:8px}.strip-chip{display:inline-flex;align-items:center;gap:10px;padding:10px 14px;border-radius:999px;border:2px solid rgba(255,255,255,.15);background:#0006;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all .2s ease}.strip-chip.turn{border-color:var(--uno-yellow);box-shadow:0 0 20px #ffde0033}.chip-name{font-weight:700}.spectator-hint{padding:12px 16px;border-radius:999px;border:1px solid rgba(255,255,255,.1);background:#0000004d;color:#ffffffb3;font-size:.9rem}.table-hud{width:100%;max-width:480px;padding:14px 18px;border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#00000080;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:grid;gap:10px}.hud-line{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:center}.hud-value{font-weight:900;font-size:1.1rem;letter-spacing:.02em}.declared-pill{padding:8px 16px;border-radius:999px;font-weight:900;font-size:.9rem;text-transform:uppercase;letter-spacing:.05em;transition:all .2s ease}.declared-pill.none{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#ffffff80}.declared-pill.red{background:var(--uno-red);color:#fff;box-shadow:0 4px 12px #ed1c2466}.declared-pill.yellow{background:var(--uno-yellow);color:#333;box-shadow:0 4px 12px #ffde0066}.declared-pill.green{background:var(--uno-green);color:#fff;box-shadow:0 4px 12px #00a65166}.declared-pill.blue{background:var(--uno-blue);color:#fff;box-shadow:0 4px 12px #0072bc66}.hud-warn{text-align:center;font-weight:700;color:#ffd56a;padding:8px 12px;background:#ffd56a26;border-radius:8px;animation:warnPulse 1.5s ease-in-out infinite}@keyframes warnPulse{0%,to{opacity:1}50%{opacity:.7}}.piles{display:flex;gap:30px;align-items:center;justify-content:center;padding:16px}.pile{display:grid;gap:10px;justify-items:center}.pile-stack{position:relative;width:var(--pileCardW);height:var(--pileCardH)}.pile-draw .pile-stack:before,.pile-draw .pile-stack:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:var(--cardRadius);background:var(--uno-black);border:3px solid #fff}.pile-draw .pile-stack:before{transform:translate(6px,6px) rotate(-2deg);opacity:.6}.pile-draw .pile-stack:after{transform:translate(3px,3px) rotate(-1deg);opacity:.8}.pile.clickable{cursor:pointer}.pile.clickable .pile-stack{transition:transform .18s ease}.pile.clickable:hover .pile-stack{transform:scale(1.05)}.pile.clickable .card{animation:drawPileGlow 2s ease-in-out infinite}@keyframes drawPileGlow{0%,to{box-shadow:0 4px 8px #0000004d,0 12px 24px #00000040}50%{box-shadow:0 4px 8px #0000004d,0 12px 24px #00000040,0 0 30px #ffd56a66}}.pile-discard .pile-stack{filter:drop-shadow(0 8px 20px rgba(0,0,0,.4))}.pile-caption{font-weight:900;font-size:.85rem;letter-spacing:.12em;text-transform:uppercase;color:#fff9}.card{width:var(--pileCardW);height:var(--pileCardH);border-radius:var(--cardRadius);border:3px solid #fff;box-shadow:0 4px 8px #0000004d,0 12px 24px #00000040,inset 0 1px #ffffff4d;display:grid;place-items:center;color:#fff;font-weight:900;-webkit-user-select:none;user-select:none;position:relative;overflow:hidden}.card:before{content:"";position:absolute;width:85%;height:75%;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-25deg);border-radius:50%;background:#fff;box-shadow:0 4px 12px #0003,inset 0 0 0 3px currentColor}.card.back{background:var(--uno-black);border-color:#fff}.card.back:before{background:linear-gradient(135deg,var(--uno-red) 0%,var(--uno-red) 25%,var(--uno-yellow) 25%,var(--uno-yellow) 50%,var(--uno-green) 50%,var(--uno-green) 75%,var(--uno-blue) 75%,var(--uno-blue) 100%);box-shadow:none;width:70%;height:55%;transform:translate(-50%,-50%) rotate(0)}.card.back .card-label{font-family:Arial Black,Helvetica Neue,sans-serif;font-size:1.4rem;font-weight:900;font-style:italic;color:#fff;text-shadow:2px 2px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000;letter-spacing:-.02em}.card.back .corner{display:none}.card.empty{background:#ffffff0f;border:2px dashed rgba(255,255,255,.3);color:#ffffff80}.card.empty:before{display:none}.corner{position:absolute;top:6px;left:6px;font-size:1.1rem;font-weight:900;z-index:2;text-shadow:1px 1px 0 rgba(0,0,0,.3),-1px -1px 0 rgba(255,255,255,.2);line-height:1}.corner.br{top:auto;left:auto;right:6px;bottom:6px;transform:rotate(180deg)}.card-label{position:relative;z-index:2;font-size:3rem;font-weight:900;line-height:1;text-shadow:2px 2px 0 rgba(0,0,0,.25),0 4px 8px rgba(0,0,0,.3)}.card-symbol{position:relative;z-index:2;font-size:2.8rem;line-height:1}.hand-fan{position:fixed;left:0;right:0;bottom:calc(80px + env(safe-area-inset-bottom));height:200px;padding:0 20px;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;touch-action:pan-x;z-index:30;scrollbar-width:none}.hand-fan::-webkit-scrollbar{display:none}.hand-row{width:max-content;margin:0 auto;height:100%;display:flex;align-items:flex-end;justify-content:center;padding:0 40px 20px;pointer-events:auto}.hand-card{position:relative;width:var(--handCardW);height:var(--handCardH);border-radius:var(--cardRadius);border:3px solid #fff;box-shadow:0 4px 8px #0000004d,0 8px 16px #0003;display:grid;place-items:center;color:#fff;font-weight:900;pointer-events:auto;-webkit-user-select:none;user-select:none;overflow:hidden;transform-origin:50% 100%;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s ease,filter .18s ease,margin-top .18s ease;cursor:pointer}.hand-card:before{content:"";position:absolute;width:85%;height:75%;top:50%;left:50%;transform:translate(-50%,-50%) rotate(-25deg);border-radius:50%;background:#fff;box-shadow:inset 0 0 0 2px currentColor}.hand-card .corner{font-size:.75rem;top:4px;left:4px}.hand-card .corner.br{right:4px;bottom:4px}.hand-card .card-label{font-size:1.8rem}.hand-card:hover:not(.blocked){transform:translateY(-20px) scale(1.08)!important;box-shadow:0 12px 24px #0006,0 24px 48px #0003;z-index:100!important}.hand-card.selected{transform:translateY(-32px) scale(1.12)!important;box-shadow:0 0 0 4px #ffd56ae6,0 16px 32px #00000080,0 0 40px #ffd56a66;z-index:110!important}.hand-card.pending{box-shadow:0 0 0 4px #ff9632e6,0 12px 24px #0006;animation:pendingPulse 1.5s ease-in-out infinite}@keyframes pendingPulse{0%,to{box-shadow:0 0 0 4px #ff9632e6,0 12px 24px #0006}50%{box-shadow:0 0 0 6px #ff963299,0 0 20px #ff963266,0 12px 24px #0006}}.hand-card.blocked{filter:brightness(.6) saturate(.5);cursor:not-allowed}.hand-card.playable:not(.selected):not(:hover){animation:playableGlow 2s ease-in-out infinite}@keyframes playableGlow{0%,to{box-shadow:0 4px 8px #0000004d,0 8px 16px #0003}50%{box-shadow:0 4px 8px #0000004d,0 8px 16px #0003,0 0 15px #ffffff4d}}.action-bar{position:fixed;left:0;right:0;bottom:0;padding:12px 16px calc(12px + env(safe-area-inset-bottom));display:flex;gap:12px;overflow-x:auto;align-items:center;justify-content:center;background:linear-gradient(180deg,#080a0ef2,#080a0efa);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-top:1px solid rgba(255,255,255,.1);z-index:40}.action-bar button{white-space:nowrap;min-width:70px;font-size:.95rem;padding:12px 20px}.action-bar .primary{min-width:90px;font-size:1rem}.uno-toggle{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:#ffffff0f;color:#ffffffeb;font-size:.9rem;white-space:nowrap}.uno-toggle input{margin:0}.uno-toggle.on{border-color:#4ade8073;background:#16a34a2e}.primary.uno{background:linear-gradient(180deg,#4ade80,#16a34a);color:#fff;font-size:1.1rem;padding:12px 24px;animation:unoPulse 1s ease-in-out infinite}@keyframes unoPulse{0%,to{box-shadow:0 8px 16px #16a34a66}50%{box-shadow:0 8px 24px #16a34a99,0 0 30px #4ade804d}}.color-choices{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:2px solid rgba(255,255,255,.2);background:#0006}.color-choices .muted{font-size:.85rem;margin-right:4px}.color-dot{width:32px;height:32px;border-radius:50%;border:3px solid rgba(255,255,255,.4);padding:0;transition:transform .15s ease,box-shadow .15s ease}.color-dot:hover{transform:scale(1.15)}.color-dot.on{transform:scale(1.2);box-shadow:0 0 0 3px #ffffffe6,0 4px 12px #0000004d;border-color:#fff}.color-dot.red{background:var(--uno-red)}.color-dot.yellow{background:var(--uno-yellow)}.color-dot.green{background:var(--uno-green)}.color-dot.blue{background:var(--uno-blue)}.overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000bf;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;place-items:center;padding:20px;z-index:60;animation:overlayIn .2s ease-out}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.modal{width:min(480px,96vw);border-radius:20px;border:1px solid rgba(255,255,255,.15);background:linear-gradient(180deg,#141923fa,#0a0c12fa);box-shadow:0 24px 64px #00000080,0 0 0 1px #ffffff0d inset;padding:24px;animation:modalIn .25s cubic-bezier(.34,1.56,.64,1)}@keyframes modalIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.modal h3{margin:0 0 12px;font-size:1.3rem;text-align:center}.modal .muted{text-align:center;margin-bottom:16px}.modal .row-buttons{justify-content:center;margin-top:8px}.modal .row-buttons button{min-width:120px}.big-number{margin:12px 0;text-align:center;font-weight:900;font-size:3rem;letter-spacing:.06em;color:#ffd56a}.log-drawer{position:fixed;right:16px;top:70px;bottom:100px;width:min(380px,calc(100vw - 32px));border-radius:16px;border:1px solid rgba(255,255,255,.12);background:#0a0c12f2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:0 16px 48px #00000080;overflow:hidden;z-index:70;display:grid;grid-template-rows:auto 1fr;animation:slideIn .2s ease-out}@keyframes slideIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.log-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.1);background:#0003}.log-title{font-weight:700;font-size:.95rem}.log-list{margin:0;padding:12px 16px;list-style:none;overflow-y:auto;font-size:.85rem;color:#fffc}.log-list li{padding:10px 0;border-bottom:1px solid rgba(255,255,255,.06);line-height:1.4}.log-list li:last-child{border-bottom:none}.toast-stack{position:fixed;right:16px;top:16px;display:grid;gap:10px;z-index:80}.toast{display:flex;align-items:flex-start;gap:12px;background:linear-gradient(135deg,#1e1e23fa,#141419fa);color:#fff;padding:14px 18px;border-radius:12px;max-width:min(380px,calc(100vw - 32px));box-shadow:0 8px 32px #0006,inset 0 0 0 1px #ffffff1a;z-index:80;font-weight:500;animation:toastIn .25s cubic-bezier(.34,1.56,.64,1);border-left:4px solid var(--uno-red)}.toast-success{border-left-color:var(--uno-green)}.toast-info{border-left-color:var(--uno-yellow)}.toast-error{border-left-color:var(--uno-red)}.toast-close{margin-left:auto;padding:0;border:none;background:transparent;color:#ffffffb8;font-size:1rem;line-height:1;cursor:pointer}.toast-close:hover{color:#fff}@keyframes toastIn{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.result-hero{text-align:center;padding:20px}.result-hero h2{margin:0;font-size:2rem;font-weight:900;background:linear-gradient(180deg,var(--uno-yellow),#fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.result-hero p{margin:8px 0 0;font-size:.95rem}.result-list{margin:0;padding:0;list-style:none;display:grid;gap:10px}.result-list li{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:12px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);font-weight:600;counter-increment:rank}.result-list li:before{content:counter(rank);display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-weight:900;font-size:1rem}.result-list li:first-child{background:linear-gradient(135deg,#ffd70033,#ffd7000d);border-color:#ffd7004d}.result-list li:first-child:before{background:linear-gradient(180deg,gold,#ffb700);color:#1a1a1a}.result-list li:nth-child(2):before{background:linear-gradient(180deg,silver,#a0a0a0);color:#1a1a1a}.result-list li:nth-child(3):before{background:linear-gradient(180deg,#cd7f32,sienna);color:#fff}.result-list li:nth-child(n+4):before{background:#ffffff1a;color:#ffffffb3}.red{background:var(--uno-red);color:var(--uno-red)}.red .corner,.red .card-label,.red .card-symbol{color:var(--uno-red)}.yellow{background:var(--uno-yellow);color:var(--uno-yellow-dark)}.yellow .corner,.yellow .card-label,.yellow .card-symbol{color:var(--uno-yellow-dark)}.green{background:var(--uno-green);color:var(--uno-green)}.green .corner,.green .card-label,.green .card-symbol{color:var(--uno-green)}.blue{background:var(--uno-blue);color:var(--uno-blue)}.blue .corner,.blue .card-label,.blue .card-symbol{color:var(--uno-blue)}.wild{background:var(--uno-black);color:#333}.wild:before{background:conic-gradient(from 45deg,var(--uno-red) 0deg 90deg,var(--uno-yellow) 90deg 180deg,var(--uno-green) 180deg 270deg,var(--uno-blue) 270deg 360deg);box-shadow:none}.wild .corner,.wild .card-label,.wild .card-symbol{color:#fff;text-shadow:1px 1px 0 #000,-1px -1px 0 #000,1px -1px 0 #000,-1px 1px 0 #000}@media (max-width: 980px){.lobby-grid{grid-template-columns:1fr}.table-grid{grid-template-columns:1fr;grid-template-areas:"top" "center" "bottom";grid-template-rows:auto 1fr auto}.left-area,.right-area{display:none}.seat{min-width:min(92vw,320px)}.piles{gap:20px}}@media (max-width: 520px){:root{--pileCardW: 100px;--pileCardH: 140px;--handCardW: 68px;--handCardH: 95px}.hand-fan{height:170px;bottom:calc(76px + env(safe-area-inset-bottom))}.hand-card .card-label{font-size:1.5rem}.hand-card .corner{font-size:.65rem}.action-bar{padding:10px 12px calc(10px + env(safe-area-inset-bottom));gap:8px}.action-bar button{padding:10px 14px;font-size:.85rem;min-width:60px}.color-dot{width:28px;height:28px}.table-hud{padding:10px 14px}.hud-value{font-size:1rem}}
