:root{
  --bg:#0f1117;
  --bg-2:#141720;
  --surface:#1b1e28;
  --surface-2:#222733;
  --surface-3:#2a3040;
  --line:#323a4a;
  --line-soft:#29303e;
  --text:#f5f7fb;
  --muted:#9aa6b8;
  --muted-2:#717c90;
  --green:#20d17a;
  --green-2:#13a866;
  --cyan:#58d8ff;
  --blue:#5b8def;
  --red:#ff5252;
  --yellow:#f7c948;
  --purple:#b85cff;
  --shadow:0 22px 60px rgba(0,0,0,.32);
  --radius:18px;
}
*{box-sizing:border-box}
html,body{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;font-size:14px}
body{display:flex;overflow-x:hidden}
a{color:var(--green);text-decoration:none}
button,input,select{font:inherit}
button{border:0;border-radius:12px;background:linear-gradient(135deg,var(--green),var(--green-2));color:#04130c;font-weight:900;padding:11px 16px;cursor:pointer;transition:.18s ease;box-shadow:0 10px 25px rgba(32,209,122,.13)}
button:hover{transform:translateY(-1px);filter:brightness(1.04)}
button:active{transform:translateY(0)}
.secondary-btn{background:#242b39;color:var(--text);border:1px solid #3b4658;box-shadow:none}
.small-btn{padding:8px 12px;border-radius:10px;font-size:12px}

.sidebar{width:250px;min-height:100vh;position:fixed;inset:0 auto 0 0;background:linear-gradient(180deg,#181b23,#12151c);border-right:1px solid var(--line);padding:20px 14px;display:flex;flex-direction:column;z-index:20}
.brand{display:flex;gap:12px;align-items:center;padding:8px 8px 24px}.brand-dot{width:18px;height:18px;border-radius:8px;background:var(--green);box-shadow:0 0 24px rgba(32,209,122,.75)}.brand strong{display:block;font-size:22px;letter-spacing:-.03em}.brand small{color:var(--muted);font-weight:800;letter-spacing:.14em;text-transform:uppercase;font-size:10px}.nav-list{display:grid;gap:8px}.nav{background:transparent;color:var(--muted);text-align:left;padding:12px 14px;border-radius:13px;border:1px solid transparent;font-weight:900;box-shadow:none}.nav:hover,.nav.active{background:#222734;color:#fff;border-color:#333d4e}.nav.active{box-shadow:inset 3px 0 0 var(--green)}.sidebar-user{margin-top:auto;padding:14px;border-radius:16px;background:#20242e;border:1px solid #303746}.sidebar-user b,.sidebar-user span,.sidebar-user a{display:block}.sidebar-user span{color:var(--muted);font-size:11px;margin:4px 0 10px}

.main{margin-left:250px;width:calc(100% - 250px);padding:22px;min-height:100vh;background:radial-gradient(circle at 75% 0%,rgba(32,209,122,.06),transparent 28%),var(--bg)}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:16px}.topbar h1{margin:0;font-size:30px;letter-spacing:-.04em}.topbar p{margin:5px 0 0;color:var(--muted)}.topbar-actions{display:flex;gap:10px;align-items:center}.status-pill{display:flex;align-items:center;gap:8px;background:#1d242d;border:1px solid #31404d;color:#dfe7f3;border-radius:999px;padding:9px 12px;font-weight:900}.status-pill span{width:9px;height:9px;border-radius:999px;background:var(--green);box-shadow:0 0 16px var(--green)}
.page{display:none}.page.active{display:block}.panel,.map-panel,.alerts-panel,.device-card,.mini-kpi,.profile-detail,.device-row-card{background:rgba(27,30,40,.96);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.panel{padding:18px;margin-bottom:18px}.panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}.panel-head h2,.section-title h2{margin:0;font-size:20px;letter-spacing:-.02em}.panel-head p{margin:4px 0 0}.muted{color:var(--muted)}

.ops-header{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:14px}.mini-kpi{padding:16px;background:linear-gradient(180deg,#20242e,#181b23)}.mini-kpi small{display:block;color:var(--muted);font-weight:900;text-transform:uppercase;font-size:11px}.mini-kpi b{display:block;font-size:32px;margin-top:4px;letter-spacing:-.04em}.ops-layout{display:grid;grid-template-columns:minmax(0,1fr) 410px;gap:14px;align-items:stretch}.map-panel{overflow:hidden;padding:0}.map-head{padding:16px 18px;margin:0;border-bottom:1px solid var(--line);background:#1c2029}.legend{display:flex;gap:12px;align-items:center;flex-wrap:wrap;color:var(--muted);font-weight:900;font-size:12px}.legend span{display:flex;gap:6px;align-items:center}.dot{width:10px;height:10px;border-radius:999px;display:inline-block}.dot.online{background:var(--green)}.dot.offline{background:var(--purple)}.dot.alarm{background:var(--red)}#deviceMap{height:610px;background:#cfd8d8}.leaflet-container{font:inherit}.leaflet-control-attribution{font-size:10px}.map-popup{color:#10141a;min-width:190px}.map-popup b{display:block;margin-bottom:4px}.marker-dot{width:22px;height:22px;border-radius:999px;border:3px solid rgba(255,255,255,.9);box-shadow:0 8px 22px rgba(0,0,0,.38)}.marker-dot.online{background:var(--green)}.marker-dot.offline{background:var(--purple)}.marker-dot.alarm{background:var(--red)}.alerts-panel{padding:16px;min-height:610px}.alert-feed{display:grid;gap:10px;max-height:540px;overflow:auto;padding-right:4px}.alert-card{border:1px solid #343b49;border-left:4px solid var(--red);background:#20242d;border-radius:14px;padding:12px}.alert-card.warn{border-left-color:var(--yellow)}.alert-card.ok{border-left-color:var(--green)}.alert-card b{display:block;margin-bottom:4px}.alert-card span{color:#d9e0ec}.alert-card small{color:var(--muted);font-weight:700}.section-title{display:flex;justify-content:space-between;align-items:end;margin:22px 0 12px}

.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(285px,1fr));gap:14px}.profile-cards{grid-template-columns:repeat(auto-fill,minmax(315px,1fr))}.device-card{padding:16px;position:relative;overflow:hidden;background:linear-gradient(180deg,#20242e,#181b23)}.device-card:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--green),var(--cyan));opacity:.85}.device-card.offline:before{background:linear-gradient(90deg,var(--purple),#7c3aed)}.device-card h3{margin:12px 0 4px;font-size:18px}.device-card p{margin:5px 0;color:var(--muted)}.device-meta{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-top:14px}.metric{background:#151820;border:1px solid #2e3542;border-radius:13px;padding:10px}.metric small{display:block;color:var(--muted);font-size:11px;font-weight:900;text-transform:uppercase}.metric b{display:block;margin-top:4px}.metric .on{color:#7effbd}.metric .off{color:#c8b5ff}.badge{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;text-transform:uppercase;border:1px solid transparent;margin-right:6px}.badge.ok{background:rgba(32,209,122,.12);color:#7effbd;border-color:rgba(32,209,122,.25)}.badge.off{background:rgba(184,92,255,.12);color:#d8b7ff;border-color:rgba(184,92,255,.25)}.badge.neutral{background:#2a303c;color:#cad4e4;border-color:#3a4352}.badge.alarm{background:rgba(255,82,82,.13);color:#ff9a9a;border-color:rgba(255,82,82,.25)}.profile-badge{background:#263142;color:#9ed2ff;border-color:#394c66}.card-actions{margin-top:14px}.token-mini code{color:#dfffe9;background:#101410;border:1px solid #254836;border-radius:8px;padding:2px 6px}

.layout-2{display:grid;grid-template-columns:370px minmax(0,1fr);gap:16px;align-items:start}.compact-panel{position:sticky;top:18px}.form-stack{display:grid;gap:13px}.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:13px}.form-grid.two{grid-template-columns:1fr 1fr}label{display:grid;gap:6px;color:#d7dfeb;font-weight:900;font-size:12px}input,select{width:100%;background:#151820;color:#fff;border:1px solid #3b4657;border-radius:12px;padding:11px 12px;outline:none}input:focus,select:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(32,209,122,.12)}.token-row{display:flex;gap:8px}.token-row input{min-width:0}.token-row-wide input{font-family:Consolas,monospace}.config-form.empty-state .cfg-fields{display:none}.config-form:not(.empty-state) .empty-box{display:none}.empty-box{border:1px dashed #3d4655;border-radius:16px;padding:28px;text-align:center;color:var(--muted);background:#171a22}.cfg-fields{display:grid;gap:14px}.profile-editor-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(270px,.85fr);gap:14px}.secret-card,.control-card,.schedule-card,.profile-section{background:#171a22;border:1px solid #303847;border-radius:16px;padding:14px}.profile-section h3{margin:0 0 12px;font-size:15px}.secret-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}.secret-head span,.hint,.schedule-card span{color:var(--muted);font-size:12px}.switch-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:10px 0}.switch-row+ .switch-row{border-top:1px solid #2f3644}.switch-row span{display:block;color:var(--muted);font-size:12px;margin-top:3px}.switch{display:inline-flex}.switch input{display:none}.switch span{width:52px;height:28px;border-radius:999px;background:#3a4150;position:relative;display:block}.switch span:before{content:"";position:absolute;width:22px;height:22px;left:3px;top:3px;border-radius:999px;background:#fff;transition:.2s}.switch input:checked+span{background:var(--green)}.switch input:checked+span:before{transform:translateX(24px)}.schedule-card.pro{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:13px}.schedule-card small{display:block;color:var(--muted);font-weight:900;text-transform:uppercase;font-size:11px;margin-bottom:7px}.schedule-preview{background:#11141b;border:1px solid #2f3847;border-radius:14px;padding:12px}.schedule-preview b{display:block;font-size:20px;margin-bottom:4px}.form-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:4px}.advanced-fields.hidden{display:none!important}.profile-help{border:1px solid #2f3948;background:#151922;border-radius:14px;padding:12px;color:var(--muted)}.profile-help b{color:#fff;display:block;margin-bottom:4px}.section-note{font-size:12px;color:var(--muted);margin:0 0 12px}

.device-workspace{display:grid;grid-template-columns:370px minmax(0,1fr);gap:16px;align-items:start}.device-list-panel{position:sticky;top:18px}.device-list{display:grid;gap:10px;max-height:650px;overflow:auto;padding-right:4px}.device-row-card{padding:12px;background:#171b24;box-shadow:none;cursor:pointer;transition:.18s ease}.device-row-card:hover,.device-row-card.active{border-color:rgba(32,209,122,.45);background:#202633}.device-row-card h3{font-size:15px;margin:8px 0 4px}.device-row-card p{margin:0;color:var(--muted);font-size:12px}.device-row-meta{display:flex;justify-content:space-between;gap:8px;margin-top:10px;color:var(--muted);font-size:12px}.profile-detail{padding:18px;min-height:340px}.profile-detail.empty{display:grid;place-items:center;color:var(--muted);border-style:dashed;background:#151922}.detail-hero{display:flex;justify-content:space-between;gap:14px;border-bottom:1px solid var(--line-soft);padding-bottom:14px;margin-bottom:14px}.detail-hero h2{margin:8px 0 4px;font-size:24px}.detail-hero p{margin:0;color:var(--muted)}.detail-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.detail-actions{display:flex;gap:10px;align-items:flex-start}.mini-chart{height:90px;border:1px solid #303847;border-radius:14px;background:linear-gradient(180deg,#171b24,#12151c);display:flex;align-items:end;gap:4px;padding:8px;margin-top:12px}.mini-chart i{display:block;flex:1;min-width:6px;border-radius:8px 8px 0 0;background:linear-gradient(180deg,var(--green),#167f50);opacity:.85}.mini-chart.empty{align-items:center;justify-content:center;color:var(--muted)}

.table-wrap{overflow:auto}table{width:100%;border-collapse:collapse}th,td{padding:12px;border-bottom:1px solid #303746;text-align:left;vertical-align:top}th{color:#aeb8c8;font-size:12px;text-transform:uppercase}td{color:#f1f4fa}.code{white-space:pre-wrap;background:#11141b;border:1px solid #303847;border-radius:15px;padding:16px;color:#d7ffe7;overflow:auto}.alert-list{display:grid;gap:10px}.profile-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:14px}.profile-grid article{background:#171a22;border:1px solid #303847;border-radius:16px;padding:16px}.profile-grid span{display:block;color:var(--muted);margin-top:6px}

.login-page{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at top left,rgba(32,209,122,.15),transparent 30%),var(--bg)}.login-card{width:min(420px,92vw);background:var(--surface);border:1px solid var(--line);border-radius:24px;padding:26px;box-shadow:var(--shadow)}.login-card h1{margin:0 0 6px}.login-card p{margin:0 0 18px;color:var(--muted)}.error-box{border:1px solid rgba(255,82,82,.35);background:rgba(255,82,82,.1);color:#ffb0b0;border-radius:14px;padding:12px;margin-bottom:14px}
@media(max-width:1250px){.ops-layout{grid-template-columns:1fr}.alerts-panel{min-height:auto}.layout-2,.device-workspace{grid-template-columns:1fr}.compact-panel,.device-list-panel{position:static}.profile-editor-grid{grid-template-columns:1fr}.schedule-card.pro{grid-template-columns:1fr}.detail-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){body{display:block}.sidebar{position:static;width:100%;min-height:auto}.main{margin-left:0;width:100%;padding:14px}.topbar,.panel-head,.section-title,.detail-hero{display:grid}.ops-header{grid-template-columns:repeat(2,1fr)}#deviceMap{height:430px}.form-grid{grid-template-columns:1fr}.cards{grid-template-columns:1fr}.device-meta,.detail-grid{grid-template-columns:1fr}.token-row{display:grid}.topbar-actions{justify-content:start}.form-actions{justify-content:stretch;display:grid}}

/* v13 - mapa editable */
.map-tools{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
#mapEditBtn.active{background:var(--green);color:#06140d;border-color:rgba(32,209,122,.75)}
#deviceMap.map-editing{outline:2px solid rgba(32,209,122,.7);outline-offset:-2px;cursor:grab}
#deviceMap.map-editing .leaflet-marker-icon{cursor:move!important}
.device-tooltip{background:#12151c!important;color:#eef4ff!important;border:1px solid #303847!important;border-radius:12px!important;box-shadow:0 12px 32px rgba(0,0,0,.35)!important;padding:0!important}
.device-tooltip:before{border-top-color:#303847!important}
.map-tooltip{display:flex;align-items:center;gap:8px;padding:7px 9px;white-space:nowrap}
.map-tooltip b{font-size:12px;max-width:180px;overflow:hidden;text-overflow:ellipsis}
.tooltip-state,.popup-status{display:inline-flex;align-items:center;border-radius:999px;padding:3px 7px;font-size:10px;font-weight:900;text-transform:uppercase;letter-spacing:.03em}
.tooltip-state.online,.popup-status.online,.popup-status.ok{background:rgba(32,209,122,.14);color:#7effbd;border:1px solid rgba(32,209,122,.35)}
.tooltip-state.offline,.popup-status.offline{background:rgba(184,92,255,.14);color:#d8b7ff;border:1px solid rgba(184,92,255,.35)}
.tooltip-state.alarm,.popup-status.alarm{background:rgba(255,82,82,.14);color:#ff9a9a;border:1px solid rgba(255,82,82,.35)}
.map-popup .popup-status{margin-left:6px;color:#10141a;background:#e9f4ef;border-color:#c4ddd1}
.map-edit-hint{color:var(--muted);font-size:12px}
@media(max-width:760px){.map-tools{justify-content:flex-start}}
.map-popup .popup-status.online,.map-popup .popup-status.ok{background:#20d17a;color:#06140d;border-color:#20d17a}
.map-popup .popup-status.offline{background:#b85cff;color:#ffffff;border-color:#b85cff}
.map-popup .popup-status.alarm{background:#ff5252;color:#ffffff;border-color:#ff5252}


/* v14 - etiquetas permanentes de dispositivo en mapa */
.custom-marker{background:transparent!important;border:0!important}
.marker-wrap{display:flex;align-items:center;gap:7px;min-width:170px;height:32px;filter:drop-shadow(0 8px 16px rgba(0,0,0,.28))}
.marker-wrap .marker-dot{flex:0 0 auto}
.marker-label{background:#101218;color:#f3f6fb;border:1px solid rgba(255,255,255,.14);border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900;line-height:1;max-width:135px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;pointer-events:none;box-shadow:0 10px 22px rgba(0,0,0,.35)}
.map-tooltip-rich{display:grid;gap:8px;min-width:245px;padding:10px 11px;white-space:normal}
.map-tooltip-head{display:flex;align-items:center;justify-content:space-between;gap:10px}
.map-tooltip-head b{font-size:13px;max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.map-tooltip-line{font-size:11px;color:#aeb8c8;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.map-tooltip-grid{display:grid;grid-template-columns:auto 1fr;gap:5px 12px;font-size:11px;border-top:1px solid #2e3542;border-bottom:1px solid #2e3542;padding:8px 0}
.map-tooltip-grid span{color:#9aa6b6;font-weight:800}
.map-tooltip-grid b{color:#f1f5fb;font-weight:900;text-align:right;max-width:none}
.map-tooltip-foot{font-size:10px;color:#8e99aa;font-weight:800}


/* v15: el nombre queda fijo en el marcador; la ficha de datos abre con click, usando el mismo estilo negro */
.device-popup-dark .leaflet-popup-content-wrapper{
  background:#12151c!important;
  color:#eef4ff!important;
  border:1px solid #303847!important;
  border-radius:14px!important;
  box-shadow:0 16px 42px rgba(0,0,0,.46)!important;
  padding:0!important;
}
.device-popup-dark .leaflet-popup-content{
  margin:0!important;
  width:auto!important;
}
.device-popup-dark .leaflet-popup-tip{
  background:#12151c!important;
  border:1px solid #303847!important;
  box-shadow:0 8px 22px rgba(0,0,0,.35)!important;
}
.device-popup-dark.leaflet-popup{margin-bottom:18px!important}
.device-popup-dark .map-tooltip-rich{min-width:260px;max-width:300px}

/* v16 - organización de dispositivos y alta desde configuración */
.installed-config-panel{margin-top:18px}
.settings-layout{align-items:stretch}
.create-map-panel{min-height:520px;display:flex;flex-direction:column}
#deviceCreateMap{height:430px;min-height:430px;border-radius:18px;overflow:hidden;border:1px solid var(--line);background:#11141b;flex:1}
.create-map-panel .map-edit-hint{margin:12px 0 0}
#settings .compact-panel{position:sticky;top:18px}
#settings .form-stack{gap:12px}
#settings .panel-head h2{margin-bottom:4px}
@media(max-width:1250px){#settings .compact-panel{position:static}.create-map-panel{min-height:auto}#deviceCreateMap{height:380px;min-height:380px}}
@media(max-width:760px){#deviceCreateMap{height:340px;min-height:340px}.installed-config-panel{margin-top:14px}}

/* v20 - atributos estilo ThingsBoard / IoTix */
.attr-rule,
.condition-help{
  border:1px solid rgba(77, 255, 166, .22);
  background:rgba(77, 255, 166, .06);
  border-radius:16px;
  padding:14px 16px;
  display:flex;
  flex-direction:column;
  gap:4px;
}
.attr-rule b,
.condition-help b{color:#f4fff9;font-size:13px;letter-spacing:.02em;}
.attr-rule span,
.condition-help span{color:var(--muted);font-size:12px;line-height:1.45;}
.shared-attrs{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(180px,1fr));
  gap:10px;
  margin-top:12px;
}
.shared-attr{
  border:1px solid rgba(255,255,255,.09);
  background:rgba(0,0,0,.18);
  border-radius:14px;
  padding:12px;
}
.shared-attr small{display:block;color:var(--muted);font-size:11px;margin-bottom:4px;}
.shared-attr b{display:block;color:#fff;font-size:14px;}
.alarm-formula{
  margin-top:8px;
  padding:10px 12px;
  border-radius:12px;
  background:rgba(255,176,32,.08);
  border:1px solid rgba(255,176,32,.2);
  color:#ffd28a;
  font-size:12px;
}
