/* ============================================================
   Component styles — Ville d'Adriville
   Token-driven classes applied by the React components. Kept in
   CSS (not CSS-in-JS) so :hover / :focus-visible states work and
   consumers who only link styles.css still get correct visuals.
   ============================================================ */

/* ---------------- Button ---------------- */
.adr-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  white-space: nowrap;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: background-color var(--duration-base) var(--ease-standard),
              color var(--duration-base) var(--ease-standard),
              border-color var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
  height: 2.25rem;        /* 36 */
  padding: 0 var(--space-4);
}
.adr-btn svg { width: 1rem; height: 1rem; flex-shrink: 0; pointer-events: none; }
.adr-btn:focus-visible { outline: none; box-shadow: 0 0 0 var(--ring-width) var(--ring-color); }
.adr-btn:disabled { pointer-events: none; opacity: 0.5; }

.adr-btn--sm { height: 2rem; padding: 0 var(--space-3); gap: var(--space-1); }
.adr-btn--lg { height: 2.5rem; padding: 0 var(--space-6); }
.adr-btn--icon { height: 2.25rem; width: 2.25rem; padding: 0; }

.adr-btn--default { background: var(--primary); color: var(--primary-foreground); }
.adr-btn--default:hover { background: color-mix(in srgb, var(--primary) 90%, black); }

.adr-btn--secondary { background: var(--secondary); color: var(--secondary-foreground); }
.adr-btn--secondary:hover { background: color-mix(in srgb, var(--secondary) 80%, white); }

.adr-btn--outline { background: var(--background); color: var(--foreground); border-color: var(--border); }
.adr-btn--outline:hover { background: var(--accent); color: var(--accent-foreground); }

.adr-btn--ghost { background: transparent; color: var(--foreground); }
.adr-btn--ghost:hover { background: var(--accent); color: var(--accent-foreground); }

.adr-btn--destructive { background: var(--destructive); color: var(--destructive-foreground); }
.adr-btn--destructive:hover { background: color-mix(in srgb, var(--destructive) 90%, black); }

.adr-btn--link { background: transparent; color: var(--primary); height: auto; padding: 0; }
.adr-btn--link:hover { text-decoration: underline; text-underline-offset: 4px; }

/* ---------------- Badge ---------------- */
.adr-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-1);
  width: fit-content;
  padding: 0.125rem var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-xs);
  font-weight: var(--font-weight-medium);
  line-height: 1.3;
  white-space: nowrap;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
}
.adr-badge svg { width: 0.75rem; height: 0.75rem; }
.adr-badge--default { background: var(--primary); color: var(--primary-foreground); }
.adr-badge--secondary { background: var(--secondary); color: var(--secondary-foreground); }
.adr-badge--destructive { background: var(--destructive); color: var(--destructive-foreground); }
.adr-badge--outline { background: transparent; color: var(--foreground); border-color: var(--border); }

/* ---------------- Card ---------------- */
.adr-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
  background: var(--card);
  color: var(--card-foreground);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-sm);
}
.adr-card__header { display: flex; flex-direction: column; gap: 0.375rem; padding: var(--space-6) var(--space-6) 0; }
.adr-card__title { font-family: var(--font-display); font-size: var(--text-lg); font-weight: var(--font-weight-semibold); line-height: 1.2; letter-spacing: var(--tracking-display); }
.adr-card__description { color: var(--muted-foreground); font-size: var(--text-sm); }
.adr-card__content { padding: 0 var(--space-6); }
.adr-card__content:last-child { padding-bottom: var(--space-6); }
.adr-card__footer { display: flex; align-items: center; gap: var(--space-3); padding: 0 var(--space-6) var(--space-6); }

/* ---------------- Separator ---------------- */
.adr-separator { flex-shrink: 0; background: var(--border); border: none; }
.adr-separator--horizontal { height: 1px; width: 100%; }
.adr-separator--vertical { width: 1px; align-self: stretch; }

/* ---------------- Label ---------------- */
.adr-label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  color: var(--foreground);
  user-select: none;
}

/* ---------------- Input / Textarea ---------------- */
.adr-input, .adr-textarea {
  width: 100%;
  min-width: 0;
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--foreground);
  background: var(--input-background);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  transition: border-color var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
  outline: none;
}
.adr-input { height: 2.25rem; padding: 0 var(--space-3); }
.adr-textarea { min-height: 4.5rem; padding: var(--space-2) var(--space-3); line-height: var(--leading-normal); resize: vertical; }
.adr-input::placeholder, .adr-textarea::placeholder { color: var(--muted-foreground); }
.adr-input:focus-visible, .adr-textarea:focus-visible {
  border-color: var(--ring);
  box-shadow: 0 0 0 var(--ring-width) var(--ring-color);
}
.adr-input:disabled, .adr-textarea:disabled { opacity: 0.5; cursor: not-allowed; }

/* ---------------- Select ---------------- */
.adr-select {
  height: 2.25rem;
  padding: 0 2.25rem 0 var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  color: var(--foreground);
  background-color: var(--input-background);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%235a6178' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  appearance: none;
  cursor: pointer;
  outline: none;
  transition: border-color var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
}
.adr-select:focus-visible { border-color: var(--ring); box-shadow: 0 0 0 var(--ring-width) var(--ring-color); }
.adr-select:disabled { opacity: 0.5; cursor: not-allowed; }

/* ---------------- Switch ---------------- */
.adr-switch {
  position: relative;
  display: inline-flex;
  align-items: center;
  flex-shrink: 0;
  width: 2rem;
  height: 1.15rem;
  padding: 0;
  border: none;
  border-radius: var(--radius-full);
  background: var(--switch-background);
  cursor: pointer;
  transition: background-color var(--duration-base) var(--ease-standard);
}
.adr-switch[data-state="checked"] { background: var(--primary); }
.adr-switch:focus-visible { outline: none; box-shadow: 0 0 0 var(--ring-width) var(--ring-color); }
.adr-switch:disabled { opacity: 0.5; cursor: not-allowed; }
.adr-switch__thumb {
  display: block;
  width: 1rem;
  height: 1rem;
  margin: 0 1px;
  border-radius: var(--radius-full);
  background: var(--card);
  box-shadow: var(--shadow-xs);
  transition: transform var(--duration-base) var(--ease-standard);
}
.adr-switch[data-state="checked"] .adr-switch__thumb { transform: translateX(0.85rem); }

/* ---------------- Checkbox ---------------- */
.adr-checkbox {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  padding: 0;
  background: var(--input-background);
  border: 1px solid var(--border);
  border-radius: 4px;
  cursor: pointer;
  color: var(--primary-foreground);
  transition: background-color var(--duration-fast) var(--ease-standard),
              border-color var(--duration-fast) var(--ease-standard);
}
.adr-checkbox[data-state="checked"] { background: var(--primary); border-color: var(--primary); }
.adr-checkbox:focus-visible { outline: none; box-shadow: 0 0 0 var(--ring-width) var(--ring-color); }
.adr-checkbox svg { width: 0.875rem; height: 0.875rem; }

/* ---------------- Slider ---------------- */
.adr-slider { position: relative; display: flex; align-items: center; width: 100%; height: 1rem; }
.adr-slider__track { position: relative; flex-grow: 1; height: 1rem; border-radius: var(--radius-full); background: var(--brand-100); overflow: hidden; }
.adr-slider__range { position: absolute; height: 100%; background: var(--primary); }
.adr-slider__thumb {
  position: absolute;
  top: 50%;
  width: 1rem;
  height: 1rem;
  transform: translate(-50%, -50%);
  background: var(--background);
  border: 1px solid var(--primary);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-sm);
  cursor: grab;
}

/* ---------------- Tabs ---------------- */
.adr-tabs { display: flex; flex-direction: column; gap: var(--space-2); }
.adr-tabs__list {
  display: inline-flex;
  align-items: center;
  height: 2.25rem;
  padding: 3px;
  gap: 2px;
  background: var(--muted);
  border-radius: var(--radius-xl);
  color: var(--muted-foreground);
}
.adr-tabs__trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  height: 100%;
  padding: 0 var(--space-3);
  font-family: var(--font-sans);
  font-size: var(--text-sm);
  font-weight: var(--font-weight-medium);
  color: var(--foreground);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius-lg);
  cursor: pointer;
  white-space: nowrap;
  transition: background-color var(--duration-base) var(--ease-standard),
              box-shadow var(--duration-base) var(--ease-standard);
}
.adr-tabs__trigger svg { width: 1rem; height: 1rem; }
.adr-tabs__trigger[data-state="active"] { background: var(--card); border-color: var(--border); box-shadow: var(--shadow-sm); color: var(--brand-700); }
.adr-tabs__trigger:focus-visible { outline: none; box-shadow: 0 0 0 var(--ring-width) var(--ring-color); }

/* ---------------- Alert ---------------- */
.adr-alert {
  position: relative;
  display: grid;
  grid-template-columns: 0 1fr;
  gap: 0 0;
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--card);
  color: var(--card-foreground);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  align-items: start;
}
.adr-alert:has(> svg) { grid-template-columns: 1rem 1fr; column-gap: var(--space-3); }
.adr-alert > svg { width: 1rem; height: 1rem; transform: translateY(2px); color: currentColor; }
.adr-alert__title { grid-column-start: 2; font-weight: var(--font-weight-medium); letter-spacing: -0.01em; line-height: 1.3; }
.adr-alert__description { grid-column-start: 2; color: var(--muted-foreground); font-size: var(--text-sm); line-height: var(--leading-relaxed); }
.adr-alert--destructive { color: var(--destructive); }
.adr-alert--destructive .adr-alert__description { color: color-mix(in srgb, var(--destructive) 90%, transparent); }
