*{margin:0;padding:0;box-sizing:border-box}:root,[data-theme=dark]{--bg: #1a1a2e;--surface: #16213e;--accent: #4ecca3;--accent-hover: #3db892;--accent-dim: #2a7a5a;--text: #eee;--text-muted: #888;--text-label: #aaa;--border: #333;--error: #ff6b6b}[data-theme=light]{--bg: #f0f2f5;--surface: #ffffff;--accent: #2a9d6e;--accent-hover: #238a5e;--accent-dim: #a3d4bf;--text: #1a1a2e;--text-muted: #666;--text-label: #555;--border: #ddd;--error: #d9534f}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh}#root{display:flex;flex-direction:column;min-height:100vh}a{color:var(--accent)}.header{background:var(--surface);padding:1rem 2rem;display:flex;justify-content:space-between;align-items:center;border-bottom:2px solid var(--accent)}.header-logo{font-size:1.5rem;font-weight:700;color:var(--accent);cursor:pointer;text-decoration:none}.header-nav{display:flex;align-items:center;gap:1rem}.header-greeting{color:var(--text-muted)}.header-btn{background:transparent;border:1px solid var(--accent);color:var(--accent);padding:.5rem 1rem;cursor:pointer;border-radius:4px;transition:background .2s,color .2s;text-decoration:none;font-size:inherit}.header-btn:hover{background:var(--accent);color:var(--bg)}.footer{background:var(--surface);padding:1rem 2rem;text-align:center;border-top:2px solid var(--accent);color:var(--text-muted);font-size:.875rem;margin-top:auto}.main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.card{background:var(--surface);border-radius:8px;padding:2rem;width:100%;max-width:400px;border:1px solid var(--border)}.card-title{font-size:1.5rem;margin-bottom:.5rem;color:var(--accent)}.card-subtitle{color:var(--text-muted);margin-bottom:1.5rem}.form-group{margin-bottom:.5rem}.form-label{display:block;margin-bottom:.5rem;color:var(--text-label);font-size:.875rem}.form-input{width:100%;padding:.75rem;background:var(--bg);border:1px solid var(--border);border-radius:4px;color:var(--text);font-size:1rem;transition:border-color .2s}.form-input:focus{outline:none;border-color:var(--accent)}.form-input--valid,.form-input--valid:focus{border-color:var(--accent)}.form-input--invalid,.form-input--invalid:focus{border-color:var(--error)}.form-hint{margin-top:.35rem;font-size:.78rem;line-height:1.2}.form-hint--hidden{visibility:hidden}.form-hint--error{color:var(--error)}.btn{width:100%;padding:.75rem;border:none;border-radius:4px;font-size:1rem;cursor:pointer;margin-top:1rem;transition:background .2s}.btn-primary{background:var(--accent);color:var(--bg);font-weight:700}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{background:var(--accent-dim);cursor:not-allowed}.error-msg{background:#ff6b6b22;border:1px solid var(--error);color:var(--error);padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.875rem}.dashboard{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.dashboard-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.level-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:1.5rem}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.level-badge{font-size:1.25rem;font-weight:700;color:var(--accent)}.level-xp{color:var(--text-muted);font-size:.875rem}.xp-bar{height:8px;background:var(--bg);border-radius:4px;overflow:hidden}.xp-bar-fill{height:100%;background:var(--accent);border-radius:4px;transition:width .4s ease}.level-total{margin-top:.5rem;color:var(--text-muted);font-size:.8rem;text-align:right}.daily-rewards-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.25rem;margin-bottom:1.5rem}.daily-rewards-header{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1rem}.daily-rewards-title{color:var(--accent);font-size:1.2rem}.daily-rewards-streak{color:var(--text-muted);font-size:.9rem;white-space:nowrap}.daily-rewards-list{display:flex;flex-direction:column;gap:.75rem}.daily-reward-card{background:var(--bg);border:1px solid var(--border);border-radius:8px;padding:1rem;display:flex;align-items:center;justify-content:space-between;gap:1rem}.daily-reward-card--done{opacity:.72}.daily-reward-main{min-width:0}.daily-reward-title-row{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-bottom:.25rem}.daily-reward-name{color:var(--text);font-size:1rem}.daily-reward-xp{color:var(--accent);font-size:.85rem;font-weight:700}.daily-reward-description{color:var(--text-muted);font-size:.85rem}.daily-reward-progress{display:flex;align-items:center;gap:.75rem;margin-top:.7rem}.daily-reward-progress-bar{flex:1;min-width:120px;height:7px;background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.daily-reward-progress-fill{height:100%;background:var(--accent);transition:width .3s ease}.daily-reward-progress-text{color:var(--text-muted);font-size:.8rem;font-weight:700;min-width:2.5rem;text-align:right}.daily-reward-status{border:1px solid var(--accent);border-radius:4px;color:var(--accent);font-size:.8rem;font-weight:700;padding:.35rem .6rem;white-space:nowrap}.daily-reward-status--done{border-color:var(--border);color:var(--text-muted)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:var(--surface);padding:1.5rem;border-radius:8px;border:1px solid var(--border)}.stat-label{color:var(--text-muted);font-size:.875rem;margin-bottom:.5rem}.stat-value{font-size:1.25rem;color:var(--accent)}.link-text{text-align:center;margin-top:1.5rem;color:var(--text-muted)}.leaderboard{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.leaderboard-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.lb-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.lb-tab{background:transparent;border:1px solid var(--border);color:var(--text-muted);padding:.5rem 1.25rem;cursor:pointer;border-radius:4px;font-size:.95rem;transition:background .2s,color .2s,border-color .2s}.lb-tab:hover{border-color:var(--accent);color:var(--text)}.lb-tab--active{background:var(--accent);color:var(--bg);border-color:var(--accent);font-weight:700}.lb-game-select{margin-bottom:1.5rem}.lb-game-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.lb-empty{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:2.5rem;text-align:center;color:var(--text-muted)}.lb-empty-sub{margin-top:.5rem;font-size:.875rem;color:var(--text-muted)}.lb-loading{text-align:center;color:var(--text-muted);padding:2rem}.lb-table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:8px;overflow:hidden;-webkit-user-select:none;user-select:none;cursor:default}.lb-table{width:100%;border-collapse:collapse;-webkit-user-select:none;user-select:none;cursor:default}.lb-table th{text-align:left;padding:.75rem 1rem;color:var(--text-muted);font-size:.875rem;border-bottom:1px solid var(--border);background:var(--bg)}.lb-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border)}.lb-table tbody tr:last-child td{border-bottom:none}.lb-table tbody tr:hover{background:#4ecca30d}.lb-rank{font-weight:700;color:var(--text-muted);width:3rem}.lb-name{font-weight:600;color:var(--text)}.lb-xp{color:var(--accent);font-weight:600}.lb-row--top1 .lb-rank{color:gold}.lb-row--top2 .lb-rank{color:silver}.lb-row--top3 .lb-rank{color:#cd7f32}.settings{flex:1;padding:2rem;max-width:600px;margin:0 auto;width:100%}.settings-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:1rem}.settings-section-title{font-size:1.1rem;color:var(--accent);margin-bottom:.75rem}.settings-current{color:var(--text-muted);font-size:.875rem;margin-bottom:.75rem}.settings-cooldown{color:var(--error);font-size:.8rem;margin-bottom:.5rem}.settings-row{display:flex;gap:.75rem;align-items:center}.settings-row .form-input{flex:1}.settings-btn{width:auto;margin-top:0;padding:.75rem 1.5rem;white-space:nowrap}.settings-msg{margin-top:.5rem;font-size:.85rem}.settings-msg--ok{color:var(--accent)}.settings-msg--err{color:var(--error)}.theme-toggle{display:flex;align-items:center;gap:.75rem;color:var(--text-muted)}.theme-label--active{color:var(--accent);font-weight:700}.toggle-switch{position:relative;width:48px;height:26px;background:var(--border);border:none;border-radius:13px;cursor:pointer;transition:background .2s;padding:0}.toggle-switch--on{background:var(--accent)}.toggle-knob{position:absolute;top:3px;left:3px;width:20px;height:20px;background:var(--text);border-radius:50%;transition:transform .2s}.toggle-switch--on .toggle-knob{transform:translate(22px)}.player-search{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.player-search-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.ps-search-bar{display:flex;gap:.75rem;margin-bottom:1.5rem}.ps-input{flex:1}.ps-btn{width:auto;margin-top:0;padding:.75rem 1.5rem;white-space:nowrap}.friends-page{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.friends-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.friends-add{display:flex;gap:.75rem}.friends-add-input{flex:1}.friends-add-btn{width:auto;margin-top:0;padding:.75rem 1.5rem;white-space:nowrap}.friends-list{display:flex;flex-direction:column;gap:.5rem}.friend-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center}.friend-info{display:flex;flex-direction:column;gap:.25rem}.friend-name{font-weight:600;color:var(--text)}.friend-detail{font-size:.85rem;color:var(--text-muted)}.friend-actions{display:flex;gap:.5rem}.friend-action-btn{width:auto;margin-top:0;padding:.5rem 1rem;font-size:.875rem;text-decoration:none;text-align:center}.friend-remove-btn{background:transparent;border:1px solid var(--error);color:var(--error)}.friend-remove-btn:hover{background:var(--error);color:var(--bg)}.messages-page{flex:1;padding:2rem;max-width:800px;margin:0 auto;width:100%}.messages-title{font-size:2rem;color:var(--accent);margin-bottom:1.5rem}.conversation-list{display:flex;flex-direction:column;gap:.5rem}.conversation-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:1rem 1.25rem;display:flex;justify-content:space-between;align-items:center;text-decoration:none;color:var(--text);transition:border-color .2s}.conversation-card:hover{border-color:var(--accent)}.conversation-info{display:flex;flex-direction:column;gap:.25rem;min-width:0;flex:1}.conversation-name{font-weight:600;display:flex;align-items:center;gap:.5rem}.conversation-badge{background:var(--accent);color:var(--bg);font-size:.75rem;font-weight:700;padding:.1rem .5rem;border-radius:10px}.conversation-preview{font-size:.85rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-time{font-size:.8rem;color:var(--text-muted);white-space:nowrap;margin-left:1rem}.chat-page{flex:1;display:flex;flex-direction:column;max-width:800px;margin:0 auto;width:100%;padding:0;height:calc(100vh - 130px)}.chat-header{display:flex;align-items:center;gap:1rem;padding:1rem 2rem;background:var(--surface);border-bottom:1px solid var(--border)}.chat-back{color:var(--accent);text-decoration:none;font-size:1.1rem}.chat-partner-name{font-size:1.25rem;color:var(--text);margin:0}.e2e-badge{margin-left:auto;background:var(--accent);color:var(--bg);font-size:.7rem;font-weight:700;padding:.2rem .6rem;border-radius:4px;letter-spacing:.05em}.chat-messages{flex:1;overflow-y:auto;padding:1rem 2rem;display:flex;flex-direction:column;gap:.5rem}.chat-empty{text-align:center;color:var(--text-muted);padding:3rem 0}.chat-bubble{max-width:70%;padding:.75rem 1rem;border-radius:12px;word-wrap:break-word}.chat-bubble--mine{align-self:flex-end;background:var(--accent);color:var(--bg)}.chat-bubble--theirs{align-self:flex-start;background:var(--surface);border:1px solid var(--border);color:var(--text)}.chat-bubble-content{font-size:.95rem;line-height:1.4}.chat-bubble-time{font-size:.7rem;opacity:.7;margin-top:.25rem;text-align:right}.chat-input-row{display:flex;gap:.75rem;padding:1rem 2rem;background:var(--surface);border-top:1px solid var(--border)}.chat-input{flex:1}.chat-send-btn{width:auto;margin-top:0;padding:.75rem 1.5rem;white-space:nowrap}.notif-wrapper{position:relative}.notif-bell{background:transparent;border:1px solid var(--accent);color:var(--accent);width:40px;height:40px;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;transition:background .2s,color .2s}.notif-bell:hover{background:var(--accent);color:var(--bg)}.notif-badge{position:absolute;top:-6px;right:-6px;background:var(--error);color:#fff;font-size:.65rem;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px}.notif-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:320px;max-height:400px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:0 4px 16px #0000004d;z-index:1000;overflow:hidden;display:flex;flex-direction:column}.notif-dropdown-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-bottom:1px solid var(--border);font-weight:600;font-size:.9rem}.notif-mark-read{background:transparent;border:none;color:var(--accent);font-size:.8rem;cursor:pointer}.notif-mark-read:hover{text-decoration:underline}.notif-list{overflow-y:auto;flex:1}.notif-item{display:flex;flex-direction:column;gap:.2rem;padding:.75rem 1rem;border-bottom:1px solid var(--border);text-decoration:none;color:var(--text);transition:background .15s}.notif-item:hover{background:#4ecca30d}.notif-item--unread{background:#4ecca314}.notif-item--unread .notif-text{font-weight:600}.notif-text{font-size:.85rem;line-height:1.3;overflow-wrap:anywhere}.notif-time{font-size:.75rem;color:var(--text-muted)}.notif-empty{padding:2rem;text-align:center;color:var(--text-muted);font-size:.875rem}
