:root{
  --bg:#f6f7f9; --card:#fff; --ink:#1f2430; --muted:#6b7280; --line:#e4e7ec;
  --primary:#2563eb; --primary-ink:#fff;
  --ok:#16a34a; --error:#dc2626; --parcial:#d97706;
}
*{box-sizing:border-box}
/* El atributo hidden debe ganar siempre, aunque la clase fije display (modal,
   panel de guardar filtro, etc.). Si no, [hidden] y .clase empatan y el elemento
   se queda visible. */
[hidden]{display:none!important}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:var(--bg);color:var(--ink);font-size:14px}
a{color:var(--primary);text-decoration:none}
a:hover{text-decoration:underline}

.topbar{display:flex;align-items:center;gap:24px;background:#111827;color:#fff;
  padding:10px 20px}
.topbar .brand{color:#fff;font-weight:700;font-size:16px}
.topbar nav a{color:#cbd5e1}
.topbar-user{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:13px}
.topbar-user .tb-email{color:#e5e7eb}
.topbar-user .tb-rol{background:#2563eb;color:#fff;border-radius:999px;padding:1px 8px;
  font-size:11px;font-weight:600}
.topbar-user a{color:#cbd5e1}
.tb-logout{background:transparent;border:1px solid #374151;color:#e5e7eb;border-radius:6px;
  padding:4px 10px;cursor:pointer;font-size:12px}
.tb-logout:hover{border-color:#6b7280}

/* Login */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:28px;width:100%;max-width:360px;box-shadow:0 6px 24px rgba(17,24,39,.06)}
.login-brand{font-size:20px;font-weight:700;margin-bottom:4px}
.login-field{display:flex;flex-direction:column;gap:5px;margin:14px 0;font-size:13px;color:var(--muted)}
.login-field input{padding:9px 10px;border:1px solid var(--line);border-radius:8px;
  font-size:14px;color:var(--ink)}
.login-btn{width:100%;margin-top:6px;padding:10px}
.login-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:8px;
  padding:9px 12px;font-size:13px;margin:10px 0}

/* Admin: usuarios */
.admin-card{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:16px;margin-bottom:14px;position:relative}
.admin-card h2{font-size:15px;margin-bottom:12px}
.admin-nuevo{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.admin-nuevo label,.admin-user-controls label{display:flex;flex-direction:column;gap:4px;
  font-size:12px;color:var(--muted)}
.admin-nuevo input,.admin-nuevo select,.admin-user-controls input,.admin-user-controls select{
  padding:7px 9px;border:1px solid var(--line);border-radius:6px;font-size:13px;color:var(--ink)}
.admin-user-head{display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;
  align-items:flex-start;margin-bottom:12px}
.admin-user-controls{display:flex;gap:14px;flex-wrap:wrap;align-items:flex-end}
.admin-user-controls label.chk{flex-direction:row;align-items:center;gap:6px}
.admin-props{border-top:1px solid var(--line);padding-top:10px}
.admin-props-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));
  gap:6px;margin-top:8px}
.admin-props-grid label.chk{display:flex;align-items:center;gap:7px;font-size:13px}
.admin-actions{margin-top:12px}
.admin-del{position:absolute;top:16px;right:16px}
.container{max-width:1280px;margin:0 auto;padding:22px}

.page-head{display:flex;justify-content:space-between;align-items:flex-end;
  gap:16px;margin-bottom:18px;flex-wrap:wrap}
h1{font-size:22px;margin:0}
h2{font-size:17px;margin:0}
.muted{color:var(--muted);font-size:12px}
.head-actions,.actions{display:flex;gap:8px;flex-wrap:wrap}

.btn{display:inline-block;background:#fff;border:1px solid var(--line);
  border-radius:7px;padding:8px 12px;cursor:pointer;color:var(--ink);font-size:13px}
.btn:hover{border-color:#cbd5e1;text-decoration:none}
.btn-primary{background:var(--primary);color:var(--primary-ink);border-color:var(--primary)}
.btn-sm{padding:5px 9px;font-size:12px}

.grid{width:100%;border-collapse:collapse;background:var(--card);
  border:1px solid var(--line);border-radius:10px;overflow:hidden}
.grid th,.grid td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);
  vertical-align:top}
.grid th{background:#f9fafb;font-size:12px;text-transform:uppercase;letter-spacing:.03em;
  color:var(--muted)}
.grid tr:last-child td{border-bottom:none}

.badge{display:inline-block;padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600}
.badge-ok{background:#dcfce7;color:var(--ok)}
.badge-error{background:#fee2e2;color:var(--error)}
.badge-parcial{background:#fef3c7;color:var(--parcial)}

.cuenta{margin:6px 0 14px}
.cuenta-head{display:flex;justify-content:space-between;align-items:center;
  background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 16px}
.empty{background:var(--card);border:1px dashed var(--line);border-radius:10px;
  padding:28px;text-align:center;color:var(--muted)}

/* Controles del informe */
.controls{display:flex;gap:16px;align-items:flex-end;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;margin-bottom:16px}
.controls fieldset{border:none;padding:0;margin:0;display:flex;gap:12px;flex-wrap:wrap}
.controls legend{font-size:11px;color:var(--muted);text-transform:uppercase;
  letter-spacing:.04em;margin-bottom:6px;float:left;width:100%}
.controls label{display:flex;flex-direction:column;font-size:11px;color:var(--muted);gap:3px}
.controls input{padding:6px 8px;border:1px solid var(--line);border-radius:6px;
  font-size:13px;color:var(--ink);width:90px}
.controls input[type=date]{width:140px}
.rangos-rapidos{display:flex;gap:6px;flex-wrap:wrap;width:100%;margin-bottom:8px}
.rangos-rapidos .chip{padding:4px 10px}

/* Tarjetas resumen */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));
  gap:10px;margin-bottom:16px}
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;padding:12px 14px}
.card .v{font-size:22px;font-weight:700}
.card .k{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}

.filtros-estado{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:10px}
.chip{border:1px solid var(--line);background:#fff;border-radius:999px;padding:5px 12px;
  cursor:pointer;font-size:12px}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}

/* Formulario ajustes */
.form-ajustes{max-width:720px}
.form-ajustes fieldset{background:var(--card);border:1px solid var(--line);
  border-radius:10px;padding:16px;margin-bottom:16px}
.form-ajustes legend{font-weight:600;padding:0 6px}
.form-ajustes label.block{display:block;margin-bottom:10px}
.form-ajustes textarea{width:100%;border:1px solid var(--line);border-radius:6px;
  padding:8px;font-family:ui-monospace,monospace;font-size:13px}
.form-ajustes label.check{display:block;margin:8px 0}
.grid-umbrales{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px}
.grid-umbrales input{width:100%;padding:6px 8px;border:1px solid var(--line);border-radius:6px}

.disk-alert{border-radius:10px;padding:10px 14px;margin-bottom:14px;font-size:13px}
.disk-alert-ok{background:#f0f9ff;border:1px solid #bae6fd;color:#075985}
.disk-alert-warn{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}

.sparkline{font-family:ui-monospace,monospace;letter-spacing:1px}
.estado-tag{padding:2px 8px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}

/* Columna URL: texto clicable (abre keywords) + icono externo */
.url-kw{color:var(--primary);cursor:pointer}
.url-kw:hover{text-decoration:underline}
.url-ext{color:var(--muted);text-decoration:none;margin-left:4px;font-size:12px}
.url-ext:hover{color:var(--primary)}

/* Modal de keywords por URL */
.kw-modal{position:fixed;inset:0;background:rgba(17,24,39,.45);display:flex;
  align-items:center;justify-content:center;z-index:50;padding:20px}
.kw-modal-card{background:var(--card);border-radius:12px;width:100%;max-width:680px;
  max-height:80vh;display:flex;flex-direction:column;box-shadow:0 12px 40px rgba(0,0,0,.25)}
.kw-modal-head{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;
  padding:16px 18px;border-bottom:1px solid var(--line)}
.kw-modal-label{font-size:11px;text-transform:uppercase;letter-spacing:.04em;color:var(--muted)}
.kw-modal-url{font-weight:600;word-break:break-all;font-size:14px;margin:2px 0}
.kw-modal-actions{display:flex;gap:8px;flex-shrink:0}
#kw-modal-body{overflow:auto;padding:8px 18px 18px}
.kw-count{margin:8px 0}
.kw-table{width:100%;border-collapse:collapse;font-size:13px}
.kw-table th,.kw-table td{text-align:left;padding:7px 10px;border-bottom:1px solid var(--line)}
.kw-table th{position:sticky;top:0;background:#f9fafb;font-size:11px;text-transform:uppercase;
  letter-spacing:.03em;color:var(--muted)}
.kw-table td.num,.kw-table th.num{text-align:right;font-variant-numeric:tabular-nums}
.kw-table th.sortable{cursor:pointer;user-select:none;white-space:nowrap}
.kw-table th.sortable:hover{color:var(--ink)}

/* Gráfica de tráfico (clics/impresiones, estilo Search Console) */
.traffic-card{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;margin-bottom:12px}
.traffic-head{display:flex;justify-content:space-between;align-items:flex-start;
  gap:16px;flex-wrap:wrap;margin-bottom:10px}
.traffic-toggles{display:flex;gap:10px;flex-wrap:wrap}
.traffic-gran{display:flex;align-items:center;gap:6px;flex-wrap:wrap}
.traffic-gran .gran-label{font-size:12px}
.metric-toggle{display:flex;flex-direction:column;gap:2px;text-align:left;
  border:1px solid var(--line);background:#fff;border-radius:10px;padding:8px 14px;
  cursor:pointer;min-width:150px;opacity:.5;transition:opacity .15s,box-shadow .15s}
.metric-toggle.active{opacity:1;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.metric-toggle .mt-dot{display:inline-block;width:10px;height:10px;border-radius:3px;
  margin-right:6px;vertical-align:middle}
.metric-toggle .mt-name{font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.03em}
.metric-toggle .mt-val{font-size:20px;font-weight:700;font-variant-numeric:tabular-nums}
.traffic-chart-wrap{position:relative;height:300px}

/* Filtro de URL (estilo Search Console) */
.filtro-url{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:14px 16px;margin-bottom:12px}
.filtro-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:10px}
.filtro-guardados{display:flex;gap:6px;flex-wrap:wrap;margin-left:auto}
.filtro-chip{display:inline-flex;align-items:center;gap:6px}
.filtro-chip .fc-x{color:var(--muted);font-size:11px;border-radius:4px;padding:0 3px}
.filtro-chip .fc-x:hover{background:#fee2e2;color:var(--error)}
.filtro-chip .fc-owner{color:var(--muted);font-size:11px;font-style:italic}

.guardar-filtro-panel{display:flex;gap:12px;align-items:center;flex-wrap:wrap;
  background:#f8fafc;border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-top:10px}
.guardar-filtro-panel input[type=text]{padding:7px 9px;border:1px solid var(--line);
  border-radius:6px;font-size:13px;min-width:200px}
.guardar-filtro-panel .chk{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--ink)}
.filtro-reglas{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.regla-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.regla-row select{padding:6px 8px;border:1px solid var(--line);border-radius:6px;
  font-size:13px;color:var(--ink);background:#fff}
.regla-row .r-valor{flex:1;min-width:220px;padding:6px 8px;border:1px solid var(--line);
  border-radius:6px;font-size:13px;font-family:ui-monospace,monospace}
.regla-row .r-del{padding:5px 9px;color:var(--muted)}
.regla-row .r-del:hover{border-color:var(--error);color:var(--error)}
.filtro-acciones{display:flex;gap:8px;flex-wrap:wrap}

.filtro-activo{background:#eef6ff;border:1px solid #bcdcff;border-radius:10px;
  padding:10px 14px;margin-bottom:14px}
.filtro-activo .fa-title{font-size:13px;margin-bottom:6px}
.filtro-activo .fa-reglas{display:flex;gap:6px;flex-wrap:wrap}
.fa-chip{background:#fff;border:1px solid #bcdcff;border-radius:999px;
  padding:3px 10px;font-size:12px;color:#075985}
.fa-chip code{font-family:ui-monospace,monospace;color:#0c4a6e}
.filtro-activo .fa-error{margin-top:6px;font-size:12px;color:var(--error)}
