/* public/assets/ui/framework/04_components.css
   KomodUI Components v0.1
   Component primitives: card, buttons, forms, avatars, tables, badges, alerts.
*/

/* =========================
   Card
   ========================= */

.card {
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-7);
  box-shadow: var(--shadow-sm);
}

.card-sm { padding: var(--space-6); }
.card-lg { padding: var(--space-8); }

@media (max-width: 576px) {
  .card { padding: var(--space-6); }
}

/* =========================
   Buttons
   ========================= */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);

  padding: 10px 18px;
  border-radius: var(--radius-sm);
  border: 1px solid transparent;

  cursor: pointer;
  user-select: none;
  font-weight: var(--font-weight-bold);
  font-size: 0.95rem;
  line-height: 1;

  transition: var(--transition);
}

.btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.btn-sm { padding: 8px 14px; font-size: 0.9rem; }
.btn-lg { padding: 12px 22px; font-size: 1rem; }

.btn-primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: var(--shadow-sm);
}
.btn-primary:hover { background: var(--color-primary-dark); }

.btn-outline {
  background: transparent;
  border-color: var(--color-border);
  color: var(--color-text-main);
}
.btn-outline:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: #fff;
}

.btn-accent {
  background: var(--color-accent);
  color: #fff;
}
.btn-accent:hover { background: var(--color-accent-hover); }

.btn-danger {
  background: var(--color-danger);
  color: #fff;
}
.btn-danger:hover { filter: brightness(0.92); }

/* =========================
   Forms
   ========================= */

.form-group { margin-bottom: var(--space-5); }

.form-label {
  display: block;
  margin-bottom: var(--space-2);
  font-weight: var(--font-weight-bold);
  font-size: 0.9rem;
  color: var(--color-text-heading);
}

.form-control {
  width: 100%;
  padding: 10px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #fff;
  color: var(--color-text-main);
  transition: var(--transition);
}

.form-control:focus-visible {
  border-color: var(--color-primary);
  box-shadow: var(--focus-ring);
}

.form-hint {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* =========================
   Badge
   ========================= */

.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-border);
  background: #fff;
  color: var(--color-text-main);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1.2;
}

.badge-primary {
  border-color: rgba(79,70,229,0.25);
  background: rgba(79,70,229,0.08);
  color: var(--color-primary-dark);
}

.badge-danger {
  border-color: rgba(239,68,68,0.25);
  background: rgba(239,68,68,0.08);
  color: #991B1B;
}

/* =========================
   Alert
   ========================= */

.alert {
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border);
  background: #fff;
  padding: var(--space-5);
  box-shadow: var(--shadow-sm);
}

.alert-info {
  border-color: rgba(59,130,246,0.25);
  background: rgba(59,130,246,0.07);
}

.alert-success {
  border-color: rgba(16,185,129,0.25);
  background: rgba(16,185,129,0.07);
}

.alert-warning {
  border-color: rgba(245,158,11,0.25);
  background: rgba(245,158,11,0.08);
}

.alert-danger {
  border-color: rgba(239,68,68,0.25);
  background: rgba(239,68,68,0.08);
}

/* =========================
   Avatar (anti-squish)
   ========================= */

.avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  overflow: hidden;
  background: var(--color-primary-soft);
  border: 1px solid var(--color-border);
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.avatar-32 { width: 32px; height: 32px; }
.avatar-40 { width: 40px; height: 40px; }
.avatar-56 { width: 56px; height: 56px; }
.avatar-80 { width: 80px; height: 80px; }
.avatar-96 { width: 96px; height: 96px; }

/* Safety net for legacy “avatar-like” blocks */
[class*="avatar"] img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* =========================
   Tables (mobile-safe)
   ========================= */

.table-scroll {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.table {
  width: 100%;
  border-collapse: collapse;
  background: var(--color-bg-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden; /* radius works on table wrapper in many browsers */
}

/* If table needs width to prevent squeezing columns */
.table--wide {
  min-width: 720px;
}

.table th,
.table td {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  text-align: left;
  vertical-align: top;
}

.table th {
  font-size: var(--text-sm);
  font-weight: var(--font-weight-black);
  color: var(--color-text-heading);
  background: #F8FAFC;
}

.table tr:last-child td {
  border-bottom: none;
}

.table td {
  color: var(--color-text-main);
}

/* Row hover for desktop */
@media (hover: hover) {
  .table tbody tr:hover td {
    background: rgba(79,70,229,0.04);
  }
}  