/* ============================================================
   LIIT — Core Components
   ============================================================ */

/* ─── Buttons ─────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-weight: var(--weight-semibold);
  font-size: var(--text-base);
  line-height: 1;
  padding: 0 var(--space-6);
  height: 48px;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  transition:
    background-color var(--dur-base) var(--ease-out),
    border-color var(--dur-base) var(--ease-out),
    color var(--dur-base) var(--ease-out),
    transform var(--dur-fast) var(--ease-out),
    box-shadow var(--dur-base) var(--ease-out);
}
.btn:focus-visible {
  outline: 2px solid var(--brand);
  outline-offset: 2px;
}
.btn:active { transform: translateY(1px); }
.btn[disabled], .btn:disabled {
  opacity: 0.4;
  cursor: not-allowed;
  transform: none;
}

/* sizes */
.btn--sm { height: 36px; padding: 0 var(--space-4); font-size: var(--text-sm); border-radius: var(--radius-sm); }
.btn--md { height: 44px; padding: 0 var(--space-5); font-size: var(--text-base); }
.btn--lg { height: 56px; padding: 0 var(--space-8); font-size: var(--text-md); border-radius: var(--radius-lg); }

/* variants */
.btn--primary {
  background: var(--brand);
  color: var(--fg-on-brand);
  box-shadow: 0 1px 2px rgba(14,19,24,0.06);
}
.btn--primary:hover { background: var(--brand-hover); box-shadow: var(--shadow-brand); }
.btn--primary:active { background: var(--brand-active); }

.btn--secondary {
  background: var(--gray-900);
  color: var(--gray-0);
}
.btn--secondary:hover { background: var(--gray-700); }

.btn--outline {
  background: transparent;
  color: var(--fg);
  border-color: var(--border-strong);
}
.btn--outline:hover { border-color: var(--brand); color: var(--brand-hover); background: var(--brand-soft); }

.btn--ghost {
  background: transparent;
  color: var(--fg);
}
.btn--ghost:hover { background: var(--bg-muted); }

.btn--brand-soft {
  background: var(--brand-soft);
  color: var(--brand-active);
}
.btn--brand-soft:hover { background: var(--liit-mint-100); }

.btn--danger {
  background: var(--color-danger);
  color: var(--fg-on-brand);
}
.btn--danger:hover { filter: brightness(0.95); }

/* icon-only */
.btn--icon { width: 44px; padding: 0; }
.btn--icon.btn--sm { width: 36px; }
.btn--icon.btn--lg { width: 56px; }

/* full-width */
.btn--block { width: 100%; }

/* ─── Inputs ──────────────────────────────────────────────── */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.field__label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--fg);
}
.field__hint {
  font-size: var(--text-xs);
  color: var(--fg-subtle);
}
.input, .textarea, .select {
  width: 100%;
  font-family: inherit;
  font-size: var(--text-base);
  color: var(--fg);
  background: var(--bg);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius-md);
  padding: 0 var(--space-4);
  height: 48px;
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out);
}
.input::placeholder, .textarea::placeholder { color: var(--fg-subtle); }
.input:hover, .textarea:hover, .select:hover { border-color: var(--gray-400); }
.input:focus, .textarea:focus, .select:focus {
  outline: none;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px var(--brand-soft);
}
.textarea { height: auto; padding: var(--space-3) var(--space-4); min-height: 96px; resize: vertical; line-height: var(--lh-normal); }
.select { appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 20 20' fill='none' stroke='%236B7783' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'><polyline points='5 8 10 13 15 8'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 44px; }

/* ─── Badge ───────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  background: var(--brand-soft);
  color: var(--brand-active);
  letter-spacing: 0;
}
.badge--neutral { background: var(--gray-100); color: var(--gray-700); }
.badge--success { background: #E5F8EF; color: #0F7A4A; }
.badge--warn    { background: #FFF4E0; color: #8A5A00; }
.badge--danger  { background: #FCE8E9; color: #A32228; }
.badge--dot::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: currentColor;
}

/* ─── Card ────────────────────────────────────────────────── */
.card {
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: border-color var(--dur-base) var(--ease-out), box-shadow var(--dur-base) var(--ease-out), transform var(--dur-base) var(--ease-out);
}
.card--hover:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-lg);
  transform: translateY(-2px);
}
.card--brand {
  background: linear-gradient(135deg, var(--brand-deep) 0%, var(--liit-mint-700) 100%);
  color: var(--fg-on-brand);
  border-color: transparent;
}
