/* ══════════════════════════════════════════════════════════
   Linux Cloud — Design System v1
   by RedNova · lnx.rednova.ar
   Based on RouterOS Cloud Design System v3
   Accent: green (#22c55e) en lugar de cyan
══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Geist:wght@300;400;500;600;700&family=IBM+Plex+Mono:wght@400;500&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
    --bg:#080b12;--surface:#0c1220;--elevated:#101828;--overlay:#141f32;--hover:rgba(255,255,255,.03);
    --border:rgba(255,255,255,.06);--border2:rgba(255,255,255,.09);--border3:rgba(255,255,255,.14);
    /* Verde como acento principal (diferencia visual con RouterOS Cloud) */
    --accent:#22c55e;--accent-bg:rgba(34,197,94,.1);--accent-glow:rgba(34,197,94,.2);
    --green:#22c55e;--green-bg:rgba(34,197,94,.1);
    --red:#f43f5e;--red-bg:rgba(244,63,94,.1);
    --amber:#f59e0b;--amber-bg:rgba(245,158,11,.1);
    --violet:#8b5cf6;--violet-bg:rgba(139,92,246,.1);
    --blue:#3b82f6;--blue-bg:rgba(59,130,246,.1);
    --cyan:#06b6d4;--cyan-bg:rgba(6,182,212,.1);
    --text:#f1f5f9;--text2:#94a3b8;--text3:#475569;--text4:#334155;
    --font:'Geist',system-ui,-apple-system,sans-serif;
    --mono:'IBM Plex Mono','JetBrains Mono',monospace;
    --r-sm:5px;--r-md:8px;--r-lg:12px;--r-xl:16px;
    --shadow-sm:0 1px 3px rgba(0,0,0,.4);
    --shadow-md:0 4px 12px rgba(0,0,0,.5);
    --shadow-lg:0 8px 32px rgba(0,0,0,.6);
}

/* ── Tema claro ── */
[data-theme="light"]{
    --bg:#f1f5f9;--surface:#ffffff;--elevated:#f8fafc;--overlay:#e2e8f0;--hover:rgba(0,0,0,.04);
    --border:rgba(0,0,0,.08);--border2:rgba(0,0,0,.12);--border3:rgba(0,0,0,.18);
    --accent:#16a34a;--accent-bg:rgba(22,163,74,.08);--accent-glow:rgba(22,163,74,.15);
    --green:#16a34a;--green-bg:rgba(22,163,74,.08);
    --red:#dc2626;--red-bg:rgba(220,38,38,.08);
    --amber:#d97706;--amber-bg:rgba(217,119,6,.08);
    --violet:#7c3aed;--violet-bg:rgba(124,58,237,.08);
    --blue:#2563eb;--blue-bg:rgba(37,99,235,.08);
    --text:#0f172a;--text2:#475569;--text3:#94a3b8;--text4:#cbd5e1;
    --shadow-sm:0 1px 3px rgba(0,0,0,.1);
    --shadow-md:0 4px 12px rgba(0,0,0,.15);
    --shadow-lg:0 8px 32px rgba(0,0,0,.2);
}

html{color-scheme:dark}
body{font-family:var(--font);background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;-webkit-font-smoothing:antialiased}
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}
::-webkit-scrollbar-thumb:hover{background:var(--border3)}

/* ── Layout ── */
.layout{display:flex;height:100vh;overflow:hidden}
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.content{flex:1;overflow-y:auto;padding:20px 22px}

/* ── Sidebar ── */
.sidebar{width:240px;min-width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;height:100vh;overflow:hidden;flex-shrink:0}
.sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;flex-direction:column;gap:10px}
.logo{display:flex;align-items:center;gap:10px}
.logo-icon{width:32px;height:32px;border-radius:var(--r-md);background:var(--accent-bg);border:1px solid rgba(34,197,94,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.logo-icon svg{width:16px;height:16px}
.logo-product{font-size:13px;font-weight:600;line-height:1.1;letter-spacing:-.3px}
.logo-company{font-size:10px;font-weight:500;color:var(--accent);letter-spacing:.04em;text-transform:uppercase}
.tenant-selector{background:var(--elevated);border:1px solid var(--border2);border-radius:var(--r-lg);padding:9px 11px;display:flex;align-items:center;gap:9px;cursor:pointer;transition:border-color .15s}
.tenant-selector:hover{border-color:var(--border3)}
.tenant-badge{width:24px;height:24px;border-radius:var(--r-sm);background:linear-gradient(135deg,#16a34a,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0}
.tenant-name{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}
.tenant-plan{font-size:10px;color:var(--text3)}
.tenant-info{flex:1;min-width:0}
.nav{flex:1;padding:10px 8px;overflow-y:auto}
.nav-section{padding:10px 8px 4px;font-size:10px;font-weight:600;color:var(--text4);text-transform:uppercase;letter-spacing:.1em}
.nav-item{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:var(--r-md);color:var(--text2);cursor:pointer;transition:all .12s;position:relative;text-decoration:none;border:none;background:none;width:100%;text-align:left;font-family:var(--font);font-size:13px}
.nav-item:hover{background:var(--hover);color:var(--text)}
.nav-item.active{background:var(--accent-bg);color:var(--accent)}
.nav-item.active::before{content:'';position:absolute;left:0;top:20%;bottom:20%;width:2px;background:var(--accent);border-radius:0 2px 2px 0}
.nav-icon{width:16px;height:16px;flex-shrink:0;display:flex;align-items:center}
.nav-icon svg{width:100%;height:100%}
.nav-text{font-weight:500;flex:1}
.nav-chip{font-size:10px;font-weight:700;padding:2px 6px;border-radius:20px}
.nav-chip.green{background:var(--green-bg);color:var(--green)}
.nav-chip.amber{background:var(--amber-bg);color:var(--amber)}
.nav-chip.red{background:var(--red-bg);color:var(--red)}
.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border)}
.sidebar-user{display:flex;align-items:center;gap:9px}
.sidebar-avatar{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,#16a34a,#7c3aed);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.sidebar-username{font-size:12px;font-weight:600}
.sidebar-role{font-size:10px;color:var(--text3)}
.sidebar-actions{margin-left:auto;display:flex;gap:4px}

/* ── Topbar ── */
.topbar{background:var(--surface);border-bottom:1px solid var(--border);height:48px;padding:0 20px;display:flex;align-items:center;gap:10px;flex-shrink:0}
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px}
.breadcrumb-sep{color:var(--text4)}
.breadcrumb-link{color:var(--text3);text-decoration:none}
.breadcrumb-link:hover{color:var(--text)}
.breadcrumb-current{color:var(--text);font-weight:600}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:6px}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border-radius:var(--r-md);border:1px solid var(--border2);background:var(--elevated);color:var(--text2);font-family:var(--font);font-size:12px;font-weight:600;cursor:pointer;transition:all .12s;white-space:nowrap;text-decoration:none}
.btn:hover{border-color:var(--border3);color:var(--text);text-decoration:none}
.btn svg{width:13px;height:13px;flex-shrink:0}
.btn.sm,.btn-sm{padding:4px 10px;font-size:11px}
.btn.lg{padding:9px 18px;font-size:14px}
.btn.primary,.btn-primary{background:var(--accent);border-color:var(--accent);color:#052e16;font-weight:700}
.btn.primary:hover,.btn-primary:hover{opacity:.88;color:#052e16}
.btn.danger,.btn-danger{background:var(--red-bg);border:1px solid rgba(244,63,94,.3);color:var(--red)}
.btn.success{background:var(--green-bg);border-color:rgba(34,197,94,.3);color:var(--green)}
.btn.ghost,.btn-ghost{background:transparent;border-color:transparent;color:var(--text3)}
.btn.ghost:hover,.btn-ghost:hover{background:var(--hover);color:var(--text);border-color:transparent}
.btn-secondary{background:var(--elevated);border:1px solid var(--border2);color:var(--text2);padding:7px 14px;border-radius:var(--r-md);cursor:pointer;font-family:var(--font);font-size:13px}
.icon-btn{width:32px;height:32px;border-radius:var(--r-md);background:transparent;border:1px solid var(--border2);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--text3);transition:all .12s;flex-shrink:0}
.icon-btn:hover{color:var(--text);border-color:var(--border3)}
.icon-btn svg{width:14px;height:14px}
.btn-group{display:flex;gap:6px;flex-wrap:wrap}

/* ── Page header ── */
.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:20px;gap:12px}
.page-title{font-size:20px;font-weight:700;letter-spacing:-.5px;line-height:1}
.page-subtitle{font-size:12px;color:var(--text3);margin-top:4px}
.page-actions{display:flex;gap:8px;flex-shrink:0}

/* ── Stats ── */
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px;position:relative;overflow:hidden}
.stat-card::before{content:'';position:absolute;top:0;left:0;right:0;height:2px}
.stat-card.total::before{background:linear-gradient(90deg,var(--accent),transparent)}
.stat-card.online::before{background:linear-gradient(90deg,var(--green),transparent)}
.stat-card.offline::before{background:linear-gradient(90deg,var(--red),transparent)}
.stat-card.warn::before{background:linear-gradient(90deg,var(--amber),transparent)}
.stat-card .num{font-size:32px;font-weight:700;letter-spacing:-1.5px;line-height:1;margin-bottom:6px}
.stat-card.total .num{color:var(--accent)}
.stat-card.online .num{color:var(--green)}
.stat-card.offline .num{color:var(--red)}
.stat-card.warn .num{color:var(--amber)}
.stat-card .lbl{font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.08em}

/* ── Cards ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;margin-bottom:14px}
.card-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.card-title{font-size:13px;font-weight:600;color:var(--text)}
.card-body{padding:14px;min-height:60px}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden;margin-bottom:14px}
.panel-header{padding:12px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;font-size:13px;font-weight:600}
.panel-body{padding:16px}

/* ── Tables ── */
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);overflow:hidden}
.table-wrap{overflow-x:auto}
.table-toolbar{padding:10px 14px;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:8px}
table,table.rtable{width:100%;border-collapse:collapse;font-size:13px}
thead tr{background:var(--elevated)}
th{padding:8px 14px;text-align:left;font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);white-space:nowrap}
td{padding:10px 14px;border-bottom:1px solid var(--border);vertical-align:middle}
tbody tr:last-child td{border-bottom:none}
tbody tr{transition:background .1s}
tbody tr:hover td{background:var(--hover)}
.search-input{background:var(--elevated);border:1px solid var(--border2);border-radius:var(--r-md);padding:5px 10px;color:var(--text);font-family:var(--font);font-size:12px;outline:none;min-width:200px}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--text4)}
.select-sm{background:var(--elevated);border:1px solid var(--border2);border-radius:var(--r-md);padding:5px 10px;color:var(--text);font-family:var(--font);font-size:12px;outline:none;cursor:pointer}
.select-sm:focus{border-color:var(--accent)}

/* ── Badges ── */
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.badge.online{background:var(--green-bg);color:var(--green)}
.badge.offline{background:var(--red-bg);color:var(--red)}
.badge.unknown{background:rgba(71,85,105,.15);color:var(--text3)}
.badge.warn{background:var(--amber-bg);color:var(--amber)}
.badge.info{background:var(--blue-bg);color:var(--blue)}
.badge-dot{width:5px;height:5px;border-radius:50%;background:currentColor}
.board{font-family:var(--mono);font-size:10px;color:var(--text2);background:var(--overlay);border:1px solid var(--border2);padding:2px 7px;border-radius:4px;white-space:nowrap}

/* Status específicos Linux Cloud */
.status-active{background:var(--green-bg);color:var(--green);border:1px solid rgba(34,197,94,.25);display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.status-pending{background:var(--amber-bg);color:var(--amber);border:1px solid rgba(245,158,11,.25);display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.status-unreachable{background:var(--red-bg);color:var(--red);border:1px solid rgba(244,63,94,.25);display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.status-disabled{background:rgba(71,85,105,.1);color:var(--text3);border:1px solid var(--border2);display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600}
.status-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;font-family:var(--mono)}

/* Status dots */
.status-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;display:inline-block}
.status-dot.online{background:var(--green);box-shadow:0 0 5px rgba(34,197,94,.5)}
.status-dot.offline{background:var(--red)}
.status-dot.unknown{background:var(--text4)}

/* ── Metrics / bars ── */
.metric{font-family:var(--mono);font-size:12px;font-weight:500}
.metric.low{color:var(--text2)}
.metric.warn{color:var(--amber)}
.metric.crit{color:var(--red)}
.mini-bar{display:flex;align-items:center;gap:7px}
.bar-track{width:44px;height:3px;background:var(--overlay);border-radius:2px;overflow:hidden}
.bar-fill{height:100%;border-radius:2px;transition:width .3s}
.bar-fill.low{background:var(--green)}
.bar-fill.warn{background:var(--amber)}
.bar-fill.crit{background:var(--red)}

/* ── Forms ── */
.form-group{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.form-group label,.form-label{font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-full{grid-column:1/-1}
.form-hint{font-size:11px;color:var(--text3)}
.form-actions{display:flex;gap:8px;margin-top:4px}
input,select,textarea,.form-input{background:var(--elevated);border:1px solid var(--border2);border-radius:var(--r-md);color:var(--text);font-family:var(--font);font-size:13px;padding:8px 12px;outline:none;transition:border-color .15s;color-scheme:dark;width:100%}
input:focus,select:focus,textarea:focus,.form-input:focus{border-color:var(--accent)}
input::placeholder,textarea::placeholder,.form-input::placeholder{color:var(--text4)}
select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475569' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px;cursor:pointer}
textarea{resize:vertical;min-height:80px}

/* ── Modals ── */
.overlay,.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:1000;align-items:flex-start;justify-content:center;padding:40px 20px;overflow-y:auto}
.overlay.open,.modal-overlay.open{display:flex}
.modal{background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-xl);width:100%;max-width:640px;box-shadow:var(--shadow-lg);margin:auto;padding:22px}
.modal h3{font-size:16px;font-weight:700;margin-bottom:16px;letter-spacing:-.3px}
.modal-header{padding:16px 20px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.modal-header h3{font-size:15px;font-weight:700;letter-spacing:-.3px;margin-bottom:0}
.modal-close{background:none;border:none;color:var(--text3);cursor:pointer;font-size:20px;line-height:1;padding:0 4px}
.modal-close:hover{color:var(--text)}
.modal-body{padding:20px}
.modal-footer{padding:14px 20px;border-top:1px solid var(--border);display:flex;gap:8px;justify-content:flex-end}

/* ── Alerts / Toast ── */
.alert{border-radius:var(--r-md);padding:10px 14px;margin-bottom:14px;font-size:13px;font-weight:600;display:flex;align-items:center;gap:8px}
.alert.success,.alert-success{background:var(--green-bg);border:1px solid rgba(34,197,94,.25);color:var(--green)}
.alert.error,.alert-error{background:var(--red-bg);border:1px solid rgba(244,63,94,.25);color:var(--red)}
.alert.warning,.alert-warning{background:var(--amber-bg);border:1px solid rgba(245,158,11,.25);color:var(--amber)}
.alert.info,.alert-info{background:var(--blue-bg);border:1px solid rgba(59,130,246,.25);color:var(--blue)}
#toast,#toasts,.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}
.toast{padding:10px 16px;border-radius:var(--r-md);font-size:13px;font-weight:600;box-shadow:var(--shadow-md);pointer-events:auto;display:flex;align-items:center;gap:8px;animation:toastIn .2s ease}
.toast.ok,.toast.success{background:var(--green-bg);border:1px solid rgba(34,197,94,.3);color:var(--green)}
.toast.error{background:var(--red-bg);border:1px solid rgba(244,63,94,.3);color:var(--red)}
.toast.warn{background:var(--amber-bg);border:1px solid rgba(245,158,11,.3);color:var(--amber)}
.toast.info{background:var(--blue-bg);border:1px solid rgba(59,130,246,.3);color:var(--blue)}
@keyframes toastIn{from{transform:translateX(20px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ── Tabs ── */
.tabs{display:flex;gap:2px;border-bottom:1px solid var(--border);margin-bottom:16px}
.tab,.tab-btn{padding:8px 14px;background:none;border:none;border-bottom:2px solid transparent;color:var(--text3);font-family:var(--font);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s;margin-bottom:-1px}
.tab:hover,.tab-btn:hover{color:var(--text2)}
.tab.active,.tab-btn.active{color:var(--accent);border-bottom-color:var(--accent)}
.tab-content{display:none}
.tab-content.active{display:block}

/* ── Install card (específico Linux Cloud) ── */
.install-card{border-color:rgba(34,197,94,.2)!important}
.install-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}
.install-header h3{font-size:.95rem;font-weight:600}
.expiry-badge{font-family:var(--mono);font-size:10px;color:var(--amber);background:var(--amber-bg);border:1px solid rgba(245,158,11,.2);padding:2px 8px;border-radius:20px}
.install-desc{font-size:12px;color:var(--text3);margin-bottom:12px}
.curl-command{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--border2);border-radius:var(--r-md);padding:10px 14px;margin-bottom:14px;font-family:var(--mono);font-size:12px;color:var(--accent);overflow-x:auto}
.curl-command code{flex:1;white-space:nowrap}
.copy-btn{background:none;border:none;color:var(--text3);cursor:pointer;padding:2px;transition:color .15s;flex-shrink:0}
.copy-btn:hover{color:var(--accent)}
.install-steps{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}
.step{display:flex;align-items:flex-start;gap:9px;font-size:12px;color:var(--text2)}
.step-num{width:20px;height:20px;background:var(--elevated);border:1px solid var(--border2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--text3);flex-shrink:0;margin-top:1px}
.install-footer{display:flex;gap:6px;padding-top:12px;border-top:1px solid var(--border)}
.install-expired{text-align:center;padding:12px 0}
.install-expired h3{color:var(--red);margin-bottom:6px}
.install-expired p{color:var(--text3);font-size:12px;margin-bottom:14px}

/* ── Server detail ── */
.server-detail-grid{display:flex;flex-direction:column;gap:14px}
.info-grid{display:grid;grid-template-columns:140px 1fr;gap:6px 12px;font-size:12px}
.info-grid dt{color:var(--text3)}
.info-grid dd{color:var(--text)}

/* ── Quick actions ── */
.quick-actions{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}
.action-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 10px;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);color:var(--text2);font-size:12px;transition:all .15s;text-align:center;text-decoration:none}
.action-card:hover{border-color:rgba(34,197,94,.3);background:var(--accent-bg);color:var(--accent);text-decoration:none;transform:translateY(-1px)}
.action-icon{font-size:1.3rem}
.action-label{font-weight:600}

/* ── Terminal / Logs ── */
.terminal{background:var(--bg);border:1px solid var(--border2);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column}
.terminal-out{flex:1;overflow-y:auto;padding:12px 14px;font-family:var(--mono);font-size:12px;line-height:1.7;color:var(--text2)}
.terminal-prompt-row{background:var(--elevated);border-top:1px solid var(--border);padding:8px 12px;display:flex;align-items:center;gap:8px}
.terminal-prompt{color:var(--accent);font-family:var(--mono);font-size:13px;font-weight:500}
.terminal-input{flex:1;background:transparent;border:none;color:var(--text);font-family:var(--mono);font-size:13px;outline:none;caret-color:var(--accent)}

/* ── Module layout ── */
.module-layout{display:flex;height:calc(100vh - 48px);overflow:hidden}
.module-sidebar{width:240px;min-width:240px;background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}
.module-sidebar-header{padding:10px 14px;font-size:10px;font-weight:700;color:var(--text4);text-transform:uppercase;letter-spacing:.08em;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.module-main{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:14px}
.server-list{overflow-y:auto;flex:1}
.server-item{padding:10px 14px;display:flex;align-items:center;gap:9px;cursor:pointer;border-bottom:1px solid var(--border);transition:background .1s}
.server-item:hover{background:var(--hover)}
.server-item.active{background:var(--accent-bg)}
.server-item-name{font-size:12px;font-weight:600;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}
.server-item-ip{font-family:var(--mono);font-size:10px;color:var(--text3);margin-top:1px}

/* ── Login ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:var(--bg)}
.login-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border2);border-radius:var(--r-xl);padding:28px;box-shadow:var(--shadow-lg)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo-icon{width:52px;height:52px;border-radius:var(--r-xl);background:var(--accent-bg);border:1px solid rgba(34,197,94,.25);display:flex;align-items:center;justify-content:center;margin:0 auto 14px}
.login-logo-icon svg{width:24px;height:24px;color:var(--accent)}
.login-product{font-size:18px;font-weight:700;letter-spacing:-.4px}
.login-company{font-size:11px;color:var(--accent);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-top:2px}
.login-hint{text-align:center;font-size:11px;color:var(--text4);margin-top:18px}

/* ── Misc ── */
code{background:var(--overlay);border:1px solid var(--border2);border-radius:4px;padding:1px 6px;font-family:var(--mono);font-size:12px;color:var(--accent)}
.spinner{display:inline-block;width:14px;height:14px;border:2px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.pulse-dot{width:7px;height:7px;border-radius:50%;background:var(--green);animation:pulseAnim 2.5s ease-in-out infinite;flex-shrink:0}
@keyframes pulseAnim{0%,100%{box-shadow:0 0 0 0 rgba(34,197,94,.4)}50%{box-shadow:0 0 0 4px transparent}}
.spacer{flex:1}
.sep{width:1px;height:18px;background:var(--border2);margin:0 4px}
.text-muted{color:var(--text3)}
.text-sm{font-size:12px}
.text-xs{font-size:11px}
.font-mono{font-family:var(--mono)}
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;color:var(--text3);text-align:center}
.empty-state h3{font-size:15px;font-weight:600;color:var(--text);margin-bottom:8px;margin-top:8px}
.empty-state p{font-size:12px;line-height:1.6;max-width:360px;margin-bottom:16px}
.row-actions{display:flex;gap:3px;justify-content:flex-end}
.flash{padding:9px 22px;font-size:13px;font-weight:600;border-bottom:1px solid transparent}
.flash.success{background:var(--green-bg);border-color:rgba(34,197,94,.3);color:var(--green)}
.flash.error{background:var(--red-bg);border-color:rgba(244,63,94,.3);color:var(--red)}
input[type=checkbox]{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:3px;border:1.5px solid var(--border3);background:var(--elevated);cursor:pointer;flex-shrink:0;transition:all .15s;vertical-align:middle}
input[type=checkbox]:hover{border-color:var(--accent)}
input[type=checkbox]:checked{background:var(--accent);border-color:var(--accent);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10 10'%3E%3Cpolyline points='1.5,5 4,7.5 8.5,2.5' fill='none' stroke='%23052e16' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:10px 10px}

/* Compat */
.main-content { flex:1; overflow-y:auto; padding:20px 22px; }
body { display:flex; }

/* Fix layout */
.main-content { padding: 24px 28px; }
.card { padding: 0; }
.card-header { padding: 12px 16px; }
.card-body { padding: 14px 16px; }
.info-grid { padding: 0 2px; row-gap: 10px; }
.info-grid dt { font-size: 11px; font-weight: 600; color: var(--text3); text-transform: uppercase; letter-spacing: .05em; }
.info-grid dd { font-size: 13px; }
.server-detail-grid { gap: 14px; }
.page-header { margin-bottom: 20px; }
.page-title { font-size: 20px; font-weight: 700; }
.status-active { font-size: 11px; }

/* Quick actions */
.quick-actions { grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); gap: 10px; margin-top: 4px; }
.action-card { padding: 18px 12px; border-radius: var(--r-lg); font-size: 12px; font-weight: 600; }
.action-icon { font-size: 1.5rem; margin-bottom: 2px; }

/* Danger zone */
.card-danger { border-color: rgba(244,63,94,.2); }
.card-danger .card-title { color: var(--red); }

/* Aliases servers.php */
.btn-primary { background:var(--accent);border:1px solid var(--accent);color:#052e16;font-weight:700;padding:7px 13px;border-radius:var(--r-md);cursor:pointer;font-family:var(--font);font-size:12px;display:inline-flex;align-items:center;gap:6px;text-decoration:none;white-space:nowrap; }
.btn-primary:hover { opacity:.88; text-decoration:none; color:#052e16; }
.btn-ghost { background:transparent;border:1px solid var(--border2);color:var(--text2);padding:7px 13px;border-radius:var(--r-md);cursor:pointer;font-family:var(--font);font-size:12px;display:inline-flex;align-items:center;gap:6px;text-decoration:none;white-space:nowrap; }
.btn-ghost:hover { border-color:var(--border3);color:var(--text);text-decoration:none; }
.btn-sm { padding:4px 10px;font-size:11px; }
.btn-danger { background:var(--red-bg);border:1px solid rgba(244,63,94,.3);color:var(--red);padding:7px 13px;border-radius:var(--r-md);cursor:pointer;font-family:var(--font);font-size:12px;display:inline-flex;align-items:center;gap:6px; }
.form-input { background:var(--elevated);border:1px solid var(--border2);border-radius:var(--r-md);color:var(--text);font-family:var(--font);font-size:13px;padding:8px 12px;outline:none;width:100%; }
.form-input:focus { border-color:var(--accent); }
.form-label { font-size:11px;font-weight:600;color:var(--text3);text-transform:uppercase;letter-spacing:.05em;display:block;margin-bottom:5px; }
.form-hint { font-size:11px;color:var(--text3);margin-top:4px;display:block; }
.form-actions { display:flex;gap:8px;margin-top:8px; }
.header-actions { display:flex;gap:8px;align-items:center; }
.text-muted { color:var(--text3); }
.mono { font-family:var(--mono);font-size:12px; }
.alert-success { background:var(--green-bg);border:1px solid rgba(34,197,94,.25);color:var(--green);border-radius:var(--r-md);padding:10px 14px;margin-bottom:14px;font-size:13px;font-weight:600; }
.alert-error { background:var(--red-bg);border:1px solid rgba(244,63,94,.25);color:var(--red);border-radius:var(--r-md);padding:10px 14px;margin-bottom:14px;font-size:13px;font-weight:600; }
.server-detail-grid { display:flex;flex-direction:column;gap:14px; }
.info-grid { display:grid;grid-template-columns:160px 1fr;gap:8px 16px;font-size:13px; }
.info-grid dt { color:var(--text3);font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;display:flex;align-items:center; }
.info-grid dd { color:var(--text); }

/* Full width fix */
.layout { width: 100%; }
.main { width: 100%; }
.content { max-width: none; width: 100%; }
.panel { max-width: none; }
.table-card { max-width: none; }
.section-box { max-width: none; }
