:root{--bg-abyss: #08060e;--bg-deep: #0d0a16;--bg-card: #110e1a;--bg-card-hover: #171323;--purple-core: #9333ea;--purple-glow: #a855f7;--purple-dim: #6b21a8;--purple-muted: #3b1a6e;--purple-faint: #1e0a3e;--text-bright: #e8e0f0;--text-mid: #a89cc0;--text-dim: #6b5f80;--accent-gold: #d4a843;--accent-red: #dc2626;--accent-green: #22c55e;--border: rgba(147, 51, 234, .15);--border-active: rgba(147, 51, 234, .4);--glow-sm: 0 0 10px rgba(147, 51, 234, .2);--glow-md: 0 0 20px rgba(147, 51, 234, .3);--glow-lg: 0 0 40px rgba(147, 51, 234, .15), 0 0 80px rgba(147, 51, 234, .05)}*{box-sizing:border-box;margin:0;padding:0}.hidden{display:none!important}html,body{min-height:100%;font-family:Noto Kufi Arabic,system-ui,sans-serif;background:var(--bg-abyss);color:var(--text-bright);direction:rtl}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse at 20% 30%,rgba(147,51,234,.08),transparent 50%),radial-gradient(ellipse at 80% 70%,rgba(147,51,234,.06),transparent 50%);pointer-events:none;z-index:0}#app{position:relative;z-index:1;min-height:100vh;display:flex;flex-direction:column}.auth-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem}.auth-card{width:100%;max-width:440px;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2.25rem 2rem;box-shadow:var(--glow-md)}.auth-title{font-size:1.6rem;font-weight:800;color:var(--text-bright);text-align:center;margin-bottom:1.25rem;text-shadow:0 0 20px rgba(168,85,247,.4)}.auth-body{margin-bottom:1.25rem}.auth-form{display:flex;flex-direction:column;gap:.8rem}.form-row{display:flex;flex-direction:column;gap:.35rem}.form-label{font-size:.85rem;color:var(--text-mid);font-weight:600}.form-input{padding:.7rem .9rem;background:#9333ea0d;border:1px solid var(--border);border-radius:8px;color:var(--text-bright);font-family:inherit;font-size:.95rem;transition:border-color .15s ease,background .15s ease}.form-input:focus{outline:none;border-color:var(--border-active);background:#9333ea1a}.form-checkbox{display:flex;align-items:center;gap:.5rem;font-size:.88rem;color:var(--text-mid)}.form-hint{font-size:.8rem;color:var(--text-dim);margin-top:-.3rem}.form-error{padding:.6rem .8rem;background:#dc26261f;border:1px solid rgba(220,38,38,.35);border-radius:8px;color:#fca5a5;font-size:.85rem;margin-bottom:.3rem}.primary-btn{padding:.85rem 1.25rem;background:linear-gradient(135deg,#9333ea59,#a855f726);border:1px solid var(--border-active);border-radius:8px;color:var(--text-bright);font-family:inherit;font-size:1rem;font-weight:700;cursor:pointer;box-shadow:var(--glow-sm);transition:background .15s ease,transform .1s ease,box-shadow .2s ease;margin-top:.3rem}.primary-btn:hover{background:linear-gradient(135deg,#9333ea80,#a855f740);transform:translateY(-2px);box-shadow:var(--glow-md)}.primary-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.ghost-btn{padding:.55rem 1rem;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-mid);font-family:inherit;font-size:.85rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.ghost-btn:hover{background:#9333ea14;color:var(--text-bright);border-color:var(--border-active)}.auth-footer{display:flex;flex-direction:column;gap:.5rem;align-items:center;padding-top:1rem;border-top:1px solid var(--border)}.auth-link{color:var(--text-mid);text-decoration:none;font-size:.88rem;transition:color .15s}.auth-link:hover{color:var(--purple-glow)}.auth-link.primary-link{color:var(--purple-glow);font-weight:700}.auth-msg{color:var(--text-mid);text-align:center;line-height:1.7}.lobby-wrap{width:100%;max-width:960px;margin:0 auto;padding:2rem 1.5rem}.lobby-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border)}.lobby-brand h1{font-size:2rem;font-weight:800;color:var(--text-bright);text-shadow:0 0 20px rgba(168,85,247,.4)}.lobby-user{display:flex;align-items:center;gap:1rem}.lobby-user-text{display:flex;flex-direction:column;align-items:flex-end}.lobby-user-name{color:var(--text-bright);font-weight:700}.lobby-user-handle{color:var(--text-dim);font-size:.85rem}.lobby-rank{display:flex;align-items:center;gap:.6rem;padding:.5rem .9rem;background:#9333ea1a;border:1px solid var(--border-active);border-radius:8px;box-shadow:var(--glow-sm)}.lobby-rank-icon{font-size:1.7rem;line-height:1;filter:drop-shadow(0 0 6px rgba(168,85,247,.4))}.lobby-rank-text{display:flex;flex-direction:column}.lobby-rank-name{color:var(--text-bright);font-weight:700;font-size:.9rem}.lobby-rank-rating{color:var(--purple-glow);font-weight:800;font-family:Noto Kufi Arabic,monospace;font-size:1rem}.lobby-section{margin-bottom:2rem}.section-title{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:1rem}.time-control-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem}.time-control-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.25rem;text-align:center;transition:border-color .15s,transform .1s}.time-control-card:hover{border-color:var(--border-active);transform:translateY(-2px)}.tc-name{font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:.25rem}.tc-duration{font-size:1.3rem;color:var(--purple-glow);margin-bottom:.8rem;font-family:Noto Kufi Arabic,monospace}.tc-buttons{display:flex;flex-direction:column;gap:.4rem}.tc-play-btn{padding:.55rem .8rem;background:#9333ea1a;border:1px solid var(--border);border-radius:6px;color:var(--text-mid);font-family:inherit;font-size:.85rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.tc-play-btn:disabled{opacity:.5;cursor:not-allowed}.tc-play-btn:not(:disabled):hover{background:#9333ea33;color:var(--text-bright);border-color:var(--border-active)}.mode-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1rem}.mode-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem;text-align:center;text-decoration:none;color:inherit;transition:border-color .15s,transform .1s,box-shadow .2s}.mode-card:hover{border-color:var(--border-active);transform:translateY(-3px);box-shadow:var(--glow-sm)}.mode-icon{font-size:2.5rem;margin-bottom:.5rem}.mode-name{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:.25rem}.mode-desc{font-size:.85rem;color:var(--text-dim)}.game-wrap{width:100%;display:flex;flex-direction:column;align-items:center;padding:1rem;overflow:hidden;max-height:100vh}.game-top-bar{width:100%;max-width:720px;display:flex;justify-content:flex-start;margin-bottom:1rem}#game-root{display:flex;justify-content:center}.online-game-wrap{max-width:720px;margin:0 auto}.online-status{color:var(--text-mid);font-size:.95rem}.players-bar{width:100%;max-width:580px;margin:.5rem auto}.players-bar.hidden{display:none}.player-card{display:flex;justify-content:space-between;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:.7rem 1rem}.player-card .player-info{display:flex;flex-direction:column}.player-card .player-name{color:var(--text-bright);font-weight:700}.player-card .player-handle{color:var(--text-dim);font-size:.8rem}.player-card .player-clock{font-family:Noto Kufi Arabic,monospace;font-size:1.4rem;color:var(--purple-glow);padding:.3rem .8rem;background:#9333ea1a;border-radius:6px;border:1px solid var(--border)}.online-actions{display:flex;justify-content:center;gap:.8rem;margin-top:1rem}.online-actions.hidden{display:none}.ghost-btn.danger{border-color:#dc262659;color:#fca5a5}.ghost-btn.danger:hover{background:#dc26261f;color:#fecaca}.profile-wrap{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.profile-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.profile-you{color:var(--text-dim);font-size:.9rem}.profile-loading,.profile-error{text-align:center;color:var(--text-mid);padding:3rem 1rem}.profile-identity{display:flex;gap:1.5rem;align-items:center;background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.75rem 1.5rem;margin-bottom:1.5rem;box-shadow:var(--glow-sm)}.profile-avatar{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,var(--purple-dim),var(--purple-core));display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:800;color:var(--text-bright);border:2px solid var(--purple-glow);box-shadow:var(--glow-sm);flex-shrink:0}.profile-identity-text{display:flex;flex-direction:column;gap:.25rem}.profile-name{font-size:1.8rem;font-weight:800;color:var(--text-bright)}.profile-handle{color:var(--text-dim);font-size:.9rem}.profile-title{color:var(--accent-gold);font-size:.9rem;font-weight:600}.profile-meta{display:flex;gap:1.2rem;margin-top:.5rem;font-size:.85rem;color:var(--text-mid)}.profile-meta strong{color:var(--purple-glow);font-weight:800}.profile-rank-row{display:flex;align-items:center;gap:.8rem;margin-top:.5rem}.profile-rank-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .9rem;background:#9333ea1f;border:1px solid var(--border-active);border-radius:999px;font-weight:700;color:var(--text-bright);box-shadow:var(--glow-sm)}.profile-rank-icon{font-size:1.25rem;filter:drop-shadow(0 0 6px rgba(168,85,247,.4))}.profile-rating{font-size:1.8rem;font-weight:800;color:var(--purple-glow);font-family:Noto Kufi Arabic,monospace;text-shadow:0 0 12px rgba(168,85,247,.3)}.rating-chart-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1rem;overflow:hidden}.rating-chart-wrap svg{width:100%;height:auto;display:block}.profile-section.hidden{display:none}.leaderboard-wrap{max-width:960px;margin:0 auto;padding:2rem 1.5rem}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.leaderboard-title{font-size:1.8rem;font-weight:800;color:var(--text-bright);text-shadow:0 0 20px rgba(168,85,247,.4)}.leaderboard-loading{text-align:center;color:var(--text-mid);padding:3rem 1rem}.leaderboard-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.leaderboard-table{width:100%;border-collapse:collapse;font-size:.9rem}.leaderboard-table thead{background:#9333ea14}.leaderboard-table th{text-align:right;padding:.85rem 1rem;color:var(--text-mid);font-weight:600;font-size:.8rem;border-bottom:1px solid var(--border)}.leaderboard-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(147,51,234,.05);color:var(--text-bright);vertical-align:middle}.lb-row:last-child td{border-bottom:none}.lb-rank-col{width:80px}.lb-rank{display:flex;align-items:center;gap:.3rem;font-weight:700;color:var(--purple-glow)}.lb-medal{font-size:1.2rem}.lb-rank-num{font-family:Noto Kufi Arabic,monospace}.lb-player{display:flex;align-items:center;gap:.6rem}.lb-rank-icon{font-size:1.35rem;filter:drop-shadow(0 0 6px rgba(168,85,247,.3))}.lb-player-name{color:var(--text-bright);font-weight:700;text-decoration:none}.lb-player-name:hover{color:var(--purple-glow)}.lb-rank-name{color:var(--text-dim);font-size:.78rem}.lb-rating{color:var(--purple-glow);font-weight:800;font-family:Noto Kufi Arabic,monospace}.lb-num{color:var(--text-mid);font-family:Noto Kufi Arabic,monospace}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.8rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1rem;text-align:center;transition:border-color .15s}.stat-card:hover{border-color:var(--border-active)}.stat-value{font-size:1.75rem;font-weight:800;color:var(--text-bright);margin-bottom:.25rem}.stat-label{font-size:.8rem;color:var(--text-mid)}.profile-section{margin-top:2rem}.empty-state{color:var(--text-dim);text-align:center;padding:2rem;background:var(--bg-card);border:1px dashed var(--border);border-radius:10px}.match-table-wrap{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;overflow:hidden}.match-table{width:100%;border-collapse:collapse;font-size:.88rem}.match-table thead{background:#9333ea14}.match-table th{text-align:right;padding:.75rem 1rem;color:var(--text-mid);font-weight:600;font-size:.8rem;border-bottom:1px solid var(--border)}.match-table td{padding:.75rem 1rem;border-bottom:1px solid rgba(147,51,234,.05);color:var(--text-bright)}.match-row:last-child td{border-bottom:none}.match-row.win .match-result{color:var(--accent-green);font-weight:700}.match-row.loss .match-result{color:var(--accent-red);font-weight:700}.match-opponent a{color:var(--text-bright);text-decoration:none;font-weight:600}.match-opponent a:hover{color:var(--purple-glow)}.match-opponent-handle{display:block;font-size:.75rem;color:var(--text-dim)}.match-condition,.match-tc,.match-duration,.match-date{color:var(--text-mid)}.turn-bar{display:inline-flex;align-items:center;gap:.75rem;padding:.4rem 1rem;background:#110e1ab3;border:1px solid var(--border);border-radius:999px;font-size:.9rem;color:var(--text-mid);backdrop-filter:blur(4px);transition:border-color .2s ease,box-shadow .2s ease}.turn-bar[data-player="1"]{border-color:#a855f773;box-shadow:0 0 20px #a855f72e}.turn-bar[data-player="2"]{border-color:#d4a84373;box-shadow:0 0 20px #d4a8432e}.turn-dot{width:10px;height:10px;border-radius:50%;background:currentColor;flex-shrink:0}.turn-bar[data-player="1"] .turn-dot{background:var(--purple-glow);box-shadow:0 0 8px var(--purple-glow)}.turn-bar[data-player="2"] .turn-dot{background:var(--accent-gold);box-shadow:0 0 8px var(--accent-gold)}.turn-player{color:var(--text-bright);font-weight:700}.turn-sep{color:var(--text-dim)}.turn-number{font-family:Noto Kufi Arabic,monospace;color:var(--text-mid)}#game-root{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}#game-root canvas{box-shadow:var(--glow-lg);border-radius:4px}.promotion-modal{position:fixed;inset:0;z-index:100;display:flex;align-items:center;justify-content:center;pointer-events:auto}.promotion-modal.hidden{display:none}.modal-backdrop{position:absolute;inset:0;background:#08060ed1;backdrop-filter:blur(4px)}.modal-content{position:relative;background:var(--bg-card);border:1px solid var(--border-active);border-radius:12px;padding:2rem 2.5rem;box-shadow:var(--glow-lg);max-width:560px;width:90%}.modal-title{font-size:1.6rem;font-weight:800;color:var(--text-bright);text-align:center;margin-bottom:.4rem;text-shadow:0 0 20px rgba(168,85,247,.4)}.modal-subtitle{font-size:.95rem;color:var(--text-mid);text-align:center;margin-bottom:1.5rem}.promotion-choices{display:grid;grid-template-columns:repeat(4,1fr);gap:.85rem}.promotion-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:1.1rem .6rem;background:#9333ea14;border:1px solid var(--border);border-radius:8px;color:var(--text-bright);font-family:inherit;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .1s ease}.promotion-btn:hover{background:#9333ea2e;border-color:var(--border-active);transform:translateY(-2px)}.promotion-btn:active{transform:translateY(0)}.btn-emoji{font-size:2.2rem;line-height:1}.btn-label{color:var(--text-mid)}.game-over-modal{position:fixed;inset:0;z-index:110;display:flex;align-items:center;justify-content:center}.game-over-modal.hidden{display:none}.game-over-content{text-align:center;padding:2.5rem 3rem;min-width:360px}.game-over-crown{font-size:3.5rem;line-height:1;margin-bottom:.6rem;filter:drop-shadow(0 0 20px rgba(212,168,67,.5))}.game-over-rating{display:flex;align-items:center;justify-content:center;gap:.6rem;margin-top:.8rem;font-family:Noto Kufi Arabic,monospace;font-size:1.4rem;font-weight:800}.game-over-rating.hidden{display:none}.rating-change.rating-up{color:var(--accent-green)}.rating-change.rating-down{color:var(--accent-red)}.rating-arrow{color:var(--text-dim);font-size:1rem}.rating-after{color:var(--purple-glow)}.restart-btn{margin-top:1.6rem;padding:.85rem 2rem;background:linear-gradient(135deg,#9333ea40,#a855f71a);border:1px solid var(--border-active);border-radius:8px;color:var(--text-bright);font-family:inherit;font-size:1.05rem;font-weight:700;cursor:pointer;transition:background .15s ease,border-color .15s ease,transform .1s ease;box-shadow:var(--glow-sm)}.restart-btn:hover{background:linear-gradient(135deg,#9333ea66,#a855f733);border-color:#a855f7b3;transform:translateY(-2px);box-shadow:var(--glow-md)}.restart-btn:active{transform:translateY(0)}.landing-wrap{max-width:960px;margin:0 auto;padding:3rem 1.5rem;text-align:center}.landing-hero{margin-bottom:3rem}.landing-title{font-size:4rem;font-weight:900;color:var(--text-bright);text-shadow:0 0 40px rgba(168,85,247,.5);margin-bottom:.5rem;letter-spacing:.1em}.landing-subtitle{font-size:1.3rem;color:var(--purple-glow);font-weight:700;margin-bottom:1rem}.landing-desc{color:var(--text-mid);font-size:1rem;line-height:1.8;max-width:600px;margin:0 auto 2rem}.landing-ctas{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.landing-btn{min-width:220px!important;text-align:center!important;padding:.9rem 2.5rem!important;font-size:1.05rem!important;font-weight:700!important;text-decoration:none!important;display:inline-flex!important;align-items:center!important;justify-content:center!important;box-sizing:border-box!important;height:54px!important;border-radius:8px!important;border:1px solid var(--border-active)!important;color:var(--text-bright)!important;cursor:pointer!important}.landing-btn.ghost-btn{background:#9333ea14!important}.landing-btn.ghost-btn:hover{background:#9333ea2e!important}.landing-features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.25rem;margin-bottom:3rem}.feature-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem;text-align:center;transition:border-color .15s,transform .1s}.feature-card:hover{border-color:var(--border-active);transform:translateY(-3px)}.feature-icon{font-size:2.5rem;margin-bottom:.8rem}.feature-card h3{color:var(--text-bright);font-weight:700;margin-bottom:.5rem}.feature-card p{color:var(--text-dim);font-size:.85rem;line-height:1.7}.landing-footer{padding-top:2rem;border-top:1px solid var(--border);color:var(--text-dim);font-size:.85rem;display:flex;justify-content:center;gap:.8rem;align-items:center}.landing-sep{color:var(--text-dim)}.rules-wrap{max-width:800px;margin:0 auto;padding:2rem 1.5rem}.rules-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.rules-title{font-size:1.8rem;font-weight:800;color:var(--text-bright);text-shadow:0 0 20px rgba(168,85,247,.4)}.rules-section{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem;margin-bottom:1.25rem}.rules-section h2{font-size:1.1rem;font-weight:700;color:var(--text-bright);margin-bottom:.8rem}.rules-section p{color:var(--text-mid);line-height:1.8;margin-bottom:.5rem}.rules-section ul,.rules-section ol{color:var(--text-mid);line-height:1.8;padding-right:1.5rem;margin-bottom:.5rem}.rules-section li{margin-bottom:.3rem}.rules-table{width:100%;border-collapse:collapse;font-size:.9rem}.rules-table th{text-align:right;padding:.6rem .8rem;color:var(--text-mid);font-weight:600;border-bottom:1px solid var(--border)}.rules-table td{padding:.5rem .8rem;color:var(--text-bright);border-bottom:1px solid rgba(147,51,234,.05)}.settings-wrap{max-width:640px;margin:0 auto;padding:2rem 1.5rem}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.settings-sections{display:flex;flex-direction:column;gap:1.25rem}.settings-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem}.settings-card h2{font-size:1.05rem;font-weight:700;color:var(--text-bright);margin-bottom:.8rem}.settings-danger{border-color:#dc26264d}.settings-danger h2{color:#fca5a5}.settings-success{color:var(--accent-green);font-size:.88rem;padding:.6rem 0}.settings-success.hidden{display:none}.language-toggle{display:flex;gap:.6rem}.lang-btn{padding:.5rem 1.2rem;background:#9333ea0f;border:1px solid var(--border);border-radius:6px;color:var(--text-mid);font-family:inherit;font-size:.9rem;cursor:pointer;transition:background .15s,color .15s,border-color .15s}.lang-btn.active{background:#9333ea33;border-color:var(--border-active);color:var(--text-bright);font-weight:700}.avatar-upload-area{display:flex;align-items:center;gap:1rem}.avatar-preview{width:64px;height:64px;border-radius:50%;overflow:hidden;background:var(--bg-deep);border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{font-size:1.8rem;font-weight:800;color:var(--text-dim)}.lang-btn:hover{background:#9333ea1f}.chat-panel{position:fixed;bottom:1rem;left:1rem;width:300px;max-height:400px;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;display:flex;flex-direction:column;z-index:50;box-shadow:var(--glow-md);overflow:hidden;transition:max-height .2s ease}.chat-panel.chat-minimized{max-height:44px}.chat-panel.chat-minimized .chat-messages,.chat-panel.chat-minimized .chat-presets,.chat-panel.chat-minimized .chat-input-row{display:none}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem .8rem;font-weight:700;font-size:.85rem;color:var(--text-bright);border-bottom:1px solid var(--border);cursor:pointer}.chat-toggle-btn{background:transparent;border:none;color:var(--text-mid);font-size:1.1rem;cursor:pointer}.chat-messages{flex:1;min-height:120px;max-height:200px;overflow-y:auto;padding:.5rem .7rem;font-size:.82rem;display:flex;flex-direction:column;gap:.3rem}.chat-msg{padding:.25rem 0}.chat-sender{color:var(--purple-glow);font-weight:700}.chat-msg-own .chat-sender{color:var(--accent-gold)}.chat-text{color:var(--text-mid)}.chat-presets{display:flex;flex-wrap:wrap;gap:.3rem;padding:.4rem .7rem;border-top:1px solid var(--border)}.chat-preset-btn{padding:.25rem .6rem;background:#9333ea14;border:1px solid var(--border);border-radius:999px;color:var(--text-mid);font-family:inherit;font-size:.75rem;cursor:pointer;transition:background .1s,color .1s}.chat-preset-btn:hover{background:#9333ea33;color:var(--text-bright)}.chat-input-row{display:flex;border-top:1px solid var(--border)}.chat-input{flex:1;padding:.5rem .7rem;background:transparent;border:none;color:var(--text-bright);font-family:inherit;font-size:.85rem;outline:none}.chat-send-btn{padding:.5rem .7rem;background:transparent;border:none;border-right:1px solid var(--border);color:var(--purple-glow);font-size:1rem;cursor:pointer}.chat-send-btn:hover{background:#9333ea26}@media (max-width: 768px){.landing-title{font-size:2.5rem}.landing-subtitle{font-size:1rem}.lobby-header{flex-direction:column;gap:1rem;text-align:center}.lobby-user{flex-wrap:wrap;justify-content:center}.lobby-rank{order:-1}.time-control-grid{grid-template-columns:repeat(2,1fr)}.mode-row{grid-template-columns:1fr}.leaderboard-table{font-size:.78rem}.leaderboard-table th,.leaderboard-table td{padding:.5rem .6rem}.profile-identity{flex-direction:column;text-align:center}.profile-meta{justify-content:center;flex-wrap:wrap}.stats-grid{grid-template-columns:repeat(3,1fr)}.match-table{font-size:.75rem}.match-table th,.match-table td{padding:.5rem}.rules-wrap,.settings-wrap,.friend-game-wrap,.lobby-wrap,.leaderboard-wrap,.profile-wrap{padding:1rem}.online-game-wrap,.game-wrap{padding:.5rem}.player-card .player-clock{font-size:1.1rem}#game-root canvas{max-width:100%;height:auto!important}}@media (max-width: 480px){.landing-title{font-size:2rem}.time-control-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.landing-features{grid-template-columns:1fr}.room-code-display{font-size:2rem}}.friends-wrap{max-width:640px;margin:0 auto;padding:2rem 1.5rem}.friends-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.friends-add{margin-bottom:1.5rem}.add-friend-form{display:flex;gap:.6rem}.add-friend-form .form-input{flex:1}.add-friend-form .primary-btn{white-space:nowrap}.add-status{font-size:.85rem;margin-top:.4rem;min-height:1.2em}.add-status.success{color:var(--accent-green)}.add-status.error{color:var(--accent-red)}.friends-section-title{font-size:.95rem;font-weight:700;color:var(--text-mid);margin:1.25rem 0 .6rem}.friends-list{display:flex;flex-direction:column;gap:.5rem}.friend-card{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:8px}.friend-card.pending-card{border-color:#d4a84340}.friend-info{display:flex;align-items:center;gap:.5rem}.friend-rank-icon{font-size:1.2rem}.friend-name{color:var(--text-bright);font-weight:700;text-decoration:none}.friend-name:hover{color:var(--purple-glow)}.friend-handle{color:var(--text-dim);font-size:.82rem}.friend-rating{color:var(--purple-glow);font-weight:800;font-family:Noto Kufi Arabic,monospace;font-size:.9rem}.friend-actions{display:flex;gap:.4rem}.primary-btn.small,.ghost-btn.small{padding:.35rem .7rem;font-size:.8rem}.pending-label{color:var(--text-dim);font-size:.82rem;font-style:italic}.friends-loading{text-align:center;color:var(--text-mid);padding:2rem}.online-dot{color:var(--accent-green);font-size:.7rem;margin-right:.2rem}.piece-tooltip{position:fixed;z-index:60;background:var(--bg-card);border:1px solid var(--border-active);border-radius:8px;padding:.7rem .9rem;box-shadow:var(--glow-md);min-width:180px;max-width:260px;pointer-events:none;font-size:.82rem}.piece-tooltip.hidden{display:none}.tooltip-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.35rem}.tooltip-emoji{font-size:1.5rem}.tooltip-name{font-weight:800;color:var(--text-bright);font-size:1rem}.tooltip-owner{color:var(--text-dim);font-size:.78rem;margin-bottom:.25rem}.tooltip-zone{color:var(--text-mid);margin-bottom:.2rem}.tooltip-move{color:var(--purple-glow);font-weight:600}.check-indicator{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1.2rem;background:#dc262626;border:1px solid rgba(220,38,38,.5);border-radius:999px;color:#fca5a5;font-weight:800;font-size:1rem;animation:checkPulse 1s ease-in-out infinite;margin:.5rem auto;width:fit-content}.check-indicator.hidden{display:none}.check-icon{font-size:1.2rem}.check-text{letter-spacing:.05em}@keyframes checkPulse{0%,to{opacity:1;border-color:#dc262680}50%{opacity:.7;border-color:#dc2626e6}}.ai-difficulty-label{color:var(--text-mid);font-size:.9rem;font-weight:600}.replay-wrap{max-width:720px;margin:0 auto;padding:2rem 1.5rem}.replay-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.replay-board{display:flex;justify-content:center;margin-bottom:1rem}.replay-board canvas{box-shadow:var(--glow-lg);border-radius:4px}.replay-info{display:flex;gap:.6rem;justify-content:center;align-items:center;color:var(--text-mid);font-size:.88rem;margin-bottom:1rem}.replay-controls{display:flex;justify-content:center;align-items:center;gap:.6rem;margin-bottom:.8rem}.replay-counter{color:var(--purple-glow);font-weight:700;font-family:Noto Kufi Arabic,monospace;min-width:80px;text-align:center}.replay-move-info{text-align:center;color:var(--text-mid);font-size:.85rem;min-height:1.5em}.admin-wrap{max-width:1000px;margin:0 auto;padding:2rem 1.5rem;direction:ltr;font-family:system-ui,-apple-system,sans-serif}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.admin-header h1{font-size:1.5rem;color:var(--text-bright)}.admin-user{color:var(--text-dim);font-size:.85rem}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.admin-tab{padding:.6rem 1.2rem;background:var(--bg-card);border:1px solid var(--border);border-radius:6px;color:var(--text-mid);font-family:inherit;font-size:.9rem;cursor:pointer;transition:all .15s}.admin-tab.active{background:#9333ea33;border-color:var(--border-active);color:var(--text-bright);font-weight:700}.admin-content{min-height:300px}.admin-stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.admin-stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:1.5rem;text-align:center}.admin-stat-value{font-size:2.5rem;font-weight:800;color:var(--purple-glow)}.admin-stat-label{color:var(--text-mid);font-size:.85rem;margin-top:.3rem}.admin-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-table th{text-align:left;padding:.7rem .8rem;color:var(--text-mid);font-weight:600;border-bottom:1px solid var(--border);background:#9333ea0d}.admin-table td{padding:.6rem .8rem;border-bottom:1px solid rgba(147,51,234,.05);color:var(--text-bright)}.admin-actions{display:flex;gap:.3rem}.admin-btn{padding:.3rem .6rem;border:1px solid var(--border);border-radius:4px;background:var(--bg-card);color:var(--text-mid);font-size:.75rem;cursor:pointer;transition:all .15s}.admin-btn:hover{background:#9333ea26;color:var(--text-bright)}.admin-btn.ban{border-color:#dc262666;color:#fca5a5}.admin-btn.ban:hover{background:#dc262633}.admin-btn.warn{border-color:#d4a84366;color:var(--accent-gold)}.admin-btn.dismiss{border-color:#22c55e66;color:var(--accent-green)}.admin-search{display:flex;gap:.6rem;margin-bottom:1rem}.admin-search .form-input{flex:1}.admin-user-card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:1.2rem;display:flex;justify-content:space-between;align-items:center}.admin-user-info{line-height:1.7;color:var(--text-mid)}.admin-user-info strong{color:var(--text-bright)}.admin-user-actions{display:flex;gap:.5rem}.admin-empty{text-align:center;color:var(--accent-green);padding:3rem;font-size:1.1rem}.admin-error{color:var(--accent-red);text-align:center;padding:2rem}
