:root{font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.4;font-weight:400;color:#222;background-color:#333;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}body{margin:0;display:flex;align-items:center;justify-content:center;min-width:320px;min-height:100vh;width:100%}button{font-family:inherit;cursor:pointer}*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}body{overscroll-behavior:none}#root{background:#333;width:100%;min-height:100vh;display:flex;align-items:center;justify-content:center}.page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;text-align:center;width:350px;height:700px;background:#e4e4e4;border-radius:8px}.page h1{font-size:2em;color:#222}.page h2{font-size:1.1em;color:#888;font-weight:400;margin-top:2px}.welcome-text{color:#555}.error-text{color:#b00020;font-size:.9em}.username-form{display:flex;flex-direction:column;gap:12px;width:260px}.username-form input{padding:10px 14px;border-radius:8px;border:1px solid #ccc;background:#fafafa;color:#222;font-size:1em;outline:none}.username-form input:focus{border-color:#4a90d9}.username-form button{padding:14px 0;font-size:1em;border-radius:10px;border:none;cursor:pointer;font-weight:600;width:100%;background:#4a90d9;color:#fff;transition:background .15s}.username-form button:hover:not(:disabled){background:#3a7bc8}.username-form button:disabled{opacity:.45;cursor:default}.home-buttons{display:flex;flex-direction:column;gap:12px;width:220px}.home-btn{padding:14px 0;font-size:1em;border-radius:10px;border:none;cursor:pointer;font-weight:600;width:100%}.home-btn.solo{background:#e67e22;color:#fff}.home-btn.solo:hover:not(:disabled){background:#cf6d17}.home-btn.find{background:#4a90d9;color:#fff}.home-btn.find:hover:not(:disabled){background:#3a7bc8}.home-btn.create{background:#28a745;color:#fff}.home-btn.create:hover:not(:disabled){background:#218838}.home-btn:disabled{opacity:.5}.bot-info{font-size:.82em;color:#777;text-align:center;padding:4px 16px 8px}.solo-btn{background:#e67e22!important}.solo-btn:hover{background:#cf6d17!important}.browse-page{padding:16px;justify-content:flex-start;gap:0}.browse-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:12px;flex-shrink:0}.browse-header h2{font-size:1.15em;color:#333;font-weight:700}.browse-back-btn,.browse-refresh-btn{width:32px;height:32px;border-radius:8px;border:1px solid #ccc;background:#fafafa;cursor:pointer;font-size:1.1em;display:flex;align-items:center;justify-content:center;color:#555}.browse-back-btn:hover,.browse-refresh-btn:hover{background:#eee}.browse-list{flex:1;overflow-y:auto;width:100%;display:flex;flex-direction:column;gap:8px}.browse-empty{color:#999;text-align:center;padding:40px 0;font-size:.95em}.browse-card{background:#fff;border-radius:10px;padding:10px 12px;border:1px solid #ddd;position:relative}.browse-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.browse-host{font-weight:700;color:#222;font-size:.95em}.browse-players{font-size:.85em;color:#666;background:#f0f0f0;padding:2px 8px;border-radius:4px}.browse-card-mid{margin-bottom:4px}.browse-setting{font-size:.82em;color:#555}.browse-card-bot{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:6px}.browse-detail{font-size:.78em;color:#888}.browse-tag{font-size:.72em;background:#e8d5f5;color:#7b2ea8;padding:1px 6px;border-radius:4px;font-weight:600}.browse-join-btn{position:absolute;right:12px;top:50%;transform:translateY(-50%);padding:6px 16px;border-radius:8px;border:none;background:#4a90d9;color:#fff;font-weight:600;cursor:pointer;font-size:.85em}.browse-join-btn:hover:not(:disabled){background:#3a7bc8}.browse-join-btn:disabled{opacity:.4;cursor:default}.create-page{padding:16px;justify-content:flex-start;gap:0}.create-header{display:flex;align-items:center;justify-content:space-between;width:100%;margin-bottom:10px;flex-shrink:0}.create-header h2{font-size:1.15em;color:#333;font-weight:700}.preset-bar{display:flex;align-items:center;gap:6px;width:100%;margin-bottom:10px;flex-shrink:0}.preset-select{flex:1;padding:7px 26px 7px 10px;border-radius:8px;border:1px solid #ccc;background:#fafafa;font-size:.82em;color:#555;outline:none;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23999'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}.preset-select:focus{border-color:#4a90d9}.preset-name-input{flex:1;padding:7px 10px;border-radius:8px;border:1px solid #4a90d9;background:#fff;font-size:.82em;color:#333;outline:none}.preset-btn{padding:6px 10px;border-radius:8px;border:1px solid #ccc;background:#fafafa;font-size:.78em;cursor:pointer;color:#555;font-weight:600;white-space:nowrap}.preset-btn:hover{background:#eee}.preset-btn:disabled{opacity:.4;cursor:default}.preset-btn.save{color:#4a90d9;border-color:#b8d4f0}.preset-btn.save:hover{background:#e8f0fe}.preset-btn.confirm{color:#28a745;border-color:#a3d9b1}.preset-btn.confirm:hover{background:#e8f5e9}.preset-btn.confirm:disabled:hover{background:#fafafa}.preset-btn.cancel{color:#999}.preset-btn.delete{color:#dc3545;border-color:#f0b8bd;padding:6px 8px;font-size:.9em;line-height:1}.preset-btn.delete:hover{background:#fde8ea}.create-form{flex:1;overflow-y:auto;width:100%;display:flex;flex-direction:column;gap:14px;padding-bottom:8px}.create-section{display:flex;flex-direction:column;gap:6px}.create-label{font-size:.82em;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.5px}.create-hint{font-weight:400;color:#999;text-transform:none;letter-spacing:0}.create-hint--below-label{font-size:.78em;line-height:1.25;margin-top:-3px}.create-stepper-hint-stack{display:flex;flex-direction:column;width:100%;gap:1px}.create-hint--micro-under-stepper{font-size:.78em;line-height:1.15;margin-top:3px;text-align:center}.create-toggle-row{display:flex;gap:0;border-radius:8px;overflow:hidden;border:1px solid #ccc}.create-toggle{flex:1;padding:8px 0;border:none;background:#fafafa;font-size:.88em;cursor:pointer;color:#666;font-weight:500}.create-toggle.active{background:#4a90d9;color:#fff;font-weight:600}.create-stepper{display:flex;align-items:center;justify-content:center;gap:0;border:1px solid #ccc;border-radius:8px;overflow:hidden;background:#fafafa}.create-stepper button{width:36px;height:34px;border:none;background:transparent;font-size:1.1em;cursor:pointer;color:#333}.create-stepper button:hover{background:#eee}.create-stepper.dual button{font-size:.85em;width:auto;padding:0 8px}.create-stepper .step-big{font-size:.72em;color:#888}.create-stepper span{min-width:60px;text-align:center;font-weight:600;font-size:.95em;color:#222}.create-stepper.sm button{width:28px;height:28px;font-size:.95em}.create-stepper.sm span{min-width:30px;font-size:.85em}.create-bank-row{display:flex;gap:4px;justify-content:space-between}.create-bank-item{display:flex;align-items:center;gap:4px;min-width:0}.bank-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.bank-dot.orange{background:#f5a623}.bank-dot.green{background:#28a745}.bank-dot.red{background:#dc3545}.create-row-pair{display:flex;gap:12px}.create-pair{flex:1;display:flex;flex-direction:column;gap:4px}.create-pair-label{font-size:.78em;color:#777}.create-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.8em;color:#555}.create-checkbox input[type=checkbox]{width:16px;height:16px;accent-color:#4a90d9;cursor:pointer}.create-advanced-toggle-section{align-items:flex-start}.create-advanced-toggle{text-align:left}.create-dice-header{display:flex;justify-content:space-between;align-items:center}.create-link{font-size:.8em;color:#4a90d9;background:none;border:none;cursor:pointer;text-decoration:underline;padding:0}.create-link:hover{color:#3a7bc8}.reset-link{align-self:flex-end;margin-top:2px}.create-dice-grid{display:flex;flex-direction:column;gap:6px}.dice-rule-row{display:flex;align-items:flex-start;gap:6px}.dice-num{width:20px;height:24px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85em;color:#333;flex-shrink:0}.dice-moves{display:flex;flex-wrap:wrap;gap:3px}.dice-move-btn{padding:3px 6px;border-radius:4px;border:1px solid #ddd;background:#fafafa;font-size:.68em;cursor:pointer;color:#888}.dice-move-btn.on{background:#4a90d9;color:#fff;border-color:#4a90d9}.dice-move-btn:hover{border-color:#aaa}.create-submit-btn{width:100%;padding:14px 0;border-radius:10px;border:none;background:#28a745;color:#fff;font-size:1em;font-weight:700;cursor:pointer;flex-shrink:0;margin-top:8px}.create-submit-btn:hover{background:#218838}.loading-page{color:#999;text-align:center}.loading-spinner{width:36px;height:36px;border:3px solid #ddd;border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 12px}.gameplay{position:relative;width:350px;height:700px;background:#e4e4e4;display:flex;flex-direction:column;overflow:hidden;border-radius:8px;touch-action:manipulation;-webkit-user-select:none;user-select:none}.animation-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;z-index:50}.flying-gem{position:absolute;object-fit:contain;pointer-events:none;filter:drop-shadow(0 2px 6px rgba(0,0,0,.35));z-index:51}.anim-hide-content .field-piece-img,.anim-hide-content .collect-qty,.anim-hide-content.pouch-item img,.anim-hide-content.pouch-item span,.anim-hide-content .side-icon,.anim-hide-content .field-icon,.anim-hide-content .theft-gem,.anim-hide-content .theft-icon,.anim-hide-content .theft-count{opacity:0}.waiting-overlay{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:20px}.waiting-overlay h2{color:#333;font-size:1.3em}.cancel-queue-btn{padding:8px 28px;border-radius:8px;border:1px solid #ccc;background:#fff;color:#666;font-size:.9em;cursor:pointer}.cancel-queue-btn:hover{border-color:#999;color:#333}.lobby-row{display:flex;align-items:center;gap:16px;font-size:1.1em}.lobby-name{color:#333;font-weight:700;padding:8px 16px;background:#d8d8d8;border-radius:8px}.lobby-name.rdy{background:#d4edda;color:#155724}.lobby-vs{color:#aaa;font-weight:700}.btn-ready,.btn-unready{padding:10px 30px;font-size:1em;border-radius:10px;border:none;cursor:pointer;font-weight:600}.btn-ready{background:#28a745;color:#fff}.btn-ready:hover{background:#218838}.btn-unready{background:#dc3545;color:#fff}.btn-unready:hover{background:#c82333}.player-area{display:flex;flex-direction:column;flex:0 0 auto;position:relative}.info-row{display:flex;align-items:center;height:60px;padding:0 6px}.info-side{width:30%;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:2px}.side-icon{height:44px;object-fit:contain}@keyframes dice-spin-decel{0%{transform:rotate(0)}to{transform:rotate(var(--dice-spin-to-deg, 1080deg))}}.dice-spinning{animation-name:dice-spin-decel;animation-duration:var(--dice-spin-duration, .62s);animation-timing-function:var( --dice-spin-easing, cubic-bezier(.06, .85, .16, 1) );animation-fill-mode:forwards;animation-iteration-count:1;transform-origin:center center}.side-icon.dice-spinning{transition:none}@media (prefers-reduced-motion: reduce){.dice-spinning{animation:none}}.info-center{width:40%;text-align:center}.info-name-with-status{display:flex;justify-content:center;align-items:center;gap:4px;width:100%}.info-status-fisheye{font-size:10px;line-height:1;flex-shrink:0}.info-status-fisheye--on{color:#1a7f37}.info-status-fisheye--off{color:#cf222e}.info-status-balance{visibility:hidden;pointer-events:none;-webkit-user-select:none;user-select:none}.info-name-with-status .info-name{margin:0;flex-shrink:0}.info-name{font-size:13px;color:#171717}.opponent-area .info-name-with-status{margin-top:5px}.info-score{font-size:24px;font-weight:700;color:#111;transition:color .3s}.info-score.score-winner{color:#28a745}.action-corner{gap:2px}.action-img{height:28px;object-fit:contain;cursor:pointer;transition:transform .1s}@media (hover: hover){.action-img:hover{transform:scale(1.1)}.action-img:active{transform:scale(.92)}}.clickable-thief{cursor:pointer}@media (hover: hover){.clickable-thief:hover .side-icon{transform:scale(1.1)}.clickable-thief:active .side-icon{transform:scale(.9)}}.side-icon{transition:transform .1s}.pouch-row{display:flex;justify-content:center;align-items:center;gap:24px;height:32px}.pouch-item{display:flex;align-items:center;gap:3px}.pouch-item img{width:18px;height:18px;object-fit:contain}.pouch-item span{font-size:12px;color:#333;font-weight:600}.shields-row{position:relative;display:flex;justify-content:center}.shields-strip{position:relative;width:100%;aspect-ratio:1054 / 174}.shields-strip-rail{width:100%;height:100%;object-fit:fill;display:block}.shield-slot{position:absolute;top:50%;transform:translate(-50%,-50%);height:88%;display:flex;align-items:center;justify-content:center;pointer-events:none}.shield-slot-img{width:120%;height:120%;object-fit:contain;display:block}.shield-slot--breaking{z-index:2}.wins-badge{position:absolute;display:flex;align-items:center;gap:3px;z-index:1}.wins-badge.wins-left{left:6px}.wins-badge.wins-right{right:6px}.wins-badge.wins-badge-clickable{cursor:pointer;border-radius:6px;padding:2px 4px;margin:-2px -4px}@media (hover: hover){.wins-badge.wins-badge-clickable:hover{background:#0000000f}}.opponent-rw{bottom:43px}.player-rw{top:30px}.wins-num{font-size:22px;font-weight:700;color:#222;line-height:1}.wins-icon{width:14px;height:14px;color:#888;flex-shrink:0}.wins-icon.trophy{width:17px;height:17px}.match-wins-row{position:absolute;left:0;right:0;display:flex;flex-direction:row;align-items:center;justify-content:space-between;padding:0 6px;z-index:2}.match-wins-row.opponent-rw{bottom:43px}.match-wins-row.player-rw{top:30px}.match-wins-stack{display:flex;flex-direction:column;gap:5px;align-items:flex-start}.match-wins-stack .wins-badge{position:relative;left:auto;right:auto}.wins-badge.wins-trophy{position:relative;left:auto}.spectator-corner{position:relative;flex-shrink:0}.spectator-corner-btn{display:flex;flex-direction:column;align-items:center;gap:1px;background:none;border:none;cursor:pointer;color:#555;padding:2px 6px;border-radius:8px}@media (hover: hover){.spectator-corner-btn:hover{background:#0000000f}}.spectator-eye-icon{width:24px;height:24px}.spectator-count{font-size:10px;font-weight:600;opacity:.65;line-height:1}.spec-menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:400}.spec-menu-pop{position:fixed;z-index:401;left:50%;top:40%;transform:translate(-50%,-50%);width:min(300px,92vw);background:#f4f4f4;border-radius:12px;padding:16px;box-shadow:0 12px 40px #00000040;text-align:left;color:#222}.spec-menu-title{font-weight:700;margin-bottom:8px;font-size:1rem}.spec-menu-names{list-style:none;margin-bottom:12px;max-height:120px;overflow-y:auto;font-size:.9rem}.spec-menu-empty{color:#888;font-style:italic}.spec-menu-toggle{display:flex;align-items:center;gap:8px;font-size:.88rem;margin-bottom:10px;cursor:pointer}.spec-menu-opp{font-size:.82rem;color:#555;margin-bottom:12px;line-height:1.35}.spec-menu-close{width:100%;padding:10px;border-radius:8px;border:1px solid #ccc;background:#fff;cursor:pointer;font-size:.95rem}.tournament-page{justify-content:flex-start;align-items:stretch;text-align:left;gap:10px;padding:16px 14px 24px;overflow-y:auto}.tour-header{display:flex;align-items:center;gap:8px;flex-shrink:0}.tour-back-btn{background:#fff;border:1px solid #ccc;border-radius:8px;width:34px;height:34px;font-size:1.4rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#333;flex-shrink:0}.tour-title-block{flex:1;display:flex;align-items:center;gap:6px}.tour-title{font-size:1.05rem;font-weight:700;color:#222;margin:0}.tour-phase-pill{font-size:.62rem;text-transform:uppercase;letter-spacing:.06em;padding:2px 6px;border-radius:10px;background:#e0e0e0;color:#555;font-weight:600}.tour-capacity-badge{font-size:.8rem;font-weight:700;color:#444;background:#e8e8e8;padding:3px 8px;border-radius:10px;flex-shrink:0}.tour-pairing-banner{background:linear-gradient(135deg,#1a3a5c,#2a6099);border-radius:10px;padding:10px 14px;color:#e8f4ff;animation:tourBannerIn .5s cubic-bezier(.22,1,.36,1) both}@keyframes tourBannerIn{0%{opacity:0;transform:translateY(-8px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.tour-pairing-label{display:block;font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7;margin-bottom:6px}.tour-pairing-list{list-style:none;display:flex;flex-direction:column;gap:4px}.tour-pairing-item{display:flex;align-items:center;gap:6px;font-size:.85rem}.tour-p-name{font-weight:600}.tour-p-vs{font-size:.7rem;opacity:.6}.tour-p-bye{font-size:.78rem;opacity:.8;margin-top:4px;padding-top:4px;border-top:1px solid rgba(255,255,255,.15)}.tour-scoreboard{background:#fff;border-radius:10px;border:1px solid #e0e0e0;overflow:hidden}.tour-sb-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px 6px;border-bottom:1px solid #eee}.tour-sb-title{font-size:.65rem;text-transform:uppercase;letter-spacing:.08em;color:#888;font-weight:700}.tour-sb-remaining{font-size:.7rem;color:#666}.tour-sb-rows{display:flex;flex-direction:column}.tour-sb-row{display:flex;align-items:center;gap:6px;padding:6px 12px;border-bottom:1px solid #f0f0f0;font-size:.85rem}.tour-sb-rows--stats .tour-sb-row{display:grid;grid-template-columns:18px 16px minmax(0,1fr) 32px 32px 32px;align-items:center;gap:4px}.tour-sb-rows--stats .tour-sb-row--head{font-size:.58rem;color:#999;text-transform:uppercase;letter-spacing:.04em;font-weight:700;padding-top:4px;padding-bottom:4px;border-bottom:1px solid #e8e8e8}.tour-sb-rows--stats .tour-sb-row--head .tour-sb-name{font-weight:700;color:#999}.tour-sb-head-spacer{width:12px}.tour-sb-stat{text-align:right;font-variant-numeric:tabular-nums;font-weight:700;font-size:.82rem;color:#333}.tour-sb-stat--h{font-size:.58rem;color:#aaa;font-weight:800}.tour-sb-format-sep{opacity:.5}.tour-sb-row:last-child{border-bottom:none}.tour-sb-row--lead{background:#fffbea}.tour-sb-row--left .tour-sb-name{color:#b83232;font-weight:500}.tour-sb-row--self .tour-sb-name{font-weight:800}.tour-sb-rank{font-size:.7rem;color:#aaa;min-width:14px}.tour-sb-name{flex:1;color:#222;font-weight:500}.tour-sb-pts{font-weight:800;font-size:.95rem;color:#1a1a1a}.tour-sb-format{font-size:.68rem;color:#999;padding:5px 12px 7px;border-top:1px solid #f0f0f0}.tour-winner-banner{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 12px;background:linear-gradient(135deg,#1a5f1a,#2e8b2e);border-radius:12px;color:#fff;text-align:center}.tour-winner-icon{font-size:2rem;line-height:1}.tour-winner-name{font-size:1.1rem;font-weight:800}.tour-winner-sub{font-size:.72rem;opacity:.8}.tour-hint{font-size:.8rem;color:#666;text-align:center;padding:0 4px}.tour-empty{font-size:.9rem;color:#888;text-align:center}.tour-bye-card{background:#fff8e6;border:1px solid #e8cc7a;border-radius:10px;padding:10px 12px;display:flex;flex-direction:column;gap:8px;align-items:flex-start}.tour-bye-msg{font-size:.82rem;color:#5a4800}.tour-spec-btn{padding:8px 14px;border-radius:8px;border:none;background:#4a90d9;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600}.tour-spec-btn--with-icon{display:inline-flex;align-items:center;gap:8px}.tour-spec-eye-icon{width:22px;height:22px;flex-shrink:0;color:inherit}.tour-spec-eye-icon--on-btn{width:20px;height:20px}.tour-wait-card{background:#eef6ff;border:1px solid #9ec5eb;border-radius:10px;padding:10px 12px;margin-bottom:8px}.tour-wait-msg{font-size:.82rem;color:#1a3d5c;margin:0 0 10px;line-height:1.35}.tour-wait-pairings{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.tour-wait-row{display:flex;align-items:center;justify-content:space-between;gap:8px;font-size:.8rem}.tour-wait-names{flex:1;min-width:0;color:#222}.tour-wait-spec{flex-shrink:0;width:40px;height:36px;border-radius:8px;border:none;background:#4a90d9;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;line-height:0}.tour-wait-done{flex-shrink:0;font-size:.72rem;font-weight:600;color:#6a7a88;text-transform:uppercase;letter-spacing:.04em}.tour-grid{display:grid;gap:8px;width:100%}.tour-cell{display:flex;flex-direction:column;align-items:center;gap:0;padding:0;background:#f2f2f2;border-radius:10px;border:1.5px solid #ddd;overflow:visible;position:relative;transition:border-color .15s}.tour-cell--mine{border-color:#4a90d9;background:#e8f2fc}.tour-cell--empty{border-style:dashed;border-color:#ccc;background:#f9f9f9;min-height:72px;display:flex;align-items:center;justify-content:center}.tour-empty-slot{font-size:1.4rem;color:#ccc;font-weight:300}.tour-tourney-field-box .field-outline{width:52px;height:52px}.tour-tourney-ready-outline{padding:0;margin:0;background:transparent;font:inherit}.tour-tourney-ready-outline.field-outline{box-sizing:border-box}.tour-tourney-ready--readonly{cursor:default;pointer-events:none;-webkit-user-select:none;user-select:none}.tour-ready-toggle{width:100%;display:flex;align-items:center;justify-content:center;padding:8px 6px 6px;background:none;border:none;border-bottom:1px solid rgba(0,0,0,.06);cursor:default;flex-shrink:0}.tour-ready-toggle--clickable{cursor:pointer}.tour-ready-toggle--clickable:active{filter:brightness(.93)}.tour-ready-img{width:40px;height:40px;object-fit:contain;display:block}.tour-cell-name-row{display:flex;align-items:center;justify-content:center;gap:5px;padding:6px 8px 7px;width:100%;box-sizing:border-box}.tour-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.tour-dot--on{background:#3cba3c}.tour-dot--off{background:#e04040}.tour-cell-name{font-size:.78rem;font-weight:600;color:#222;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:0 1 auto;min-width:0;max-width:100%;text-align:center}.tour-cell-ingame{font-size:.62rem;color:#4a90d9;font-weight:600;padding:0 8px 6px;width:100%;text-align:center}.tour-done-btn{margin-top:4px;padding:13px;width:100%;border-radius:10px;border:1px solid #ccc;background:#fff;cursor:pointer;font-size:.95rem;font-weight:600;color:#333}.browse-tag.tournament-tag{background:#2d5a87;color:#fff}.shields-img{width:100%;display:block}.board-area{flex:1;display:flex;flex-direction:column;min-height:0}.field-edge{position:relative;height:84px;margin:10px 0}.field-side-left,.field-side-right{position:absolute;top:50%;transform:translateY(-50%);z-index:1}.field-side-left{left:10px}.field-side-right{right:10px}.field-icon{height:44px;object-fit:contain}.field-icon.clickable{cursor:pointer;transition:transform .1s}@media (hover: hover){.field-icon.clickable:hover{transform:scale(1.12)}.field-icon.clickable:active{transform:scale(.9)}}.field-box{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;align-items:center;justify-content:center;gap:6px}.field-box.tour-tourney-field-box{position:relative;left:auto;top:auto;transform:none;width:100%;max-width:72px;margin:8px auto 2px}.field-outline{position:relative;width:60px;height:60px;border:2px dashed #bbb;border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.collect-pass-alert{position:absolute;top:2px;right:2px;bottom:2px;left:2px;width:calc(100% - 4px);height:calc(100% - 4px);object-fit:contain;pointer-events:none;z-index:2}.field-outline.has-content{border-color:#999;background:#fff6}.field-box.collect-bluff-flash--bluff .field-outline,.field-box.collect-bluff-flash--truth .field-outline{animation:collectBluffFlashVar .42s ease-in-out}.field-box.collect-bluff-flash--bluff .field-outline{--bluff-flash: #d70200;--bluff-flash-glow: rgba(215, 2, 0, .5)}.field-box.collect-bluff-flash--truth .field-outline{--bluff-flash: #3ed803;--bluff-flash-glow: rgba(62, 216, 3, .55)}@keyframes collectBluffFlashVar{0%,to{box-shadow:none}15%,35%{box-shadow:0 0 0 2px var(--bluff-flash),0 0 14px var(--bluff-flash-glow)}50%{box-shadow:none}65%,85%{box-shadow:0 0 0 2px var(--bluff-flash),0 0 14px var(--bluff-flash-glow)}}.clickable-ready{cursor:pointer}.clickable-ready:active{opacity:.7}.field-piece-img{height:39px;object-fit:contain}.collect-qty{font-size:12px;font-weight:700;color:#333}.theft-left,.theft-right{position:absolute;top:50%;transform:translateY(-50%);display:flex;flex-direction:column;align-items:center;gap:1px;z-index:1}.theft-left{right:calc(50% + 48px)}.theft-right{left:calc(50% + 48px)}.theft-icon{width:42px;height:42px;object-fit:contain}.theft-count{font-size:10px;color:#555;font-weight:600}.theft-gem{display:flex;align-items:center;gap:2px}.theft-gem img{width:23px;height:23px;object-fit:contain}.theft-gem span{font-size:10px;color:#333;font-weight:600}.diamond-board{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:4px 8px;position:relative}.diamond-slot{flex:1;display:flex;align-items:center;justify-content:center}.pile-slot{position:relative}.pile-container{position:relative;width:110px;height:110px}.pile-gem{position:absolute;object-fit:contain;transition:transform .15s;pointer-events:none}.diamond-slot.clickable{cursor:pointer;border-radius:10px}.diamond-slot.clickable:active .pile-gem{filter:brightness(.9)}@media (hover: hover){.diamond-slot.clickable:hover{background:#4a90d914}.diamond-slot.clickable:hover .pile-gem{filter:brightness(1.1)}}.round-banner-wrap{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:10;pointer-events:none;animation:banner-life 2.5s ease-in-out forwards}@keyframes banner-life{0%{opacity:0;transform:scale(.85)}12%{opacity:1;transform:scale(1)}70%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes opponent-action-flash{0%{opacity:0}12%{opacity:1}88%{opacity:1}to{opacity:0}}.opponent-action-flash{animation:opponent-action-flash 1.5s linear forwards;cursor:default;pointer-events:none}.opponent-area .info-row--bluff-call{position:relative;overflow:visible;z-index:2}@keyframes bluff-call-bubble-host{0%{opacity:0;transform:translateY(-50%) scale(.96)}4%{opacity:1;transform:translateY(-50%) scale(1)}78%{opacity:1;transform:translateY(-50%) scale(1)}to{opacity:0;transform:translateY(-50%) scale(1)}}@keyframes bluff-call-bubble-host-reduced{0%,80%{opacity:1;transform:translateY(-50%) scale(1)}to{opacity:0;transform:translateY(-50%) scale(1)}}.bluff-call-bubble-host{position:absolute;left:70%;right:2px;top:50%;z-index:4;display:flex;justify-content:center;align-items:center;pointer-events:none;animation:bluff-call-bubble-host 2.2s linear forwards}@media (prefers-reduced-motion: reduce){.bluff-call-bubble-host{animation:bluff-call-bubble-host-reduced 2.2s linear forwards}}.bluff-call-bubble{position:relative;box-sizing:border-box;width:100px;height:48px;background:#fff;border:1px solid #c8c8c8;border-radius:12px;padding:5px 8px 6px 9px;box-shadow:0 8px 22px #00000024,inset 0 1px #ffffffe6}.bluff-call-bubble:before{content:"";position:absolute;left:-5px;top:10px;width:0;height:0;border-style:solid;border-width:5px 8px 5px 0;border-color:transparent #fff transparent transparent;transform:rotate(-20deg);transform-origin:100% 50%;filter:drop-shadow(-1px 0 0 #b8b8b8)}.bluff-call-bubble__inner{display:flex;flex-direction:column;justify-content:center;height:100%;gap:2px;line-height:1.15;text-align:left}.bluff-call-bubble__line{font-size:12px;font-weight:700;letter-spacing:.01em;white-space:nowrap;min-height:1.2em}.bluff-call-bubble__line--first,.bluff-call-bubble__line--second{color:#111}.bluff-call-bubble__text-second{color:#d32f2f}.bluff-call-bubble__caret{display:inline-block;width:2px;height:.95em;margin-left:1px;vertical-align:-.05em;background:#333;animation:bluff-call-caret-blink .55s step-end infinite}.bluff-call-bubble__line--second .bluff-call-bubble__caret{background:#c62828}@keyframes bluff-call-caret-blink{0%,50%{opacity:1}51%,to{opacity:0}}@media (prefers-reduced-motion: reduce){.bluff-call-bubble__caret{animation:none;opacity:0}}.round-banner{display:flex;flex-direction:column;align-items:center;gap:2px;padding:14px 36px;border-radius:12px;box-shadow:0 4px 20px #00000040}.round-banner.win{background:linear-gradient(135deg,#28a745,#20c997)}.round-banner.loss{background:linear-gradient(135deg,#dc3545,#e74c3c)}.round-banner-label{font-size:18px;font-weight:800;color:#fff;text-transform:uppercase;letter-spacing:1px}.round-banner-score{font-size:14px;font-weight:600;color:#ffffffd9}.round-banner-mode{font-size:10px;font-weight:500;color:#ffffffa6;margin-top:1px}.bottom-bar{display:flex;align-items:center;justify-content:center;gap:10px;padding:4px 8px 6px;flex-wrap:wrap}.wait-spinner{display:inline-block;width:32px;height:32px;border:2px solid rgba(0,0,0,.08);border-top-color:#0000004d;border-right-color:#0000004d;border-radius:50%;animation:spin 6.4s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.result-bar{display:flex;flex-direction:column;align-items:center;gap:6px;width:100%}.round-result-text{font-size:13px;font-weight:700;color:#28a745}.game-result-text{font-size:15px;font-weight:700;color:#333}.menu-btn{padding:2px 12px;font-size:10px;border-radius:4px;border:1px solid #ccc;background:transparent;color:#999;cursor:pointer}.menu-btn:hover{border-color:#666;color:#666}.menu-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0006;z-index:110;display:flex;align-items:center;justify-content:center}.menu-popup{background:#f5f5f5;border-radius:12px;padding:16px;width:280px;display:flex;flex-direction:column;gap:14px;box-shadow:0 8px 32px #00000040}.score-history-popup{width:min(320px,calc(100vw - 32px));max-height:min(78vh,520px)}.score-history-title{font-size:11px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.5px}.score-history-rules{display:flex;flex-direction:column;gap:4px;padding-bottom:10px;border-bottom:1px solid #ddd}.score-history-rule-line{font-size:12px;font-weight:700;color:#222;line-height:1.3}.score-history-body{display:flex;flex-direction:column;gap:6px;overflow-y:auto;font-size:12px;line-height:1.35;color:#333;padding-right:4px}.score-history-line{white-space:pre-wrap;word-break:break-word}.score-history-set{font-weight:700;margin-top:4px}.score-history-set:first-child{margin-top:0}.score-history-round{padding-left:12px;font-weight:500;color:#444}.score-history-empty{color:#777;font-style:italic}.score-history-wl{font-weight:700}.score-history-wl.win{color:#15803d}.score-history-wl.lose{color:#b91c1c}.menu-settings{display:flex;flex-direction:column;gap:4px}.menu-settings-title{font-size:11px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px}.menu-settings-row{display:flex;justify-content:space-between;font-size:11px;color:#666}.menu-settings-row span:last-child{font-weight:600;color:#333}.menu-more-btn{background:none;border:none;color:#4a90d9;font-size:11px;cursor:pointer;padding:2px 0;text-align:left}.menu-more-btn:hover{text-decoration:underline}.menu-dice-section{display:flex;flex-direction:column;gap:2px;margin-top:4px}.menu-dice-title{font-size:10px;font-weight:700;color:#777;text-transform:uppercase;letter-spacing:.3px}.menu-dice-row{display:flex;gap:8px;font-size:10px;color:#666}.menu-dice-num{width:12px;font-weight:700;color:#444}.menu-dice-moves{color:#555}.menu-actions{display:flex;flex-direction:column;gap:8px}.menu-action-btn{padding:10px 0;border-radius:8px;border:none;font-size:.9em;font-weight:600;cursor:pointer;width:100%}.menu-action-btn.resign{background:#fff;color:#dc3545;border:1px solid #dc3545}.menu-action-btn.resign:hover,.menu-action-btn.leave{background:#dc3545;color:#fff}.menu-action-btn.leave:hover{background:#c82333}.menu-close-btn{padding:8px 0;border-radius:8px;border:1px solid #ccc;background:#fff;color:#666;font-size:.85em;cursor:pointer}.menu-close-btn:hover{background:#eee}.gameover-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#0000008c;z-index:100;display:flex;align-items:center;justify-content:center}.gameover-card{background:#f5f5f5;border-radius:14px;width:260px;overflow:hidden;box-shadow:0 10px 40px #0000004d;display:flex;flex-direction:column;align-items:center}.gameover-banner{width:100%;text-align:center;padding:18px 0 14px;font-size:26px;font-weight:800;letter-spacing:1px;text-transform:uppercase}.gameover-banner.win{background:linear-gradient(135deg,#28a745,#20c997);color:#fff}.gameover-banner.loss{background:linear-gradient(135deg,#dc3545,#e74c3c);color:#fff}.gameover-banner.draw{background:linear-gradient(135deg,#5a6268,#868e96);color:#fff}.gameover-detail{padding:10px 0 4px}.gameover-detail .gameover-sub{font-size:16px;color:#444}.gameover-sub{font-size:15px;color:#444}.gameover-scores{display:flex;align-items:center;gap:10px;padding:8px 0 16px}.gameover-player{display:flex;flex-direction:column;align-items:center;gap:2px}.gameover-pname{font-size:12px;color:#666;font-weight:500}.gameover-rwins{font-size:28px;font-weight:800;color:#333}.gameover-player.winner .gameover-rwins{color:#28a745}.gameover-dash{font-size:24px;font-weight:700;color:#bbb;align-self:flex-start;margin-top:4px}.gameover-history-btn{width:calc(100% - 32px);margin:0 16px 8px;padding:10px 0;border-radius:8px;border:1px solid #444;background:#fff;color:#333;font-size:.9em;font-weight:600;cursor:pointer}.gameover-history-btn:hover{background:#eee}.gameover-leave-btn{width:calc(100% - 32px);margin:0 16px 16px;padding:11px 0;border-radius:8px;border:none;background:#333;color:#fff;font-size:.9em;font-weight:600;cursor:pointer}.gameover-leave-btn:hover{background:#222}@keyframes hint-pulse{0%{opacity:1}12%{opacity:var(--hint-pulse-low, .28)}24%{opacity:1}36%{opacity:var(--hint-pulse-low, .28)}48%{opacity:1}70%{opacity:1}85%{opacity:var(--hint-pulse-low, .28)}to{opacity:1}}.hint-pulse{--hint-pulse-low: .28;--hint-pulse-duration: 5s;animation:hint-pulse var(--hint-pulse-duration) ease-in-out infinite}.hint-toggle{padding:3px 12px;border-radius:6px;border:1px solid #ccc;font-size:11px;font-weight:600;cursor:pointer;background:#eee;color:#888;transition:background .15s,color .15s}.hint-toggle.on{background:#4a90d9;color:#fff;border-color:#4a90d9}@media (max-width: 500px){html,body,#root{height:100vh;height:100dvh;overflow:hidden}body,#root{min-height:0;align-items:stretch;justify-content:flex-start}.page,.gameplay{width:100%;height:100%;border-radius:0;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom)}.loading-page{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center}.pile-container{transform:scale(1.1)}.action-corner{gap:7px}.field-edge{height:90px;margin:6px 0}.field-outline{width:66px;height:66px}.field-piece-img{height:43px}.collect-qty{font-size:13px}.field-icon{height:48px}.pouch-row{height:34px}.pouch-item img{width:20px;height:20px}.pouch-item span{font-size:13px}}@media (max-width: 500px) and (max-height: 700px){.field-edge{height:80px;margin:4px 0}.field-outline{width:60px;height:60px}.field-piece-img{height:39px}.info-row{height:52px}.pile-container{transform:scale(1)}.pouch-row{height:30px}}.username-input-wrap{position:relative;width:100%}.username-input-wrap input{width:100%;padding-right:44px}.username-char-count{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:11px;font-weight:600;color:#bbb;pointer-events:none;transition:color .15s}.username-char-count.ok{color:#28a745}.username-char-count.over{color:#dc3545}.username-error{color:#dc3545;font-size:.82em;margin-top:-4px}.username-hint-text{font-size:.78em;color:#aaa;margin-top:-8px}.loading-page{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px}.loading-logo{font-size:2em;font-weight:800;color:#333;margin-bottom:4px}.loading-spinner--warn{border-top-color:#e67e22;border-right-color:transparent}.loading-status{color:#888;font-size:.9em}.loading-status--warn{color:#e67e22;font-weight:600}.loading-reconnect-hint{color:#aaa;font-size:.78em;text-align:center;max-width:220px}@keyframes reconnect-dot-blink{0%,to{opacity:1}50%{opacity:.3}}.reconnecting-banner{display:flex;align-items:center;gap:7px;background:#fff8e6;border:1px solid #f5c842;border-radius:8px;padding:6px 14px;font-size:.82em;font-weight:600;color:#7a5700;width:100%}.reconnecting-dot{width:8px;height:8px;border-radius:50%;background:#e67e22;flex-shrink:0;animation:reconnect-dot-blink 1.2s step-end infinite}.browse-refresh-btn--spinning{animation:spin .9s linear infinite;pointer-events:none;opacity:.6}.browse-loading-spinner{width:28px;height:28px;border:2px solid #ddd;border-top-color:#4a90d9;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 8px}.browse-empty-hint{font-size:.78em;color:#bbb;margin-top:4px}.browse-auto-refresh-hint{font-size:.72em;color:#bbb;text-align:center;padding:4px 0 2px;flex-shrink:0}.gameover-tour-btn{background:#4a90d9!important}.gameover-tour-btn:hover{background:#3a7bc8!important}
