*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #1a1a2e;--bg-card: #16213e;--bg-card-hover: #1a2744;--border: #0f3460;--text: #e0e0e0;--text-dim: #8892a4;--accent: #e94560;--green: #4ade80;--red: #f87171;--yellow: #facc15;--blue: #60a5fa;--orange: #fb923c;--font-mono: "Consolas", "Courier New", monospace}html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}#app{display:flex;flex-direction:column;height:100vh;padding:16px;gap:16px}header{display:flex;align-items:center;justify-content:space-between;padding-bottom:8px;border-bottom:1px solid var(--border)}header h1{font-size:1.3rem;font-weight:600}header .subtitle{color:var(--text-dim);font-weight:400;margin-left:8px}.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:500}.badge:before{content:"";width:8px;height:8px;border-radius:50%}.badge-connected{background:#4ade8026;color:var(--green)}.badge-connected:before{background:var(--green)}.badge-disconnected{background:#f8717126;color:var(--red)}.badge-disconnected:before{background:var(--red)}.badge-unknown{background:#8892a426;color:var(--text-dim)}.badge-unknown:before{background:var(--text-dim)}.config-changed-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:8px;font-size:.7rem;font-weight:500;background:#fb923c26;color:var(--orange, #fb923c);margin-left:6px;animation:pulse-config 2s infinite}@keyframes pulse-config{0%,to{opacity:1}50%{opacity:.5}}main{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:20px}main section h2{font-size:1rem;font-weight:500;color:var(--text-dim);margin-bottom:10px;text-transform:uppercase;letter-spacing:.05em}.card-grid{display:flex;flex-wrap:wrap;gap:12px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:16px;min-width:300px;flex:1;max-width:500px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.card-name{font-weight:600;font-size:1rem}.card-pid{font-size:.75rem;color:var(--text-dim);font-family:var(--font-mono)}.status{display:inline-flex;align-items:center;gap:6px;font-size:.85rem;font-weight:500}.status-dot{width:10px;height:10px;border-radius:50%}.status-running .status-dot{background:var(--green)}.status-running{color:var(--green)}.status-stopped .status-dot{background:var(--red)}.status-stopped{color:var(--red)}.status-external .status-dot{background:var(--blue)}.status-external{color:var(--blue)}.status-starting .status-dot{background:var(--yellow);animation:pulse 1s infinite}.status-starting{color:var(--yellow)}.status-failed .status-dot{background:var(--red)}.status-failed{color:var(--red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.card-actions{display:flex;gap:6px;margin-top:10px}.btn{display:inline-flex;align-items:center;padding:6px 14px;border:1px solid var(--border);border-radius:6px;background:transparent;color:var(--text);font-size:.8rem;cursor:pointer;transition:background .15s,border-color .15s}.btn:hover{background:var(--bg-card-hover);border-color:var(--text-dim)}.btn-start{border-color:var(--green);color:var(--green)}.btn-start:hover{background:#4ade801a}.btn-stop{border-color:var(--red);color:var(--red)}.btn-stop:hover{background:#f871711a}.btn-restart{border-color:var(--yellow);color:var(--yellow)}.btn-restart:hover{background:#facc151a}.btn-sm{padding:3px 10px;font-size:.75rem}.btn:disabled{opacity:.4;cursor:not-allowed}.game-info{margin-top:10px;padding:10px;background:#0003;border-radius:6px;font-size:.85rem}.game-info-row{display:flex;gap:16px;flex-wrap:wrap}.game-info-item{display:flex;gap:4px}.game-info-label{color:var(--text-dim)}.game-info-value{font-weight:500}.phase-lobby{color:var(--blue)}.phase-playing{color:var(--green)}.phase-voting{color:var(--yellow)}.phase-results{color:var(--orange)}.phase-transition{color:var(--text-dim)}.player-toggle{margin-top:8px;font-size:.8rem;color:var(--text-dim);cursor:pointer;border:none;background:none;padding:4px 0}.player-toggle:hover{color:var(--text)}.player-list{margin-top:8px}.player-list table{width:100%;border-collapse:collapse;font-size:.8rem}.player-list th{text-align:left;color:var(--text-dim);font-weight:500;padding:4px 8px;border-bottom:1px solid var(--border)}.player-list td{padding:4px 8px}.player-list tr:nth-child(2n){background:#00000026}.deps{margin-top:6px;font-size:.75rem;color:var(--text-dim)}.dep-tag{display:inline-block;padding:2px 6px;background:#60a5fa1a;border:1px solid rgba(96,165,250,.3);border-radius:4px;margin-left:4px;font-family:var(--font-mono)}.child-services{margin-top:10px;padding-left:12px;border-left:2px solid var(--border)}.child-service{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:.85rem}#logs-section{border-top:1px solid var(--border);padding-top:12px;flex-shrink:0}.logs-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.logs-header h2{font-size:1rem;font-weight:500;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em}#log-output{height:180px;overflow-y:auto;background:#0000004d;border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-family:var(--font-mono);font-size:.78rem;line-height:1.5}.log-line{white-space:pre-wrap;word-break:break-all}.log-ts{color:var(--text-dim);margin-right:8px}.log-source{font-weight:600;margin-right:8px}.log-source-mysql{color:var(--blue)}.log-source-web-client{color:var(--orange)}.log-source-manager{color:var(--green)}.log-source-default{color:var(--accent)}.log-level-stderr{color:var(--red)}.log-level-manager{color:var(--text-dim);font-style:italic}.card-uptime{font-size:.7rem;color:var(--text-dim);font-family:var(--font-mono);margin-left:8px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:8px;padding:20px 24px;min-width:300px;max-width:400px}.modal p{margin-bottom:16px;font-size:.95rem}.modal-actions{display:flex;justify-content:flex-end;gap:8px}.card-crash{font-size:.7rem;color:var(--orange);font-family:var(--font-mono);margin-left:8px;padding:2px 6px;background:#fb923c1a;border:1px solid rgba(251,146,60,.3);border-radius:4px}.card-resource{font-size:.7rem;color:var(--text-dim);font-family:var(--font-mono);margin-left:8px}.card-manual-stop{font-size:.7rem;color:var(--text-dim);font-family:var(--font-mono);margin-left:8px;padding:2px 6px;background:#8892a41a;border:1px solid rgba(136,146,164,.3);border-radius:4px}.settings-panel{position:fixed;top:0;right:0;bottom:0;width:360px;background:var(--bg-card);border-left:1px solid var(--border);z-index:900;display:flex;flex-direction:column;box-shadow:-4px 0 20px #0000004d}.settings-panel-inner{padding:20px;display:flex;flex-direction:column;height:100%;overflow:hidden}.settings-panel h3{font-size:1.1rem;font-weight:600;margin-bottom:4px}.settings-desc{color:var(--text-dim);font-size:.8rem;margin-bottom:16px}.auto-start-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:4px}.auto-start-item{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:background .15s}.auto-start-item:hover{background:var(--bg-card-hover)}.auto-start-item input[type=checkbox]{accent-color:var(--green);width:16px;height:16px}.auto-start-id{color:var(--text-dim);font-family:var(--font-mono);font-size:.7rem;margin-left:auto}.settings-actions{display:flex;justify-content:flex-end;gap:8px;padding-top:12px;border-top:1px solid var(--border);margin-top:auto}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.section-header h2{margin-bottom:0}.server-table{width:100%;border-collapse:collapse;font-size:.85rem}.server-table thead th{text-align:left;color:var(--text-dim);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:8px 12px;border-bottom:1px solid var(--border)}.server-table tbody tr{border-bottom:1px solid var(--border);transition:background .15s}.server-table tbody tr:hover{background:var(--bg-card-hover)}.server-table td{padding:10px 12px;vertical-align:middle}.server-table .mono{font-family:var(--font-mono);font-size:.8rem}.server-table .col-name{font-weight:600}.server-table .col-address,.server-table .col-pid,.server-table .col-uptime{color:var(--text-dim)}.server-table .col-actions{display:flex;gap:6px}.server-table .text-dim{color:var(--text-dim)}.new-server-form{display:flex;flex-direction:column;gap:8px;overflow-y:auto;padding-bottom:4px}.form-group{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.form-group label{font-size:.75rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.03em}.form-group input,.form-group select{width:100%;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:6px 8px;color:var(--text);font-size:.85rem;font-family:var(--font-mono)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--blue)}.form-row{display:flex;gap:10px}.form-section-title{font-size:.7rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;margin-top:8px;padding-bottom:4px;border-bottom:1px solid var(--border)}.server-id-label{font-family:var(--font-mono);font-size:.8rem;color:var(--text-dim);padding:6px 8px;background:var(--bg);border:1px solid var(--border);border-radius:6px}.btn-delete{border-color:#f8717166;color:var(--text-dim);font-size:.7rem}.btn-delete:hover{border-color:var(--red);color:var(--red);background:#f871711a}.btn-config{border-color:var(--blue);color:var(--blue)}.btn-config:hover{background:#60a5fa1a}.config-form{display:flex;flex-direction:column;gap:8px;overflow-y:auto;flex:1;padding-bottom:4px}.config-readonly input,.config-readonly select{opacity:.5;cursor:not-allowed}.config-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}.config-toggle-row label{font-size:.8rem;color:var(--text)}.config-toggle-row input[type=checkbox]{accent-color:var(--green);width:16px;height:16px}.config-toggle-row.config-readonly label{color:var(--text-dim)}.config-stopped-tag{font-size:.7rem;color:var(--warning, #e9a945);font-weight:400;margin-left:4px}.empty{color:var(--text-dim);font-size:.85rem;padding:12px;text-align:center}#players-panel .settings-panel-inner{max-width:700px}.players-role-list{max-height:400px;overflow-y:auto}.player-role-table{width:100%;border-collapse:collapse;font-size:.8rem}.player-role-table thead th{text-align:left;color:var(--text-dim);font-weight:500;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;padding:6px 8px;border-bottom:1px solid var(--border)}.player-role-table tbody td{padding:6px 8px;vertical-align:middle}.player-role-table tbody tr:nth-child(2n){background:#00000026}.role-select{background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:3px 6px;color:var(--text);font-size:.8rem;font-family:var(--font-mono);cursor:pointer}.role-select:focus{outline:none;border-color:var(--blue)}.settings-menu{position:relative}.settings-dropdown{position:absolute;right:0;top:calc(100% + 4px);background:var(--bg-card);border:1px solid var(--border);border-radius:6px;box-shadow:0 4px 16px #0006;z-index:950;min-width:180px;overflow:hidden}.settings-dropdown button{display:block;width:100%;padding:8px 14px;border:none;background:none;color:var(--text);font-size:.8rem;text-align:left;cursor:pointer;transition:background .15s}.settings-dropdown button:hover{background:var(--bg-card-hover)}.settings-dropdown button+button{border-top:1px solid var(--border)}.hidden{display:none}.manager-config-textarea{flex:1;min-height:300px;background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;color:var(--text);font-family:var(--font-mono);font-size:.8rem;line-height:1.5;resize:vertical;-moz-tab-size:2;tab-size:2}.manager-config-textarea:focus{outline:none;border-color:var(--blue)}#login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:9999;display:flex;align-items:center;justify-content:center;background:var(--bg)}.login-box{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:32px;width:340px;display:flex;flex-direction:column;gap:16px;text-align:center}.login-box h2{color:var(--accent);font-size:1.4rem}.login-box p{color:var(--text-dim);font-size:.9rem}.login-box input{background:var(--bg);border:1px solid var(--border);border-radius:6px;padding:10px 12px;color:var(--text);font-size:.95rem;width:100%}.login-box input:focus{outline:none;border-color:var(--blue)}.login-box button{background:var(--accent);color:#fff;border:none;border-radius:6px;padding:10px 0;font-size:.95rem;cursor:pointer;font-weight:600}.login-box button:hover{opacity:.9}.login-error{color:var(--red);font-size:.85rem;min-height:1.2em}
