:root{--play-bg: #312e2b;--play-bg-dark: #272522;--play-surface: #3d3a37;--play-surface-hover: #48453f;--play-surface-active: #524e48;--play-sidebar-bg: #262421;--play-panel-bg: rgba(48, 46, 43, .92);--play-panel-header: #21201e;--play-board-light: #ebecd0;--play-board-dark: #779556;--play-board-highlight: rgba(255, 255, 50, .4);--play-accent: #81b64c;--play-accent-hover: #95c960;--play-accent-dark: #629a2e;--play-text: #e0ddd5;--play-text-muted: #9e9b93;--play-text-dim: #7b7874;--play-border: rgba(255, 255, 255, .08);--play-border-active: rgba(129, 182, 76, .5);--play-danger: #e05555;--play-danger-hover: #e86d6d;--play-warning: #e8a73e;--play-info: #5ca8d4;--play-win: #81b64c;--play-loss: #e05555;--play-draw: #b0a890;--play-radius: 6px;--play-radius-lg: 10px;--play-shadow: 0 2px 10px rgba(0, 0, 0, .35);--play-shadow-lg: 0 6px 28px rgba(0, 0, 0, .45);--play-font: "Segoe UI", Arial, Helvetica, sans-serif;--play-font-mono: "Consolas", "Courier New", monospace;--play-sidebar-width: 52px;--play-sidebar-expanded: 200px;--play-panel-width: 380px;--play-clock-font: var(--play-font-mono);--play-transition: .15s ease}.play-page{display:flex;height:100vh;overflow:hidden;background:var(--play-bg);color:var(--play-text);font-family:var(--play-font);font-size:14px}.play-sidebar{width:var(--play-sidebar-expanded);min-width:var(--play-sidebar-expanded);background:var(--play-sidebar-bg);display:flex;flex-direction:column;border-right:1px solid var(--play-border);overflow-y:auto;overflow-x:hidden;z-index:10}.play-sidebar__brand{display:flex;align-items:center;gap:10px;padding:14px 16px;text-decoration:none;color:var(--play-text);border-bottom:1px solid var(--play-border)}.play-sidebar__brand-icon{width:32px;height:32px;display:grid;place-items:center;border-radius:6px;background:linear-gradient(135deg,#81b64c,#5a9e2e);color:#fff;font-size:18px;font-weight:700;flex-shrink:0}.play-sidebar__brand-text{display:flex;flex-direction:column;line-height:1.2}.play-sidebar__brand-text strong{font-size:15px;letter-spacing:-.01em}.play-sidebar__brand-text small{font-size:10px;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.06em}.play-sidebar__nav{flex:1;padding:8px 0}.play-sidebar__link{display:flex;align-items:center;gap:12px;padding:10px 16px;text-decoration:none;color:var(--play-text-muted);font-size:14px;font-weight:500;transition:background var(--play-transition),color var(--play-transition);border-left:3px solid transparent}.play-sidebar__link:hover{background:var(--play-surface);color:var(--play-text)}.play-sidebar__link--active{color:#fff;background:#81b64c1f;border-left-color:var(--play-accent)}.play-sidebar__link-icon{font-size:18px;width:24px;text-align:center;flex-shrink:0}.play-sidebar__link-label{display:flex;flex-direction:column;line-height:1.3}.play-sidebar__link-label small{font-size:11px;color:var(--play-text-dim);font-weight:400}.play-sidebar__divider{height:1px;background:var(--play-border);margin:6px 16px}.play-sidebar__search{padding:8px 12px}.play-sidebar__search input{width:100%;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius);color:var(--play-text);padding:7px 10px;font-size:13px;font-family:inherit;outline:none;transition:border-color var(--play-transition)}.play-sidebar__search input::placeholder{color:var(--play-text-dim)}.play-sidebar__search input:focus{border-color:var(--play-accent)}.play-sidebar__user{padding:12px 16px;border-top:1px solid var(--play-border);display:flex;align-items:center;gap:10px}.play-sidebar__avatar{width:32px;height:32px;border-radius:4px;background:var(--play-surface);display:grid;place-items:center;font-size:16px;flex-shrink:0}.play-sidebar__user-info{display:flex;flex-direction:column;overflow:hidden}.play-sidebar__user-name{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-sidebar__user-status{font-size:11px;color:var(--play-accent);display:flex;align-items:center;gap:4px}.play-sidebar__user-status:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--play-accent)}.play-main{flex:1;display:flex;min-width:0}.play-board-area{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 16px;min-width:0;position:relative;overflow-y:auto}.play-board-container{width:min(100%,calc(100vh - 100px));max-width:720px;display:flex;flex-direction:column;gap:4px}.play-player-bar{display:flex;align-items:center;gap:12px;padding:8px 12px;background:var(--play-bg-dark);border-radius:var(--play-radius)}.play-player-bar__avatar{width:42px;height:42px;border-radius:6px;background:var(--play-surface);display:grid;place-items:center;font-size:22px;flex-shrink:0;overflow:hidden}.play-player-bar__info{flex:1;min-width:0}.play-player-bar__name{font-weight:600;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-player-bar__rating{font-size:13px;color:var(--play-text-muted)}.play-player-bar__captured{display:flex;align-items:center;gap:1px;font-size:13px;color:var(--play-text-muted);margin-left:auto}.play-player-bar__clock{font-family:var(--play-clock-font);font-size:28px;font-weight:700;padding:6px 16px;border-radius:var(--play-radius);min-width:100px;text-align:center;flex-shrink:0;transition:background var(--play-transition),color var(--play-transition)}.play-player-bar__clock--active{background:#fff;color:#000;box-shadow:0 0 12px #ffffff26}.play-player-bar__clock--inactive{background:var(--play-surface);color:var(--play-text-muted)}.play-player-bar__clock--low{background:var(--play-danger);color:#fff;animation:clock-pulse 1s ease-in-out infinite}@keyframes clock-pulse{0%,to{opacity:1}50%{opacity:.7}}.play-board-wrap{position:relative;width:100%;border-radius:10px;overflow:hidden;isolation:isolate;contain:paint;border:1.5px solid rgba(255,255,255,.22);box-shadow:0 0 18px #81b64c2e,0 0 40px #58e8bc14,0 8px 32px #00000073,inset 0 1px #ffffff1f;transform:none;transition:box-shadow .4s ease}.play-board-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:2;pointer-events:none;border-radius:inherit;background:linear-gradient(135deg,rgba(255,255,255,.1) 0%,rgba(255,255,255,.03) 40%,transparent 60%,rgba(255,255,255,.04) 100%)}.play-board-wrap:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;z-index:3;pointer-events:none;background:radial-gradient(120% 65% at 50% -10%,rgba(255,255,255,.06) 0%,rgba(255,255,255,.02) 45%,transparent 72%);opacity:.65}.play-board-wrap:hover{transform:none;box-shadow:0 0 24px #81b64c47,0 0 60px #58e8bc1f,0 12px 40px #00000080,inset 0 1px #ffffff2e}.play-board-wrap--disabled{opacity:.85}.play-piece-node{pointer-events:none}.play-piece-image{pointer-events:none;backface-visibility:hidden;image-rendering:auto}.play-live-result-overlay{position:absolute;top:0;right:0;bottom:0;left:0;z-index:9;display:flex;align-items:center;justify-content:center;padding:clamp(10px,2vw,20px);background:linear-gradient(180deg,#040a122e,#040a1294);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.play-live-result-overlay__card{width:min(92%,420px);border-radius:16px;border:1px solid rgba(130,214,255,.4);background:linear-gradient(160deg,#081c36e6,#071120f5);box-shadow:0 16px 48px #00000080,0 0 32px #48c4ff26;padding:clamp(12px,2.4vw,18px);color:#eaf6ff;text-align:center}.play-live-result-overlay__badge{display:inline-flex;align-items:center;justify-content:center;min-width:70px;padding:4px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.28);background:#ffffff14;font-size:12px;font-weight:700;letter-spacing:.08em}.play-live-result-overlay__title{margin:10px 0 0;font-size:clamp(1.1rem,2.5vw,1.45rem);line-height:1.2}.play-live-result-overlay__reason{margin:6px 0 0;color:#dfedffeb;font-size:clamp(.84rem,1.8vw,.95rem)}.play-live-result-overlay__delta{display:inline-block;margin-top:9px;padding:5px 10px;border-radius:10px;font-weight:700;background:#ffffff14}.play-live-result-overlay__delta--up{color:#9ff5b2;background:#58d6802e}.play-live-result-overlay__delta--down{color:#ffb6b6;background:#ff737333}.play-live-result-overlay__actions{margin-top:12px;display:flex;flex-direction:column;gap:8px}.play-live-result-overlay__status{font-size:12px;color:#d1e5f8f5}.play-live-result-overlay__rematch-btn{width:100%;border:none;border-radius:12px;padding:11px 12px;font-weight:800;letter-spacing:.01em;cursor:pointer;color:#041428;background:linear-gradient(120deg,#55f4cb,#67e0ff);box-shadow:0 0 0 1px #12204059 inset,0 8px 26px #54f0cf57;transition:transform .12s ease,filter .12s ease}.play-live-result-overlay__rematch-btn:hover{transform:translateY(-1px);filter:brightness(1.02)}.play-live-result-overlay__rematch-btn:active{transform:translateY(0)}.play-live-result-overlay__ghost-btn,.play-live-result-overlay__link-btn{border-radius:10px;border:1px solid rgba(134,184,225,.4);background:#061426bf;color:#ddecfb;font-size:12px;font-weight:700;padding:8px 10px;cursor:pointer}.play-live-result-overlay__quick-links{margin-top:10px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.play-panel{width:var(--play-panel-width);min-width:var(--play-panel-width);background:var(--play-panel-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-left:1px solid var(--play-border);display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;box-shadow:-2px 0 16px #00000026}.play-panel__tabs{display:flex;border-bottom:1px solid var(--play-border);background:var(--play-panel-header)}.play-panel__tab{flex:1;padding:12px 8px;display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;color:var(--play-text-muted);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;border-bottom:2px solid transparent;transition:color var(--play-transition),border-color var(--play-transition)}.play-panel__tab:hover{color:var(--play-text)}.play-panel__tab--active{color:#fff;border-bottom-color:var(--play-accent)}.play-panel__tab-icon{font-size:16px}.play-panel__body{flex:1;overflow-y:auto;padding:0}.play-newgame{padding:0}.play-tc-selector{padding:12px 16px;border-bottom:1px solid var(--play-border)}.play-tc-selector__btn{width:100%;display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius-lg);color:var(--play-text);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:border-color var(--play-transition)}.play-tc-selector__btn:hover{border-color:var(--play-accent)}.play-tc-selector__btn-icon{margin-right:8px;font-size:16px}.play-tc-selector__chevron{font-size:12px;color:var(--play-text-muted);transition:transform var(--play-transition)}.play-tc-selector__chevron--open{transform:rotate(180deg)}.play-options-row{display:flex;gap:8px;padding:8px 16px;border-bottom:1px solid var(--play-border)}.play-variant-select{flex:1;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius-lg);color:var(--play-text);padding:8px 12px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-align:center}.play-rated-toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--play-text)}.play-rated-toggle__switch{width:40px;height:22px;border-radius:11px;background:var(--play-surface);border:none;cursor:pointer;position:relative;transition:background var(--play-transition);flex-shrink:0}.play-rated-toggle__switch--on{background:var(--play-accent)}.play-rated-toggle__switch:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform var(--play-transition)}.play-rated-toggle__switch--on:after{transform:translate(18px)}.play-tc-grid{padding:8px 16px 12px}.play-tc-category{margin-bottom:8px}.play-tc-category__label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:700;color:var(--play-text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.play-tc-category__icon{font-size:14px}.play-tc-category__buttons{display:flex;gap:6px;flex-wrap:wrap}.play-tc-pill{padding:8px 16px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--play-transition);white-space:nowrap}.play-tc-pill:hover{background:var(--play-surface-hover);border-color:#ffffff26;transform:translateY(-1px)}.play-tc-pill--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-tc-more{display:flex;align-items:center;justify-content:center;gap:4px;padding:8px;background:none;border:none;color:var(--play-text-muted);font-size:12px;font-family:inherit;cursor:pointer;width:100%}.play-tc-more:hover{color:var(--play-text)}.play-start-btn{display:block;width:calc(100% - 32px);margin:10px 16px;padding:16px 24px;border:none;border-radius:var(--play-radius-lg);background:linear-gradient(180deg,#81b64c,#629a2e);color:#fff;font-size:17px;font-weight:700;font-family:inherit;cursor:pointer;text-align:center;transition:filter var(--play-transition),transform var(--play-transition),box-shadow var(--play-transition);box-shadow:0 3px 12px #629a2e59}.play-start-btn:hover{filter:brightness(1.08);transform:translateY(-2px);box-shadow:0 5px 18px #629a2e73}.play-start-btn:active{transform:translateY(0)}.play-start-btn:disabled{opacity:.6;cursor:not-allowed;transform:none;filter:saturate(.5)}.play-start-btn--searching{background:linear-gradient(180deg,#5a9e2e,#4a8526);animation:search-pulse 2s ease-in-out infinite}@keyframes search-pulse{0%,to{box-shadow:0 3px 12px #629a2e59}50%{box-shadow:0 3px 24px #629a2ea6}}.play-menu-list{padding:6px 16px 14px;display:flex;flex-direction:column;gap:6px}.play-menu-btn{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius-lg);color:var(--play-text);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;text-decoration:none;transition:background var(--play-transition),border-color var(--play-transition),transform var(--play-transition)}.play-menu-btn:hover{background:var(--play-surface-hover);border-color:#ffffff26;transform:translateY(-1px)}.play-menu-btn__icon{font-size:20px;width:26px;text-align:center;flex-shrink:0}.play-stats-footer{padding:10px 16px;border-top:1px solid var(--play-border);display:flex;align-items:center;justify-content:center;gap:16px;font-size:12px;color:var(--play-text-muted);margin-top:auto}.play-stats-footer__item{display:flex;align-items:center;gap:4px}.play-stats-footer__item strong{color:var(--play-text)}.play-games-panel{padding:12px 16px}.play-games-panel__header{font-size:13px;font-weight:700;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}.play-game-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:var(--play-radius);transition:background var(--play-transition);cursor:pointer}.play-game-row:hover{background:var(--play-surface)}.play-game-row__result{width:24px;height:24px;border-radius:3px;display:grid;place-items:center;font-size:12px;font-weight:700;flex-shrink:0}.play-game-row__result--W{background:var(--play-win);color:#fff}.play-game-row__result--L{background:var(--play-loss);color:#fff}.play-game-row__result--D{background:var(--play-draw);color:#333}.play-game-row__opponent{flex:1;font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-game-row__meta{font-size:12px;color:var(--play-text-dim)}.play-players-panel{padding:0}.play-players-panel__tabs{display:flex;border-bottom:1px solid var(--play-border)}.play-players-panel__tab{flex:1;padding:10px 8px;background:none;border:none;color:var(--play-text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;border-bottom:2px solid transparent;transition:color var(--play-transition)}.play-players-panel__tab:hover{color:var(--play-text)}.play-players-panel__tab--active{color:#fff;border-bottom-color:var(--play-accent)}.play-players-panel__search{padding:8px 12px}.play-players-panel__search input{width:100%;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius);color:var(--play-text);padding:7px 10px 7px 30px;font-size:13px;font-family:inherit;outline:none;background-image:url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%237b7874' viewBox='0 0 16 16'%3e%3cpath d='M11.742 10.344a6.5 6.5 0 1 0-1.397 1.398h-.001c.03.04.062.078.098.115l3.85 3.85a1 1 0 0 0 1.415-1.414l-3.85-3.85a1.007 1.007 0 0 0-.115-.1zM12 6.5a5.5 5.5 0 1 1-11 0 5.5 5.5 0 0 1 11 0z'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:8px center}.play-players-panel__search input:focus{border-color:var(--play-accent)}.play-player-row{display:flex;align-items:center;gap:8px;padding:6px 12px;transition:background var(--play-transition);cursor:pointer}.play-player-row:hover{background:var(--play-surface)}.play-player-row__badge{font-size:11px;font-weight:700;color:var(--play-warning);width:22px;flex-shrink:0}.play-player-row__name{flex:1;font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.play-player-row__rating{font-size:12px;color:var(--play-text-muted);font-weight:600}.play-player-row__status{font-size:11px;padding:2px 8px;border-radius:999px;font-weight:600}.play-player-row__status--online{background:#81b64c26;color:var(--play-accent)}.play-player-row__status--playing{background:#5ca8d426;color:var(--play-info)}.play-live-layout{display:flex;height:100vh;overflow:hidden;background:var(--play-bg);color:var(--play-text);font-family:var(--play-font)}.play-game-info{width:var(--play-panel-width);min-width:var(--play-panel-width);background:var(--play-panel-bg);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-left:1px solid var(--play-border);display:flex;flex-direction:column;box-shadow:-2px 0 16px #00000026}.play-game-info__header{padding:10px 14px;border-bottom:1px solid var(--play-border);background:var(--play-panel-header)}.play-game-info__meta{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--play-text-muted)}.play-game-info__meta strong{color:var(--play-text)}.play-move-list{flex:1;overflow-y:auto;padding:0}.play-move-list__row{display:grid;grid-template-columns:32px 1fr 1fr;font-size:13px;border-bottom:1px solid rgba(255,255,255,.03)}.play-move-list__row:nth-child(odd){background:#ffffff05}.play-move-list__num{padding:6px 8px;color:var(--play-text-dim);font-weight:600;text-align:right}.play-move-list__white,.play-move-list__black{padding:6px 10px;font-weight:500;cursor:pointer;transition:background var(--play-transition)}.play-move-list__white:hover,.play-move-list__black:hover{background:var(--play-surface)}.play-move-list__current{background:#81b64c33!important}.play-game-controls{padding:12px 14px;border-top:1px solid var(--play-border);display:flex;gap:8px;flex-wrap:wrap}.play-ctrl-btn{flex:1;min-width:0;padding:10px 16px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--play-transition);white-space:nowrap}.play-ctrl-btn:hover{background:var(--play-surface-hover);transform:translateY(-1px);box-shadow:0 2px 6px #0003}.play-ctrl-btn--danger{border-color:#e055554d}.play-ctrl-btn--danger:hover{background:#e0555526;border-color:#e0555580}.play-ctrl-btn--accent{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-ctrl-btn--accent:hover{background:var(--play-accent)}.play-ctrl-btn:disabled{opacity:.4;cursor:not-allowed;transform:none;box-shadow:none}.play-chat-panel{display:flex;flex-direction:column;flex:1;min-height:0}.play-chat-messages{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:4px}.play-chat-msg{font-size:13px;line-height:1.4;padding:4px 0}.play-chat-msg__sender{font-weight:700;color:var(--play-accent);margin-right:6px}.play-chat-input{display:flex;gap:6px;padding:8px 12px;border-top:1px solid var(--play-border)}.play-chat-input input{flex:1;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius);color:var(--play-text);padding:7px 10px;font-size:13px;font-family:inherit;outline:none}.play-chat-input input:focus{border-color:var(--play-accent)}.play-chat-input button{padding:7px 14px;background:var(--play-accent-dark);border:none;border-radius:var(--play-radius);color:#fff;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer}.play-info-tabs{display:flex;border-bottom:1px solid var(--play-border)}.play-info-tab{flex:1;padding:10px 8px;background:none;border:none;border-bottom:2px solid transparent;color:var(--play-text-muted);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;text-align:center;transition:color var(--play-transition)}.play-info-tab:hover{color:var(--play-text)}.play-info-tab--active{color:#fff;border-bottom-color:var(--play-accent)}.play-connection-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;padding:3px 8px;border-radius:999px}.play-connection-badge--connected{background:#81b64c26;color:var(--play-accent)}.play-connection-badge--reconnecting{background:#e8a73e26;color:var(--play-warning)}.play-connection-badge--disconnected{background:#e0555526;color:var(--play-danger)}.play-connection-badge__dot{width:6px;height:6px;border-radius:50%;background:currentColor}.play-latency-badge{font-size:11px;color:var(--play-text-dim);font-family:var(--play-font-mono)}.play-result{max-width:680px;margin:0 auto;padding:40px 24px;text-align:center}.play-result__hero{margin-bottom:24px}.play-result__icon{font-size:56px;margin-bottom:12px}.play-result__title{font-size:32px;font-weight:700;margin:0 0 6px}.play-result__title--victory{color:var(--play-win)}.play-result__title--defeat{color:var(--play-loss)}.play-result__title--draw{color:var(--play-draw)}.play-result__reason{font-size:14px;color:var(--play-text-muted);margin:0}.play-result__rating{display:inline-flex;align-items:center;gap:8px;margin-top:12px;padding:8px 16px;border-radius:var(--play-radius-lg);background:var(--play-surface);font-size:16px;font-weight:700}.play-result__rating--up{color:var(--play-win)}.play-result__rating--down{color:var(--play-loss)}.play-result__rating--flat{color:var(--play-draw)}.play-result__cards{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin:20px 0;text-align:left}.play-result__card{background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius-lg);padding:14px}.play-result__card-title{font-size:12px;font-weight:700;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 8px;display:flex;align-items:center;gap:6px}.play-result__card-row{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.play-result__card-row span:first-child{color:var(--play-text-muted)}.play-result__pgn{background:var(--play-bg-dark);border:1px solid var(--play-border);border-radius:var(--play-radius);padding:10px;font-family:var(--play-font-mono);font-size:12px;color:var(--play-text-muted);white-space:pre-wrap;word-break:break-all;max-height:120px;overflow-y:auto;margin-top:8px;text-align:left}.play-result__actions{display:flex;gap:8px;justify-content:center;flex-wrap:wrap}.play-computer-settings{padding:16px}.play-computer-section{margin-bottom:20px}.play-computer-section__title{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:700;margin-bottom:12px}.play-computer-section__title-icon{font-size:18px}.play-computer-difficulty-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.play-computer-difficulty-actions{display:flex;gap:6px;flex-wrap:wrap;flex:1 1 auto}.play-start-btn--inline{width:auto;margin:0;padding:10px 14px;border-radius:12px;font-size:13px;line-height:1.2;box-shadow:0 2px 10px #629a2e4d;white-space:nowrap}@media (max-width: 640px){.play-computer-difficulty-actions{width:100%}.play-start-btn--inline{width:100%;display:flex;justify-content:center}}.play-level-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:6px;margin-top:10px}.play-level-chip{display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 4px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text);font-size:12px;font-weight:600;cursor:pointer;transition:all var(--play-transition)}.play-level-chip:hover{background:var(--play-surface-hover)}.play-level-chip--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-level-chip__icon{font-size:20px}.play-range-slider{width:100%;height:4px;border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--play-surface);outline:none;margin:8px 0}.play-range-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:var(--play-accent);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px #0000004d}.play-range-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--play-accent);cursor:pointer;border:2px solid #fff;box-shadow:0 1px 4px #0000004d}.play-banner{padding:8px 14px;font-size:13px;display:flex;align-items:center;gap:6px}.play-banner--info{background:#5ca8d41a;color:var(--play-info);border-bottom:1px solid rgba(92,168,212,.2)}.play-banner--error{background:#e055551a;color:var(--play-danger);border-bottom:1px solid rgba(224,85,85,.2)}.play-banner--warning{background:#e8a73e1a;color:var(--play-warning);border-bottom:1px solid rgba(232,167,62,.2)}.play-banner--success{background:#81b64c1a;color:var(--play-accent);border-bottom:1px solid rgba(129,182,76,.2)}.play-opening-badge{font-size:12px;color:var(--play-text-muted);padding:4px 8px;background:#ffffff08;border-radius:var(--play-radius);display:inline-block}.play-interaction-hint{text-align:center;font-size:12px;color:var(--play-text-dim);padding:4px 0;margin:0}.play-queue-info{padding:8px 16px;font-size:12px;color:var(--play-text-muted);display:flex;gap:12px;justify-content:center}.play-queue-proposal{margin:10px 16px 0;padding:12px;border-radius:14px;border:1px solid color-mix(in srgb,var(--play-accent) 44%,transparent);background:linear-gradient(145deg,color-mix(in srgb,var(--play-accent) 20%,#07182d 80%),color-mix(in srgb,#0b1320 70%,#000 30%));box-shadow:inset 0 1px #ffffff29,0 10px 20px #00000038}.play-queue-proposal__title{font-size:14px;font-weight:800;color:#f3fbff}.play-queue-proposal__text{margin-top:4px;font-size:12px;color:#e9f3ffeb}.play-queue-proposal__actions{display:flex;gap:8px;margin-top:10px}.play-queue-proposal__btn{flex:1;border-radius:999px;border:1px solid rgba(255,255,255,.2);padding:8px 10px;font-size:13px;font-weight:700;cursor:pointer;transition:transform .12s ease,filter .12s ease}.play-queue-proposal__btn:hover{filter:brightness(1.08);transform:translateY(-1px)}.play-queue-proposal__btn:disabled{opacity:.65;cursor:default;transform:none}.play-queue-proposal__btn--accept{background:linear-gradient(135deg,#74e9ec,#5fd9ff);color:#032036}.play-queue-proposal__btn--ignore{background:#070d18b8;color:#ebf4ff}.play-challenge-section{padding:12px 16px;border-top:1px solid var(--play-border)}.play-challenge-section__toggle{width:100%;display:flex;align-items:center;justify-content:space-between;padding:8px 0;background:none;border:none;color:var(--play-text);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer}.play-challenge-body{padding-top:8px}.play-challenge-row{display:flex;gap:8px;margin-bottom:8px}.play-challenge-row select{flex:1;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius);color:var(--play-text);padding:6px 10px;font-size:13px;font-family:inherit}.play-seek-panel{padding:12px 16px;border-top:1px solid var(--play-border)}.play-seek-section{margin-bottom:14px}.play-seek-section__label{font-size:11px;font-weight:700;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.06em;margin-bottom:8px}.play-seek-section__row{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.play-seek-mode-toggle{display:flex;gap:6px}.play-seek-mode-pill{flex:1;padding:8px 12px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text-muted);font-size:13px;font-weight:600;cursor:pointer;transition:all var(--play-transition);font-family:inherit;text-align:center}.play-seek-mode-pill:hover{background:var(--play-surface-hover);color:var(--play-text)}.play-seek-mode-pill--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-seek-tc-grid{display:flex;flex-direction:column;gap:10px}.play-seek-tc-group__label{font-size:11px;font-weight:700;color:var(--play-text-dim);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}.play-seek-tc-group__pills{display:flex;flex-wrap:wrap;gap:4px}.play-seek-side-picker{display:flex;gap:6px}.play-seek-side-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text-muted);cursor:pointer;transition:all var(--play-transition);font-family:inherit}.play-seek-side-btn:hover{background:var(--play-surface-hover);color:var(--play-text)}.play-seek-side-btn--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-seek-side-btn__icon{font-size:22px}.play-seek-side-btn__label{font-size:11px;font-weight:600}.play-seek-rating-range{padding:4px 0}.play-seek-rating-range__row{margin-bottom:6px}.play-seek-rating-range__row label{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--play-text-muted)}.play-seek-rating-range__row label span:first-child{width:28px;font-weight:600;text-align:right}.play-seek-rating-range__value{min-width:40px;text-align:right;font-family:var(--play-font-mono);font-weight:700;color:var(--play-accent)}.play-seek-toggle-chip{padding:3px 10px;border-radius:999px;background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text-dim);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:all var(--play-transition);font-family:inherit}.play-seek-toggle-chip--on{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-seek-active-info{display:flex;align-items:center;gap:8px;padding:8px 12px;margin-top:8px;background:#81b64c14;border:1px solid rgba(129,182,76,.2);border-radius:var(--play-radius);font-size:12px;color:var(--play-accent);font-weight:600}.play-seek-active-info__dot{width:8px;height:8px;border-radius:50%;background:var(--play-accent);animation:play-pulse 1.5s ease-in-out infinite}@keyframes play-pulse{0%,to{opacity:1}50%{opacity:.3}}.play-range-slider{flex:1;height:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:var(--play-border);border-radius:2px;outline:none;cursor:pointer}.play-range-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--play-accent);border:2px solid var(--play-surface);cursor:pointer}.play-range-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--play-accent);border:2px solid var(--play-surface);cursor:pointer}.play-tc-more{padding:4px 8px;margin-top:6px;background:none;border:none;color:var(--play-text-dim);font-size:11px;font-weight:600;cursor:pointer;font-family:inherit;transition:color var(--play-transition)}.play-tc-more:hover{color:var(--play-accent)}.play-request-list{margin-top:8px}.play-request-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;background:var(--play-surface);border-radius:var(--play-radius);margin-bottom:4px;font-size:13px}.play-request-item__actions{display:flex;gap:4px}.play-request-item__btn{padding:4px 10px;border-radius:var(--play-radius);border:1px solid var(--play-border);background:none;color:var(--play-text);font-size:12px;font-weight:600;font-family:inherit;cursor:pointer}.play-request-item__btn--accept{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-empty-state{padding:32px 20px;text-align:center;color:var(--play-text-muted)}.play-empty-state__icon{font-size:40px;margin-bottom:12px}.play-empty-state__title{font-size:16px;font-weight:700;color:var(--play-text);margin:0 0 6px}.play-empty-state__text{font-size:13px;margin:0}.play-loading{display:flex;align-items:center;justify-content:center;padding:40px;color:var(--play-text-muted);font-size:14px}.play-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:700}.play-badge--live{background:#e0555526;color:var(--play-danger)}.play-badge--active{background:#81b64c26;color:var(--play-accent)}@media (max-width: 1200px){.play-panel,.play-game-info{width:340px;min-width:340px}.play-board-container{max-width:640px}}@media (max-width: 900px){.play-page,.play-live-layout{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.play-sidebar{width:100%;min-width:100%;flex-direction:row;overflow-x:auto;border-right:none;border-bottom:1px solid var(--play-border)}.play-sidebar__brand-text,.play-sidebar__search,.play-sidebar__divider,.play-sidebar__link-label small{display:none}.play-sidebar__nav{display:flex;flex-direction:row;padding:0;flex:1}.play-sidebar__link{padding:8px 12px;border-left:none;border-bottom:2px solid transparent;flex-direction:column;gap:2px;font-size:11px;text-align:center}.play-sidebar__link--active{border-bottom-color:var(--play-accent)}.play-sidebar__user{border-top:none;border-left:1px solid var(--play-border);padding:8px 12px}.play-main{flex-direction:column}.play-panel,.play-game-info{width:100%;min-width:100%;border-left:none;border-top:1px solid var(--play-border);max-height:50vh;backdrop-filter:none;-webkit-backdrop-filter:none;box-shadow:0 -2px 12px #00000026;background:var(--play-bg-dark)}.play-board-container{max-width:85vw;width:min(85vw,calc(100vh - 200px))}}@media (max-width: 600px){.play-player-bar__clock{font-size:18px;padding:3px 8px;min-width:70px}.play-result__cards{grid-template-columns:1fr}.play-level-grid{grid-template-columns:repeat(5,1fr);gap:4px}}.play-settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:#0000008c;display:flex;align-items:center;justify-content:center;animation:play-overlay-in .2s ease-out}@keyframes play-overlay-in{0%{opacity:0}to{opacity:1}}.play-settings-panel{width:460px;max-width:95vw;max-height:85vh;background:var(--play-bg-dark);border-radius:12px;box-shadow:0 8px 40px #00000080,0 0 0 1px #ffffff0f;display:flex;flex-direction:column;overflow:hidden}.play-settings-tabs{display:flex;background:var(--play-panel-header);border-bottom:1px solid var(--play-border)}.play-settings-tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:14px 8px 12px;background:none;border:none;border-bottom:2px solid transparent;color:var(--play-text-muted);font-size:11px;font-weight:600;font-family:inherit;cursor:pointer;transition:color var(--play-transition),border-color var(--play-transition)}.play-settings-tab:hover{color:var(--play-text)}.play-settings-tab--active{color:#fff;border-bottom-color:var(--play-accent)}.play-settings-tab__icon{font-size:20px}.play-settings-tab__label{text-transform:capitalize;letter-spacing:.02em}.play-settings-subtabs{display:flex;border-bottom:1px solid var(--play-border);background:var(--play-bg-dark)}.play-settings-subtab{flex:1;padding:10px 8px;background:none;border:none;border-bottom:2px solid transparent;color:var(--play-text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-align:center;transition:color var(--play-transition),border-color var(--play-transition)}.play-settings-subtab:hover{color:var(--play-text)}.play-settings-subtab--active{color:#fff;border-bottom-color:var(--play-accent)}.play-settings-content{flex:1;overflow-y:auto;min-height:0}.play-settings-body{padding:4px 0}.play-settings-row{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.04);transition:background var(--play-transition)}.play-settings-row:hover{background:#ffffff05}.play-settings-row__label{font-size:14px;font-weight:500;color:var(--play-text);display:flex;align-items:center;gap:6px}.play-settings-row__tooltip{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;font-size:11px;border-radius:50%;background:var(--play-surface);color:var(--play-text-muted);cursor:help;flex-shrink:0}.play-settings-toggle{width:44px;height:24px;border-radius:12px;background:var(--play-surface);border:none;cursor:pointer;position:relative;transition:background .2s ease;flex-shrink:0}.play-settings-toggle--on{background:var(--play-accent)}.play-settings-toggle__knob{position:absolute;top:3px;left:3px;width:18px;height:18px;border-radius:50%;background:#fff;transition:transform .2s ease;pointer-events:none}.play-settings-toggle--on .play-settings-toggle__knob{transform:translate(20px)}.play-settings-select{min-width:140px;padding:7px 28px 7px 12px;background:var(--play-surface);border:1px solid var(--play-border);border-radius:var(--play-radius);color:var(--play-text);font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath d='M1 1l4 4 4-4' fill='none' stroke='%239e9b93' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;transition:border-color var(--play-transition)}.play-settings-select:hover,.play-settings-select:focus{border-color:var(--play-accent);outline:none}.play-settings-preview{padding:16px 20px 8px}.play-settings-preview__board{border-radius:4px;overflow:hidden;border:1px solid var(--play-border)}.play-settings-preview__row{display:flex}.play-settings-preview__square{width:12.5%;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.play-settings-preview__piece{font-size:clamp(14px,3vw,22px);line-height:1;filter:drop-shadow(0 1px 1px rgba(0,0,0,.3))}.play-settings-footer{display:flex;gap:10px;padding:14px 20px;border-top:1px solid var(--play-border);background:var(--play-bg-dark)}.play-settings-footer__cancel,.play-settings-footer__save{flex:1;padding:12px 16px;border:none;border-radius:var(--play-radius-lg);font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:filter var(--play-transition),transform var(--play-transition)}.play-settings-footer__cancel{background:var(--play-surface);color:var(--play-text)}.play-settings-footer__cancel:hover{filter:brightness(1.15)}.play-settings-footer__save{background:linear-gradient(180deg,#81b64c,#629a2e);color:#fff;box-shadow:0 2px 8px #629a2e4d}.play-settings-footer__save:hover{filter:brightness(1.08);transform:translateY(-1px)}.play-settings-footer__save:active{transform:translateY(0)}.play-sidebar__settings-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;margin-left:auto;background:var(--play-surface);border:1px solid var(--play-border);border-radius:8px;color:var(--play-text-muted);font-size:18px;cursor:pointer;transition:background var(--play-transition),color var(--play-transition),transform .3s ease}.play-sidebar__settings-btn:hover{background:var(--play-surface-hover);color:var(--play-text);transform:rotate(45deg)}@media (max-width: 500px){.play-settings-panel{width:100vw;max-width:100vw;max-height:100vh;border-radius:0}.play-settings-row{padding:12px 14px}.play-settings-select{min-width:110px}}@keyframes play-fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.play-animate-in{animation:play-fade-in .2s ease-out}@media (prefers-reduced-motion: reduce){.play-animate-in,.play-start-btn--searching,.play-player-bar__clock--low,.play-settings-overlay{animation:none}.play-sidebar__settings-btn:hover{transform:none}}.play-friend-page{flex:1;display:flex;flex-direction:column;padding:20px 28px;overflow-y:auto;max-width:1100px;margin:0 auto;width:100%}.play-friend-page__header{margin-bottom:20px}.play-friend-back-btn{background:none;border:none;color:var(--play-text-muted);font-size:13px;font-family:inherit;cursor:pointer;padding:4px 0;margin-bottom:8px;transition:color var(--play-transition)}.play-friend-back-btn:hover{color:var(--play-accent)}.play-friend-page__title{font-size:24px;font-weight:700;color:var(--play-text);margin:0 0 4px}.play-friend-page__subtitle{font-size:14px;color:var(--play-text-muted);margin:0}.play-friend-layout{display:grid;grid-template-columns:1fr 360px;gap:20px;flex:1;min-height:0}.play-friend-list-panel{background:var(--play-panel-bg);border-radius:var(--play-radius-lg);border:1px solid var(--play-border);overflow-y:auto;max-height:calc(100vh - 200px)}.play-friend-section{padding:16px}.play-friend-section__title{font-size:13px;font-weight:700;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.04em;margin:0 0 12px;display:flex;align-items:center;gap:8px}.play-friend-online-dot{width:8px;height:8px;border-radius:50%;background:var(--play-accent);display:inline-block;box-shadow:0 0 6px #81b64c99}.play-friend-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.play-friend-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:var(--play-radius);transition:background var(--play-transition)}.play-friend-item:hover{background:var(--play-surface-hover)}.play-friend-item--offline{opacity:.55}.play-friend-item__info{display:flex;align-items:center;gap:12px;min-width:0}.play-friend-avatar{width:40px;height:40px;border-radius:8px;background:linear-gradient(135deg,var(--play-surface-active),var(--play-surface));display:grid;place-items:center;position:relative;flex-shrink:0}.play-friend-avatar__letter{font-size:18px;font-weight:700;color:var(--play-text)}.play-friend-avatar__dot{position:absolute;bottom:-2px;right:-2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--play-bg-dark)}.play-friend-avatar__dot--online{background:var(--play-accent);box-shadow:0 0 5px #81b64c80}.play-friend-item__name{font-size:14px;font-weight:600;color:var(--play-text)}.play-friend-item__meta{font-size:12px;color:var(--play-text-dim)}.play-friend-challenge-btn{padding:7px 16px;border:1px solid var(--play-accent-dark);border-radius:var(--play-radius);background:#81b64c1f;color:var(--play-accent);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--play-transition);white-space:nowrap}.play-friend-challenge-btn:hover{background:#81b64c40;border-color:var(--play-accent);transform:translateY(-1px)}.play-friend-challenge-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.play-friend-offline-label{font-size:12px;color:var(--play-text-dim);font-style:italic}.play-friend-loading,.play-friend-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;color:var(--play-text-muted)}.play-friend-empty__icon{font-size:48px;margin-bottom:12px}.play-friend-config-panel{background:var(--play-panel-bg);border-radius:var(--play-radius-lg);border:1px solid var(--play-border);padding:20px;display:flex;flex-direction:column;align-self:flex-start;position:sticky;top:20px}.play-friend-config__title{font-size:16px;font-weight:700;margin:0 0 18px;color:var(--play-text)}.play-friend-config__group{margin-bottom:16px}.play-friend-config__label{font-size:12px;font-weight:700;color:var(--play-text-muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:8px;display:block}.play-friend-config__row{display:flex;gap:8px}.play-friend-option-btn{flex:1;padding:10px 12px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-align:center;transition:all var(--play-transition)}.play-friend-option-btn:hover{background:var(--play-surface-hover);border-color:#ffffff26}.play-friend-option-btn--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-friend-config__tc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.play-friend-tc-btn{display:flex;flex-direction:column;align-items:center;gap:2px;padding:10px 8px;border-radius:var(--play-radius);background:var(--play-surface);border:1px solid var(--play-border);color:var(--play-text);font-family:inherit;cursor:pointer;transition:all var(--play-transition)}.play-friend-tc-btn:hover{background:var(--play-surface-hover);border-color:#ffffff26}.play-friend-tc-btn--active{background:var(--play-accent-dark);border-color:var(--play-accent);color:#fff}.play-friend-tc-btn__value{font-size:15px;font-weight:700}.play-friend-tc-btn__cat{font-size:10px;opacity:.7;text-transform:uppercase;letter-spacing:.04em}.play-friend-config__actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.play-friend-send-btn{padding:14px 24px;border:none;border-radius:var(--play-radius-lg);background:linear-gradient(180deg,#81b64c,#629a2e);color:#fff;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;text-align:center;transition:filter var(--play-transition),transform var(--play-transition),box-shadow var(--play-transition);box-shadow:0 3px 12px #629a2e59}.play-friend-send-btn:hover{filter:brightness(1.08);transform:translateY(-2px);box-shadow:0 5px 18px #629a2e73}.play-friend-cancel-btn{padding:10px 24px;border:1px solid var(--play-border);border-radius:var(--play-radius-lg);background:var(--play-surface);color:var(--play-text-muted);font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;text-align:center;transition:all var(--play-transition)}.play-friend-cancel-btn:hover{background:var(--play-surface-hover);color:var(--play-text)}.play-friend-waiting{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 20px;gap:12px}.play-friend-waiting h3{margin:0;font-size:16px;font-weight:700}.play-friend-waiting__spinner{width:48px;height:48px;border:3px solid var(--play-border);border-top-color:var(--play-accent);border-radius:50%;animation:friend-spinner .8s linear infinite}@keyframes friend-spinner{to{transform:rotate(360deg)}}.play-friend-result{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 20px;gap:8px}.play-friend-result__icon{font-size:40px;margin-bottom:4px}.play-friend-result h3{margin:0;font-size:18px;font-weight:700}.play-friend-result p{margin:0;color:var(--play-text-muted);font-size:14px}.play-friend-result--accepted .play-friend-result__icon{animation:accepted-bounce .5s ease-out}@keyframes accepted-bounce{0%{transform:scale(.5);opacity:0}60%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}.play-friend-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:48px 20px;color:var(--play-text-muted);min-height:200px}.play-friend-placeholder__icon{font-size:38px;margin-bottom:12px;opacity:.6}.play-friend-placeholder p{margin:2px 0}.play-friend-incoming{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.play-friend-incoming__card{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 18px;background:linear-gradient(135deg,#81b64c26,#81b64c0d);border:1px solid rgba(129,182,76,.35);border-radius:var(--play-radius-lg);animation:incoming-slide-in .3s ease-out}@keyframes incoming-slide-in{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.play-friend-incoming__info{display:flex;align-items:center;gap:12px}.play-friend-incoming__icon{font-size:24px}.play-friend-incoming__details{font-size:12px;color:var(--play-text-muted);margin-top:2px}.play-friend-incoming__actions{display:flex;gap:8px;flex-shrink:0}.text-secondary{color:var(--play-text-muted);font-size:13px}.btn--sm{padding:7px 16px;font-size:13px;border-radius:var(--play-radius)}.btn--primary{background:linear-gradient(180deg,#81b64c,#629a2e);color:#fff;border:none;font-weight:600;font-family:inherit;cursor:pointer;transition:filter var(--play-transition)}.btn--primary:hover{filter:brightness(1.1)}.btn--ghost{background:var(--play-surface);color:var(--play-text-muted);border:1px solid var(--play-border);font-weight:600;font-family:inherit;cursor:pointer;transition:all var(--play-transition)}.btn--ghost:hover{background:var(--play-surface-hover);color:var(--play-text)}@media (max-width: 900px){.play-friend-layout{grid-template-columns:1fr}.play-friend-config-panel{position:static}}@media (max-width: 720px){.play-live-result-overlay{padding:8px}.play-live-result-overlay__card{width:min(96%,360px);border-radius:14px;padding:12px}.play-live-result-overlay__quick-links{grid-template-columns:1fr}}
