/* =========================================================================
 * Aida AI Components v2
 * Reusable building blocks. Use these instead of hand-rolling styles in
 * each page. All values reference tokens.css — never hardcode here.
 *
 * BEM-ish naming: .block, .block--modifier, .block__element
 * ========================================================================= */

/* === Button ====================================================== */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  height: 44px;
  padding: 0 var(--space-5);
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  letter-spacing: var(--letter-spacing-wide);
  text-decoration: none;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
  border: 1px solid transparent;
  border-radius: var(--radius-md);
  background: transparent;
  color: inherit;
  transition:
    background var(--duration-fast) var(--easing-standard),
    color var(--duration-fast) var(--easing-standard),
    border-color var(--duration-fast) var(--easing-standard),
    transform var(--duration-fast) var(--easing-standard),
    box-shadow var(--duration-base) var(--easing-standard);
}
.btn:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
}
.btn:active {
  transform: translateY(1px);
}
.btn[disabled],
.btn[aria-disabled="true"] {
  opacity: 0.5;
  pointer-events: none;
}

.btn--primary {
  background: linear-gradient(135deg, var(--color-accent-primary), #9aaeff);
  color: var(--color-accent-on);
  box-shadow: 0 8px 24px rgba(122, 149, 255, 0.32);
}
.btn--primary:hover {
  background: linear-gradient(135deg, var(--color-accent-hover), #aebeff);
  box-shadow: 0 12px 32px rgba(122, 149, 255, 0.42);
}

.btn--secondary {
  background: var(--color-bg-elevated);
  color: var(--color-text-primary);
  border-color: var(--color-border-default);
  backdrop-filter: var(--backdrop-blur);
}
.btn--secondary:hover {
  background: var(--color-bg-hover);
  border-color: var(--color-border-strong);
}

.btn--ghost {
  background: transparent;
  color: var(--color-text-secondary);
}
.btn--ghost:hover {
  background: var(--color-bg-hover);
  color: var(--color-text-primary);
}

.btn--danger {
  background: var(--color-danger-bg);
  color: var(--color-danger-strong);
  border-color: rgba(255, 157, 141, 0.4);
}
.btn--danger:hover {
  background: rgba(255, 157, 141, 0.18);
}

.btn--sm { height: 32px; padding: 0 var(--space-3); font-size: var(--font-size-sm); border-radius: var(--radius-sm); }
.btn--lg { height: 56px; padding: 0 var(--space-6); font-size: var(--font-size-lg); }
.btn--block { width: 100%; }
.btn--icon { width: 44px; padding: 0; }

/* === Card / surface ============================================== */
.card {
  position: relative;
  padding: var(--space-6);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-xl);
  backdrop-filter: var(--backdrop-blur);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.card--raised { background: var(--color-bg-raised); }
.card--overlay { background: var(--color-bg-overlay); }
.card--form { max-width: 540px; margin: var(--space-12) auto; }
.card--hero { padding: var(--space-12) var(--space-8); }
.card--inset { background: var(--color-bg-subtle); }
.card::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: linear-gradient(140deg, rgba(255, 255, 255, 0.08), transparent 32%);
  opacity: 0.55;
}
.card__title {
  margin: 0 0 var(--space-2);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
}
.card__subtitle {
  margin: 0 0 var(--space-4);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
}
.card__body { color: var(--color-text-secondary); line-height: var(--line-height-base); }
.card__footer {
  margin-top: var(--space-6);
  padding-top: var(--space-4);
  border-top: 1px solid var(--color-border-subtle);
}

/* === Form field ================================================== */
.field {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.field__label {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  letter-spacing: var(--letter-spacing-wide);
}
.field__hint {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}
.field__error {
  font-size: var(--font-size-xs);
  color: var(--color-danger);
}

.input,
.textarea,
.select {
  width: 100%;
  height: 44px;
  padding: 0 var(--space-4);
  font-family: var(--font-family-sans);
  font-size: var(--font-size-base);
  color: var(--color-text-primary);
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
  transition:
    border-color var(--duration-fast) var(--easing-standard),
    background var(--duration-fast) var(--easing-standard),
    box-shadow var(--duration-fast) var(--easing-standard);
}
.textarea { height: auto; min-height: 96px; padding: var(--space-3) var(--space-4); resize: vertical; }
.input::placeholder,
.textarea::placeholder { color: var(--color-text-muted); }
.input:hover,
.textarea:hover,
.select:hover { border-color: var(--color-border-default); background: var(--color-bg-hover); }
.input:focus-visible,
.textarea:focus-visible,
.select:focus-visible {
  outline: none;
  border-color: var(--color-border-focus);
  background: var(--color-bg-hover);
  box-shadow: var(--shadow-focus);
}
.input[aria-invalid="true"],
.textarea[aria-invalid="true"] { border-color: var(--color-danger); box-shadow: var(--shadow-focus-danger); }
.input[disabled] { opacity: 0.5; cursor: not-allowed; }

.input--lg { height: 56px; font-size: var(--font-size-lg); padding: 0 var(--space-5); }
.input--sm { height: 32px; font-size: var(--font-size-sm); padding: 0 var(--space-3); }

/* === Password field (input + visibility toggle) ================== */
.password-field { position: relative; display: flex; align-items: center; }
.password-field > .input { width: 100%; padding-right: 44px; }
.password-toggle {
  position: absolute;
  right: 6px; top: 50%; transform: translateY(-50%);
  width: 32px; height: 32px;
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: 0;
  border-radius: var(--radius-sm);
  color: var(--color-text-muted);
  cursor: pointer; font-size: 16px;
  transition: background var(--duration-fast) var(--easing-standard), color var(--duration-fast) var(--easing-standard);
}
.password-toggle:hover,
.password-toggle:focus-visible {
  background: var(--color-bg-hover);
  color: var(--color-text-primary);
  outline: none;
}

/* === Badge (formerly .tag) ======================================= */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  height: 26px;
  padding: 0 var(--space-3);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-secondary);
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-pill);
  white-space: nowrap;
}
.badge--accent { color: var(--color-accent-primary); background: var(--color-accent-soft); border-color: rgba(122, 149, 255, 0.32); }
.badge--success { color: var(--color-success); background: var(--color-success-bg); border-color: rgba(79, 224, 193, 0.32); }
.badge--warning { color: var(--color-warning); background: var(--color-warning-bg); border-color: rgba(255, 184, 77, 0.32); }
.badge--danger { color: var(--color-danger); background: var(--color-danger-bg); border-color: rgba(255, 157, 141, 0.32); }
.badge--info { color: var(--color-info); background: var(--color-info-bg); border-color: rgba(122, 149, 255, 0.32); }
.badge--lg { height: 32px; padding: 0 var(--space-4); font-size: var(--font-size-sm); }

/* === Notice (info / success / warning / danger) ================== */
.notice {
  display: flex;
  align-items: flex-start;
  gap: var(--space-3);
  padding: var(--space-4);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  color: var(--color-text-secondary);
  background: var(--color-info-bg);
  border: 1px solid rgba(122, 149, 255, 0.32);
  border-radius: var(--radius-md);
}
.notice--success { color: var(--color-success); background: var(--color-success-bg); border-color: rgba(79, 224, 193, 0.32); }
.notice--warning { color: var(--color-warning); background: var(--color-warning-bg); border-color: rgba(255, 184, 77, 0.32); }
.notice--danger { color: var(--color-danger); background: var(--color-danger-bg); border-color: rgba(255, 157, 141, 0.32); }
.notice__icon { flex: 0 0 auto; line-height: 1; }

/* === Modal (dialog) ============================================== */
.modal-backdrop {
  position: fixed; inset: 0;
  z-index: var(--z-modal);
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-4);
  background: rgba(4, 11, 21, 0.7);
  backdrop-filter: var(--backdrop-blur);
  animation: modal-fade-in var(--duration-base) var(--easing-standard);
}
.modal {
  position: relative;
  width: 100%;
  max-width: 480px;
  max-height: calc(100vh - var(--space-8));
  overflow: auto;
  padding: var(--space-6);
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-xl);
  animation: modal-pop-in var(--duration-base) var(--easing-emphasized);
}
.modal__title { margin: 0 0 var(--space-3); font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); }
.modal__body { color: var(--color-text-secondary); line-height: var(--line-height-base); }
.modal__actions { display: flex; gap: var(--space-3); justify-content: flex-end; margin-top: var(--space-6); }
@keyframes modal-fade-in { from { opacity: 0 } to { opacity: 1 } }
@keyframes modal-pop-in { from { opacity: 0; transform: translateY(8px) scale(0.98) } to { opacity: 1; transform: none } }

/* === Tabs ======================================================== */
.tabs {
  display: flex;
  gap: var(--space-1);
  padding: var(--space-1);
  background: var(--color-bg-subtle);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-md);
}
.tabs__btn {
  flex: 1;
  height: 36px;
  padding: 0 var(--space-4);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
  color: var(--color-text-muted);
  background: transparent;
  border: 0;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--duration-fast) var(--easing-standard), color var(--duration-fast) var(--easing-standard);
}
.tabs__btn:hover { color: var(--color-text-primary); }
.tabs__btn[aria-selected="true"] {
  color: var(--color-text-primary);
  background: var(--color-bg-elevated);
  box-shadow: var(--shadow-sm);
}

/* === Toast (transient notification) ============================= */
.toast {
  position: fixed;
  bottom: var(--space-6); right: var(--space-6);
  z-index: var(--z-toast);
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-overlay);
  border: 1px solid var(--color-border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  font-size: var(--font-size-sm);
  color: var(--color-text-primary);
  animation: toast-slide-in var(--duration-slow) var(--easing-emphasized);
}
@keyframes toast-slide-in { from { transform: translateY(20px); opacity: 0 } to { transform: none; opacity: 1 } }

/* === Spinner (loading) =========================================== */
.spinner {
  display: inline-block;
  width: 16px; height: 16px;
  border: 2px solid var(--color-border-default);
  border-top-color: var(--color-accent-primary);
  border-radius: var(--radius-circle);
  animation: spin 0.8s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg) } }

/* === Skeleton (loading placeholder) ============================== */
.skeleton {
  display: block;
  background: linear-gradient(90deg, var(--color-bg-subtle) 0%, var(--color-bg-hover) 50%, var(--color-bg-subtle) 100%);
  background-size: 200% 100%;
  border-radius: var(--radius-sm);
  animation: skeleton-shimmer 1.4s linear infinite;
}
@keyframes skeleton-shimmer { from { background-position: 200% 0 } to { background-position: -200% 0 } }

/* === Empty state ================================================= */
.empty {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: var(--space-3);
  padding: var(--space-12) var(--space-6);
  text-align: center;
  color: var(--color-text-muted);
}
.empty__icon { font-size: 48px; line-height: 1; opacity: 0.5; }
.empty__title { font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); color: var(--color-text-secondary); }
.empty__hint { font-size: var(--font-size-sm); max-width: 360px; }

/* === Data table ================================================== */
.data-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--font-size-sm);
  background: var(--color-bg-elevated);
  border: 1px solid var(--color-border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.data-table th {
  text-align: left;
  padding: var(--space-3) var(--space-4);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-uppercase);
  text-transform: uppercase;
  color: var(--color-text-muted);
  background: var(--color-bg-raised);
  border-bottom: 1px solid var(--color-border-subtle);
}
.data-table td {
  padding: var(--space-3) var(--space-4);
  color: var(--color-text-secondary);
  border-bottom: 1px solid var(--color-border-subtle);
}
.data-table tr:last-child td { border-bottom: 0; }
.data-table tr:hover td { background: var(--color-bg-hover); }

/* === Brand (logo + title) ======================================== */
.brand {
  display: inline-flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  color: var(--color-text-primary);
}
.brand__logo { width: 40px; height: 40px; }
.brand__title { font-size: var(--font-size-md); font-weight: var(--font-weight-semibold); line-height: 1.1; }
.brand__subtitle { font-size: var(--font-size-xs); color: var(--color-text-muted); letter-spacing: var(--letter-spacing-wide); }

/* === Eyebrow / small label ======================================= */
.eyebrow {
  display: inline-block;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  letter-spacing: var(--letter-spacing-uppercase);
  text-transform: uppercase;
  color: var(--color-accent-primary);
}

/* === Heading scale =============================================== */
.h1 { margin: 0 0 var(--space-3); font-size: var(--font-size-3xl); font-weight: var(--font-weight-bold); line-height: var(--line-height-tight); color: var(--color-text-primary); letter-spacing: var(--letter-spacing-tight); }
.h2 { margin: 0 0 var(--space-3); font-size: var(--font-size-2xl); font-weight: var(--font-weight-semibold); line-height: var(--line-height-tight); color: var(--color-text-primary); }
.h3 { margin: 0 0 var(--space-2); font-size: var(--font-size-lg); font-weight: var(--font-weight-semibold); line-height: var(--line-height-snug); color: var(--color-text-primary); }
.h4 { margin: 0 0 var(--space-2); font-size: var(--font-size-md); font-weight: var(--font-weight-semibold); color: var(--color-text-primary); }

/* === Link ======================================================== */
.link {
  color: var(--color-text-link);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: color var(--duration-fast) var(--easing-standard), border-color var(--duration-fast) var(--easing-standard);
}
.link:hover { color: var(--color-text-link-hover); border-bottom-color: currentColor; }
.link--muted { color: var(--color-text-muted); }
.link--muted:hover { color: var(--color-text-secondary); }

/* === Footer links (was .footer-links) ============================ */
.footer-links {
  display: flex; flex-wrap: wrap; gap: var(--space-3) var(--space-4);
  padding-top: var(--space-4);
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  border-top: 1px solid var(--color-border-subtle);
}
.footer-links a { color: var(--color-text-muted); text-decoration: none; }
.footer-links a:hover { color: var(--color-text-secondary); }

/* === No-JS fallback ============================================== */
.noscript-fallback {
  max-width: 720px;
  margin: var(--space-6) auto;
  padding: var(--space-4) var(--space-5);
  border-radius: var(--radius-md);
  background: var(--color-danger-bg);
  border: 1px solid rgba(255, 157, 141, 0.35);
  color: var(--color-danger-strong);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  text-align: center;
}

/* === Kbd (keyboard shortcut) ===================================== */
.kbd {
  display: inline-block;
  padding: 2px 6px;
  font-family: var(--font-family-mono);
  font-size: var(--font-size-xs);
  color: var(--color-text-secondary);
  background: var(--color-bg-raised);
  border: 1px solid var(--color-border-default);
  border-bottom-width: 2px;
  border-radius: var(--radius-sm);
}

/* === Avatar ====================================================== */
.avatar {
  display: inline-flex;
  align-items: center; justify-content: center;
  width: 40px; height: 40px;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-semibold);
  color: var(--color-text-primary);
  background: linear-gradient(135deg, var(--color-accent-primary), var(--color-accent-secondary));
  border-radius: var(--radius-circle);
  user-select: none;
}
.avatar--sm { width: 32px; height: 32px; font-size: var(--font-size-xs); }
.avatar--lg { width: 56px; height: 56px; font-size: var(--font-size-lg); }

/* === Progress (linear) =========================================== */
.progress {
  width: 100%;
  height: 6px;
  background: var(--color-bg-subtle);
  border-radius: var(--radius-pill);
  overflow: hidden;
}
.progress__bar {
  height: 100%;
  background: linear-gradient(90deg, var(--color-accent-primary), var(--color-accent-secondary));
  transition: width var(--duration-slow) var(--easing-standard);
}
