*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',sans-serif;background:#111827;color:#f0f0f0;min-height:100vh}

.topbar{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:#1e2235;border-bottom:0.5px solid #2a2f3a;position:sticky;top:0;z-index:100}
.logo-area{display:flex;align-items:center;gap:10px}
.logo-text{display:flex;flex-direction:column;line-height:1.1}
.logo-name{font-size:14px;font-weight:500;color:#f0f0f0;letter-spacing:.3px}
.logo-sub{font-size:10px;color:#f07800;letter-spacing:1px;text-transform:uppercase}
.nav-menu{display:flex;align-items:center;gap:4px}
.nav-link{color:#9ca3af;text-decoration:none;font-size:13px;font-weight:500;padding:6px 14px;border-radius:6px;transition:all .2s}
.nav-link:hover{color:#f0f0f0;background:#23262e}
.nav-active{color:#f07800!important;background:rgba(240,120,0,.12)!important;border:0.5px solid rgba(240,120,0,.3)}
.nav-actions{display:flex;align-items:center;gap:8px}
.nav-cliente{font-size:13px;color:#9ca3af}
.btn-danger{background:transparent;color:#e74c3c;padding:6px 14px;border-radius:6px;text-decoration:none;border:0.5px solid #c0392b;font-size:13px;font-weight:500;transition:all .2s}
.btn-danger:hover{background:#3a1515}

.content{padding:24px;max-width:1400px;margin:0 auto}
.footer{display:flex;justify-content:space-between;padding:16px 24px;font-size:11px;color:#6b7280;border-top:0.5px solid #1e222d}

.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}
.page-title{font-size:22px;font-weight:600;color:#f0f0f0}
.page-sub{font-size:13px;color:#9ca3af;margin-top:4px}

.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:12px;margin-bottom:20px}
.stat-card{background:#1e2235;border:0.5px solid #2a2f3a;border-radius:10px;padding:16px 18px;display:flex;align-items:center;gap:14px;transition:border-color .2s}
.stat-card:hover{border-color:#3a3f4a}
.stat-icon{width:40px;height:40px;border-radius:8px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.icon-blue{background:rgba(59,130,246,.15);color:#3b82f6}
.icon-green{background:rgba(46,204,113,.15);color:#2ecc71}
.icon-orange{background:rgba(240,120,0,.15);color:#f07800}
.icon-purple{background:rgba(168,85,247,.15);color:#a855f7}
.stat-label{font-size:11px;color:#9ca3af;margin-bottom:4px;text-transform:uppercase;letter-spacing:.5px}
.stat-value{font-size:24px;font-weight:600;color:#f0f0f0}
.stat-unit{font-size:13px;font-weight:400;color:#9ca3af}
.stat-green{color:#2ecc71}
.stat-orange{color:#f07800}
.stat-purple{color:#a855f7}
.stat-body{flex:1}

.dashboard-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr}}
.dash-left,.dash-right{display:flex;flex-direction:column;gap:20px}

.card{background:#1e2235;border:0.5px solid #2a2f3a;border-radius:10px;padding:20px}
.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}
.card-title{font-size:14px;font-weight:500;color:#e0e0e0}

.speedtest-container{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.gauge-wrap{position:relative;width:220px;flex-shrink:0}
.gauge-center{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);text-align:center}
.gauge-val{font-size:32px;font-weight:700;color:#f07800;display:block}
.gauge-unit{font-size:11px;color:#9ca3af}
.speed-metrics{flex:1;min-width:160px}
.metric-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:0.5px solid #1e222d}
.metric-row:last-child{border-bottom:none}
.metric-label{font-size:12px;color:#9ca3af}
.metric-val{font-size:13px;font-weight:600;color:#f0f0f0}

.btn-run-speed{background:#f07800;color:#fff;border:none;padding:7px 16px;border-radius:6px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}
.btn-run-speed:hover{background:#d96a00}
.btn-run-speed:disabled{opacity:.5;cursor:not-allowed}

.event-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:0.5px solid #1e222d}
.event-row:last-child{border-bottom:none}
.event-dot{width:7px;height:7px;border-radius:50%;margin-top:5px;flex-shrink:0}
.dot-red{background:#e74c3c}
.dot-orange{background:#f07800}
.dot-blue{background:#3b82f6}
.event-text{font-size:13px;color:#ccd}
.event-time{font-size:11px;color:#6b7280;margin-top:2px}

.device-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:0.5px solid #1e222d}
.device-row:last-child{border-bottom:none}
.device-icon{width:32px;height:32px;background:#23262e;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#9ca3af;flex-shrink:0}
.device-name{font-size:13px;color:#e0e0e0;font-weight:500}
.device-ip{font-size:11px;color:#6b7280;margin-top:2px}
.device-status{font-size:11px;font-weight:500;padding:3px 10px;border-radius:20px;white-space:nowrap}
.status-online{background:rgba(46,204,113,.12);color:#2ecc71;border:0.5px solid rgba(46,204,113,.2)}
.status-offline{background:rgba(100,100,100,.1);color:#6b7280}
.device-body{flex:1}
.empty-state{font-size:13px;color:#6b7280;text-align:center;padding:20px 0}

.btn-primary{background:#f07800;color:#fff;border:none;padding:8px 18px;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}
.btn-primary:hover{background:#d96a00}

.perfiles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.perfil-card{background:#1e2235;border:0.5px solid #2a2f3a;border-radius:10px;padding:20px}
.perfil-header{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.perfil-icon{width:40px;height:40px;background:#23262e;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#f07800;flex-shrink:0}
.perfil-nombre{font-size:14px;font-weight:500;color:#e0e0e0;margin:0}
.perfil-desc{font-size:12px;color:#6b7280;margin:3px 0 0}
.perfil-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:16px}
.tag{font-size:11px;font-weight:500;padding:3px 10px;border-radius:10px}
.tag-red{background:rgba(231,76,60,.12);color:#e74c3c;border:0.5px solid rgba(231,76,60,.2)}
.tag-orange{background:rgba(240,120,0,.12);color:#f07800;border:0.5px solid rgba(240,120,0,.2)}
.tag-purple{background:rgba(168,85,247,.12);color:#a855f7;border:0.5px solid rgba(168,85,247,.2)}
.btn-delete{background:transparent;color:#e74c3c;border:0.5px solid rgba(231,76,60,.3);padding:7px 14px;border-radius:6px;font-size:12px;cursor:pointer;width:100%;transition:all .2s}
.btn-delete:hover{background:rgba(231,76,60,.1)}
.empty-card{background:#1e2235;border:0.5px solid #2a2f3a;border-radius:10px;padding:48px;text-align:center}

.bloqueo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bloqueo-item{display:flex;align-items:flex-start;gap:10px;background:#181c28;border:0.5px solid #2a2f3a;border-radius:8px;padding:14px;cursor:pointer;transition:border-color .2s}
.bloqueo-item:hover{border-color:#3a3f4a}
.bloqueo-check{margin-top:3px;accent-color:#f07800;flex-shrink:0}
.bloqueo-icons{display:flex;gap:4px;margin-bottom:6px}
.app-dot{width:20px;height:20px;border-radius:5px;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;color:#fff}
.bloqueo-nombre{font-size:13px;font-weight:500;color:#e0e0e0;margin:0 0 3px}
.bloqueo-apps{font-size:11px;color:#6b7280;margin:0;line-height:1.4}

.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;background:#111827}
.login-wrapper{width:100%;max-width:400px;padding:20px}
.login-card{background:#1e2235;border:0.5px solid #2a2f3a;border-radius:12px;padding:40px}
.login-logo{text-align:center;margin-bottom:32px}
.login-title{font-size:20px;font-weight:600;margin-top:12px;color:#f0f0f0}
.login-sub{font-size:12px;color:#9ca3af;margin-top:4px}
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:12px;color:#9ca3af;margin-bottom:6px;font-weight:500}
.form-input{width:100%;background:#181c28;border:0.5px solid #2a2f3a;border-radius:6px;padding:10px 14px;color:#f0f0f0;font-size:14px;font-family:'Inter',sans-serif;transition:border-color .2s;outline:none}
.form-input:focus{border-color:#f07800}
.form-input::placeholder{color:#6b7280}
.btn-login{width:100%;background:#f07800;color:#fff;border:none;padding:12px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;margin-top:8px;transition:background .2s;font-family:'Inter',sans-serif}
.btn-login:hover{background:#d96a00}
.alert-error{background:rgba(231,76,60,.1);border:0.5px solid rgba(231,76,60,.3);color:#e74c3c;padding:10px 14px;border-radius:6px;font-size:13px;margin-bottom:16px}
.login-footer{text-align:center;font-size:11px;color:#333;margin-top:24px}
