:root{--bg: #0f172a;--surface: #1e293b;--border: #334155;--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--blue: #3b82f6;--text: #f1f5f9;--muted: #94a3b8}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;font-size:15px}.app{display:flex;flex-direction:column;min-height:100vh}main{flex:1;max-width:1100px;margin:0 auto;width:100%;padding:28px 20px}.navbar{background:var(--surface);border-bottom:1px solid var(--border);padding:0 20px;display:flex;align-items:center;height:56px;gap:4px;position:sticky;top:0;z-index:50}.navbar-brand{font-weight:800;font-size:.95rem;color:var(--green);margin-right:12px;letter-spacing:-.02em;flex-shrink:0}.navbar-brand span{color:var(--muted);font-weight:400}.nav-tab{background:none;border:none;color:var(--muted);padding:7px 14px;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:background .15s,color .15s}.nav-tab:hover{background:#ffffff0f;color:var(--text)}.nav-tab.active{background:#22c55e1f;color:var(--green)}.nav-spacer{flex:1}.nav-logout{background:none;border:1px solid var(--border);color:var(--muted);padding:5px 12px;border-radius:6px;cursor:pointer;font-size:.8rem}.nav-logout:hover{color:var(--red);border-color:var(--red)}.page-header{margin-bottom:24px}.page-header h1{font-size:1.4rem;font-weight:700}.page-header p{color:var(--muted);margin-top:4px;font-size:.875rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.card-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:14px}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 640px){.grid-2{grid-template-columns:1fr}}.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:999px;font-size:.75rem;font-weight:600}.badge:before{content:"";width:6px;height:6px;border-radius:50%}.badge-green{background:#22c55e1f;color:var(--green)}.badge-green:before{background:var(--green)}.badge-red{background:#ef44441f;color:var(--red)}.badge-red:before{background:var(--red)}.badge-gray{background:#94a3b81a;color:var(--muted)}.badge-gray:before{background:var(--muted)}.badge-yellow{background:#f59e0b1f;color:var(--yellow)}.badge-yellow:before{background:var(--yellow)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:7px;border:none;cursor:pointer;font-size:.875rem;font-weight:500;transition:opacity .15s,background .15s;white-space:nowrap}.btn:hover:not(:disabled){opacity:.85}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--blue);color:#fff}.btn-green{background:var(--green);color:#0f172a;font-weight:700}.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){opacity:1;color:var(--text);border-color:var(--muted)}.btn-danger{background:#ef44441f;color:var(--red);border:1px solid rgba(239,68,68,.2)}.btn-sm{padding:5px 11px;font-size:.8rem}.form-stack{display:flex;flex-direction:column;gap:14px}.form-group{display:flex;flex-direction:column;gap:5px}.form-group label{font-size:.8rem;font-weight:500;color:var(--muted)}.form-group input,.form-group select{background:var(--bg);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:7px;font-size:.875rem;width:100%;transition:border-color .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--blue)}.form-group select option{background:var(--surface)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px}.modal{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:460px;max-height:90vh;overflow-y:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.modal-header h2{font-size:1.05rem;font-weight:700}.modal-close{background:none;border:none;color:var(--muted);font-size:1.4rem;cursor:pointer;line-height:1;padding:2px 6px;border-radius:4px}.modal-close:hover{color:var(--text);background:#ffffff0f}.modal-footer{display:flex;justify-content:flex-end;gap:10px;margin-top:22px}.table-wrap{overflow-x:auto}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:.72rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:8px 12px;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:11px 12px;border-bottom:1px solid rgba(51,65,85,.5);vertical-align:middle}.table tr:last-child td{border-bottom:none}.toggle-wrap{display:flex;align-items:center}.toggle{position:relative;display:inline-block;width:40px;height:22px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0;position:absolute}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:22px;cursor:pointer;transition:background .2s}.toggle input:checked+.toggle-slider{background:var(--green)}.toggle input:disabled+.toggle-slider{opacity:.4;cursor:not-allowed}.toggle-slider:before{content:"";position:absolute;height:16px;width:16px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle input:checked+.toggle-slider:before{transform:translate(18px)}.avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;flex-shrink:0;color:#fff}.connect-addr{font-family:SFMono-Regular,Consolas,monospace;font-size:.8rem;background:#0f172acc;border:1px solid var(--border);padding:5px 10px;border-radius:5px;color:var(--green);display:inline-block;margin-top:8px;-webkit-user-select:all;user-select:all}.world-list{display:flex;flex-direction:column;gap:10px}.world-card{background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:16px 18px;display:flex;align-items:center;gap:14px}.world-card.permanent{border-left:3px solid var(--green)}.world-card.active{border-left:3px solid var(--blue)}.world-info{flex:1;min-width:0}.world-name{font-weight:600;font-size:.95rem}.world-meta{font-size:.78rem;color:var(--muted);margin-top:3px}.stat-row{display:flex;flex-direction:column;gap:10px}.stat-item{display:flex;justify-content:space-between;align-items:center}.stat-label{font-size:.8rem;color:var(--muted)}.stat-value{font-size:.9rem;font-weight:500}.loading{display:flex;align-items:center;justify-content:center;height:100vh;color:var(--muted);font-size:.9rem;gap:10px}.error-msg{color:var(--red);font-size:.82rem;margin-top:6px}.section-gap{margin-top:24px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.mt-1{margin-top:4px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.mb-4{margin-bottom:16px}.w-full{width:100%}.text-sm{font-size:.875rem}.text-xs{font-size:.78rem}.text-muted{color:var(--muted)}.font-mono{font-family:monospace}.font-bold{font-weight:700}.refresh-note{font-size:.75rem;color:var(--muted);text-align:right;margin-bottom:12px}.spinning{display:inline-block;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}
