:root{font-family:Hiragino Sans,Noto Sans JP,system-ui,sans-serif;line-height:1.5;color:#1a1a2e;background:#f0f4f8}*{box-sizing:border-box}body{margin:0;min-height:100vh}#root{min-height:100vh}.error-boundary{max-width:480px;margin:4rem auto;padding:2rem 1.5rem;text-align:center;background:#fff;border-radius:12px;box-shadow:0 4px 24px #0f172a14}.error-boundary h1{margin:0 0 .75rem;font-size:1.25rem}.error-boundary p{margin:0 0 1.25rem;color:#64748b}.error-boundary button{padding:.55rem 1.25rem;border:none;border-radius:8px;background:#2563eb;color:#fff;font-weight:600;cursor:pointer}.app{max-width:480px;margin:0 auto;padding:2rem 1rem}h1{font-size:1.75rem;margin:0 0 2rem}.subtitle{color:#5a6a7a;margin:0 0 2rem;font-size:.9rem}.app-footer{margin-top:2rem;padding-top:1rem;text-align:center}.app-footer__copy{margin:.65rem 0 0;font-size:.75rem;color:#94a3b8}.mottainai-links--footer{margin-top:0}.card{background:#fff;border-radius:12px;padding:1.25rem;box-shadow:0 2px 8px #00000014;margin-bottom:1rem}label{display:block;font-size:.85rem;font-weight:600;margin-bottom:.35rem}input{width:100%;padding:.6rem .75rem;border:1px solid #ccd5df;border-radius:8px;font-size:1rem;margin-bottom:1rem}button{width:100%;padding:.75rem;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;background:#2563eb;color:#fff}button:disabled{opacity:.5;cursor:not-allowed}button.secondary{background:#e2e8f0;color:#1a1a2e;margin-top:.5rem}.error{color:#dc2626;font-size:.9rem;margin-bottom:1rem}.room-code{font-size:2rem;font-weight:700;letter-spacing:.2em;text-align:center;margin:1rem 0}.mottainai-links{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:.35rem .5rem;margin-top:.4rem;font-size:.78rem}.mottainai-links a{color:#2563eb;text-decoration:none;font-weight:600}.mottainai-links a:hover{text-decoration:underline}.mottainai-links__sep{color:#94a3b8}.mottainai-links--lobby,.mottainai-links--footer{flex-shrink:0;padding:.65rem 0 .25rem}.room-invite{margin:.25rem 0 .5rem}.room-invite--compact{margin:.35rem 0 .45rem;text-align:center}.room-invite--compact .room-code{margin:0 0 .4rem;font-size:1.5rem;letter-spacing:.18em}.room-invite .room-code{margin:0 0 .35rem}.room-invite__url{margin:0 0 .65rem;padding:.45rem .55rem;font-size:.72rem;line-height:1.4;word-break:break-all;text-align:center;color:#64748b;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0}.room-invite__feedback{margin:0 0 .35rem;font-size:.72rem;font-weight:600;text-align:center;color:#059669}.room-invite__actions{display:grid;gap:.45rem}.room-invite__actions--row{display:flex;gap:.35rem}.room-invite__actions--row button{flex:1;min-width:0;margin-top:0;padding:.42rem .3rem;font-size:.78rem}.room-invite__actions button{margin-top:0}.share-x-btn--compact{flex:1.15;min-width:0;padding:.42rem .25rem;font-size:.72rem;border-radius:8px;line-height:1.2}.share-x-btn{margin-top:0;border:none;border-radius:10px;padding:.65rem 1rem;font-size:.9rem;font-weight:700;background:#0f1419;color:#fff;cursor:pointer}.share-x-btn:hover{background:#272c30}.share-x-btn--block{width:100%}.share-x-btn--block+.secondary,.share-x-btn--block+button{margin-top:0}.card .share-x-btn--block{margin-top:.75rem}.invite-hint{margin:.35rem 0 .5rem;text-align:center;color:#2563eb;font-weight:600}.home-rules{margin-bottom:1rem}.home-rules__heading{margin:0 0 .75rem;font-size:1.05rem;text-align:center}.home-rules__actions{display:grid;gap:.5rem}.home-rules__btn{margin-top:0}.home-rules__comic{list-style:none;margin:0;padding:0;display:grid;gap:.65rem}.home-rules__comic--modal{padding:.65rem .85rem 1rem;overflow-x:hidden;overflow-y:auto;flex:1 1 auto;min-height:0;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.home-rules__panel{margin:0;border-radius:12px;overflow:hidden;border:1px solid #e2e8f0;background:#fff;box-shadow:0 2px 8px #0f172a0f}.rules-modal .home-rules__panel{overflow:visible;border:none;box-shadow:none;background:transparent}.home-rules__img{display:block;width:100%;max-width:100%;height:auto;object-fit:contain}.card-effects-btn--block{width:100%;margin-top:0}.lobby-screen__recommended{display:block;margin-top:.2rem;font-size:.72rem;color:#94a3b8}.lobby-warning{margin:.45rem 0 0;padding:.55rem .65rem;border-radius:10px;border:1px solid #fcd34d;background:#fffbeb}.lobby-warning__title{margin:0 0 .35rem;font-size:.85rem;font-weight:700;color:#92400e}.lobby-warning__body{margin:0;font-size:.78rem;line-height:1.5;color:#78350f}.game-shell--lobby{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.lobby-screen{display:flex;flex-direction:column;flex:1;min-height:0;gap:.5rem;padding:.5rem .65rem calc(.5rem + env(safe-area-inset-bottom,0px));overflow:hidden}.lobby-screen__header{flex-shrink:0;display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;padding:.35rem .15rem 0}.lobby-screen__header-main{min-width:0}.lobby-screen__role{margin:0;font-size:.95rem;font-weight:800;color:#0f172a}.lobby-screen__count{margin:.15rem 0 0;font-size:.82rem;color:#64748b}.lobby-screen__recommended{display:block;margin-top:.15rem;font-size:.72rem;color:#94a3b8}.lobby-screen__invite{flex-shrink:0}.lobby-screen__members{flex:1;min-height:0;display:flex;flex-direction:column;gap:.45rem;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:.15rem 0}.lobby-screen__members-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;padding:0 .1rem}.lobby-screen__members-head--observers{margin-top:.25rem}.lobby-screen__members-title{margin:0;font-size:.88rem;font-weight:800;color:#334155}.lobby-screen__members-count{font-size:.78rem;font-weight:700;color:#64748b}.lobby-player-grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(auto-fill,minmax(8.5rem,1fr));gap:.45rem}.lobby-player-grid--observers{grid-template-columns:repeat(auto-fill,minmax(7.5rem,1fr))}.lobby-player-card{display:flex;flex-direction:column;gap:.2rem;padding:.55rem .65rem;border-radius:10px;border:1px solid #e2e8f0;background:#fff;min-height:3.25rem}.lobby-player-card--me{border-color:#93c5fd;background:#eff6ff;box-shadow:0 0 0 1px #93c5fd59}.lobby-player-card--host{border-color:#fcd34d}.lobby-player-card--observer{background:#f8fafc}.lobby-player-card__seat{font-size:.68rem;font-weight:700;color:#94a3b8}.lobby-player-card__name{font-size:.92rem;font-weight:700;color:#0f172a;line-height:1.25;word-break:break-word}.lobby-player-card__tags{display:flex;flex-wrap:wrap;gap:.2rem;margin-top:auto}.lobby-player-card__tag{font-size:.62rem;font-weight:700;padding:.1rem .35rem;border-radius:999px;background:#e2e8f0;color:#475569}.lobby-player-card__manage{display:flex;gap:.3rem;margin-top:.35rem}.lobby-player-card__action{flex:1;min-width:0;margin:0;padding:.28rem .35rem;font-size:.68rem;border-radius:6px}.lobby-player-card__action--kick{color:#b91c1c;border:1px solid #fecaca;background:#fff}.lobby-player-card__rename{display:flex;flex-direction:column;gap:.25rem;width:100%}.lobby-player-card__rename-input{width:100%;margin:0;padding:.35rem .45rem;font-size:.82rem}.lobby-player-card__rename-hint{margin:0;font-size:.62rem;color:#94a3b8;line-height:1.3}.lobby-player-card__rename-actions{display:flex;gap:.3rem}.lobby-player-card--me .lobby-player-card__tag{background:#dbeafe;color:#1d4ed8}.lobby-screen__footer{flex-shrink:0;display:flex;flex-direction:column;gap:.45rem;padding-top:.25rem;border-top:1px solid #e2e8f0}.lobby-screen__actions{display:flex;flex-direction:column;gap:.5rem}.lobby-screen__actions .cpu-controls{margin-bottom:0}.lobby-screen__actions>button{margin-bottom:0}.lobby-screen__waiting{margin:0;text-align:center}.lobby-screen__members .collapsible{margin-top:.15rem}.lobby-section{margin-top:.35rem;padding-top:.35rem;border-top:1px solid #e2e8f0}.lobby-section__head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;padding:0 .1rem .35rem}.lobby-section__title{margin:0;font-size:.88rem;font-weight:800;color:#334155}.lobby-announcements{position:fixed;top:.65rem;left:50%;transform:translate(-50%);z-index:120;display:flex;flex-direction:column;gap:.35rem;width:min(100% - 1.5rem,24rem);pointer-events:none}.lobby-announcements__item{margin:0;padding:.55rem .85rem;border-radius:999px;background:#0f172ae0;color:#f8fafc;font-size:.82rem;font-weight:600;text-align:center;box-shadow:0 8px 24px #0000002e;animation:lobby-announce-in .25s ease-out}@keyframes lobby-announce-in{0%{opacity:0;transform:translateY(-.35rem)}to{opacity:1;transform:translateY(0)}}.lobby-seat-order{padding:.65rem .75rem;border-radius:10px;border:1px solid #e2e8f0;background:#f8fafc}.lobby-seat-order__head{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.lobby-seat-order__title{margin:0;font-size:.75rem;font-weight:600;color:#64748b}.lobby-seat-order__shuffle{width:auto;min-width:0;margin:0;padding:.25rem .55rem;font-size:.72rem}.lobby-seat-order__hint{margin:.35rem 0 0;font-size:.68rem;color:#94a3b8}.lobby-seat-order__track{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .35rem;margin-top:.45rem}.lobby-seat-order--editable,.lobby-seat-order--editable .lobby-seat-order__track,.lobby-seat-order--editable .lobby-seat-order__seat,.lobby-seat-order--editable .lobby-seat-order__hint{user-select:none;-webkit-user-select:none;-webkit-touch-callout:none}body.lobby-seat-order-dragging{user-select:none!important;-webkit-user-select:none!important;cursor:grabbing}body.lobby-seat-order-dragging *{cursor:grabbing!important}.lobby-seat-order__arrow{font-size:.7rem;color:#cbd5e1;-webkit-user-select:none;user-select:none}.lobby-seat-order__seat{display:flex;flex-direction:column;align-items:center;gap:.1rem;min-width:3.25rem;padding:.35rem .45rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff;touch-action:none}.lobby-seat-order__seat--me{border-color:#93c5fd;background:#eff6ff}.lobby-seat-order__seat--editable{cursor:grab}.lobby-seat-order__seat--editable:active{cursor:grabbing}.lobby-seat-order__seat--dragging{box-shadow:0 8px 20px #0000002e;opacity:.95}.lobby-seat-order__index{font-size:.62rem;font-weight:700;color:#94a3b8}.lobby-seat-order__name{font-size:.72rem;font-weight:700;color:#0f172a;text-align:center;line-height:1.2;word-break:break-word}.lobby-seat-order__badge{font-size:.58rem;font-weight:700;padding:.05rem .3rem;border-radius:999px;background:#e2e8f0;color:#475569}.lobby-seat-order__wrap{font-size:.75rem;color:#94a3b8}.lobby-screen__members .seat-order{margin-bottom:0}.home-join-observe{margin-top:.35rem}.product-ad-banner--lobby{margin:0}.player-list{list-style:none;padding:0;margin:0}.player-list li{padding:.5rem 0;border-bottom:1px solid #eef2f6}.status{font-size:.8rem;color:#64748b}.game-status{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center;margin-bottom:1rem;font-size:.85rem}.room-chrome{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.room-chrome button{width:auto;flex:1 1 auto;min-width:7rem;padding:.5rem .75rem;font-size:.85rem;margin-top:0}.room-chrome__leave{flex:0 1 auto}.room-chrome__advance{background:#f59e0b;animation:advance-pulse 1.2s ease-in-out infinite}@keyframes advance-pulse{0%,to{box-shadow:0 0 #f59e0b66}50%{box-shadow:0 0 0 6px #f59e0b00}}.seat-order{margin-bottom:1rem;padding:.75rem;background:#f8fafc;border-radius:10px;border:1px solid #e2e8f0}.seat-order__title{margin:0 0 .5rem;font-size:.75rem;font-weight:600;color:#64748b}.seat-order__track{display:flex;flex-wrap:wrap;align-items:center;gap:.25rem .35rem}.seat-order__seat{display:flex;flex-direction:column;align-items:center;gap:.1rem;padding:.35rem .5rem;border-radius:8px;background:#fff;border:1px solid #e2e8f0;min-width:3.5rem;font-size:.72rem}.seat-order__seat--current{border-color:#2563eb;background:#eff6ff;box-shadow:0 0 0 2px #2563eb26}.seat-order__seat--me{font-weight:700}.seat-order__seat--retired{opacity:.45;text-decoration:line-through}.seat-order__index{font-size:.65rem;color:#94a3b8;font-weight:600}.seat-order__name{max-width:4.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.seat-order__badge{font-size:.6rem;padding:.05rem .35rem;border-radius:999px;background:#2563eb;color:#fff;font-weight:600}.seat-order__arrow{color:#94a3b8;font-size:.85rem;font-weight:700;flex-shrink:0}.seat-order__arrow--draw{color:#059669;font-size:.7rem;font-weight:600}.seat-order__wrap{color:#cbd5e1;font-size:1rem;margin-left:.15rem}.rejoin-fallback .status{margin-bottom:1rem}.product-ad-banner{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;padding:.65rem .75rem;border-radius:12px;background:#0a0a0a;color:#fff;text-decoration:none;box-shadow:0 4px 16px #0000002e;transition:transform .15s ease,box-shadow .15s ease}.product-ad-banner:hover{transform:translateY(-1px);box-shadow:0 6px 20px #0000003d}.product-ad-banner--home{margin-bottom:1rem}.product-ad-banner--lobby{margin:0 0 .65rem;flex-shrink:0}.product-ad-banner__img{width:56px;height:56px;object-fit:cover;border-radius:6px;flex-shrink:0;border:1px solid rgb(255 255 255 / 15%)}.product-ad-banner__text{display:flex;flex-direction:column;gap:.1rem;min-width:0}.product-ad-banner__headline{font-size:.72rem;font-weight:800;color:#fbbf24;letter-spacing:.02em}.product-ad-banner__body{font-size:.88rem;font-weight:800;line-height:1.3}.product-ad-banner__cta{font-size:.68rem;font-weight:600;color:#ffffffb8}.product-ad-popup-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:flex;align-items:center;justify-content:center;padding:1.25rem;background:#0f172a8c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.product-ad-popup{position:relative;width:min(100%,320px);padding:1rem 1rem 1.1rem;border-radius:14px;background:#0a0a0a;color:#fff;box-shadow:0 16px 48px #00000059;animation:product-ad-popup-in .22s ease-out}@keyframes product-ad-popup-in{0%{opacity:0;transform:translateY(12px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.product-ad-popup__close{position:absolute;top:.35rem;right:.35rem;z-index:1;width:2rem;height:2rem;padding:0;margin:0;border:none;border-radius:999px;background:#ffffff1f;color:#fff;font-size:1.25rem;line-height:1;font-weight:400;cursor:pointer}.product-ad-popup__close:hover{background:#ffffff38}.product-ad-popup__link{display:flex;flex-direction:column;align-items:center;gap:.55rem;color:inherit;text-decoration:none;text-align:center}.product-ad-popup__img{width:min(72vw,200px);height:auto;border-radius:8px;border:1px solid rgb(255 255 255 / 15%)}.product-ad-popup__headline{margin:0;font-size:.9rem;font-weight:800;color:#fbbf24}.product-ad-popup__body{margin:0;font-size:1.05rem;font-weight:800;line-height:1.35}.product-ad-popup__cta{font-size:.82rem;font-weight:700;color:#ffffffbf}.rejoin-fallback button{margin-top:0}.game-end-actions{display:grid;gap:.5rem;margin:1rem 0 .75rem}.game-end-actions button{margin-top:0}.game-end{display:grid;gap:1rem}.game-end__reason,.game-end__section{margin:0}.game-end__heading{margin:0 0 .5rem;font-size:.82rem;font-weight:700;color:#64748b;letter-spacing:.02em}.game-end__retire-list{margin:0;padding:0;list-style:none;display:grid;gap:.35rem}.game-end__retire-item{display:flex;align-items:center;gap:.5rem;padding:.45rem .55rem;border-radius:8px;background:#f8fafc;border:1px solid #e2e8f0}.game-end__retire-item--me{border-color:#93c5fd;background:#eff6ff}.game-end__rank{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;border-radius:999px;background:#e2e8f0;color:#334155;font-size:.72rem;font-weight:800;flex-shrink:0}.game-end__retire-item:nth-child(1) .game-end__rank{background:#fef3c7;color:#92400e}.game-end__name{flex:1;min-width:0;font-weight:700;font-size:.9rem}.game-end__badge{flex-shrink:0;padding:.1rem .4rem;border-radius:999px;font-size:.62rem;font-weight:800}.game-end__badge--fast{background:#dcfce7;color:#166534}.game-end__outcomes{margin:0;padding:0;list-style:none;display:grid;gap:.45rem}.game-end__outcome{display:grid;gap:.1rem;padding:.55rem .65rem;border-radius:8px;border:1px solid #e2e8f0;background:#fff}.game-end__outcome--winner{border-color:#86efac;background:#f0fdf4}.game-end__outcome--loser{border-color:#fca5a5;background:#fef2f2}.game-end__outcome--draw{border-color:#cbd5e1;background:#f8fafc}.game-end__outcome-label{font-size:.68rem;font-weight:800;color:#64748b;letter-spacing:.03em}.game-end__outcome-name{font-size:.95rem;font-weight:800;color:#0f172a}.game-end__outcome-note{font-size:.72rem;color:#64748b}.deadline-timer{margin-left:auto;padding:.2rem .55rem;border-radius:999px;background:#e0f2fe;color:#0369a1;font-size:.8rem;font-weight:700;font-variant-numeric:tabular-nums}.deadline-timer--urgent{background:#fee2e2;color:#b91c1c;animation:deadline-pulse .8s ease-in-out infinite}@keyframes deadline-pulse{0%,to{opacity:1}50%{opacity:.65}}.opponents--compact{grid-template-columns:repeat(auto-fit,minmax(7rem,1fr));gap:.4rem}.opponent--compact{padding:.4rem .5rem;font-size:.75rem}.opponent__header{display:flex;justify-content:space-between;align-items:baseline;gap:.35rem}.opponent__hand-preview{position:relative;height:28px;margin-top:.15rem}.opponent__mini-card{position:absolute;bottom:0;left:calc(var(--mini-index) * 10px);width:18px;height:26px;border-radius:3px;background:linear-gradient(145deg,#1e3a5f,#0f2744);border:1px solid #3b82f6;box-shadow:0 1px 3px #0003}.opponent--draw-source{outline:2px solid #2563eb;background:#eff6ff}.opponent__draw-badge{font-size:.65rem;font-weight:700;color:#2563eb;text-align:center}.opponent__auto-play{font-size:.65rem;font-weight:700;color:#b45309;text-align:center}.draw-zone{margin-bottom:1rem;padding:1.25rem 1rem 1.75rem;background:linear-gradient(180deg,#eff6ff,#fff);border:2px solid #93c5fd;border-radius:16px;box-shadow:0 4px 16px #2563eb1f;text-align:center;overflow:visible}.draw-zone--waiting{padding:.85rem 1rem;background:#f8fafc;border-color:#cbd5e1}.draw-zone__title{margin:0 0 .25rem;font-size:1rem;font-weight:800;color:#1e40af}.draw-zone__pair-hint{margin:0 0 .35rem;padding:.45rem .65rem;font-size:.8rem;font-weight:600;color:#b45309;background:#fffbeb;border:1px solid #fcd34d;border-radius:8px}.draw-zone__hint{margin:0 0 1rem;font-size:.8rem;color:#64748b}.draw-zone__waiting{margin:0;font-size:.85rem;font-weight:600;color:#475569}.card-fan--draw .playing-card{margin-left:-42px}.card-fan--draw .playing-card:first-child{margin-left:0}.opponents{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.opponent{background:#fff;border-radius:8px;padding:.5rem;font-size:.85rem;display:flex;flex-direction:column;gap:.25rem}.opponent.current{outline:2px solid #2563eb}.opponent.retired{opacity:.5}.spectator-banner{margin-bottom:.65rem;padding:.65rem .75rem;border-radius:10px;border:1px solid #86efac;background:#ecfdf5}.spectator-banner__title{margin:0 0 .2rem;font-size:.85rem;font-weight:800;color:#047857}.spectator-banner__body{margin:0;font-size:.75rem;color:#065f46}.opponent--spectator{grid-column:1 / -1}.card-fan--spectator{justify-content:flex-start;min-height:76px;padding:.35rem .25rem .75rem;overflow-x:auto}.card-fan--spectator .playing-card{margin-left:-20px}.card-fan--spectator .playing-card:first-child{margin-left:0}.opponent__empty-hand{margin:0;font-size:.72rem}.game-hand-dock--spectator{display:flex;align-items:center;justify-content:center;min-height:2.5rem;padding:.5rem}.spectator-dock-note{margin:0;font-size:.78rem;color:#64748b;text-align:center}.hand{display:flex;flex-wrap:wrap;gap:.35rem}.card-chip{background:#e0e7ff;border-radius:6px;padding:.35rem .5rem;font-size:.8rem}.actions{background:#fff;border-radius:12px;padding:1rem 1rem 1.25rem;margin-bottom:1rem;box-shadow:0 2px 8px #00000014;overflow:visible}.actions button{margin-bottom:.35rem}.option-row{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.option-btn{width:auto;min-width:4.5rem;padding:.55rem .75rem;margin-bottom:0;background:#e2e8f0;color:#1a1a2e;border:2px solid transparent;transition:border-color .15s,background .15s,box-shadow .15s}.option-btn.selected{background:#dbeafe;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb40}.option-btn.card-back{background:#1e3a5f;color:#fff;font-weight:700}.option-btn.card-back.selected{background:#2563eb;border-color:#93c5fd;box-shadow:0 0 0 3px #93c5fd73}.actions p{margin:0 0 .5rem;font-weight:600}.notice{background:#fef3c7;padding:.5rem .75rem;border-radius:8px;font-size:.85rem;margin-bottom:.75rem}.cpu-controls{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;margin-bottom:1rem}.cpu-controls button{margin-bottom:0}.cpu-tag{display:inline-block;margin-left:.35rem;padding:.05rem .35rem;background:#e2e8f0;border-radius:4px;font-size:.65rem;font-weight:600;vertical-align:middle}.badge{background:#fecaca;padding:.1rem .4rem;border-radius:4px;font-size:.75rem}.cpu-banner{background:#dbeafe;border:2px solid #2563eb;border-radius:10px;padding:.75rem 1rem;margin-bottom:1rem;font-weight:600;font-size:.95rem;text-align:center;animation:cpu-pulse 1.2s ease-in-out infinite}.cpu-banner--acting{background:#fef3c7;border-color:#d97706}.cpu-banner--effect{background:#ede9fe;border-color:#7c3aed}@keyframes cpu-pulse{0%,to{opacity:1}50%{opacity:.75}}.last-play{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;background:#fff;border-radius:10px;padding:.75rem 1rem;margin-bottom:1rem;box-shadow:0 2px 8px #00000014}.last-play-label{font-weight:600;font-size:.85rem}.card-chip.highlight{background:#fde68a;font-weight:700}.card-chip.small{font-size:.7rem;padding:.15rem .35rem;margin-right:.35rem}.activity-log{background:#fff;border-radius:12px;padding:.75rem 1rem;margin-top:1rem;box-shadow:0 2px 8px #00000014;max-height:220px;overflow-y:auto}.activity-log-title{margin:0 0 .5rem;font-weight:700;font-size:.85rem}.activity-log ul{list-style:none;margin:0;padding:0}.activity-log li{font-size:.8rem;padding:.35rem 0;border-bottom:1px solid #eef2f6;line-height:1.4}.activity-log li:last-child{border-bottom:none;font-weight:600;color:#1e3a5f}.my-hand{background:#fff;border-radius:12px;padding:1rem .5rem 1.5rem;box-shadow:0 2px 8px #00000014;overflow:visible;user-select:none;-webkit-user-select:none}.my-hand>p{padding:0 .5rem;margin:0 0 .5rem;font-weight:600;font-size:.85rem}.card-fan{display:flex;justify-content:center;align-items:flex-end;min-height:148px;padding:.85rem .75rem 2.75rem;overflow-x:auto;overflow-y:hidden}.my-hand .card-fan,.actions .card-fan{min-height:160px;padding:1rem .75rem 3rem}.card-fan.card-fan--draw{justify-content:center;min-height:220px;padding:1.25rem 1rem 3.25rem}.card-fan--opponent{min-height:72px;padding:.25rem 0}.playing-card{position:relative;flex-shrink:0;margin-left:-32px;border:2px solid rgb(255 255 255 / 90%);border-radius:10px;box-shadow:0 2px 4px #0000001f,0 6px 16px #0000001a;transition:transform .22s cubic-bezier(.34,1.4,.64,1),box-shadow .22s ease,filter .22s ease;transform-origin:center bottom;padding:0;font-family:inherit;-webkit-appearance:none;-moz-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;user-select:none;-webkit-user-select:none;--fan-rotate: 0deg;--fan-lift: 0px;transform:rotate(var(--fan-rotate)) translateY(var(--fan-lift))}.playing-card:first-child{margin-left:0}.playing-card--md{width:68px;height:96px}.playing-card--lg{width:96px;height:134px;margin-left:-32px;border-radius:11px}.playing-card--lg:first-child{margin-left:0}.playing-card--sm{width:48px;height:68px;margin-left:-24px;border-radius:7px}.playing-card--sm:first-child{margin-left:0}.playing-card--face{overflow:hidden;background:var(--card-bg, #fff);border-color:var(--card-border, rgb(255 255 255 / 95%))}.playing-card--back{padding:0;overflow:hidden;background:#fff;border-color:#fffffff2}.playing-card__back-img{display:block;width:100%;height:100%;object-fit:cover;border-radius:8px;pointer-events:none}.playing-card__inner{display:flex;flex-direction:column;width:100%;height:100%;padding:4px 3px 3px;gap:2px}.playing-card__name{flex-shrink:0;margin:0;padding:0 2px;color:var(--card-label, #1a1a2e);font-size:.52rem;font-weight:800;line-height:1.15;text-align:center;letter-spacing:-.01em;word-break:keep-all;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:1.196rem;user-select:none;-webkit-user-select:none}.playing-card__icon-wrap{flex:1;display:flex;align-items:center;justify-content:center;min-height:0;width:100%}.playing-card__icon{display:block;width:100%;height:100%;object-fit:contain;object-position:center;pointer-events:none;-webkit-user-select:none;user-select:none}.playing-card--sm .playing-card__icon-wrap{height:38px;flex:0 0 38px}.playing-card--md .playing-card__icon-wrap{height:54px;flex:0 0 54px}.playing-card--lg .playing-card__icon-wrap{height:76px;flex:0 0 76px}.playing-card--sm .playing-card__name{font-size:.38rem;line-height:1.1;min-height:calc(2 * 1.1 * .38rem)}.playing-card--lg .playing-card__name{font-size:.62rem;min-height:1.426rem}.playing-card__unknown{display:flex;align-items:center;justify-content:center;width:100%;height:100%;font-size:.65rem;font-weight:800;padding:4px;text-align:center}.playing-card--sm .playing-card__inner{padding:2px 2px 1px;gap:1px}.playing-card--lg .playing-card__inner{padding:5px 4px 4px;gap:3px}.playing-card--type-zangyo.playing-card--face{background:#fff;border:3px solid #000;box-shadow:0 2px 6px #0000002e,0 8px 20px #0000001f,inset 0 0 0 1px #00000014}.playing-card--type-zangyo .playing-card__inner{position:relative}.playing-card--type-zangyo .playing-card__zangyo-badge{position:absolute;top:0;right:0;z-index:1;padding:1px 4px;border-radius:0 6px;background:#000;color:#fff;font-size:.42rem;font-weight:900;line-height:1.3;letter-spacing:.04em}.playing-card--sm.playing-card--type-zangyo .playing-card__zangyo-badge{font-size:.32rem;padding:1px 3px;border-radius:0 4px}.playing-card--lg.playing-card--type-zangyo .playing-card__zangyo-badge{font-size:.5rem;padding:2px 5px}.playing-card--type-zangyo .playing-card__name{color:#171717;font-weight:900}.playing-card--type-zangyo .playing-card__icon-wrap{background:repeating-linear-gradient(-45deg,rgb(0 0 0 / 4%) 0,rgb(0 0 0 / 4%) 2px,transparent 2px,transparent 6px);border-radius:4px}.playing-card__hand{position:absolute;top:-10px;right:-6px;font-size:1.1rem;opacity:0;transform:scale(.6) translateY(4px);transition:opacity .18s ease,transform .18s ease;pointer-events:none;filter:drop-shadow(0 1px 2px rgb(0 0 0 / 30%))}.playing-card--selectable{cursor:grab}.playing-card--selectable:active{cursor:grabbing}.playing-card--selectable:hover{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 22px)) scale(1.1)!important;z-index:200!important;box-shadow:0 0 0 3px #2563eb73,0 12px 28px #2563eb59,0 4px 12px #00000026!important;filter:brightness(1.05)}.playing-card--selectable:hover .playing-card__hand{opacity:1;transform:scale(1) translateY(0)}.playing-card--selected{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 18px)) scale(1.06)!important;z-index:150!important;box-shadow:0 0 0 3px #2563eb,0 10px 24px #2563eb66,0 4px 10px #0000001f!important}.playing-card--selected .playing-card__hand{opacity:1;transform:scale(1) translateY(0)}.playing-card--confirm-ready{animation:card-confirm-pulse 1s ease-in-out infinite}.playing-card__confirm-hint{position:absolute;bottom:-1.4rem;left:50%;transform:translate(-50%);font-size:.6rem;font-weight:800;color:#2563eb;white-space:nowrap;background:#eff6ff;padding:.1rem .35rem;border-radius:4px;border:1px solid #93c5fd;pointer-events:none}@keyframes card-confirm-pulse{0%,to{box-shadow:0 0 0 3px #2563eb,0 10px 24px #2563eb66}50%{box-shadow:0 0 0 5px #2563eb8c,0 12px 28px #2563eb7f}}.playing-card--pulling-away{animation:card-pull-away .65s ease-in forwards;pointer-events:none}.playing-card--remote-hover{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 14px)) scale(1.05)!important;z-index:180!important;box-shadow:0 0 0 3px #f973168c,0 10px 22px #f9731659!important}.playing-card--remote-selected{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 20px)) scale(1.08)!important;z-index:190!important;box-shadow:0 0 0 4px #ea580c,0 14px 28px #ea580c73!important;animation:card-remote-pulse .8s ease-in-out infinite}.playing-card__remote-hand{position:absolute;top:-12px;left:50%;transform:translate(-50%);font-size:1.2rem;pointer-events:none;filter:drop-shadow(0 1px 2px rgb(0 0 0 / 35%))}@keyframes card-pull-away{0%{opacity:1;transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 10px)) scale(1.05)}to{opacity:0;transform:rotate(var(--fan-rotate)) translateY(-120px) scale(.75) translate(40px)}}@keyframes card-remote-pulse{0%,to{filter:brightness(1)}50%{filter:brightness(1.12)}}.card-transfer-fx{position:fixed;left:50%;bottom:7rem;transform:translate(-50%);z-index:500;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:.35rem}.card-transfer-fx--out .playing-card{animation:card-pull-away .7s ease-in forwards}.card-transfer-fx--in .playing-card{animation:card-receive .7s ease-out forwards}.card-transfer-fx__label{font-size:.8rem;font-weight:800;color:#1e3a5f;background:#ffffffeb;padding:.2rem .6rem;border-radius:6px;box-shadow:0 2px 8px #0000001f}@keyframes card-receive{0%{opacity:0;transform:translateY(-80px) scale(.7)}to{opacity:1;transform:translateY(0) scale(1)}}.being-targeted{background:#fff7ed;border:2px solid #fb923c;border-radius:8px;padding:.5rem .75rem;margin-bottom:.75rem;font-size:.85rem;font-weight:600;color:#9a3412;text-align:center}.opponent.remote-target{outline:2px solid #fb923c;box-shadow:0 0 0 3px #fb923c59}.opponent.remote-target-selected{outline:3px solid #ea580c;box-shadow:0 0 12px #ea580c73}.pair-row{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-bottom:.75rem}.pair-card{position:relative;width:68px;height:96px;border:2px solid rgb(255 255 255 / 90%);border-radius:10px;padding:0;overflow:hidden;background:var(--card-bg, #fff);box-shadow:0 4px 12px #0000001f;transition:transform .22s cubic-bezier(.34,1.4,.64,1),box-shadow .22s ease}.pair-card__stack{position:relative;width:100%;height:100%}.pair-card__layer{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:8px;overflow:hidden}.pair-card__layer--back{transform:rotate(-6deg) translate(-4px,-4px);opacity:.75;background:var(--card-bg);filter:brightness(.92)}.pair-card__layer--front{transform:rotate(3deg);background:var(--card-bg, #fff)}.pair-card__layer--front .playing-card__inner{height:100%}.pair-card.playing-card--selectable:hover{transform:translateY(-16px) scale(1.08);z-index:200;box-shadow:0 0 0 3px #2563eb73,0 12px 28px #2563eb59}.pair-card.playing-card--selected{transform:translateY(-14px) scale(1.05);z-index:150;box-shadow:0 0 0 3px #2563eb,0 10px 24px #2563eb66}.pair-card__badge{position:absolute;bottom:4px;right:4px;background:#00000040;color:#fff;font-size:.65rem;font-weight:800;padding:.1rem .35rem;border-radius:4px}.opponent-draw{margin-top:.5rem}.opponent-draw-label{font-size:.7rem;color:#2563eb;font-weight:600;margin:0 0 .25rem;text-align:center}.actions .action-confirm{margin-top:.5rem}.field-cards{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.field-cards__pair{display:flex;flex-wrap:wrap;gap:.5rem;align-items:flex-end}.field-cards__label{font-size:.8rem;font-weight:600;color:#64748b;margin:0}.field-cards__effect{margin:0;padding:.6rem .75rem;background:#f8fafc;border-left:3px solid #6366f1;border-radius:0 8px 8px 0;font-size:.82rem;line-height:1.45;color:#334155}.field-cards__effect strong{color:#1e293b}.peek .card-fan{min-height:120px;padding-bottom:2rem}.romance-peek{border:2px solid #f472b6;border-radius:12px;padding:.75rem;background:linear-gradient(180deg,#fdf2f8,#fff)}.romance-peek__header{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;margin-bottom:.75rem}.romance-peek__title{margin:0;font-size:.9rem;font-weight:700;color:#9d174d}.romance-peek .deadline-timer{margin-left:0}.romance-peek__actions{margin-top:.75rem}.romance-peek__actions button{margin-top:0}.romance-peek__waiting{margin:0;text-align:center}.game-status__effects-btn,.lobby-effects-btn{width:auto;min-width:0;padding:.35rem .65rem;font-size:.75rem;margin:0}.game-status__effects-btn{margin-left:auto}.lobby-effects-btn{margin-top:.75rem}.card-effect-text{margin:0;display:flex;flex-direction:column;gap:.25rem;font-size:.85rem;line-height:1.45;color:#334155}.card-effect-text strong{color:#1e293b;font-size:.9rem}.hand-card-effect{margin:.5rem 0 .75rem;padding:.65rem .75rem;background:#f5f3ff;border:1px solid #c4b5fd;border-radius:10px}.hand-card-effect__note{margin:.35rem 0 0;font-size:.7rem;color:#6b7280}.my-hand .playing-card[type=button],.my-hand .playing-card{cursor:pointer}@media(hover:hover){.my-hand .playing-card:not(.playing-card--muted):hover{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 22px)) scale(1.1)!important;z-index:200!important;box-shadow:0 0 0 3px #2563eb73,0 12px 28px #2563eb59,0 4px 12px #00000026!important;filter:brightness(1.05)}.my-hand .playing-card--selectable:not(.playing-card--muted):hover .playing-card__hand{opacity:1;transform:scale(1) translateY(0)}.my-hand .playing-card--selected:not(.playing-card--muted):hover{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 20px)) scale(1.08)!important;filter:brightness(1.1) saturate(1.22)}.my-hand .playing-card--inspected:not(.playing-card--muted):hover{box-shadow:0 0 0 2px #8b5cf6,0 10px 22px #8b5cf659,0 3px 8px #0000001f!important}}.playing-card--inspected{transform:rotate(var(--fan-rotate)) translateY(calc(var(--fan-lift) - 10px)) scale(1.03)!important;z-index:120!important;box-shadow:0 0 0 2px #8b5cf6,0 8px 18px #8b5cf64d!important}.card-effects-modal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1200;display:flex;align-items:flex-end;justify-content:center;padding:1rem}.card-effects-modal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#0f172a73;cursor:pointer}.card-effects-modal__panel{position:relative;width:min(100%,480px);max-height:min(85vh,640px);background:#fff;border-radius:16px 16px 12px 12px;box-shadow:0 16px 48px #0003;display:flex;flex-direction:column;overflow:hidden}.card-effects-modal__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;padding:1rem 1rem .5rem;border-bottom:1px solid #e2e8f0}.card-effects-modal__header h2{margin:0;font-size:1rem}.card-effects-modal__close{width:auto;min-width:0;padding:.4rem .65rem;margin:0;font-size:.8rem}.card-effects-modal__note{margin:0;padding:.5rem 1rem;font-size:.75rem;color:#64748b;background:#f8fafc}.card-effects-list{list-style:none;margin:0;padding:.5rem 1rem 1rem;overflow-y:auto}.card-effects-list__item{display:flex;gap:.75rem;align-items:flex-start;padding:.65rem 0;border-bottom:1px solid #f1f5f9}.card-effects-list__item:last-child{border-bottom:none}.card-effects-list__item .playing-card{margin-left:0;flex-shrink:0}.card-effects-list__body{min-width:0}.card-effects-list__body strong{display:block;font-size:.9rem;margin-bottom:.2rem}.card-effects-list__body p{margin:0;font-size:.8rem;line-height:1.45;color:#475569}@media(min-width:640px){.card-effects-modal{align-items:center}.card-effects-modal__panel{border-radius:16px}}.rules-modal{align-items:center;padding:max(.75rem,env(safe-area-inset-top,0px)) .75rem max(.75rem,env(safe-area-inset-bottom,0px))}.rules-modal .card-effects-modal__panel{width:min(100%,520px);height:min(92vh,720px);max-height:none;border-radius:14px}.rules-modal .home-rules__img{border-radius:10px;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0f172a0f}.rouki-reveal{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:center;justify-content:center;padding:1rem;pointer-events:none}.rouki-reveal__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#0f172a8c}.rouki-reveal__content{position:relative;display:flex;flex-direction:column;align-items:center;gap:.65rem;max-width:280px;text-align:center}.rouki-reveal__title{margin:0;font-size:1rem;font-weight:800;color:#fff;text-shadow:0 1px 4px rgb(0 0 0 / 40%)}.rouki-reveal__meta{margin:0;font-size:.78rem;color:#e2e8f0}.rouki-reveal__flip{perspective:900px;width:96px;height:134px}.rouki-reveal__flip-inner{position:relative;width:100%;height:100%;transform-style:preserve-3d;transition:transform .7s cubic-bezier(.4,.2,.2,1)}.rouki-reveal__flip--done .rouki-reveal__flip-inner{transform:rotateY(180deg)}.rouki-reveal__face{position:absolute;top:0;right:0;bottom:0;left:0;backface-visibility:hidden;display:flex;align-items:center;justify-content:center}.rouki-reveal__face .playing-card{margin-left:0}.rouki-reveal__face--front{transform:rotateY(180deg)}.rouki-reveal__result{margin:0;padding:.4rem .75rem;background:#fffffff2;border-radius:8px;font-size:.9rem;color:#1e293b;animation:rouki-result-in .35s ease-out}@keyframes rouki-result-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.app--in-game{padding:.5rem .75rem 0;height:100dvh;max-height:100dvh;display:flex;flex-direction:column;overflow:hidden}.app--in-game .app-brand{flex-shrink:0;margin-bottom:.35rem}.app--in-game h1{font-size:1rem;margin:0}.app--in-game .subtitle{display:none}.app--in-game>.error,.app--in-game>.status{flex-shrink:0;margin-bottom:.35rem}.app--in-game>.game-shell{flex:1;min-height:0}.app--in-game>.game-shell--lobby{flex:1;min-height:0}.game-shell--scroll{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.game-screen-scroll{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding-bottom:calc(.75rem + env(safe-area-inset-bottom,0px))}.game-screen-scroll>.card{margin-bottom:.5rem}.screen-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.screen-header h2{margin:0;font-size:1.1rem}.game-shell{display:flex;flex-direction:column;min-height:0;height:100%}.game-topbar{flex-shrink:0;display:flex;align-items:center;gap:.35rem;padding:.45rem .6rem;margin-bottom:.45rem;background:#fff;border-radius:10px;box-shadow:0 1px 4px #00000014}.game-topbar__info{flex:1;min-width:0;display:flex;flex-wrap:wrap;gap:.25rem .45rem;align-items:center;font-size:.78rem}.game-topbar__code{font-weight:800;letter-spacing:.08em;color:#1e40af}.game-topbar__phase{font-weight:700}.game-topbar__turn{color:#334155}.game-topbar__pairs{color:#64748b}.game-topbar .deadline-timer{margin-left:0}.game-topbar__menu-btn,.game-topbar__advance{width:2.35rem;height:2.35rem;min-width:0;padding:0;margin:0;flex-shrink:0;font-size:1rem;line-height:1}.game-topbar__advance{background:#f59e0b;animation:advance-pulse 1.2s ease-in-out infinite}.game-main{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;padding-bottom:.35rem}.game-hand-dock{flex-shrink:0;background:#fff;border-radius:14px 14px 0 0;box-shadow:0 -4px 20px #0000001f;padding:.45rem .35rem calc(.35rem + env(safe-area-inset-bottom,0px));max-height:min(46vh,360px);overflow-y:auto}.game-hand-dock .my-hand{margin:0;padding:.35rem .25rem .5rem;border-radius:0;background:transparent}.game-hand-dock .my-hand[class*=my-hand--purpose-]{margin:.1rem .12rem 0;padding:.55rem .4rem .65rem;border-radius:12px;overflow:visible}.game-hand-dock .my-hand.my-hand--purpose-info_share{background:linear-gradient(180deg,#eef2fff2,#ffffffb3)}.game-hand-dock .my-hand.my-hand--purpose-trade{background:linear-gradient(180deg,#fff7edf2,#ffffffb3)}.game-hand-dock .my-hand.my-hand--purpose-pawahara_give{background:linear-gradient(180deg,#f8fafcf2,#ffffffb3)}.game-hand-dock .my-hand.my-hand--purpose-play_or_skip{background:linear-gradient(180deg,#eff6fff2,#ffffffb3)}.my-hand__label{margin:0;padding:0 .35rem;font-weight:600;font-size:.78rem;flex:1;min-width:0}.my-hand__toolbar{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.25rem}.my-hand__shuffle{width:auto;min-width:0;flex-shrink:0;padding:.35rem .6rem;margin:0;font-size:.72rem}.my-hand__skip-pair{width:100%;margin:0 .35rem .45rem;padding:.45rem .6rem;font-size:.78rem;font-weight:700}.my-hand__hint{margin:0 0 .35rem;padding:0 .35rem;font-size:.7rem}.my-hand__hint--locked{color:#b45309}.playing-card--reorderable{cursor:grab;touch-action:none}.playing-card--reorderable:active{cursor:grabbing}.card-fan--reorder{position:relative}.card-fan--reorder-active .reorder-slot__card{transition:transform .22s cubic-bezier(.34,1.4,.64,1)}.reorder-slot{display:flex;align-items:flex-end;flex-shrink:0}.reorder-slot:not(:first-child){margin-left:-32px}.reorder-slot__card{transform-origin:center bottom;touch-action:none;cursor:grab;user-select:none;-webkit-user-select:none}.reorder-slot__card:active{cursor:grabbing}.reorder-slot__card .playing-card{margin-left:0}.card-fan--reorder-active .reorder-slot__card .playing-card:hover{transform:none!important;filter:none;box-shadow:0 2px 4px #0000001f,0 6px 16px #0000001a!important}.reorder-gap{position:relative;width:36px;flex-shrink:0;margin:0 -6px;align-self:stretch;pointer-events:none;animation:reorder-gap-in .18s ease-out}.reorder-gap:before{content:"";position:absolute;bottom:3rem;left:50%;width:4px;height:78px;transform:translate(-50%);border-radius:999px;background:linear-gradient(180deg,#2563eb26,#2563ebd9,#2563eb26);box-shadow:0 0 12px #2563eb59}@keyframes reorder-gap-in{0%{width:8px;opacity:.3}to{width:34px;opacity:1}}.reorder-float{position:fixed;z-index:4000;pointer-events:none;margin:0;user-select:none;-webkit-user-select:none}.reorder-float .playing-card{margin-left:0!important;transform:rotate(0) translateY(-26px) scale(1.1)!important;z-index:1!important;box-shadow:0 0 0 3px #2563eb7f,0 16px 36px #2563eb59,0 6px 14px #0000002e!important;filter:brightness(1.04);transition:none!important}.playing-card--muted{opacity:.35;filter:grayscale(.35)}.game-hand-dock--selecting{box-shadow:0 -4px 24px #0f172a1a,0 -1px #fffc inset;padding-left:.5rem;padding-right:.5rem}.game-hand-dock--selecting-active{animation:hand-dock-pick-glow 1.25s ease-in-out infinite;padding-left:.55rem;padding-right:.55rem;padding-top:.55rem}@keyframes hand-dock-pick-glow{0%,to{box-shadow:0 -4px 20px #2563eb1f,0 -1px #fffc inset}50%{box-shadow:0 -8px 36px #2563eb47,0 0 0 2px #2563eb38,0 -1px #ffffffe5 inset}}.my-hand--purpose-info_share,.my-hand--purpose-trade,.my-hand--purpose-pawahara_give,.my-hand--purpose-play_or_skip{position:relative;padding:.55rem .5rem .65rem;border-radius:12px;border:3px solid transparent;overflow:visible;transition:background .25s ease,border-color .25s ease}.my-hand--purpose-info_share{--hand-glow: 129 140 248;border-color:#6366f1;background:linear-gradient(180deg,#eef2fff2,#ffffffb3)}.my-hand--purpose-trade{--hand-glow: 251 146 60;border-color:#f97316;background:linear-gradient(180deg,#fff7edf2,#ffffffb3)}.my-hand--purpose-pawahara_give{--hand-glow: 148 163 184;border-color:#64748b;background:linear-gradient(180deg,#f8fafcf2,#ffffffb3)}.my-hand--purpose-play_or_skip{--hand-glow: 37 99 235;border-color:#2563eb;background:linear-gradient(180deg,#eff6fff2,#ffffffb3)}.my-hand--purpose-active{animation:hand-pick-glow 1.25s ease-in-out infinite;transition:none}.my-hand--purpose-active:before{content:"";position:absolute;top:-5px;right:-5px;bottom:-5px;left:-5px;border-radius:15px;pointer-events:none;z-index:0;border:3px solid rgb(var(--hand-glow) / 70%);animation:hand-pick-ring 1.25s ease-in-out infinite}.my-hand--purpose-active:after{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:13px;pointer-events:none;z-index:0;box-shadow:inset 0 0 12px rgb(var(--hand-glow) / 0%);animation:hand-pick-inner 1.25s ease-in-out infinite}.my-hand--purpose-active>*{position:relative;z-index:1}@keyframes hand-pick-glow{0%,to{border-color:rgb(var(--hand-glow) / 45%);box-shadow:0 0 rgb(var(--hand-glow) / 0%),0 0 8px rgb(var(--hand-glow) / 18%),0 0 16px rgb(var(--hand-glow) / 10%)}50%{border-color:rgb(var(--hand-glow) / 100%);box-shadow:0 0 0 4px rgb(var(--hand-glow) / 40%),0 0 22px rgb(var(--hand-glow) / 55%),0 0 44px rgb(var(--hand-glow) / 32%)}}@keyframes hand-pick-ring{0%,to{opacity:.35;transform:scale(1);border-color:rgb(var(--hand-glow) / 40%)}50%{opacity:1;transform:scale(1.02);border-color:rgb(var(--hand-glow) / 95%)}}@keyframes hand-pick-inner{0%,to{box-shadow:inset 0 0 8px rgb(var(--hand-glow) / 0%)}50%{box-shadow:inset 0 0 16px rgb(var(--hand-glow) / 22%)}}.my-hand--purpose-waiting{opacity:.92;animation:none;box-shadow:0 0 0 1px rgb(var(--hand-glow) / 25%)}.my-hand--purpose-waiting:before,.my-hand--purpose-waiting:after{display:none}.my-hand--has-zangyo{margin:.1rem .15rem 0;padding:.45rem .35rem .55rem;border:3px solid #000;border-radius:12px;background:repeating-linear-gradient(-45deg,rgb(0 0 0 / 3%) 0,rgb(0 0 0 / 3%) 2px,transparent 2px,transparent 8px),linear-gradient(180deg,#fff,#f8f8f8);box-shadow:0 0 0 1px #0000001a,inset 0 1px #ffffffe5}.game-hand-dock .my-hand--has-zangyo{margin:.15rem .2rem 0;background:repeating-linear-gradient(-45deg,rgb(0 0 0 / 3%) 0,rgb(0 0 0 / 3%) 2px,transparent 2px,transparent 8px),linear-gradient(180deg,#fff,#f8f8f8)}.my-hand--has-zangyo.my-hand--purpose-info_share,.my-hand--has-zangyo.my-hand--purpose-trade,.my-hand--has-zangyo.my-hand--purpose-pawahara_give,.my-hand--has-zangyo.my-hand--purpose-play_or_skip{border-color:#000}.my-hand--has-zangyo.my-hand--purpose-active{animation:hand-pick-glow-zangyo 1.25s ease-in-out infinite;transition:none}.my-hand--has-zangyo.my-hand--purpose-active:before{border-color:rgb(var(--hand-glow) / 85%)}@keyframes hand-pick-glow-zangyo{0%,to{border-color:#000;box-shadow:0 0 0 1px #000,0 0 0 3px rgb(var(--hand-glow) / 22%),0 0 10px rgb(var(--hand-glow) / 15%)}50%{border-color:#000;box-shadow:0 0 0 1px #000,0 0 0 5px rgb(var(--hand-glow) / 55%),0 0 28px rgb(var(--hand-glow) / 42%)}}.my-hand--has-zangyo.my-hand--purpose-info_share{--hand-purpose-accent: #818cf8}.my-hand--has-zangyo.my-hand--purpose-trade{--hand-purpose-accent: #fb923c}.my-hand--has-zangyo.my-hand--purpose-pawahara_give{--hand-purpose-accent: #94a3b8}.my-hand--has-zangyo.my-hand--purpose-play_or_skip{--hand-purpose-accent: #2563eb}.my-hand__zangyo-banner{margin:0 0 .4rem;padding:.32rem .5rem;border-radius:8px;background:#000;color:#fff;font-size:.72rem;font-weight:800;line-height:1.35;text-align:center;letter-spacing:.02em}.hand-pick-hint{margin:0 0 .45rem;padding:.35rem .5rem;font-size:.82rem;font-weight:700;line-height:1.4;border-radius:8px;border:1px solid transparent}.my-hand--purpose-active .hand-pick-hint{animation:hand-pick-hint-pulse 1.25s ease-in-out infinite}@keyframes hand-pick-hint-pulse{0%,to{box-shadow:0 0 rgb(var(--hand-glow) / 0%);border-color:rgb(var(--hand-glow) / 30%)}50%{box-shadow:0 0 14px rgb(var(--hand-glow) / 40%);border-color:rgb(var(--hand-glow) / 65%)}}.hand-pick-hint--info_share{color:#4338ca;background:#fffc;border-color:#818cf873}.hand-pick-hint--trade{color:#c2410c;background:#fffc;border-color:#fb923c73}.hand-pick-hint--pawahara_give{color:#475569;background:#fffc;border-color:#94a3b873}.hand-pick-hint--play_or_skip{color:#1d4ed8;background:#fffc;border-color:#2563eb73}.hand-pick-hint--waiting{font-weight:600;color:#64748b;background:#ffffff8c;animation:none}@media(prefers-reduced-motion:reduce){.game-hand-dock--selecting-active,.my-hand--purpose-active,.my-hand--has-zangyo.my-hand--purpose-active,.my-hand--purpose-active .hand-pick-hint{animation:none}.my-hand--purpose-active{border-color:rgb(var(--hand-glow) / 80%);box-shadow:0 0 0 3px rgb(var(--hand-glow) / 35%),0 0 20px rgb(var(--hand-glow) / 30%)}.game-hand-dock--selecting-active{box-shadow:0 -6px 28px #2563eb38,0 0 0 2px #2563eb2e}.my-hand--has-zangyo.my-hand--purpose-active{box-shadow:0 0 0 1px #000,0 0 0 4px rgb(var(--hand-glow) / 45%),0 0 18px rgb(var(--hand-glow) / 28%)}.my-hand--purpose-active:before,.my-hand--purpose-active:after{animation:none;opacity:.8}}.actions--compact{padding:.65rem .85rem;margin-bottom:.5rem}.actions__compact-note{margin:0;font-size:.78rem;color:#64748b;text-align:center}.game-menu{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;display:flex;align-items:flex-end;justify-content:center;padding:1rem}.game-menu__backdrop{position:absolute;top:0;right:0;bottom:0;left:0;border:none;background:#0f172a73;cursor:pointer}.game-menu__panel{position:relative;width:min(100%,480px);max-height:min(85vh,640px);min-height:0;background:#fff;border-radius:16px 16px 12px 12px;box-shadow:0 16px 48px #0003;display:flex;flex-direction:column;overflow:hidden}.game-menu__header{display:flex;align-items:flex-start;justify-content:space-between;gap:.75rem;padding:1rem 1rem .65rem;border-bottom:1px solid #e2e8f0;flex-shrink:0}.game-menu__label{margin:0;font-size:.7rem;color:#64748b;font-weight:600}.game-menu__code{margin:.1rem 0 0;font-size:1.35rem;font-weight:800;letter-spacing:.12em}.game-menu__close{width:auto;min-width:0;padding:.4rem .65rem;margin:0;font-size:.8rem}.game-menu__actions{display:grid;gap:.45rem;padding:.75rem 1rem;flex-shrink:0}.game-menu__actions button{margin-top:0}.game-menu__advance{background:#f59e0b}.game-menu__leave{background:#dc2626;color:#fff;border:none}.game-menu__leave:hover{background:#b91c1c}.game-menu__leave-confirm{display:grid;gap:.5rem;padding:.65rem .75rem;border-radius:10px;border:1px solid #fecaca;background:#fef2f2}.game-menu__leave-confirm-text{margin:0;font-size:.88rem;font-weight:700;color:#991b1b;text-align:center}.game-menu__leave-confirm-actions{display:grid;gap:.4rem}.game-menu__extra{flex:1;min-height:0;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;padding:0 1rem 1rem;display:grid;gap:.5rem;align-content:start}.collapsible{border:1px solid #e2e8f0;border-radius:10px;background:#f8fafc;overflow:hidden}.collapsible__toggle{width:100%;display:flex;align-items:center;gap:.5rem;padding:.55rem .75rem;margin:0;background:transparent;color:#1e293b;font-size:.85rem;font-weight:700;text-align:left;border-radius:0}.collapsible__title{flex:1;min-width:0}.collapsible__badge{font-size:.7rem;padding:.1rem .45rem;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-weight:700}.collapsible__chevron{font-size:.65rem;color:#94a3b8}.collapsible__body{padding:0 .75rem .75rem;border-top:1px solid #e2e8f0;background:#fff}.game-menu__extra .collapsible__body{max-height:min(40vh,260px);overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.game-menu__extra .collapsible{min-height:0}.collapsible__body .seat-order{margin:.5rem 0 0;border:none;padding:0;background:transparent}.collapsible__body .seat-order__track{max-height:none}.field-cards--compact{margin:.35rem 0 0}.field-cards--compact .field-cards__pair{justify-content:center}.activity-log--menu{max-height:200px;margin:.35rem 0 0;border:none;padding:0}.activity-log--menu ul{margin:0;padding:0}
