/* ================================================================
   ClinicFlow2 — Components
   Tutti gli stili riusabili. Legge SOLO da tokens.css.
   ================================================================ */

/* ========== BUTTONS ========== */
.cf-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-md);
  font-weight: var(--weight-medium);
  font-size: var(--text-sm);
  line-height: 1.25;
  border: 1px solid transparent;
  cursor: pointer;
  transition: background var(--motion-fast) var(--ease-standard),
              border-color var(--motion-fast) var(--ease-standard),
              color var(--motion-fast) var(--ease-standard),
              box-shadow var(--motion-fast) var(--ease-standard),
              transform var(--motion-fast) var(--ease-standard);
  white-space: nowrap;
  user-select: none;
}
.cf-btn:disabled, .cf-btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; pointer-events: none; }
.cf-btn svg { width: 1em; height: 1em; flex-shrink: 0; }

.cf-btn--primary {
  background: var(--color-primary);
  color: var(--color-text-inverted);
  box-shadow: var(--shadow-xs);
}
.cf-btn--primary:hover { background: var(--color-primary-hover); box-shadow: var(--shadow-brand); }

.cf-btn--secondary {
  background: var(--color-surface);
  color: var(--color-text);
  border-color: var(--color-border);
}
.cf-btn--secondary:hover { background: var(--color-surface-hover); border-color: var(--color-border-strong); }

.cf-btn--ghost {
  background: transparent;
  color: var(--color-text);
}
.cf-btn--ghost:hover { background: var(--color-surface-hover); }

.cf-btn--danger {
  background: var(--danger-600);
  color: var(--color-text-inverted);
}
.cf-btn--danger:hover { background: var(--danger-700); }

.cf-btn--success {
  background: var(--success-600);
  color: var(--color-text-inverted);
}
.cf-btn--success:hover { background: var(--success-700); }

.cf-btn--warning {
  background: var(--warning-600);
  color: var(--color-text-inverted);
}
.cf-btn--warning:hover { background: var(--warning-700); }

.cf-btn--link {
  background: transparent;
  color: var(--color-primary);
  padding: 0;
  border: none;
}
.cf-btn--link:hover { color: var(--color-primary-hover); text-decoration: underline; }

/* Sizes */
.cf-btn--sm { padding: var(--space-1) var(--space-3); font-size: var(--text-xs); }
.cf-btn--lg { padding: var(--space-3) var(--space-5); font-size: var(--text-base); }
.cf-btn--icon { padding: var(--space-2); aspect-ratio: 1; }
.cf-btn--block { width: 100%; }

/* ========== INPUTS ========== */
.cf-field { display: flex; flex-direction: column; gap: var(--space-2); }
.cf-label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text);
}
.cf-label--required::after { content: " *"; color: var(--danger-600); }
.cf-help { font-size: var(--text-xs); color: var(--color-text-muted); }
.cf-error { font-size: var(--text-xs); color: var(--danger-600); }

.cf-input, .cf-select, .cf-textarea {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-size: var(--text-sm);
  line-height: 1.5;
  transition: border-color var(--motion-fast), box-shadow var(--motion-fast);
}
.cf-input::placeholder, .cf-textarea::placeholder { color: var(--color-text-subtle); }
.cf-input:focus, .cf-select:focus, .cf-textarea:focus {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.cf-input[aria-invalid="true"], .cf-select[aria-invalid="true"], .cf-textarea[aria-invalid="true"] {
  border-color: var(--danger-600);
}
.cf-input:disabled, .cf-select:disabled, .cf-textarea:disabled {
  background: var(--color-surface-muted);
  color: var(--color-text-muted);
  cursor: not-allowed;
}

.cf-select {
  appearance: none;
  padding-right: var(--space-10);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 1rem;
}
.cf-select option { background: var(--color-surface); color: var(--color-text); }

.cf-textarea { min-height: 6rem; resize: vertical; }

.cf-checkbox, .cf-radio {
  width: 1rem;
  height: 1rem;
  accent-color: var(--color-primary);
  cursor: pointer;
}

.cf-switch {
  position: relative;
  display: inline-block;
  width: 2.5rem;
  height: 1.375rem;
}
.cf-switch input { opacity: 0; width: 0; height: 0; }
.cf-switch-slider {
  position: absolute; inset: 0;
  background: var(--color-border-strong);
  border-radius: var(--radius-full);
  transition: background var(--motion-fast);
  cursor: pointer;
}
.cf-switch-slider::before {
  content: "";
  position: absolute;
  height: 1.125rem; width: 1.125rem;
  left: 2px; bottom: 2px;
  background: white;
  border-radius: 50%;
  box-shadow: var(--shadow-xs);
  transition: transform var(--motion-fast) var(--ease-standard);
}
.cf-switch input:checked + .cf-switch-slider { background: var(--color-primary); }
.cf-switch input:checked + .cf-switch-slider::before { transform: translateX(1.125rem); }

/* Input group (prefix/suffix) */
.cf-input-group { position: relative; display: flex; align-items: center; }
.cf-input-group .cf-input { padding-left: 2.25rem; }
.cf-input-group__icon {
  position: absolute; left: var(--space-3);
  color: var(--color-text-muted);
  pointer-events: none;
  display: flex;
}

/* ========== CARD ========== */
.cf-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.cf-card--hover:hover { border-color: var(--color-border-strong); box-shadow: var(--shadow-sm); }
.cf-card__header {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-3);
}
.cf-card__body { padding: var(--space-5); }
.cf-card__footer {
  padding: var(--space-3) var(--space-5);
  border-top: 1px solid var(--color-border);
  background: var(--color-bg-subtle);
  display: flex; align-items: center; justify-content: flex-end; gap: var(--space-2);
}
.cf-card__title { font-size: var(--text-lg); font-weight: var(--weight-semibold); color: var(--color-text); }
.cf-card__subtitle { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }

/* ========== BADGE ========== */
.cf-badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  padding: 2px var(--space-2);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  line-height: 1.25;
  border: 1px solid transparent;
}
.cf-badge--neutral  { background: var(--neutral-100);  color: var(--neutral-700); border-color: var(--neutral-200); }
.cf-badge--primary  { background: var(--brand-50);     color: var(--brand-700);   border-color: var(--brand-100); }
.cf-badge--success  { background: var(--success-50);   color: var(--success-700); border-color: var(--success-100); }
.cf-badge--warning  { background: var(--warning-50);   color: var(--warning-700); border-color: var(--warning-100); }
.cf-badge--danger   { background: var(--danger-50);    color: var(--danger-700);  border-color: var(--danger-100); }
.cf-badge--info     { background: var(--info-50);      color: var(--info-600);    border-color: var(--info-100); }

.cf-badge--solid.cf-badge--primary { background: var(--brand-500);   color: white; border-color: var(--brand-600); }
.cf-badge--solid.cf-badge--success { background: var(--success-600); color: white; border-color: var(--success-700); }
.cf-badge--solid.cf-badge--warning { background: var(--warning-600); color: white; border-color: var(--warning-700); }
.cf-badge--solid.cf-badge--danger  { background: var(--danger-600);  color: white; border-color: var(--danger-700); }

.cf-badge--dot::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: currentColor;
}

/* ========== TABLE ========== */
.cf-table-wrapper {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: auto;
}
.cf-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--text-sm);
}
.cf-table thead { background: var(--color-bg-subtle); }
.cf-table th {
  padding: var(--space-3) var(--space-4);
  text-align: left;
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--color-text-muted);
  border-bottom: 1px solid var(--color-border);
  position: sticky; top: 0;
  background: var(--color-bg-subtle);
}
.cf-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text);
  border-bottom: 1px solid var(--color-border);
  vertical-align: middle;
}
.cf-table tbody tr { transition: background var(--motion-fast); }
.cf-table tbody tr:hover { background: var(--color-surface-hover); }
.cf-table tbody tr:last-child td { border-bottom: none; }
.cf-table--compact td, .cf-table--compact th { padding: var(--space-2) var(--space-3); }

/* ========== MODAL / DRAWER ========== */
.cf-modal-backdrop {
  position: fixed; inset: 0;
  background: var(--color-overlay);
  backdrop-filter: blur(4px);
  z-index: var(--z-modal);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: var(--space-4);
  animation: cf-fade-in var(--motion-base) var(--ease-standard);
}
.cf-modal {
  background: var(--color-surface);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  width: 100%;
  max-width: 32rem;
  max-height: calc(100dvh - 2rem);
  display: flex; flex-direction: column;
  animation: cf-slide-up var(--motion-base) var(--ease-decelerate);
}
.cf-modal--sm { max-width: 24rem; }
.cf-modal--lg { max-width: 48rem; }
.cf-modal--xl { max-width: 64rem; }
.cf-modal__header {
  padding: var(--space-5);
  border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; justify-content: space-between;
}
.cf-modal__title { font-size: var(--text-lg); font-weight: var(--weight-semibold); }
.cf-modal__close {
  padding: var(--space-1);
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  transition: background var(--motion-fast);
}
.cf-modal__close:hover { background: var(--color-surface-hover); color: var(--color-text); }
.cf-modal__body { padding: var(--space-5); overflow-y: auto; flex: 1; }
.cf-modal__footer {
  padding: var(--space-4) var(--space-5);
  border-top: 1px solid var(--color-border);
  display: flex; justify-content: flex-end; gap: var(--space-2);
  background: var(--color-bg-subtle);
}

.cf-drawer {
  position: fixed; top: 0; right: 0; bottom: 0;
  width: 100%; max-width: 32rem;
  background: var(--color-surface);
  border-left: 1px solid var(--color-border);
  box-shadow: var(--shadow-xl);
  z-index: var(--z-modal);
  display: flex; flex-direction: column;
  animation: cf-slide-in-right var(--motion-base) var(--ease-decelerate);
}

/* ========== TOAST ========== */
.cf-toast-container {
  position: fixed; bottom: var(--space-4); right: var(--space-4);
  z-index: var(--z-toast);
  display: flex; flex-direction: column; gap: var(--space-2);
  max-width: calc(100vw - 2rem);
}
.cf-toast {
  display: flex; align-items: flex-start; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-left: 3px solid var(--color-primary);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  min-width: 18rem;
  max-width: 26rem;
  animation: cf-slide-in-right var(--motion-base) var(--ease-decelerate);
}
.cf-toast--success { border-left-color: var(--success-600); }
.cf-toast--warning { border-left-color: var(--warning-600); }
.cf-toast--danger  { border-left-color: var(--danger-600); }
.cf-toast__icon { color: var(--color-primary); flex-shrink: 0; }
.cf-toast--success .cf-toast__icon { color: var(--success-600); }
.cf-toast--warning .cf-toast__icon { color: var(--warning-600); }
.cf-toast--danger  .cf-toast__icon { color: var(--danger-600); }
.cf-toast__body { flex: 1; font-size: var(--text-sm); }
.cf-toast__close { color: var(--color-text-muted); padding: 2px; }

/* ========== TABS ========== */
.cf-tabs { display: flex; gap: var(--space-1); border-bottom: 1px solid var(--color-border); }
.cf-tab {
  padding: var(--space-3) var(--space-4);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-muted);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--motion-fast), border-color var(--motion-fast);
}
.cf-tab:hover { color: var(--color-text); }
.cf-tab[aria-selected="true"], .cf-tab--active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
}

/* ========== EMPTY STATE ========== */
.cf-empty {
  display: flex; flex-direction: column; align-items: center;
  padding: var(--space-12) var(--space-4);
  text-align: center;
  color: var(--color-text-muted);
}
.cf-empty__icon {
  width: 3rem; height: 3rem;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-4);
}
.cf-empty__title {
  font-size: var(--text-lg);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin-bottom: var(--space-2);
}
.cf-empty__message { max-width: 28rem; margin-bottom: var(--space-5); }

/* ========== SKELETON ========== */
@keyframes cf-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.5; } }
.cf-skeleton {
  background: var(--color-surface-muted);
  border-radius: var(--radius-sm);
  animation: cf-pulse 1.4s ease-in-out infinite;
}
.cf-skeleton--text { height: 0.875rem; }
.cf-skeleton--title { height: 1.5rem; }
.cf-skeleton--avatar { width: 2.5rem; height: 2.5rem; border-radius: 50%; }

/* ========== DROPDOWN ========== */
.cf-dropdown {
  position: absolute;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  padding: var(--space-1);
  min-width: 12rem;
  z-index: var(--z-dropdown);
  animation: cf-slide-up var(--motion-fast) var(--ease-decelerate);
}
.cf-dropdown__item {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
  color: var(--color-text);
  transition: background var(--motion-fast);
  cursor: pointer;
  width: 100%;
  text-align: left;
}
.cf-dropdown__item:hover { background: var(--color-surface-hover); }
.cf-dropdown__item--danger { color: var(--danger-600); }
.cf-dropdown__separator { height: 1px; background: var(--color-border); margin: var(--space-1) 0; }

/* ========== TOOLTIP ========== */
.cf-tooltip {
  position: absolute;
  padding: var(--space-1) var(--space-2);
  background: var(--neutral-900);
  color: white;
  font-size: var(--text-xs);
  border-radius: var(--radius-sm);
  white-space: nowrap;
  z-index: var(--z-tooltip);
  pointer-events: none;
}

/* ========== PAGE HEADER ========== */
.cf-page-header {
  display: flex; flex-wrap: wrap; align-items: flex-start; justify-content: space-between;
  gap: var(--space-4);
  padding-bottom: var(--space-5);
  margin-bottom: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.cf-page-header__title { font-size: var(--text-2xl); font-weight: var(--weight-semibold); line-height: var(--leading-tight); }
.cf-page-header__subtitle { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-1); }
.cf-page-header__actions { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.cf-breadcrumb {
  display: flex; align-items: center; gap: var(--space-1);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-bottom: var(--space-2);
}
.cf-breadcrumb a:hover { color: var(--color-primary); }
.cf-breadcrumb__sep { opacity: 0.4; }

/* ========== APP SHELL ========== */
.cf-app {
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  grid-template-rows: var(--topbar-height) 1fr;
  grid-template-areas:
    "sidebar topbar"
    "sidebar main";
  min-height: 100dvh;
}
.cf-app[data-sidebar="collapsed"] { grid-template-columns: var(--sidebar-collapsed) 1fr; }

.app-sidebar {
  grid-area: sidebar;
  background: var(--sidebar-bg);
  border-right: 1px solid var(--sidebar-border);
  display: flex; flex-direction: column;
  position: sticky; top: 0;
  height: 100dvh;
  overflow: hidden;
  z-index: var(--z-sidebar);
}
.app-sidebar__brand {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--sidebar-border);
}
.app-sidebar__brand-logo {
  width: 2.25rem; height: 2.25rem; flex-shrink: 0;
  object-fit: contain;
}
.app-sidebar__brand-title { color: var(--sidebar-text-strong); font-weight: var(--weight-semibold); font-size: var(--text-sm); }
.app-sidebar__brand-sub   { color: var(--sidebar-text-muted); font-size: var(--text-xs); }
.app-sidebar__nav {
  flex: 1;
  overflow-y: auto;
  padding: var(--space-3);
  display: flex; flex-direction: column; gap: var(--space-1);
}
.app-sidebar__group-label {
  padding: var(--space-3) var(--space-3) var(--space-1);
  font-size: 0.6875rem;
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--sidebar-text-muted);
}
.app-sidebar__link {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  color: var(--sidebar-text);
  font-size: var(--text-sm);
  border-radius: var(--radius-md);
  transition: background var(--motion-fast), color var(--motion-fast);
  position: relative;
}
.app-sidebar__link:hover { background: var(--sidebar-bg-hover); color: var(--sidebar-text-strong); }
.app-sidebar__link[aria-current="page"] {
  background: var(--sidebar-active-bg);
  color: var(--sidebar-text-strong);
}
.app-sidebar__link[aria-current="page"]::before {
  content: "";
  position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px;
  background: var(--brand-gradient);
  border-radius: 2px;
}
.app-sidebar__link-icon { width: 1.125rem; height: 1.125rem; flex-shrink: 0; }
.app-sidebar__link-label { flex: 1; }
.app-sidebar__link-badge {
  margin-left: auto;
  padding: 0 var(--space-2);
  border-radius: var(--radius-full);
  background: var(--danger-500);
  color: white;
  font-size: 0.6875rem;
  font-weight: var(--weight-semibold);
  line-height: 1.3;
}
.app-sidebar__footer {
  padding: var(--space-3) var(--space-4);
  border-top: 1px solid var(--sidebar-border);
  color: var(--sidebar-text-muted);
  font-size: var(--text-xs);
}

.app-topbar {
  grid-area: topbar;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  display: flex; align-items: center; gap: var(--space-3);
  padding: 0 var(--space-5);
  position: sticky; top: 0;
  z-index: var(--z-topbar);
}
.app-topbar__search {
  flex: 1;
  max-width: 28rem;
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  cursor: pointer;
  transition: border-color var(--motion-fast);
}
.app-topbar__search:hover { border-color: var(--color-border-strong); }
.app-topbar__search kbd {
  margin-left: auto;
  padding: 1px 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xs);
  font-family: var(--font-mono);
  font-size: 10px;
}
.app-topbar__actions { display: flex; gap: var(--space-1); align-items: center; margin-left: auto; }
.app-topbar__icon-btn {
  width: 2.25rem; height: 2.25rem;
  display: flex; align-items: center; justify-content: center;
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  transition: background var(--motion-fast), color var(--motion-fast);
}
.app-topbar__icon-btn:hover { background: var(--color-surface-hover); color: var(--color-text); }

.app-main {
  grid-area: main;
  padding: var(--space-6);
  min-width: 0;  /* per evitare overflow orizzontale in grid child */
  background: var(--color-bg);
}
.app-main__container { max-width: var(--content-max); margin: 0 auto; }

/* Responsive: sidebar off-canvas su mobile */
@media (max-width: 1024px) {
  .cf-app {
    grid-template-columns: 1fr;
    grid-template-areas: "topbar" "main";
  }
  .app-sidebar {
    position: fixed; top: 0; left: 0;
    width: var(--sidebar-width);
    transform: translateX(-100%);
    transition: transform var(--motion-base) var(--ease-standard);
  }
  .cf-app[data-sidebar="open"] .app-sidebar { transform: translateX(0); }
  .cf-app[data-sidebar="open"]::after {
    content: "";
    position: fixed; inset: 0;
    background: var(--color-overlay);
    z-index: calc(var(--z-sidebar) - 1);
  }
}

/* ========== DRY-RUN BANNER ========== */
.cf-dryrun-banner {
  grid-column: 1 / -1;
  background: repeating-linear-gradient(45deg, var(--warning-100), var(--warning-100) 12px, var(--warning-50) 12px, var(--warning-50) 24px);
  color: var(--warning-700);
  padding: var(--space-2) var(--space-4);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  text-align: center;
  border-bottom: 1px solid var(--warning-200, #fde68a);
}

/* ========== UTILITY MINI (per sostituire tailwind selettivo) ========== */
.cf-stack   { display: flex; flex-direction: column; gap: var(--space-4); }
.cf-row     { display: flex; align-items: center; gap: var(--space-3); }
.cf-grid    { display: grid; gap: var(--space-4); }
.cf-grid-2  { grid-template-columns: repeat(2, 1fr); }
.cf-grid-3  { grid-template-columns: repeat(3, 1fr); }
.cf-grid-4  { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 768px) {
  .cf-grid-2, .cf-grid-3, .cf-grid-4 { grid-template-columns: 1fr; }
}
.cf-spacer  { flex: 1; }
.cf-muted   { color: var(--color-text-muted); }
.cf-strong  { font-weight: var(--weight-semibold); }
.cf-truncate { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* ========== ANIMATIONS ========== */
@keyframes cf-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes cf-slide-up { from { transform: translateY(12px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@keyframes cf-slide-in-right { from { transform: translateX(24px); opacity: 0; } to { transform: translateX(0); opacity: 1; } }
.cf-fade-in  { animation: cf-fade-in var(--motion-base) var(--ease-standard); }
.cf-slide-up { animation: cf-slide-up var(--motion-base) var(--ease-decelerate); }

/* ========== GRADIENT TEXT ========== */
.cf-gradient-text {
  background: var(--brand-gradient);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
