/* IcasenseCloud — Dashboard Cloud */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg:       #0f1117;
  --bg2:      #1a1d27;
  --bg3:      #22263a;
  --border:   #2d3148;
  --accent:   #3b82f6;
  --accent2:  #1d4ed8;

  /* Aliases locales para compartir estilos con Icasense local */
  --bg-base:      #0f1117;
  --bg-surface:   #1a1d27;
  --bg-elevated:  #22263a;
  --bg-hover:     #2a2f44;
  --border-light: #3a3f58;
  --text-primary:   #e2e8f0;
  --text-secondary: #94a3b8;
  --text-muted:     #64748b;
  --radius-sm:  6px;
  --green-dim:  rgba(34,197,94,.12);
  --red-dim:    rgba(239,68,68,.12);
  --accent-dim: rgba(59,130,246,.12);
  --text:     #e2e8f0;
  --text2:    #94a3b8;
  --green:    #22c55e;
  --red:      #ef4444;
  --yellow:   #f59e0b;
  --sidebar:  180px;
  --radius:   8px;
}

html, body { height: 100%; font-family: 'Segoe UI', system-ui, sans-serif; background: var(--bg); color: var(--text); font-size: 14px; }

/* ── Login ── */
#login-screen { display: flex; align-items: center; justify-content: center; height: 100vh; background: var(--bg); }
.login-box { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 40px 36px; width: 320px; display: flex; flex-direction: column; gap: 14px; }
.login-logo { font-size: 22px; font-weight: 700; color: var(--accent); text-align: center; }
.login-subtitle { font-size: 12px; color: var(--text2); text-align: center; }
.login-error { background: #3f1212; border: 1px solid var(--red); border-radius: 6px; padding: 8px 12px; color: var(--red); font-size: 13px; }
.login-box input { background: var(--bg3); border: 1px solid var(--border); border-radius: 6px; padding: 10px 14px; color: var(--text); width: 100%; outline: none; }
.login-box input:focus { border-color: var(--accent); }
.login-box button { background: var(--accent); border: none; border-radius: 6px; color: #fff; font-size: 14px; font-weight: 600; padding: 11px; cursor: pointer; }
.login-box button:hover { background: var(--accent2); }

/* ── Layout ── */
#app { display: flex; height: 100vh; }
#sidebar { width: var(--sidebar); background: var(--bg2); border-right: 1px solid var(--border); display: flex; flex-direction: column; flex-shrink: 0; }
.sidebar-logo { padding: 20px 16px 12px; font-size: 15px; font-weight: 700; color: var(--accent); border-bottom: 1px solid var(--border); }
#nav-links { list-style: none; padding: 10px 0; flex: 1; }
#nav-links li { margin: 2px 8px; }
.nav-link { display: block; padding: 8px 12px; border-radius: 6px; color: var(--text2); text-decoration: none; font-size: 13px; }
.nav-link:hover, .nav-link.active { background: var(--bg3); color: var(--text); }
.sidebar-footer { padding: 14px 16px; border-top: 1px solid var(--border); font-size: 12px; color: var(--text2); }
.sidebar-footer a { color: var(--text2); text-decoration: none; margin-left: 8px; }
.sidebar-footer a:hover { color: var(--red); }

#content { flex: 1; overflow-y: auto; padding: 24px 28px; }

/* ── Pages ── */
.page { display: none; }
.page.active { display: block; }
.page h1 { font-size: 20px; font-weight: 700; margin-bottom: 20px; color: var(--text); }
.page h2 { font-size: 15px; font-weight: 600; margin-bottom: 12px; color: var(--text2); }
.page-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 18px; flex-wrap: wrap; gap: 10px; }
.page-header h1 { margin-bottom: 0; }

/* ── Stats grid ── */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; margin-bottom: 28px; }
.stat-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 18px 20px; }
.stat-card .stat-label { font-size: 12px; color: var(--text2); margin-bottom: 6px; }
.stat-card .stat-value { font-size: 28px; font-weight: 700; color: var(--accent); }
.stat-card .stat-sub { font-size: 11px; color: var(--text2); margin-top: 4px; }

.dash-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 20px; }

/* ── Tables ── */
.data-table { width: 100%; border-collapse: collapse; }
.data-table th { background: var(--bg2); color: var(--text2); font-size: 11px; text-transform: uppercase; letter-spacing: .5px; padding: 10px 14px; text-align: left; border-bottom: 1px solid var(--border); }
.data-table td { padding: 10px 14px; border-bottom: 1px solid var(--border); vertical-align: middle; }
.data-table tr:hover td { background: var(--bg2); }
.data-table tr:last-child td { border-bottom: none; }

/* ── Status badges ── */
.badge { display: inline-block; padding: 2px 9px; border-radius: 20px; font-size: 11px; font-weight: 600; }
.badge-online  { background: #14532d; color: var(--green); }
.badge-offline { background: #3f1212; color: var(--red); }
.badge-pending { background: #451a03; color: var(--yellow); }
.badge-done    { background: #14532d; color: var(--green); }
.badge-error   { background: #3f1212; color: var(--red); }
.badge-timeout { background: #1c1917; color: var(--text2); }
.badge-success { background: #14532d; color: var(--green); }
.badge-sent    { background: #172554; color: var(--accent); }
.badge-executing { background: #451a03; color: var(--yellow); }

/* ── Buttons ── */
.btn-primary   { background: var(--accent); color: #fff; border: none; border-radius: 6px; padding: 8px 16px; cursor: pointer; font-size: 13px; font-weight: 600; }
.btn-primary:hover { background: var(--accent2); }
.btn-secondary { background: var(--bg3); color: var(--text); border: 1px solid var(--border); border-radius: 6px; padding: 7px 14px; cursor: pointer; font-size: 13px; }
.btn-secondary:hover { background: var(--bg2); }
.btn-danger    { background: #991b1b; color: #fff; border: none; border-radius: 6px; padding: 6px 12px; cursor: pointer; font-size: 12px; }
.btn-success   { background: #15803d; color: #fff; border: none; border-radius: 6px; padding: 6px 12px; cursor: pointer; font-size: 12px; }
.btn-sm        { padding: 4px 10px; font-size: 12px; border-radius: 5px; }
.btn-link      { background: none; border: none; color: var(--accent); cursor: pointer; font-size: 12px; text-decoration: underline; }

/* ── Filters ── */
.filter-row { display: flex; gap: 10px; flex-wrap: wrap; }
.filter-row select, .filter-row input { background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; padding: 7px 12px; color: var(--text); font-size: 13px; }

/* ── Pending box ── */
.pending-box { background: #451a03; border: 1px solid var(--yellow); border-radius: var(--radius); padding: 12px 16px; color: var(--yellow); margin-bottom: 16px; }

/* ── Event list ── */
.event-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 16px; margin-bottom: 10px; display: flex; gap: 12px; align-items: flex-start; }
.event-img { width: 72px; height: 54px; object-fit: cover; border-radius: 5px; cursor: pointer; flex-shrink: 0; }
.event-img-placeholder { width: 72px; height: 54px; background: var(--bg3); border-radius: 5px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; color: var(--text2); font-size: 20px; }
.event-body { flex: 1; }
.event-type { font-weight: 600; font-size: 13px; color: var(--text); }
.event-meta { font-size: 11px; color: var(--text2); margin-top: 3px; }

/* ── Modal ── */
.modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,.6); }
.modal-overlay { position: absolute; inset: 0; }
.modal-box { position: relative; background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 28px; width: 420px; max-width: 95vw; display: flex; flex-direction: column; gap: 12px; }
.modal-box h2 { font-size: 17px; font-weight: 700; margin-bottom: 4px; }
.modal-box input, .modal-box select, .modal-box textarea { width: 100%; background: var(--bg3); border: 1px solid var(--border); border-radius: 6px; padding: 9px 12px; color: var(--text); font-size: 13px; }
.modal-box textarea { min-height: 80px; resize: vertical; font-family: monospace; }
.modal-box label { font-size: 12px; color: var(--text2); }
.modal-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 4px; }
.modal-close { position: absolute; top: 12px; right: 14px; background: none; border: none; font-size: 18px; color: var(--text2); cursor: pointer; }
.img-modal-inner { position: relative; z-index: 1; max-width: 90vw; max-height: 90vh; }
.img-modal-inner img { max-width: 90vw; max-height: 85vh; border-radius: var(--radius); }

/* ── Pagination ── */
.pagination { display: flex; gap: 8px; margin-top: 16px; align-items: center; }
.pagination button { background: var(--bg2); border: 1px solid var(--border); border-radius: 5px; padding: 5px 12px; color: var(--text); cursor: pointer; font-size: 12px; }
.pagination button:disabled { opacity: .4; cursor: not-allowed; }
.pagination span { font-size: 12px; color: var(--text2); }

/* ── Dashboard lists ── */
.mini-list { display: flex; flex-direction: column; gap: 8px; }
.mini-item { background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; padding: 10px 14px; font-size: 12px; }
.mini-item .mi-title { font-weight: 600; color: var(--text); margin-bottom: 2px; }
.mini-item .mi-sub   { color: var(--text2); }

/* ── Toast ── */
#toast { position: fixed; bottom: 22px; right: 22px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }
.toast-item { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); padding: 12px 18px; font-size: 13px; min-width: 200px; box-shadow: 0 4px 16px rgba(0,0,0,.4); animation: fadeIn .2s; }
.toast-item.ok  { border-left: 3px solid var(--green); }
.toast-item.err { border-left: 3px solid var(--red); }
@keyframes fadeIn { from { opacity:0; transform: translateY(8px); } to { opacity:1; } }

/* ── Separador nav ── */
.nav-sep { height: 1px; background: var(--border); margin: 8px 16px; }

/* ── Panel Remoto ── */
.panel-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; flex-wrap: wrap; gap: 12px; }
.panel-left { display: flex; align-items: center; gap: 14px; }
.panel-left h1 { margin-bottom: 0; }
.panel-left select { background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; padding: 7px 12px; color: var(--text); font-size: 13px; min-width: 220px; }
.panel-right { display: flex; align-items: center; gap: 10px; }

.agent-badge { font-size: 13px; font-weight: 600; padding: 5px 12px; border-radius: 20px; }
.agent-badge.online  { background: #14532d; color: var(--green); }
.agent-badge.offline { background: #3f1212; color: var(--red); }

.panel-offline-msg { background: #451a03; border: 1px solid var(--yellow); border-radius: var(--radius); padding: 12px 16px; color: var(--yellow); margin-bottom: 16px; font-size: 13px; }

.panel-devices-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }

/* ── Device card ── */
.device-card { background: var(--bg2); border: 1px solid var(--border); border-radius: var(--radius); overflow: hidden; }
.device-card.offline-card { opacity: .6; }
.device-card-header { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border); }
.device-card-title { font-weight: 600; font-size: 14px; }
.device-card-type { font-size: 11px; color: var(--text2); background: var(--bg3); padding: 2px 8px; border-radius: 10px; }
.device-card-body { padding: 12px 16px; display: flex; flex-direction: column; gap: 10px; }

/* ── Relay row ── */
.relay-row { display: flex; align-items: center; justify-content: space-between; padding: 8px 10px; background: var(--bg3); border-radius: 6px; gap: 8px; }
.relay-name { font-size: 13px; color: var(--text2); flex: 1; }
.relay-state { font-size: 12px; font-weight: 700; min-width: 36px; text-align: center; }
.relay-state.on  { color: var(--green); }
.relay-state.off { color: var(--text2); }
.relay-btns { display: flex; gap: 6px; }
.relay-btn { border: none; border-radius: 5px; padding: 5px 10px; font-size: 12px; font-weight: 600; cursor: pointer; transition: opacity .15s; }
.relay-btn:disabled { opacity: .35; cursor: not-allowed; }
.relay-btn.on  { background: var(--green); color: #fff; }
.relay-btn.off { background: #374151; color: var(--text); }
.relay-btn.toggle { background: var(--accent); color: #fff; }

/* ── Dahua card ── */
.dahua-status-row { display: flex; align-items: center; gap: 8px; padding: 6px 10px; background: var(--bg3); border-radius: 6px; }
.dahua-actions { display: flex; flex-wrap: wrap; gap: 6px; }
.dahua-btn { background: var(--bg3); border: 1px solid var(--border); border-radius: 5px; padding: 6px 10px; font-size: 12px; color: var(--text); cursor: pointer; }
.dahua-btn:hover:not(:disabled) { background: var(--bg2); border-color: var(--accent); }
.dahua-btn:disabled { opacity: .35; cursor: not-allowed; }

/* ── Command feedback ── */
.cmd-result { font-size: 12px; padding: 6px 10px; border-radius: 5px; }
.cmd-result.ok  { background: #14532d; color: var(--green); }
.cmd-result.err { background: #3f1212; color: var(--red); }

/* ── Responsive ── */
@media (max-width: 700px) {
  #sidebar { display: none; }
  #content { padding: 14px; }
  .dash-cols { grid-template-columns: 1fr; }
  .panel-devices-grid { grid-template-columns: 1fr; }
}

/* ── Badges extra de rol ── */
.badge-superadmin  { background:#1e1b4b; color:#a5b4fc; }
.badge-client_admin{ background:#172554; color:#93c5fd; }
.badge-user        { background:#1c1917; color:#a8a29e; }

/* ── Dash cols ── */
.dash-cols { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 20px; }
.dash-cols h2 { font-size: 15px; font-weight: 600; color: var(--text2); margin-bottom: 10px; }

/* ── Filter row en usuarios ── */
#users-filter-row { margin-bottom: 14px; }
#users-filter-row select { background: var(--bg2); border: 1px solid var(--border); border-radius: 6px; padding: 7px 12px; color: var(--text); font-size: 13px; }

/* ── Modal textarea ── */
.modal-box textarea { min-height: 70px; resize: vertical; font-family: inherit; }

/* ═══════════════════════════════════════════════════
   PANEL REMOTO — Estilos idénticos al panel local
   ═══════════════════════════════════════════════════ */

/* ── Toggle switch ── */
.toggle { position:relative; display:inline-block; width:36px; height:20px; cursor:pointer; }
.toggle input { display:none; }
.toggle-track { position:absolute; inset:0; background:var(--bg-elevated); border:1px solid var(--border-light); border-radius:20px; transition:all .2s; }
.toggle-thumb { position:absolute; top:3px; left:3px; width:14px; height:14px; background:var(--text-muted); border-radius:50%; transition:all .2s; }
.toggle input:checked ~ .toggle-track { background:var(--green-dim); border-color:var(--green); }
.toggle input:checked ~ .toggle-thumb { background:var(--green); transform:translateX(16px); }

/* ── Event pills ── */
.ev-pill { display:inline-flex; align-items:center; padding:1px 6px; border-radius:10px; font-size:10.5px; font-weight:500; white-space:nowrap; background:var(--bg-elevated); border:1px solid var(--border); color:var(--text-muted); }
.ev-cam  { background:rgba(79,126,248,.12); color:var(--accent); border-color:rgba(79,126,248,.25); }
.ev-dir  { background:rgba(168,85,247,.12); color:#c084fc; border-color:rgba(168,85,247,.3); }

/* ── Alarm card ── */
.alarm-sound-row { display:flex; align-items:center; gap:10px; margin-bottom:10px; padding:8px 10px; background:var(--bg-elevated); border-radius:var(--radius-sm); }
.alarm-triggers  { margin-bottom:10px; }
.alarm-triggers-label { font-size:11px; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:.5px; margin-bottom:6px; }
.alarm-stats { font-size:11px; color:var(--text-muted); }

/* Device card header */
.device-card-header { display:flex; align-items:center; gap:10px; margin-bottom:14px; }
.device-type-icon { width:38px;height:38px;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0; }
.device-type-icon.shelly { background: var(--green-dim); }
.device-type-icon.dahua  { background: var(--accent-dim); }

/* Badges inline */
.badge-green { background:var(--green-dim);  color:var(--green); }
.badge-red   { background:var(--red-dim);    color:var(--red); }
.status-dot  { display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px; }
.status-dot.online  { background:var(--green); box-shadow:0 0 5px var(--green); }
.status-dot.offline { background:var(--red); }

/* Relay container */
.shelly-relays { display:flex; flex-direction:column; gap:8px; }

.relay-row {
  display:flex; flex-direction:column; gap:8px;
  padding:10px 12px; border-radius:var(--radius-sm);
  border:1px solid var(--border);
  transition:border-color .2s, background .2s;
}
.relay-row.relay-on  { border-color:rgba(34,197,94,.4); background:rgba(34,197,94,.05); }
.relay-row.relay-off { border-color:var(--border); background:transparent; }

.relay-top { display:flex; align-items:center; gap:10px; }

.relay-led { display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;width:44px; }
.led-circle { width:22px;height:22px;border-radius:50%;transition:all .3s; }
.relay-on  .led-circle { background:var(--green); box-shadow:0 0 10px rgba(34,197,94,.6),0 0 20px rgba(34,197,94,.3); }
.relay-off .led-circle { background:var(--bg3); border:2px solid var(--border-light); box-shadow:none; }
.led-label { font-size:10px;font-weight:700;letter-spacing:.5px; }
.relay-on  .led-label { color:var(--green); }
.relay-off .led-label { color:var(--text-muted); }

.relay-name { flex:1;min-width:0;font-size:13px;font-weight:600;color:var(--text-primary); }

.relay-controls { display:flex;flex-wrap:wrap;gap:4px;padding-left:54px; }

.relay-metrics-row { display:flex;flex-wrap:wrap;gap:5px;padding-left:54px; }
.metric-pill { display:inline-flex;align-items:center;padding:2px 8px;background:var(--bg-elevated);border:1px solid var(--border);border-radius:20px;font-size:11px;color:var(--text-secondary);font-family:monospace; }

/* Botones relay */
.btn { display:inline-flex;align-items:center;justify-content:center;border:none;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;padding:6px 14px;transition:background .15s,opacity .15s; }
.btn:disabled { opacity:.35;cursor:not-allowed; }
.btn-sm { padding:4px 10px;font-size:12px; }
.btn-success { background:var(--green-dim);color:var(--green);border:1px solid rgba(34,197,94,.3); }
.btn-success:hover:not(:disabled) { background:rgba(34,197,94,.25); }
.btn-danger  { background:var(--red-dim);color:var(--red);border:1px solid rgba(239,68,68,.3); }
.btn-danger:hover:not(:disabled)  { background:rgba(239,68,68,.25); }
.btn-secondary-sm { background:var(--bg3);color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 10px;font-size:12px;cursor:pointer; }
.btn-secondary-sm:hover:not(:disabled) { background:var(--bg2); }

/* Dahua card */
.dahua-actions-grid { display:flex;flex-wrap:wrap;gap:6px;margin-top:8px; }
.dahua-action-btn { background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:7px 12px;font-size:13px;color:var(--text);cursor:pointer;transition:background .15s; }
.dahua-action-btn:hover:not(:disabled) { background:var(--bg2);border-color:var(--accent); }
.dahua-action-btn:disabled { opacity:.35;cursor:not-allowed; }

/* Resultado de comando */
.cmd-result-bar { margin-top:8px;padding:6px 10px;border-radius:var(--radius-sm);font-size:12px;display:none; }
.cmd-result-bar.ok  { background:var(--green-dim);color:var(--green); }
.cmd-result-bar.err { background:var(--red-dim);color:var(--red); }
