*,:before,:after{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body{color:#222;overscroll-behavior:none;background:#f4f4f4;height:100%;margin:0;padding:0;font-family:-apple-system,ui-sans-serif,sans-serif}#app{flex-direction:column;min-height:100%;display:flex}button{font-family:inherit}header.app-hd{padding:env(safe-area-inset-top,0) 12px 0;background:#fff;border-bottom:1px solid #ddd;flex:none}.app-hd .row{align-items:center;gap:8px;min-height:36px;padding:8px 0;display:flex}.app-hd h1{margin:0;font-size:14px;font-weight:600}.pill{background:#ddd;border-radius:10px;padding:2px 8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:11px}.pill.on{color:#fff;background:#1a4}.avatar-wrap{margin-left:auto;position:relative}.avatar{cursor:pointer;color:#444;background:#ddd;border:1px solid #ccc;border-radius:50%;justify-content:center;align-items:center;width:36px;height:36px;padding:0;font-size:14px;font-weight:600;display:inline-flex;overflow:hidden}.avatar img{object-fit:cover;width:100%;height:100%}.dropdown{z-index:80;background:#fff;border:1px solid #ddd;border-radius:8px;min-width:180px;padding:6px;position:absolute;top:44px;right:0;box-shadow:0 6px 24px #00000026}.dropdown-username{color:#888;word-break:break-all;border-bottom:1px solid #eee;margin-bottom:4px;padding:8px 10px 4px;font-size:12px}.dropdown-item{text-align:left;cursor:pointer;color:#222;background:0 0;border:none;border-radius:6px;width:100%;padding:10px 12px;font-size:14px;display:block}.dropdown-item:hover,.dropdown-item:active{background:#f4f4f4}.dropdown-item.danger{color:#c33}main{flex-direction:column;flex:1;gap:8px;min-height:0;padding:8px 12px 12px;display:flex}.lobby{flex:1;grid-template-columns:1fr;align-content:start;gap:14px;padding:18px 4px;display:grid}.game-card{background:#fff;border-radius:12px;flex-direction:column;gap:10px;padding:18px;display:flex;box-shadow:0 2px 8px #0000000f}.game-card .gc-head{justify-content:space-between;align-items:baseline;display:flex}.game-card .gc-title{font-size:22px;font-weight:700}.game-card .gc-online{color:#1a4;font-size:12px;font-weight:600}.game-card .gc-online .dot{vertical-align:middle;background:#1a4;border-radius:50%;width:6px;height:6px;margin-right:4px;display:inline-block}.game-card .gc-sub{color:#888;font-size:13px}.game-card .gc-cta{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:8px;min-height:48px;margin-top:4px;padding:12px;font-size:15px;font-weight:600}.game-card .gc-cta:disabled{opacity:.4;cursor:not-allowed}.modal-overlay{padding:env(safe-area-inset-top,20px) 12px 12px;z-index:150;background:#00000073;justify-content:center;align-items:flex-start;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:12px;flex-direction:column;width:100%;max-width:520px;max-height:86vh;display:flex;overflow:hidden}.modal .m-head{border-bottom:1px solid #eee;justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.modal .m-head h2{margin:0;font-size:16px;font-weight:600}.modal .m-close{cursor:pointer;color:#888;background:0 0;border:none;padding:4px 10px;font-size:22px}.modal .m-body{padding:8px 4px;overflow-y:auto}.match-row{border-bottom:1px solid #f0f0f0;flex-direction:column;gap:4px;padding:10px 14px;display:flex}.match-row .mr-top{align-items:center;gap:8px;font-size:13px;display:flex}.match-row .mr-result{border-radius:10px;padding:2px 8px;font-size:11px;font-weight:700}.match-row .mr-result.win{color:#173;background:#def7e0}.match-row .mr-result.lose{color:#900;background:#fde0e0}.match-row .mr-game{text-transform:uppercase;font-weight:600}.match-row .mr-time{color:#888;margin-left:auto;font-size:11px}.match-row .mr-players{color:#555;font-size:12px}.match-row .mr-players b{color:#222}.match-empty{text-align:center;color:#888;padding:28px;font-size:14px}.toast{color:#fff;z-index:200;pointer-events:none;background:#323232f2;border-radius:8px;max-width:90%;padding:10px 16px;font-size:14px;position:fixed;top:60px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #0000004d}.toast.error{background:#c83232f2}.toast.win{background:#14a050f2;font-weight:600}.splash{flex-direction:column;flex:1;justify-content:center;align-items:center;gap:18px;display:flex}.splash .hint{color:#888;text-align:center;padding:6px;font-size:13px}.splash a.signin,.splash button.signin{color:#fff;cursor:pointer;background:#06c;border:none;border-radius:8px;padding:16px 36px;font-size:15px;font-weight:600;text-decoration:none}.room-bar{background:#fff;border-radius:6px;flex-wrap:wrap;flex:none;align-items:center;gap:6px;padding:6px 8px;font-size:12px;display:flex}.players-bar{flex-wrap:wrap;flex:none;gap:6px;display:flex}.player-chip{background:#ddd;border-radius:14px;align-items:center;gap:4px;padding:4px 10px;font-size:12px;display:flex}.player-chip.me{background:#def;font-weight:600}.player-chip.current{color:#fff;background:#1a4}.player-chip.disc{opacity:.4;text-decoration:line-through}.player-chip .ready{color:#1a4;margin-right:2px;font-weight:600}.player-chip.current .ready{color:#ffe}.top-area{background:#fff;border-radius:8px;flex:none;justify-content:center;align-items:center;gap:16px;min-height:110px;padding:12px;display:flex}.top-area .meta{flex-direction:column;align-items:flex-start;gap:4px;display:flex}.pending{color:#fff;border-radius:10px;align-self:flex-start;padding:2px 8px;font-size:11px;font-weight:600}.deck-info{color:#888;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:11px}.turn-badge{color:#1a4;font-size:13px;font-weight:700}.uno-card{color:#fff;-webkit-user-select:none;user-select:none;cursor:pointer;border:1px solid #0003;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;min-width:50px;height:70px;padding:4px 8px;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:18px;font-weight:700;display:inline-flex}.uno-card.red{background:#d43}.uno-card.yellow{color:#333;background:#db0}.uno-card.green{background:#1a4}.uno-card.blue{background:#06c}.uno-card.wild{background:linear-gradient(135deg,#d43 0 25%,#db0 25% 50%,#1a4 50% 75%,#06c 75% 100%)}.uno-card:disabled{opacity:.35;cursor:not-allowed}.uno-card.top{cursor:default;width:70px;height:100px;font-size:28px}.actions-row{flex-wrap:wrap;flex:none;gap:8px;display:flex}.actions-row button{cursor:pointer;background:#f5f5f5;border:1px solid #999;border-radius:6px;flex:1;min-width:80px;min-height:44px;padding:10px 14px;font-size:14px;font-weight:600}button.btn-primary{color:#fff;background:#06c;border-color:#04a}button.btn-success{color:#fff;background:#1a4;border-color:#173}button.btn-warn{color:#fff;background:#d62;border-color:#a30}button.btn-danger{color:#fff;background:#c33;border-color:#900}button.btn-muted{color:#fff;background:#888;border-color:#555}.hand-scroll{-webkit-overflow-scrolling:touch;flex:none;padding:4px 0 8px;overflow-x:auto}.hand{gap:6px;min-width:max-content;display:flex}.picker-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.picker{background:#fff;border-radius:12px;flex-direction:column;gap:12px;width:100%;max-width:320px;padding:18px;display:flex;box-shadow:0 8px 32px #0000004d}.picker-label{text-align:center;font-size:14px;font-weight:600}.picker-row{justify-content:center;gap:10px;display:flex}.picker-cancel{cursor:pointer;background:0 0;border:1px solid #ccc;border-radius:6px;min-height:44px;padding:10px}
