/* ═══════════════════════════════════════════════════════════════════════════
   ECOllet UI — Reusable Components
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Panel / Card container ───────────────────────────────────────────────── */
.panel {
  background: var(--color-glass-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  overflow: hidden;
  position: relative;
}

.panel-glow-top::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, var(--color-blue-400), transparent);
  opacity: 0.4;
}

.panel-glow-top-red::before {
  background: linear-gradient(90deg, transparent, var(--color-red-500), transparent);
}

.panel-header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-subtle);
  background: rgba(255,255,255,0.015);
  flex-shrink: 0;
}

.panel-title {
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  color: var(--text-primary);
}

.panel-subtitle {
  font-size: var(--text-xs);
  color: var(--text-muted);
  margin-left: var(--space-1);
}

.panel-actions {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.panel-body {
  padding: var(--space-5);
}

/* ── Icon button ──────────────────────────────────────────────────────────── */
.icon-btn {
  width: 30px; height: 30px;
  display: flex; align-items: center; justify-content: center;
  background: var(--color-glass-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-secondary);
  font-size: 13px;
  cursor: pointer;
  transition: all var(--transition-base);
  flex-shrink: 0;
}

.icon-btn:hover {
  background: var(--color-glass-md);
  border-color: var(--border-strong);
  color: var(--color-blue-400);
}

/* ── Module icon wrap ─────────────────────────────────────────────────────── */
.module-icon-wrap {
  width: 48px; height: 48px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
}
.module-icon-wrap svg { display: block; }
.module-icon-wrap.blue   { background: rgba(37,99,235,0.10); color: var(--color-blue-500); }
.module-icon-wrap.green  { background: rgba(0,200,150,0.10); color: var(--color-green); }
.module-icon-wrap.purple { background: rgba(139,92,246,0.10); color: var(--color-purple); }
.module-icon-wrap.yellow { background: rgba(245,158,11,0.10); color: var(--color-yellow); }
.module-icon-wrap.muted  { background: rgba(148,163,184,0.10); color: var(--lz-text-3); }

/* ── Primary button ───────────────────────────────────────────────────────── */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  height: 34px;
  background: linear-gradient(135deg, var(--color-blue-700), var(--color-blue-500));
  border: 1px solid var(--border-bright);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: all var(--transition-base);
  box-shadow: 0 0 16px var(--color-blue-glow-sm);
}

.btn-primary:hover {
  background: linear-gradient(135deg, var(--color-blue-500), var(--color-blue-400));
  box-shadow: 0 0 24px var(--color-blue-glow);
  transform: translateY(-1px);
}

/* ── Badge / Tag ──────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.badge-blue   { background: rgba(59, 130, 246, 0.12); color: var(--color-blue-300); border: 1px solid rgba(59, 130, 246, 0.2); }
.badge-green  { background: rgba(0, 200, 150, 0.1);  color: var(--color-green);    border: 1px solid rgba(0, 200, 150, 0.2); }
.badge-red    { background: rgba(230, 57, 70, 0.12); color: var(--color-red-400);  border: 1px solid rgba(230, 57, 70, 0.2); }
.badge-yellow { background: rgba(245, 158, 11, 0.12);color: var(--color-yellow);   border: 1px solid rgba(245, 158, 11, 0.2); }
.badge-muted  { background: rgba(255,255,255,0.04);  color: var(--text-secondary); border: 1px solid var(--border-subtle); }
.badge-cyan   { background: rgba(6, 182, 212, 0.1);  color: var(--color-cyan);     border: 1px solid rgba(6, 182, 212, 0.2); }

/* ── Status pill ──────────────────────────────────────────────────────────── */
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
}

.status-pill::before {
  content: '';
  width: 5px; height: 5px;
  border-radius: 50%;
  flex-shrink: 0;
}

.status-pill.pending::before { background: #4a90d9; box-shadow: 0 0 5px #4a90d9; }
.status-pill.pending { color: #4a90d9; }

.status-pill.process::before { background: var(--color-yellow); box-shadow: 0 0 5px var(--color-yellow); animation: dot-pulse 1.5s infinite; }
.status-pill.process { color: var(--color-yellow); }

.status-pill.done::before { background: var(--color-green); box-shadow: 0 0 5px var(--color-green); }
.status-pill.done { color: var(--color-green); }

.status-pill.error::before { background: var(--color-red-500); box-shadow: 0 0 5px var(--color-red-500); animation: dot-pulse 0.8s infinite; }
.status-pill.error { color: var(--color-red-500); }

/* ── Progress bar ─────────────────────────────────────────────────────────── */
.progress {
  height: 3px;
  background: var(--border-subtle);
  border-radius: var(--radius-full);
  overflow: hidden;
}

.progress-track {
  height: 100%;
  border-radius: var(--radius-full);
  transition: width 0.8s cubic-bezier(0.4, 0, 0.2, 1);
}

.progress-track.blue   { background: linear-gradient(90deg, var(--color-blue-700), var(--color-blue-400)); }
.progress-track.green  { background: linear-gradient(90deg, #007a5e, var(--color-green)); }
.progress-track.yellow { background: linear-gradient(90deg, #a06300, var(--color-yellow)); }
.progress-track.red    { background: linear-gradient(90deg, var(--color-red-600), var(--color-red-400)); }

/* ── Divider ──────────────────────────────────────────────────────────────── */
.divider {
  height: 1px;
  background: var(--border-subtle);
  width: 100%;
}

/* ── Tab selector / Submenu ───────────────────────────────────────────────── */
.tab-bar {
  display: flex;
  gap: 2px;
  background: var(--color-glass-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: 4px;
  width: fit-content;
}

.tab-item {
  padding: 7px 20px;
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  cursor: pointer;
  color: var(--text-secondary);
  border: 1px solid transparent;
  transition: all var(--transition-base);
  white-space: nowrap;
}

.tab-item:hover { color: var(--text-primary); }

.tab-item.active {
  background: linear-gradient(135deg, var(--color-blue-900), var(--color-blue-800));
  color: var(--color-blue-300);
  border-color: var(--border-default);
  box-shadow: 0 0 16px var(--color-blue-glow-sm), inset 0 0 10px rgba(59,130,246,0.05);
}

/* ── Stat card ────────────────────────────────────────────────────────────── */
.stat-card {
  background: var(--color-glass-sm);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-5);
  position: relative;
  overflow: hidden;
  cursor: pointer;
  transition: all var(--transition-base);
}

.stat-card:hover {
  background: var(--color-glass-md);
  transform: translateY(-2px);
  box-shadow: var(--shadow-card);
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  opacity: 0.5;
}

.stat-card.blue::before   { background: linear-gradient(90deg, transparent, var(--color-blue-400), transparent); }
.stat-card.green::before  { background: linear-gradient(90deg, transparent, var(--color-green), transparent); }
.stat-card.yellow::before { background: linear-gradient(90deg, transparent, var(--color-yellow), transparent); }
.stat-card.red::before    { background: linear-gradient(90deg, transparent, var(--color-red-500), transparent); }

.stat-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: var(--space-4);
}

.stat-card-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-tertiary);
}

.stat-card-icon {
  width: 36px; height: 36px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px;
  background: var(--color-glass-md);
  border: 1px solid var(--border-subtle);
}

.stat-value {
  font-size: 32px;
  font-weight: var(--weight-bold);
  letter-spacing: -1.5px;
  line-height: 1;
  margin-bottom: var(--space-2);
  font-variant-numeric: tabular-nums;
}

.stat-meta {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-weight: var(--weight-semi);
}

.trend.up   { color: var(--color-green); }
.trend.down { color: var(--color-red-500); }

/* ── Request / Kanban card ────────────────────────────────────────────────── */
.req-card {
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  padding: var(--space-3) var(--space-3) var(--space-3) var(--space-4);
  margin-bottom: var(--space-2);
  cursor: pointer;
  transition: all var(--transition-base);
  position: relative;
  overflow: hidden;
}

.req-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 3px; height: 100%;
  border-radius: 0;
}

.req-card.pending::before { background: #4a90d9; }
.req-card.process::before { background: var(--color-yellow); }
.req-card.done::before    { background: var(--color-green); }
.req-card.error::before   { background: var(--color-red-500); }

.req-card:hover {
  background: var(--color-glass-hover);
  border-color: var(--border-default);
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(0,0,0,0.3);
}

.req-card.selected {
  border-color: var(--color-blue-400);
  box-shadow: 0 0 0 1px var(--color-blue-400), 0 6px 24px var(--color-blue-glow);
}

.req-id {
  font-size: 9px;
  font-family: var(--font-mono);
  color: var(--text-muted);
  letter-spacing: 0.5px;
  margin-bottom: 5px;
}

.req-name {
  font-size: var(--text-sm);
  font-weight: var(--weight-semi);
  color: var(--text-primary);
  margin-bottom: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.req-detail {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
  line-height: 1.4;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.req-footer {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.req-time {
  margin-left: auto;
  font-size: 9px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  white-space: nowrap;
}

/* ── Kanban column header ─────────────────────────────────────────────────── */
.kanban-col-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border-subtle);
}

.kanban-col-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}

.kanban-col-dot.pending { background: #4a90d9; box-shadow: 0 0 6px #4a90d9; }
.kanban-col-dot.process { background: var(--color-yellow); box-shadow: 0 0 6px var(--color-yellow); animation: dot-pulse 1.5s infinite; }
.kanban-col-dot.done    { background: var(--color-green); box-shadow: 0 0 6px var(--color-green); }
.kanban-col-dot.error   { background: var(--color-red-500); box-shadow: 0 0 6px var(--color-red-500); }

.kanban-col-label {
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-secondary);
}

.kanban-col-count {
  margin-left: auto;
  font-size: var(--text-xs);
  color: var(--text-muted);
  background: var(--color-glass-sm);
  border: 1px solid var(--border-subtle);
  padding: 1px 7px;
  border-radius: var(--radius-full);
  font-family: var(--font-mono);
}

/* ── Feed item ────────────────────────────────────────────────────────────── */
.feed-item {
  display: flex;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  transition: background var(--transition-fast);
  cursor: pointer;
}

.feed-item:last-child { border-bottom: none; }
.feed-item:hover { background: var(--color-glass-sm); }
.feed-item.is-new { background: rgba(59, 130, 246, 0.04); }

.feed-icon-wrap {
  width: 28px; height: 28px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  font-size: 13px;
  background: var(--color-glass-md);
  border: 1px solid var(--border-subtle);
  flex-shrink: 0;
  margin-top: 1px;
}

.feed-body { flex: 1; min-width: 0; }

.feed-msg {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  line-height: 1.45;
}

.feed-msg strong {
  color: var(--text-primary);
  font-weight: var(--weight-medium);
}

.feed-ts {
  font-size: 9px;
  color: var(--text-muted);
  font-family: var(--font-mono);
  margin-top: 3px;
}

/* ── Log line ─────────────────────────────────────────────────────────────── */
.log-line {
  display: grid;
  grid-template-columns: 60px 42px 1fr;
  gap: var(--space-3);
  padding: 5px var(--space-4);
  border-bottom: 1px solid rgba(255,255,255,0.018);
  font-family: var(--font-mono);
  font-size: 11px;
  line-height: 1.5;
  transition: background var(--transition-fast);
}

.log-line:hover { background: var(--color-glass-sm); }
.log-line:last-child { border-bottom: none; }

.log-ts  { color: var(--text-muted); }
.log-lvl { font-weight: var(--weight-semi); text-align: center; }
.log-msg { color: var(--text-secondary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.log-lvl.info  { color: var(--color-blue-400); }
.log-lvl.ok    { color: var(--color-green); }
.log-lvl.warn  { color: var(--color-yellow); }
.log-lvl.error { color: var(--color-red-400); }

/* ── Mini chart bars ──────────────────────────────────────────────────────── */
.mini-chart {
  display: flex;
  align-items: flex-end;
  gap: 3px;
  height: 40px;
  padding: 0 var(--space-5) var(--space-3);
}

.mini-bar {
  flex: 1;
  border-radius: 2px 2px 0 0;
  opacity: 0.65;
  transition: height 0.5s ease, opacity var(--transition-base);
  cursor: pointer;
  background: linear-gradient(to top, var(--color-blue-800), var(--color-blue-400));
  min-height: 3px;
}

.mini-bar:hover { opacity: 1; }
.mini-bar.accent { background: linear-gradient(to top, var(--color-red-600), var(--color-red-400)); }

/* ── Status pill color variants ───────────────────────────────────────────── */
.status-pill.green::before  { background: var(--color-green);    box-shadow: 0 0 5px var(--color-green); }
.status-pill.green          { color: var(--color-green); }
.status-pill.red::before    { background: var(--color-red-500);  box-shadow: 0 0 5px var(--color-red-500); animation: dot-pulse 0.8s infinite; }
.status-pill.red            { color: var(--color-red-500); }
.status-pill.yellow::before { background: var(--color-yellow);   box-shadow: 0 0 5px var(--color-yellow); }
.status-pill.yellow         { color: var(--color-yellow); }
.status-pill.blue::before   { background: var(--color-blue-400); box-shadow: 0 0 5px var(--color-blue-400); }
.status-pill.blue           { color: var(--color-blue-400); }

/* ── Contract type rows ───────────────────────────────────────────────────── */
.contract-row {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--border-subtle);
}
.contract-row:last-child { border-bottom: none; }

.contract-row-header {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* ── Utility spacing ──────────────────────────────────────────────────────── */
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }
.mt-2 { margin-top: var(--space-2); }
.mt-4 { margin-top: var(--space-4); }
.w-full { width: 100%; }

/* ── Table ────────────────────────────────────────────────────────────────── */
.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th {
  text-align: left;
  font-size: var(--text-xs);
  font-weight: var(--weight-semi);
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  white-space: nowrap;
}

.data-table td {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  color: var(--text-secondary);
  border-bottom: 1px solid var(--border-subtle);
  vertical-align: middle;
}

.table-row { transition: background var(--transition-fast); }
.table-row:hover td { background: var(--color-glass-sm); color: var(--text-primary); }
.table-row:last-child td { border-bottom: none; }

/* ═══════════════════════════════════════════════════════════════════════════
   ZONA CLARA — component overrides dentro de .main-area
   ═══════════════════════════════════════════════════════════════════════════ */

/* Panels */
.main-area .panel {
  background: var(--lz-panel);
  border-color: var(--lz-border);
  box-shadow: var(--lz-shadow-sm);
}
.main-area .panel:hover { box-shadow: var(--lz-shadow-md); }
.main-area .panel-glow-top::before,
.main-area .panel-glow-top-red::before { display: none; }
.main-area .panel-header {
  background: var(--lz-panel-header);
  border-bottom-color: var(--lz-border);
}
.main-area .panel-title    { color: var(--lz-text-1); font-size: var(--text-md); }
.main-area .panel-subtitle { color: var(--lz-text-3); }

/* Icon buttons */
.main-area .icon-btn {
  background: var(--lz-bg);
  border-color: var(--lz-border);
  color: var(--lz-text-2);
}
.main-area .icon-btn:hover {
  background: var(--lz-panel);
  border-color: var(--color-blue-500);
  color: var(--color-blue-500);
}

/* Stat cards */
.main-area .stat-card {
  background: var(--lz-panel);
  border-color: var(--lz-border);
  box-shadow: var(--lz-shadow-sm);
  border-left: 3px solid transparent;
}
.main-area .stat-card::before { display: none; }
.main-area .stat-card:hover {
  background: var(--lz-panel);
  box-shadow: var(--lz-shadow-md);
  transform: translateY(-2px);
}
.main-area .stat-card.blue   { border-left-color: var(--color-blue-400); }
.main-area .stat-card.green  { border-left-color: var(--color-green); }
.main-area .stat-card.yellow { border-left-color: var(--color-yellow); }
.main-area .stat-card.red    { border-left-color: var(--color-red-500); }
.main-area .stat-value       { color: var(--lz-text-1); }
.main-area .stat-card-label  { color: var(--lz-text-3); }
.main-area .stat-card-icon   { background: var(--lz-bg); border-color: var(--lz-border); }
.main-area .stat-meta        { color: var(--lz-text-3); }
.main-area .hover-glow-blue:hover {
  box-shadow: 0 0 0 1px var(--lz-border-hover), var(--lz-shadow-md);
}

/* Feed items */
.main-area .feed-item             { border-bottom-color: var(--lz-border); }
.main-area .feed-item:hover       { background: var(--lz-bg); }
.main-area .feed-msg              { color: var(--lz-text-2); }
.main-area .feed-msg strong       { color: var(--lz-text-1); }
.main-area .feed-ts               { color: var(--lz-text-3); }
.main-area .feed-icon-wrap        { background: var(--lz-bg); border-color: var(--lz-border); }

/* Log lines */
.main-area .log-line              { border-bottom-color: var(--lz-border); }
.main-area .log-line:hover        { background: var(--lz-bg); }
.main-area .log-ts                { color: var(--lz-text-3); }
.main-area .log-msg               { color: var(--lz-text-2); }
.main-area .log-lvl               { color: var(--lz-text-3); }
.main-area .log-lvl.info          { color: var(--color-blue-500); }
.main-area .log-lvl.warn          { color: var(--color-yellow); }
.main-area .log-lvl.error         { color: var(--color-red-500); }

/* Table */
.main-area .data-table th {
  background: var(--lz-panel-header);
  color: var(--lz-text-3);
  border-bottom: 1px solid var(--lz-border);
}
.main-area .data-table td         { color: var(--lz-text-2); border-bottom-color: var(--lz-border); }
.main-area .table-row:hover td    { background: var(--lz-bg); color: var(--lz-text-1); }
.main-area .table-row:last-child td { border-bottom: none; }

/* Req/Kanban cards */
.main-area .req-card              { background: var(--lz-bg); border-color: var(--lz-border); }
.main-area .req-card:hover        { background: var(--lz-panel-header); border-color: var(--lz-border-hover); box-shadow: var(--lz-shadow-sm); }
.main-area .req-id                { color: var(--lz-text-3); }
.main-area .req-name              { color: var(--lz-text-1); }
.main-area .req-detail            { color: var(--lz-text-2); }
.main-area .req-time              { color: var(--lz-text-3); }

/* Contract rows */
.main-area .contract-row          { border-bottom-color: var(--lz-border); }

/* Tabs */
.main-area .tab-bar               { background: var(--lz-bg); border-color: var(--lz-border); }
.main-area .tab-item              { color: var(--lz-text-2); }
.main-area .tab-item:hover        { color: var(--lz-text-1); }
.main-area .tab-item.active       { background: var(--lz-panel); color: var(--color-blue-500); border-color: var(--lz-border); box-shadow: var(--lz-shadow-sm); }

/* Dividers */
.main-area .divider               { background: var(--lz-border); }

/* Kanban column */
.main-area .kanban-col-header     { border-bottom-color: var(--lz-border); }

/* Badge counts inline */
.main-area .stage-count {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 20px; height: 20px; padding: 0 6px;
  border-radius: var(--radius-full);
  font-size: 10px; font-weight: var(--weight-bold);
  margin-left: auto;
}
.main-area .stage-count.blue   { background: rgba(37,99,235,0.12); color: var(--color-blue-500); }
.main-area .stage-count.green  { background: rgba(0,200,150,0.12); color: var(--color-green); }
.main-area .stage-count.yellow { background: rgba(245,158,11,0.12); color: var(--color-yellow); }
.main-area .stage-count.red    { background: rgba(230,57,70,0.12); color: var(--color-red-500); }

/* Live panel on light bg */
.main-area .live-label { color: var(--color-red-500); }
.main-area .live-dot   { box-shadow: 0 0 6px var(--color-red-500); }
