/* ============================================================
   NIMBOO SHOWROOM · Admin
   Estilos del Dashboard, listas, login
   ============================================================ */

/* ============================================================
   KPI / STATS - EDITORIAL
   Números enormes, líneas finas, mucho aire
   ============================================================ */
.kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--line-firm);
  border-bottom: 1px solid var(--line-firm);
  margin-bottom: var(--sp-9);
}
.kpi {
  padding: var(--sp-7) var(--sp-6) var(--sp-7) 0;
  border-right: 1px solid var(--line);
  opacity: 0;
  animation: kpi-fade-in 0.6s var(--ease-out) forwards;
  position: relative;
  cursor: default;
}
.kpi:nth-child(1) { animation-delay: 0.05s; }
.kpi:nth-child(2) { animation-delay: 0.15s; }
.kpi:nth-child(3) { animation-delay: 0.25s; }
.kpi:nth-child(4) { animation-delay: 0.35s; }
@keyframes kpi-fade-in {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}
.kpi:last-child { border-right: none; }
.kpi:not(:first-child) { padding-left: var(--sp-6); }
.kpi .num {
  font-family: var(--font-display);
  font-weight: 300;
  font-size: var(--fs-5xl);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
  color: var(--ink-1000);
  margin-bottom: var(--sp-2);
  transition: color var(--t-base) var(--ease-out);
}
.kpi:hover .num { color: var(--sage); }
.kpi .num em {
  font-style: italic;
  font-size: 0.6em;
  color: var(--ink-500);
  margin-left: 6px;
  vertical-align: top;
}
.kpi .label {
  font-size: var(--fs-2xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: var(--ink-500);
  font-weight: 500;
  transition: color var(--t-base) var(--ease-out);
}
.kpi:hover .label { color: var(--ink-700); }
.kpi .delta {
  font-family: var(--font-mono);
  font-size: var(--fs-xs);
  color: var(--success);
  margin-top: var(--sp-2);
}
.kpi .delta.flat { color: var(--ink-400); }

/* ============================================================
   PROJECTS LIST (estilo editorial - uno por fila o 2 columnas)
   ============================================================ */
.projects-list {
  display: grid;
  gap: 0;
}
.project-item {
  display: grid;
  grid-template-columns: 60px 1fr auto auto;
  gap: var(--sp-6);
  align-items: baseline;
  padding: var(--sp-6) 0;
  border-top: 1px solid var(--line);
  cursor: pointer;
  transition: padding-left 0.4s var(--ease-out),
              background var(--t-base) var(--ease-out);
  margin: 0 calc(var(--sp-3) * -1);
  padding-left: var(--sp-3);
  padding-right: var(--sp-3);
}
.project-item:first-child { border-top: 1px solid var(--line-firm); }
.project-item:hover {
  padding-left: var(--sp-6);
  background: var(--paper-soft);
}
.project-item .num {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-md);
  color: var(--ink-500);
  transition: color var(--t-base) var(--ease-out), transform var(--t-base) var(--ease-out);
}
.project-item:hover .num { color: var(--sage); transform: translateX(-4px); }
.project-item .info .name {
  font-family: var(--font-display);
  font-weight: 400;
  font-size: var(--fs-xl);
  letter-spacing: var(--tracking-display);
  color: var(--ink-1000);
  margin-bottom: 4px;
  line-height: 1.1;
}
.project-item .info .name em { font-style: italic; }
.project-item .info .meta {
  font-size: var(--fs-xs);
  color: var(--ink-500);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.project-item .arrow {
  font-family: var(--font-display);
  font-style: italic;
  font-size: var(--fs-sm);
  color: var(--ink-700);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  opacity: 0;
  transform: translateX(-8px);
  transition: opacity var(--t-base) var(--ease-out),
              transform var(--t-base) var(--ease-out),
              gap var(--t-base) var(--ease-out);
}
.project-item:hover .arrow {
  opacity: 1;
  transform: translateX(0);
  gap: 12px;
}

/* ============================================================
   QUICK SECTIONS (panel derecho del dashboard)
   ============================================================ */
.quick-actions {
  display: flex;
  flex-direction: column;
  gap: var(--sp-2);
}
.quick-action {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--sp-4);
  border: 1px solid var(--line);
  border-radius: var(--r-md);
  background: transparent;
  text-align: left;
  cursor: pointer;
  transition: all var(--t-base) var(--ease-out);
  position: relative;
  overflow: hidden;
}
.quick-action::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 0;
  background: var(--sage-softer);
  transition: width 0.4s var(--ease-out);
  z-index: 0;
}
.quick-action:hover::before { width: 100%; }
.quick-action > * { position: relative; z-index: 1; }
.quick-action:hover {
  border-color: var(--sage);
  transform: translateX(2px);
}
.quick-action .info { display: flex; flex-direction: column; gap: 2px; }
.quick-action .info strong {
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-1000);
}
.quick-action .info span {
  font-size: var(--fs-xs);
  color: var(--ink-500);
}
.quick-action svg {
  width: 16px;
  height: 16px;
  color: var(--ink-500);
  flex-shrink: 0;
  transition: color var(--t-base) var(--ease-out), transform 0.3s var(--ease-out);
}
.quick-action:hover svg {
  color: var(--sage-text);
  transform: translateX(4px);
}

/* ============================================================
   STATUS PILLS - tabla
   ============================================================ */
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--r-full);
  font-size: var(--fs-2xs);
  font-weight: 500;
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}
.status-pill::before {
  content: '';
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: currentColor;
}
.status-pill.active { background: var(--success-bg); color: var(--success); }
.status-pill.inactive { background: var(--paper-soft); color: var(--ink-500); }
.status-pill.draft { background: var(--warn-bg); color: var(--warn); }

/* ============================================================
   AVATAR EN TABLAS
   ============================================================ */
.client-avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--sage-soft);
  color: var(--sage-text);
  display: inline-grid;
  place-items: center;
  font-size: var(--fs-xs);
  font-weight: 600;
  flex-shrink: 0;
}
.client-cell {
  display: flex;
  align-items: center;
  gap: var(--sp-3);
}
.client-cell .info { display: flex; flex-direction: column; }
.client-cell .info strong { font-weight: 500; color: var(--ink-1000); }
.client-cell .info span { font-size: var(--fs-xs); color: var(--ink-500); }

/* ============================================================
   LOGIN
   ============================================================ */
.login-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  background: var(--paper);
}
.login-visual {
  background: var(--ink-1000);
  color: var(--paper);
  padding: var(--sp-9);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  position: relative;
  overflow: hidden;
}
.login-visual::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse at 20% 80%, rgba(90, 107, 79, 0.25) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(139, 159, 126, 0.15) 0%, transparent 50%);
  pointer-events: none;
}
.login-visual-content {
  position: relative;
  z-index: 2;
}
.login-visual .brand {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: var(--sp-9);
}
.login-visual .brand img {
  width: 32px;
  height: 32px;
  filter: brightness(0) invert(1);
  opacity: 0.9;
}
.login-visual .brand span {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  letter-spacing: var(--tracking-display);
}
.login-visual .brand span em { font-style: italic; }
.login-visual h1 {
  font-size: var(--fs-5xl);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--paper);
  margin-bottom: var(--sp-5);
  font-weight: 300;
}
.login-visual h1 em { font-style: italic; font-weight: 400; }
.login-visual p {
  color: rgba(250, 250, 247, 0.65);
  font-size: var(--fs-md);
  line-height: var(--lh-base);
  max-width: 420px;
}
.login-visual .footer {
  position: relative;
  z-index: 2;
  font-size: var(--fs-2xs);
  letter-spacing: var(--tracking-widest);
  text-transform: uppercase;
  color: rgba(250, 250, 247, 0.4);
}

.login-form-side {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--sp-9);
}
.login-form {
  max-width: 380px;
  width: 100%;
}
.login-form .eyebrow { margin-bottom: var(--sp-3); }
.login-form h2 {
  font-size: var(--fs-2xl);
  margin-bottom: var(--sp-2);
}
.login-form .lede {
  color: var(--ink-600);
  margin-bottom: var(--sp-7);
}
.login-form .form-stack {
  display: flex;
  flex-direction: column;
  gap: var(--sp-5);
}
.login-form .helper {
  text-align: center;
  font-size: var(--fs-xs);
  color: var(--ink-500);
  margin-top: var(--sp-5);
}

@media (max-width: 880px) {
  .login-shell { grid-template-columns: 1fr; }
  .login-visual { display: none; }
  .kpis { grid-template-columns: 1fr 1fr; }
  .kpi:nth-child(2) { border-right: none; }
  .kpi:nth-child(1), .kpi:nth-child(2) { border-bottom: 1px solid var(--line); }
  .project-item { grid-template-columns: 40px 1fr auto; }
  .project-item .arrow { display: none; }
}
