*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#1a1a2e;color:#eee;min-height:100vh}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:1rem}.login-container form{display:flex;flex-direction:column;gap:.75rem;width:280px}input{padding:.75rem;border:1px solid #333;border-radius:4px;background:#16213e;color:#eee}button{padding:.75rem 1rem;border:none;border-radius:4px;background:#0f4c75;color:#fff;cursor:pointer;transition:background .2s}button:hover:not(:disabled){background:#3282b8}button:disabled{opacity:.5;cursor:not-allowed}.error{color:#e74c3c;margin:.5rem 0}.app-container{max-width:1000px;margin:0 auto;padding:1rem}header{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;border-bottom:1px solid #333;margin-bottom:1rem}.user-info{display:flex;align-items:center;gap:1rem}table{width:100%;border-collapse:collapse}th,td{padding:.75rem;text-align:left;border-bottom:1px solid #333}th{background:#16213e}.status-running{color:#2ecc71}.status-exited,.status-stopped{color:#e74c3c}.status-missing{color:#f39c12}.error-tooltip{display:inline-block;margin-left:.5rem;cursor:help;color:#e74c3c;font-size:1rem}td button{padding:.4rem .75rem;font-size:.875rem}.action-buttons-grid{display:grid;grid-template-columns:1fr 1fr;gap:.35rem;min-width:140px}.action-buttons-grid button{margin:0;padding:.35rem .5rem;font-size:.8rem;white-space:nowrap}.btn-control{background:#4a4a5a}.btn-control:hover:not(:disabled){background:#5a5a6a}.main-content{display:grid;grid-template-columns:1fr 300px;gap:1.5rem}.servers-section{min-width:0}.server-name.clickable{cursor:pointer;color:#3282b8}.server-name.clickable:hover{text-decoration:underline}.btn-logs{background:#2c3e50}.btn-logs:hover{background:#34495e}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000}.modal-content{background:#1a1a2e;border:1px solid #333;border-radius:8px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column}.log-modal{width:900px;height:600px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid #333}.modal-header h2{font-size:1.1rem}.modal-close{background:none;border:none;color:#999;font-size:1.5rem;cursor:pointer;padding:0;line-height:1}.modal-close:hover{color:#fff}.modal-body{flex:1;overflow:hidden;padding:1rem}.log-output{width:100%;height:100%;overflow:auto;background:#0d0d1a;padding:1rem;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.8rem;line-height:1.4;white-space:pre-wrap;word-break:break-all;color:#ccc}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-top:1px solid #333;font-size:.85rem}.modal-footer label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.log-refresh-indicator{color:#666}.status-panel{background:#16213e;border-radius:8px;padding:1rem}.status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.status-header h3{font-size:1rem}.hostname{font-size:.85rem;color:#888}.status-grid{display:flex;flex-direction:column;gap:.75rem}.status-item{display:grid;grid-template-columns:60px 1fr auto;align-items:center;gap:.5rem}.status-label{font-size:.85rem;color:#888}.status-bar{height:8px;background:#0d0d1a;border-radius:4px;overflow:hidden}.status-bar-fill{height:100%;background:linear-gradient(90deg,#2ecc71,#27ae60);transition:width .3s ease}.status-value{font-size:.8rem;color:#aaa;min-width:80px;text-align:right}.servers-status{margin-top:.5rem;padding-top:.75rem;border-top:1px solid #333}.audit-logs{margin-top:1rem;border-top:1px solid #333;padding-top:.75rem}.audit-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:.25rem 0}.audit-header h4{font-size:.9rem;font-weight:400}.toggle{color:#666;font-size:.75rem}.audit-list{margin-top:.5rem;max-height:200px;overflow-y:auto}.audit-entry{display:flex;gap:.5rem;font-size:.75rem;padding:.35rem 0;border-bottom:1px solid #222}.audit-time{color:#666;min-width:70px}.audit-user{color:#3282b8;min-width:60px}.audit-action{min-width:40px}.action-start{color:#2ecc71}.action-stop{color:#e74c3c}.audit-server{color:#888}.no-logs{color:#666;font-size:.85rem;font-style:italic}.active-server-info{margin:1rem 0;padding:1rem;background:#16213e;border-radius:8px;text-align:center}.active-server-info p{margin:0;color:#aaa}.active-server-info strong{color:#3282b8}.active-server-link{color:#3282b8;cursor:pointer;text-decoration:underline}.active-server-link:hover{color:#5ba3d0}.active-servers-display{display:flex;flex-direction:column;gap:1rem;align-items:center;width:100%}.server-game-group{text-align:center;width:100%}.server-game-name{font-weight:600;color:#3282b8;font-size:1rem;margin-bottom:.4rem}.server-worlds-row{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.server-world-item{display:flex;align-items:center;gap:.3rem;color:#aaa;font-size:.9rem;cursor:help;transition:opacity .3s,transform .2s}.server-world-item.world-online{opacity:1}.server-world-item.world-offline{opacity:.5}.server-world-item:hover{transform:scale(1.05)}.status-dot{font-size:.6rem}.dot-online{color:#2ecc71}.dot-offline{color:#666}.active-servers-public-display{display:flex;flex-direction:column;gap:1.5rem;align-items:center;margin-top:.75rem}.server-game-group-public{text-align:center;width:100%}.server-game-group-public .server-game-name{font-weight:600;color:#3282b8;font-size:1.1rem;margin-bottom:.5rem}.server-game-group-public .server-worlds-row{display:flex;gap:1.5rem;justify-content:center;flex-wrap:wrap}.server-game-group-public .server-world-item{cursor:pointer;transition:transform .2s,opacity .3s}.server-game-group-public .server-world-item:hover{transform:scale(1.1)}.password-modal{width:400px;padding:1.5rem}.password-modal h2{margin-bottom:1rem;font-size:1.3rem}.warning-text{color:#f39c12;margin-bottom:1rem;padding:.75rem;background:#f39c121a;border-radius:4px;border-left:3px solid #f39c12}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#aaa;font-size:.9rem}.form-group input{width:100%}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem}.modal-actions button{flex:1}.server-status-page{width:100%}.status-page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #333}.back-button{background:#2c3e50;padding:.5rem 1rem}.back-button:hover{background:#34495e}.status-page-header h2{margin:0;font-size:1.5rem}.status-page-content{display:flex;flex-direction:column;gap:1.5rem}.logs-section{background:#16213e;border-radius:8px;padding:1rem;display:flex;flex-direction:column;min-height:500px}.logs-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid #333}.logs-header h3{margin:0;font-size:1.1rem}.logs-controls{display:flex;align-items:center;gap:1rem;font-size:.85rem}.auto-scroll-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;color:#aaa}.log-output-page{flex:1;width:100%;overflow:auto;background:#0d0d1a;padding:1rem;border-radius:4px;font-family:Consolas,Monaco,monospace;font-size:.85rem;line-height:1.5;white-space:pre-wrap;word-break:break-all;color:#ccc;min-height:400px}.loading-text{color:#666;font-style:italic}.maps-page{width:100%;height:calc(100vh - 120px);display:flex;flex-direction:column}.maps-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid #333}.maps-header h2{flex:1;margin:0;font-size:1.5rem}.fullscreen-link{color:#3282b8;text-decoration:none;padding:.5rem 1rem;border:1px solid #3282b8;border-radius:4px;transition:all .2s}.fullscreen-link:hover{background:#3282b8;color:#fff}.maps-container{flex:1;background:#0d0d1a;border-radius:8px;overflow:hidden;min-height:400px}.bluemap-iframe{width:100%;height:100%;border:none}.maps-loading,.maps-error{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;background:#16213e;border-radius:8px;padding:2rem;text-align:center;gap:1rem}.maps-error button{margin-top:1rem}.maps-info{margin-top:1rem;padding:1rem;background:#16213e;border-radius:8px;font-size:.9rem}.maps-info p{margin:.5rem 0}.maps-hint{color:#888;font-size:.85rem}.nav-section{margin-bottom:1.5rem;display:flex;gap:1rem}.nav-button{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#16213e;border:1px solid #333;border-radius:8px;color:#eee;cursor:pointer;transition:all .2s}.nav-button:hover{background:#1e2d4a;border-color:#3282b8}.nav-button-icon{font-size:1.2rem}@media (max-width: 800px){.main-content{grid-template-columns:1fr}.status-panel{order:-1}.log-modal,.console-modal{width:95vw;height:80vh}.password-modal{width:90vw;max-width:400px}.logs-section{min-height:300px}.log-output-page{min-height:250px;font-size:.75rem}.status-page-header h2{font-size:1.2rem}}.console-modal{width:90vw;max-width:1000px;height:70vh;display:flex;flex-direction:column}.console-body{display:flex;flex-direction:column;flex:1;padding:0;overflow:hidden}.console-logs{flex:1;overflow:auto;background:#0d1117;padding:1rem;margin-bottom:1rem;border-radius:4px}.console-output{margin:0;padding:0;font-family:Courier New,monospace;font-size:.9rem;line-height:1.4;color:#c9d1d9;background:transparent;white-space:pre-wrap;word-wrap:break-word}.console-input-section{padding:1rem;background:#16213e;border-top:1px solid #333}.console-form{display:flex;gap:.5rem}.console-input{flex:1;font-family:Courier New,monospace;padding:.5rem;background:#0d1117;border:1px solid #333;border-radius:4px;color:#c9d1d9}.console-input:focus{outline:none;border-color:#0f4c75}.console-send-btn{padding:.5rem 1.5rem;background:#0f4c75;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background .2s}.console-send-btn:hover:not(:disabled){background:#3282b8}.console-send-btn:disabled{opacity:.5;cursor:not-allowed}.console-info{color:#888;font-size:.85rem}.chat-interface{background:#16213e;border-radius:4px;border:1px solid #333;display:flex;flex-direction:column;overflow:hidden}.chat-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:#0f1923;border-bottom:1px solid #333}.chat-header h3{margin:0;font-size:1rem}.chat-username-display{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:#3282b8}.change-username-btn{padding:.25rem .5rem;font-size:.85rem;background:transparent;border:1px solid #333;color:#888;cursor:pointer}.change-username-btn:hover{color:#3282b8;border-color:#3282b8}.chat-username-setup{padding:2rem;display:flex;justify-content:center;align-items:center}.chat-username-setup form{display:flex;gap:.5rem;width:100%;max-width:400px}.chat-username-setup input{flex:1}.chat-messages{flex:0 0 auto;overflow-y:auto;padding:.75rem;height:180px;background:#1a1a2e;max-height:180px}.chat-empty{color:#666;text-align:center;padding:2rem}.chat-message{padding:.4rem 0;word-wrap:break-word}.chat-message.minecraft{color:#2ecc71}.chat-message.webapp{color:#eee}.chat-username{font-weight:700;margin-right:.5rem;color:#3282b8}.chat-message.minecraft .chat-username{color:#27ae60}.chat-text{color:inherit}.chat-input-form{display:flex;padding:.75rem;gap:.5rem;background:#0f1923;border-top:1px solid #333}.chat-input-form input{flex:1;margin:0}.chat-input-form button{padding:.5rem 1rem}.maps-page .chat-interface{margin-top:1rem}.main-content .chat-interface{margin-bottom:1rem}.login-container .chat-interface{width:100%;max-width:600px;margin:1.5rem auto}.chat-context-menu{position:fixed;background:#16213e;border:1px solid #3282b8;border-radius:4px;padding:.25rem 0;box-shadow:0 2px 8px #0000004d;z-index:1000}.chat-context-menu button{display:block;width:100%;padding:.5rem 1rem;background:transparent;border:none;color:#eee;text-align:left;cursor:pointer;font-size:.9rem}.chat-context-menu button:hover{background:#0f4c75}.chat-banned-notice{padding:1rem;text-align:center;color:#e74c3c;background:#1a0f0f;border-top:1px solid #333;font-weight:700}.server-details-page{width:100%;max-width:1200px;margin:0 auto}.details-page-header{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid #333}.details-page-header h2{margin:0;font-size:1.8rem}.details-page-content{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}@media (max-width: 900px){.details-page-content{grid-template-columns:1fr}}.server-info-section{display:flex;flex-direction:column;gap:1.5rem}.info-card{background:#16213e;border-radius:8px;padding:1.5rem}.info-card h3{margin:0 0 1rem;font-size:1.2rem;color:#3282b8}.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.info-item{display:flex;flex-direction:column;gap:.3rem}.info-item.full-width{grid-column:1 / -1}.youtube-embed{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #333;display:flex;justify-content:center}.youtube-embed iframe{max-width:100%;border-radius:8px}.info-label{font-size:.85rem;color:#888;font-weight:500}.info-value{font-size:1rem;color:#eee}.status-badge{display:inline-block;padding:.3rem .8rem;border-radius:4px;font-weight:600;font-size:.9rem}.status-badge.status-running{background:#2ecc7133;color:#2ecc71}.status-badge.status-stopped,.status-badge.status-exited,.status-badge.status-failed{background:#e74c3c33;color:#e74c3c}.status-badge.status-unknown,.status-badge.status-activating,.status-badge.status-deactivating{background:#f39c1233;color:#f39c12}.server-actions{display:flex;gap:1rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #333}.action-btn{flex:1;padding:.75rem 1rem;font-size:1rem;font-weight:600;border-radius:4px}.start-btn{background:#27ae60}.start-btn:hover:not(:disabled){background:#2ecc71}.stop-btn{background:#c0392b}.stop-btn:hover:not(:disabled){background:#e74c3c}.connection-info{color:#aaa;line-height:1.6}.connection-info p{margin:.5rem 0}.details-logs-section{display:flex;flex-direction:column;background:#16213e;border-radius:8px;padding:1.5rem;max-height:600px}.details-logs-section h3{margin:0 0 1rem;font-size:1.2rem;color:#3282b8}.details-logs-section .log-output-page{min-height:450px;max-height:500px}
