/* ==========================================================================
   REGINA LAFER · DESIGN SYSTEM
   components.css — Componentes base e seus estados
   Prefixo de classe: .ds-
   ========================================================================== */

/* ==========================================================================
   BOTÕES
   Variantes: primary · secondary · accent · outline · ghost · danger
   Tamanhos: sm · md (default) · lg
   Estados: :hover · :active · :focus-visible · [disabled] · .is-loading
   ========================================================================== */
.ds-btn {
  --_bg: var(--color-primary);
  --_fg: var(--color-on-primary);
  --_bg-hover: var(--color-primary-hover);
  --_bg-active: var(--color-primary-active);
  --_border: transparent;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  line-height: 1;
  letter-spacing: var(--tracking-wide);
  padding: var(--space-3) var(--space-5);
  min-height: 44px;                 /* alvo de toque acessível */
  border-radius: var(--radius-full);/* pílula — acolhedor */
  border: var(--border-width) solid var(--_border);
  background: var(--_bg);
  color: var(--_fg);
  cursor: pointer;
  user-select: none;
  white-space: nowrap;
  transition: background var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out),
              transform var(--duration-fast) var(--ease-out);
}
.ds-btn:hover { background: var(--_bg-hover); color: var(--_fg); text-decoration: none; }
.ds-btn:active { background: var(--_bg-active); transform: translateY(1px); }
.ds-btn:focus-visible { box-shadow: var(--shadow-focus); }
.ds-btn[disabled], .ds-btn.is-disabled {
  background: var(--color-disabled-bg);
  color: var(--color-disabled-text);
  border-color: var(--color-disabled-border);
  cursor: not-allowed;
  pointer-events: none;
  transform: none;
}

/* Variantes */
.ds-btn--secondary {
  --_bg: var(--color-secondary); --_fg: var(--color-on-secondary);
  --_bg-hover: var(--color-secondary-hover); --_bg-active: var(--color-secondary-active);
}
.ds-btn--accent {
  --_bg: var(--color-accent); --_fg: var(--color-on-accent);
  --_bg-hover: var(--sage-600); --_bg-active: var(--sage-700);
}
.ds-btn--danger {
  --_bg: var(--color-danger); --_fg: #fff;
  --_bg-hover: var(--red-700); --_bg-active: var(--red-700);
}
.ds-btn--outline {
  --_bg: transparent; --_fg: var(--color-primary);
  --_bg-hover: var(--color-primary-subtle); --_bg-active: var(--color-primary-muted);
  --_border: var(--color-primary);
}
.ds-btn--outline:hover { color: var(--color-primary); }
.ds-btn--ghost {
  --_bg: transparent; --_fg: var(--color-text);
  --_bg-hover: var(--color-surface-sunken); --_bg-active: var(--color-border);
}
.ds-btn--ghost:hover { color: var(--color-text); }

/* Tamanhos */
.ds-btn--sm { font-size: var(--text-xs); padding: var(--space-2) var(--space-4); min-height: 36px; }
.ds-btn--lg { font-size: var(--text-base); padding: var(--space-4) var(--space-8); min-height: 52px; }
.ds-btn--block { width: 100%; }
.ds-btn--icon { padding: var(--space-3); aspect-ratio: 1; min-width: 44px; }

/* Loading */
.ds-btn.is-loading { color: transparent !important; position: relative; pointer-events: none; }
.ds-btn.is-loading::after {
  content: ""; position: absolute;
  width: 1.1em; height: 1.1em;
  border: 2px solid currentColor; border-right-color: transparent;
  border-radius: 50%;
  animation: ds-spin 0.6s linear infinite;
  color: var(--color-on-primary);
}
@keyframes ds-spin { to { transform: rotate(360deg); } }

/* ==========================================================================
   CAMPOS DE FORMULÁRIO
   ========================================================================== */
.ds-field { display: flex; flex-direction: column; gap: var(--space-2); }
.ds-label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
}
.ds-label .ds-required { color: var(--color-danger); margin-left: 2px; }
.ds-hint { font-size: var(--text-xs); color: var(--color-text-subtle); }
.ds-error-text { font-size: var(--text-xs); color: var(--color-danger); display: flex; gap: var(--space-1); align-items: center; }

.ds-input, .ds-textarea, .ds-select {
  width: 100%;
  font-size: var(--text-base);
  color: var(--color-text);
  background: var(--color-surface);
  border: var(--border-width) solid var(--color-border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-3) var(--space-4);
  min-height: 48px;
  transition: border-color var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-fast) var(--ease-out);
}
.ds-textarea { min-height: 120px; resize: vertical; line-height: var(--leading-normal); }
.ds-input::placeholder, .ds-textarea::placeholder { color: var(--color-text-subtle); }
.ds-input:hover, .ds-textarea:hover, .ds-select:hover { border-color: var(--color-text-subtle); }
.ds-input:focus, .ds-textarea:focus, .ds-select:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.ds-input:disabled, .ds-textarea:disabled, .ds-select:disabled {
  background: var(--color-disabled-bg);
  color: var(--color-disabled-text);
  cursor: not-allowed;
  border-color: var(--color-disabled-border);
}
.ds-input.is-error, .ds-textarea.is-error, .ds-select.is-error { border-color: var(--color-danger); }
.ds-input.is-error:focus { box-shadow: 0 0 0 4px var(--color-danger-subtle); }
.ds-input.is-success { border-color: var(--color-success); }

.ds-select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%23615c52' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-4) center;
  padding-right: var(--space-10);
}

/* Input com ícone */
.ds-input-group { position: relative; display: flex; align-items: center; }
.ds-input-group .ds-input-icon {
  position: absolute; left: var(--space-4);
  color: var(--color-text-subtle); pointer-events: none; display: flex;
}
.ds-input-group .ds-input { padding-left: var(--space-10); }

/* Checkbox & Radio */
.ds-check { display: inline-flex; align-items: flex-start; gap: var(--space-3); cursor: pointer; font-size: var(--text-sm); line-height: 1.4; }
.ds-check input { position: absolute; opacity: 0; width: 0; height: 0; }
.ds-check__box {
  flex: none; width: 22px; height: 22px; margin-top: 1px;
  border: 2px solid var(--color-border-strong);
  background: var(--color-surface);
  display: grid; place-items: center;
  transition: all var(--duration-fast) var(--ease-out);
}
.ds-check--checkbox .ds-check__box { border-radius: var(--radius-xs); }
.ds-check--radio .ds-check__box { border-radius: var(--radius-full); }
.ds-check__box svg { width: 14px; height: 14px; stroke: #fff; opacity: 0; transform: scale(0.5); transition: all var(--duration-fast) var(--ease-out); }
.ds-check input:checked + .ds-check__box { background: var(--color-primary); border-color: var(--color-primary); }
.ds-check input:checked + .ds-check__box svg { opacity: 1; transform: scale(1); }
.ds-check--radio input:checked + .ds-check__box::after {
  content: ""; width: 9px; height: 9px; border-radius: 50%; background: #fff;
}
.ds-check input:focus-visible + .ds-check__box { box-shadow: var(--shadow-focus); }
.ds-check input:disabled + .ds-check__box { background: var(--color-disabled-bg); border-color: var(--color-disabled-border); }

/* Switch / Toggle */
.ds-switch { display: inline-flex; align-items: center; gap: var(--space-3); cursor: pointer; }
.ds-switch input { position: absolute; opacity: 0; }
.ds-switch__track {
  width: 46px; height: 26px; border-radius: var(--radius-full);
  background: var(--color-border-strong); position: relative;
  transition: background var(--duration-base) var(--ease-out);
}
.ds-switch__track::after {
  content: ""; position: absolute; top: 3px; left: 3px;
  width: 20px; height: 20px; border-radius: 50%; background: #fff;
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration-base) var(--ease-out);
}
.ds-switch input:checked + .ds-switch__track { background: var(--color-primary); }
.ds-switch input:checked + .ds-switch__track::after { transform: translateX(20px); }
.ds-switch input:focus-visible + .ds-switch__track { box-shadow: var(--shadow-focus); }

/* ==========================================================================
   CARTÕES
   ========================================================================== */
.ds-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: box-shadow var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out),
              border-color var(--duration-base) var(--ease-out);
}
.ds-card--interactive { cursor: pointer; }
.ds-card--interactive:hover { box-shadow: var(--shadow-lg); transform: translateY(-3px); border-color: var(--color-border-strong); }
.ds-card--flat { box-shadow: none; }
.ds-card--raised { box-shadow: var(--shadow-md); border-color: transparent; }
.ds-card__media { width: 100%; aspect-ratio: 16/9; object-fit: cover; background: var(--color-surface-sunken); }
.ds-card__body { padding: var(--space-6); }
.ds-card__header { padding: var(--space-6) var(--space-6) 0; }
.ds-card__footer { padding: var(--space-4) var(--space-6); border-top: 1px solid var(--color-divider); background: var(--color-surface-sunken); }
.ds-card__title { font-size: var(--text-lg); font-weight: var(--weight-bold); }

/* ==========================================================================
   BADGES / TAGS / CHIPS
   ========================================================================== */
.ds-badge {
  display: inline-flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs); font-weight: var(--weight-medium);
  padding: var(--space-1) var(--space-3); border-radius: var(--radius-full);
  background: var(--color-primary-subtle); color: var(--color-primary-active);
  letter-spacing: var(--tracking-wide); line-height: 1.4;
}
.ds-badge--neutral { background: var(--color-surface-sunken); color: var(--color-text-muted); }
.ds-badge--accent  { background: var(--color-accent-subtle); color: var(--sage-700); }
.ds-badge--success { background: var(--color-success-subtle); color: var(--green-700); }
.ds-badge--warning { background: var(--color-warning-subtle); color: var(--amber-700); }
.ds-badge--danger  { background: var(--color-danger-subtle); color: var(--red-700); }
.ds-badge--solid   { background: var(--color-primary); color: #fff; }
.ds-badge__dot { width: 7px; height: 7px; border-radius: 50%; background: currentColor; }

.ds-chip {
  display: inline-flex; align-items: center; gap: var(--space-2);
  font-size: var(--text-sm); padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-full); border: 1px solid var(--color-border-strong);
  background: var(--color-surface); color: var(--color-text);
  transition: all var(--duration-fast) var(--ease-out);
}
.ds-chip:hover { border-color: var(--color-primary); background: var(--color-primary-subtle); }
.ds-chip--selected { background: var(--color-primary); color: #fff; border-color: var(--color-primary); }
.ds-chip__close { display: inline-flex; opacity: 0.6; }
.ds-chip__close:hover { opacity: 1; }

/* ==========================================================================
   ALERTAS / AVISOS
   ========================================================================== */
.ds-alert {
  display: flex; gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  border-left-width: 4px;
  background: var(--color-info-subtle);
  border-left-color: var(--color-info);
  color: var(--color-text);
}
.ds-alert__icon { flex: none; color: var(--color-info); margin-top: 2px; }
.ds-alert__title { font-weight: var(--weight-medium); margin-bottom: var(--space-1); }
.ds-alert__body { font-size: var(--text-sm); color: var(--color-text-muted); }
.ds-alert--success { background: var(--color-success-subtle); border-left-color: var(--color-success); }
.ds-alert--success .ds-alert__icon { color: var(--color-success); }
.ds-alert--warning { background: var(--color-warning-subtle); border-left-color: var(--color-warning); }
.ds-alert--warning .ds-alert__icon { color: var(--color-warning); }
.ds-alert--danger  { background: var(--color-danger-subtle); border-left-color: var(--color-danger); }
.ds-alert--danger .ds-alert__icon { color: var(--color-danger); }

/* ==========================================================================
   AVATAR
   ========================================================================== */
.ds-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 44px; height: 44px; border-radius: var(--radius-full);
  background: var(--color-primary-muted); color: var(--color-primary-active);
  font-weight: var(--weight-medium); overflow: hidden; flex: none;
  border: 2px solid var(--color-surface); box-shadow: var(--shadow-xs);
}
.ds-avatar img { width: 100%; height: 100%; object-fit: cover; }
.ds-avatar--sm { width: 32px; height: 32px; font-size: var(--text-xs); }
.ds-avatar--lg { width: 64px; height: 64px; font-size: var(--text-lg); }
.ds-avatar--xl { width: 96px; height: 96px; font-size: var(--text-2xl); }
.ds-avatar-group { display: flex; }
.ds-avatar-group .ds-avatar + .ds-avatar { margin-left: -12px; }

/* ==========================================================================
   NAVEGAÇÃO / HEADER
   ========================================================================== */
.ds-navbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-6); padding: var(--space-4) var(--space-6);
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
}
.ds-navbar__brand { display: flex; align-items: center; gap: var(--space-3); font-weight: var(--weight-medium); }
.ds-navbar__brand img { height: 40px; width: auto; }
.ds-navbar__nav { display: flex; gap: var(--space-2); align-items: center; }
.ds-navlink {
  padding: var(--space-2) var(--space-4); border-radius: var(--radius-full);
  color: var(--color-text-muted); font-size: var(--text-sm); font-weight: var(--weight-medium);
  transition: all var(--duration-fast) var(--ease-out);
}
.ds-navlink:hover { background: var(--color-surface-sunken); color: var(--color-text); text-decoration: none; }
.ds-navlink.is-active { background: var(--color-primary-subtle); color: var(--color-primary-active); }

/* Em telas estreitas, a navbar quebra em vez de estourar a largura */
@media (max-width: 600px) {
  .ds-navbar { flex-wrap: wrap; gap: var(--space-3); }
  .ds-navbar__nav { flex-wrap: wrap; gap: var(--space-1); width: 100%; }
  .ds-navbar__brand img { height: 34px; }
}

/* ==========================================================================
   ABAS (TABS)
   ========================================================================== */
.ds-tabs { display: flex; gap: var(--space-1); border-bottom: 1px solid var(--color-border); }
.ds-tab {
  padding: var(--space-3) var(--space-5); font-size: var(--text-sm); font-weight: var(--weight-medium);
  color: var(--color-text-muted); border-bottom: 2px solid transparent; margin-bottom: -1px;
  transition: all var(--duration-fast) var(--ease-out);
}
.ds-tab:hover { color: var(--color-text); }
.ds-tab.is-active { color: var(--color-primary); border-bottom-color: var(--color-primary); }

/* ==========================================================================
   BREADCRUMB
   ========================================================================== */
.ds-breadcrumb { display: flex; flex-wrap: wrap; gap: var(--space-2); align-items: center; font-size: var(--text-sm); color: var(--color-text-subtle); }
.ds-breadcrumb a { color: var(--color-text-muted); }
.ds-breadcrumb__sep { color: var(--color-text-subtle); }
.ds-breadcrumb [aria-current="page"] { color: var(--color-text); font-weight: var(--weight-medium); }

/* ==========================================================================
   TABELA
   ========================================================================== */
.ds-table-wrap { overflow-x: auto; border: 1px solid var(--color-border); border-radius: var(--radius-lg); }
.ds-table { width: 100%; border-collapse: collapse; font-size: var(--text-sm); }
.ds-table th, .ds-table td { padding: var(--space-3) var(--space-4); text-align: left; }
.ds-table thead th {
  background: var(--color-surface-sunken); color: var(--color-text-muted);
  font-weight: var(--weight-medium); text-transform: uppercase;
  font-size: var(--text-xs); letter-spacing: var(--tracking-wide);
  border-bottom: 1px solid var(--color-border);
}
.ds-table tbody tr { border-top: 1px solid var(--color-divider); }
.ds-table tbody tr:hover { background: var(--color-primary-subtle); }
.ds-table--striped tbody tr:nth-child(even) { background: var(--color-surface-sunken); }

/* ==========================================================================
   PAGINAÇÃO
   ========================================================================== */
.ds-pagination { display: flex; gap: var(--space-1); align-items: center; }
.ds-page {
  min-width: 40px; height: 40px; padding: 0 var(--space-2);
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md); color: var(--color-text-muted);
  font-size: var(--text-sm); font-weight: var(--weight-medium);
  transition: all var(--duration-fast) var(--ease-out);
}
.ds-page:hover { background: var(--color-surface-sunken); color: var(--color-text); text-decoration: none; }
.ds-page.is-active { background: var(--color-primary); color: #fff; }
.ds-page[disabled] { opacity: 0.4; pointer-events: none; }

/* ==========================================================================
   PROGRESSO
   ========================================================================== */
.ds-progress { height: 8px; background: var(--color-surface-sunken); border-radius: var(--radius-full); overflow: hidden; }
.ds-progress__bar { height: 100%; background: var(--color-primary); border-radius: var(--radius-full); transition: width var(--duration-slow) var(--ease-out); }
.ds-progress--accent .ds-progress__bar { background: var(--color-accent); }

.ds-spinner {
  width: 28px; height: 28px; border: 3px solid var(--color-primary-muted);
  border-right-color: var(--color-primary); border-radius: 50%;
  animation: ds-spin 0.7s linear infinite;
}

/* ==========================================================================
   TOOLTIP (CSS puro)
   ========================================================================== */
.ds-tooltip { position: relative; display: inline-flex; }
.ds-tooltip__content {
  position: absolute; bottom: calc(100% + 8px); left: 50%; transform: translateX(-50%) translateY(4px);
  background: var(--neutral-900); color: var(--neutral-0);
  font-size: var(--text-xs); padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm); white-space: nowrap;
  opacity: 0; pointer-events: none; transition: all var(--duration-fast) var(--ease-out);
  box-shadow: var(--shadow-md); z-index: var(--z-tooltip);
}
.ds-tooltip__content::after {
  content: ""; position: absolute; top: 100%; left: 50%; transform: translateX(-50%);
  border: 5px solid transparent; border-top-color: var(--neutral-900);
}
.ds-tooltip:hover .ds-tooltip__content, .ds-tooltip:focus-within .ds-tooltip__content {
  opacity: 1; transform: translateX(-50%) translateY(0);
}

/* ==========================================================================
   MODAL / DIÁLOGO
   ========================================================================== */
.ds-modal-overlay {
  position: fixed; inset: 0; background: var(--color-overlay);
  display: grid; place-items: center; padding: var(--space-6);
  z-index: var(--z-modal); backdrop-filter: blur(2px);
}
.ds-modal {
  background: var(--color-surface); border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl); max-width: 480px; width: 100%;
  overflow: hidden; animation: ds-modal-in var(--duration-base) var(--ease-out);
}
@keyframes ds-modal-in { from { opacity: 0; transform: translateY(12px) scale(0.98); } to { opacity: 1; transform: none; } }
.ds-modal__header { padding: var(--space-6) var(--space-6) 0; display: flex; justify-content: space-between; align-items: start; gap: var(--space-4); }
.ds-modal__title { font-size: var(--text-lg); font-weight: var(--weight-bold); }
.ds-modal__body { padding: var(--space-4) var(--space-6); color: var(--color-text-muted); }
.ds-modal__footer { padding: var(--space-5) var(--space-6); display: flex; gap: var(--space-3); justify-content: flex-end; border-top: 1px solid var(--color-divider); }

/* ==========================================================================
   TOAST / NOTIFICAÇÃO
   ========================================================================== */
.ds-toast {
  display: flex; gap: var(--space-3); align-items: center;
  padding: var(--space-4) var(--space-5); background: var(--color-surface);
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg); max-width: 380px;
  border-left: 4px solid var(--color-primary);
}
.ds-toast--success { border-left-color: var(--color-success); }
.ds-toast--danger  { border-left-color: var(--color-danger); }
