/* ============================================================
   abruma · Componentes
   ------------------------------------------------------------
   Requiere abruma-tokens.css cargado antes que este archivo.
   Todas las clases van con prefijo .abr- para no colisionar.
   Los componentes consumen SOLO variables semánticas.
   ============================================================ */

/* ---------- Base tipográfica (opcional) ---------- */
.abr-root {
  background: var(--bg-canvas);
  color: var(--text-primary);
  font-family: var(--font-body);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
.abr-display { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; }
.abr-display--impact { font-weight: 800; letter-spacing: -0.025em; }
.abr-text-secondary { color: var(--text-secondary); }
.abr-text-tertiary  { color: var(--text-tertiary); }

/* ---------- Logo (Handy Organizer vía PNG) ----------
   El logo NO es texto: es una imagen. Usa la versión de color
   que contraste con el fondo (crema sobre oscuro, espresso sobre claro). */
.abr-logo { display: inline-block; line-height: 0; }
.abr-logo img { display: block; height: 26px; width: auto; }
.abr-logo--lg img { height: 40px; }


/* ---------- Botones ---------- */
.abr-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  font-family: var(--font-body); font-size: 14px; font-weight: 600;
  border-radius: var(--radius-md); padding: 11px 20px; cursor: pointer;
  border: 1px solid transparent; transition: background .15s ease, color .15s ease, box-shadow .15s ease;
  text-decoration: none;
}
.abr-btn:focus-visible { outline: none; box-shadow: var(--focus-ring); }

.abr-btn--primary  { background: var(--brand-bg-strong); color: var(--text-on-cta); }
.abr-btn--primary:hover  { background: var(--brand-bg-pressed); }

.abr-btn--soft     { background: var(--brand-bg-soft); color: var(--brand-text); border-color: var(--brand-border); }
.abr-btn--soft:hover     { background: #FBE2DA; }

.abr-btn--ghost    { background: transparent; color: var(--text-primary); border-color: var(--border-default); }
.abr-btn--ghost:hover    { background: var(--bg-hover); }

.abr-btn--link     { background: none; border: none; color: var(--link); padding: 11px 4px; }
.abr-btn--link:hover     { color: var(--link-hover); text-decoration: underline; }


/* ---------- Campos / inputs ---------- */
.abr-field { display: block; }
.abr-field__label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 7px; }
.abr-input {
  width: 100%; font-family: var(--font-body); font-size: 14px;
  background: var(--bg-surface); color: var(--text-primary);
  border: 1px solid var(--border-default); border-radius: var(--radius-md);
  padding: 11px 14px; transition: border-color .15s, box-shadow .15s;
}
.abr-input::placeholder { color: var(--text-tertiary); }
.abr-input:focus { outline: none; border-color: var(--color-periwinkle-400); box-shadow: var(--focus-ring); }


/* ---------- Card ---------- */
.abr-card {
  background: var(--bg-surface);
  border: 0.5px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 22px;
}
.abr-card__title { font-weight: 600; font-size: 15px; }
.abr-card__sub   { font-size: 13px; color: var(--text-secondary); margin-top: 4px; }


/* ---------- KPI ---------- */
/* Pasa el acento con style="--abr-accent: var(--color-…)" */
.abr-kpi {
  background: var(--bg-surface);
  border: 0.5px solid var(--border-subtle);
  border-left: 3px solid var(--abr-accent, var(--brand-bg-strong));
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  padding: 18px 20px;
}
.abr-kpi__label { font-size: 12.5px; color: var(--text-secondary); font-weight: 500; }
.abr-kpi__value { font-family: var(--font-display); font-weight: 500; font-size: 32px; letter-spacing: -0.02em; margin-top: 6px; }
.abr-kpi__delta { font-size: 12px; font-weight: 600; margin-top: 6px; display: inline-flex; gap: 4px; align-items: center; }
.abr-kpi__delta--up   { color: var(--color-sage-800); }
.abr-kpi__delta--down { color: var(--color-brick-800); }


/* ---------- Tags de categoría ---------- */
.abr-tag {
  display: inline-flex; align-items: center; gap: 7px;
  font-size: 12.5px; font-weight: 600; padding: 5px 12px; border-radius: 100px;
}
.abr-tag__dot { width: 8px; height: 8px; border-radius: 50%; }

.abr-tag--coral { background: #FDEEE9; color: var(--color-coral-800); }
.abr-tag--coral .abr-tag__dot { background: var(--color-coral-400); }
.abr-tag--peri  { background: var(--color-periwinkle-50); color: var(--color-periwinkle-800); }
.abr-tag--peri  .abr-tag__dot { background: var(--color-periwinkle-400); }
.abr-tag--pist  { background: #EEF4E0; color: #54663A; }
.abr-tag--pist  .abr-tag__dot { background: var(--color-pistachio); }
.abr-tag--apri  { background: #FCEBD7; color: #8A5A1E; }
.abr-tag--apri  .abr-tag__dot { background: var(--color-apricot); }
.abr-tag--lila  { background: #F2EBFB; color: #5B4583; }
.abr-tag--lila  .abr-tag__dot { background: var(--color-lilac); }
.abr-tag--mint  { background: #E2F4EC; color: #27664E; }
.abr-tag--mint  .abr-tag__dot { background: var(--color-mint); }


/* ---------- Badges semánticos ---------- */
.abr-badge {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12.5px; font-weight: 600; padding: 4px 11px; border-radius: 100px;
}
.abr-badge--success { background: var(--color-sage-50);  color: var(--color-sage-800); }
.abr-badge--warning { background: var(--color-honey-50); color: var(--color-honey-800); }
.abr-badge--danger  { background: var(--color-brick-50); color: var(--color-brick-800); }
.abr-badge--info    { background: var(--color-periwinkle-50); color: var(--color-periwinkle-800); }


/* ---------- Brumi (asistente IA) ---------- */
.abr-brumi {
  background: var(--brand-bg-soft);
  border: 1px solid var(--brand-border);
  border-radius: var(--radius-xl);
  padding: 22px; position: relative; overflow: hidden;
}
.abr-brumi::after {
  content: ""; position: absolute; right: -40px; top: -40px; width: 160px; height: 160px;
  background: radial-gradient(circle, rgba(248,164,148,0.35), transparent 70%); pointer-events: none;
}
.abr-brumi__head { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; position: relative; z-index: 1; }
.abr-brumi__avatar {
  width: 40px; height: 40px; border-radius: 50%; background: var(--brand-bg-strong);
  display: grid; place-items: center; color: var(--text-on-cta);
  font-weight: 700; font-family: var(--font-display); box-shadow: var(--shadow-sm); flex: none;
}
.abr-brumi__name { font-weight: 700; color: var(--brand-text); font-size: 15px; }
.abr-brumi__name span { display: block; font-size: 11.5px; font-weight: 500; color: #B0705F; }
.abr-brumi__msg { color: var(--text-on-brand); font-size: 14.5px; position: relative; z-index: 1; }
.abr-brumi__input {
  margin-top: 16px; display: flex; gap: 8px; background: var(--bg-surface);
  border: 1px solid var(--brand-border); border-radius: var(--radius-md);
  padding: 6px 6px 6px 14px; position: relative; z-index: 1;
}
.abr-brumi__input input { flex: 1; border: none; background: none; font-family: var(--font-body); font-size: 14px; color: var(--text-primary); }
.abr-brumi__input input:focus { outline: none; }
.abr-brumi__input button {
  border: none; background: var(--brand-bg-strong); color: var(--text-on-cta);
  border-radius: var(--radius-sm); padding: 8px 14px; font-weight: 600; cursor: pointer;
  font-family: var(--font-body); font-size: 13px;
}
.abr-brumi__input button:hover { background: var(--brand-bg-pressed); }


/* ---------- Sidebar / navegación ---------- */
.abr-sidebar { background: var(--bg-sidebar); padding: 20px 14px; color: var(--color-crema-200); }
.abr-sidebar__logo { padding: 6px 10px 18px; } /* dentro va <span class="abr-logo"><img ...></span> */
.abr-nav-item {
  display: flex; align-items: center; gap: 10px; padding: 9px 12px;
  border-radius: var(--radius-sm); font-size: 13.5px; font-weight: 500;
  color: rgba(247,242,233,0.72); margin-bottom: 2px; cursor: pointer;
  transition: background .15s, color .15s; text-decoration: none;
}
.abr-nav-item:hover,
.abr-nav-item--active { background: var(--bg-sidebar-hover); color: #fff; }
