/* ═══════════════════════════════════════════════════════
   COMPONENTS — Buttons, cards, badges, inputs, modals
   ═══════════════════════════════════════════════════════ */

/* ── Buttons ── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-weight: var(--weight-semibold);
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-5);
  border: none;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  white-space: nowrap;
  user-select: none;
  text-decoration: none;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn--primary {
  background: var(--gradient-gold);
  color: var(--white);
  box-shadow: var(--shadow-sm);
}

.btn--primary:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.btn--go {
  background: var(--gradient-hero);
  color: var(--white);
  font-size: var(--text-base);
  padding: var(--space-4) var(--space-8);
  box-shadow: var(--shadow-md);
}

.btn--go:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.btn--danger {
  background: var(--accent-delete);
  color: var(--white);
}

.btn--danger:hover:not(:disabled) {
  background: #c82333;
  transform: translateY(-1px);
}

.btn--ghost {
  background: var(--white);
  color: var(--text-secondary);
  border: 1px solid var(--border-default);
}

.btn--ghost:hover:not(:disabled) {
  color: var(--text-primary);
  border-color: var(--border-strong);
  background: var(--bg-hover);
}

.btn--sm {
  font-size: var(--text-xs);
  padding: var(--space-2) var(--space-3);
}

.btn--icon {
  padding: var(--space-2);
  border-radius: var(--radius-sm);
  width: 36px;
  height: 36px;
  background: var(--white);
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
}

.btn--icon:hover:not(:disabled) {
  background: var(--bg-hover);
  color: var(--text-primary);
}

/* ── Input ── */
.input-group {
  display: flex;
  align-items: stretch;
  gap: var(--space-3);
  width: 100%;
  max-width: 640px;
}

.input {
  flex: 1;
  font-family: var(--font-body);
  font-size: var(--text-base);
  padding: var(--space-3) var(--space-4);
  background: var(--white);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  transition: all var(--duration-fast) var(--ease-out);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
}

.input::placeholder {
  color: var(--text-tertiary);
}

.input:focus {
  outline: none;
  border-color: var(--vertex-blue);
  box-shadow: 0 0 0 3px rgba(0, 56, 101, 0.1);
}

.input--error {
  border-color: var(--accent-delete);
}

.input__hint {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  margin-top: var(--space-2);
}

.input__error {
  font-size: var(--text-xs);
  color: var(--accent-delete);
  margin-top: var(--space-2);
}

/* ── Cards ── */
.card {
  background: var(--white);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  transition: all var(--duration-normal) var(--ease-out);
  box-shadow: var(--shadow-sm);
}

.card:hover {
  border-color: var(--border-default);
}

.card--delete {
  border-left: 3px solid var(--accent-delete);
}

.card--archive {
  border-left: 3px solid var(--accent-archive);
}

.card--rename {
  border-left: 3px solid var(--accent-rename);
}

.card--structure {
  border-left: 3px solid var(--accent-structure);
}

/* ── Suggestion Card ── */
.suggestion-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto auto;
  gap: var(--space-2) var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--white);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: all var(--duration-normal) var(--ease-out);
  position: relative;
  overflow: hidden;
}

.suggestion-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 3px;
}

.suggestion-card[data-category="delete"]::before { background: var(--accent-delete); }
.suggestion-card[data-category="archive"]::before { background: var(--accent-archive); }
.suggestion-card[data-category="rename"]::before { background: var(--accent-rename); }
.suggestion-card[data-category="structure"]::before { background: var(--accent-structure); }

.suggestion-card__icon {
  grid-row: 1 / 3;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-sm);
  font-size: var(--text-lg);
}

.suggestion-card[data-category="delete"] .suggestion-card__icon { background: var(--accent-delete-dim); color: var(--accent-delete); }
.suggestion-card[data-category="archive"] .suggestion-card__icon { background: var(--accent-archive-dim); color: var(--accent-archive); }
.suggestion-card[data-category="rename"] .suggestion-card__icon { background: var(--accent-rename-dim); color: var(--accent-rename); }
.suggestion-card[data-category="structure"] .suggestion-card__icon { background: var(--accent-structure-dim); color: var(--accent-structure); }

.suggestion-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}

.suggestion-card__title {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.suggestion-card__severity {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid;
}

.suggestion-card__source-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: var(--weight-bold);
  letter-spacing: var(--tracking-wider);
  padding: 1px 6px;
  border-radius: var(--radius-sm);
  background: var(--accent-structure-dim);
  color: var(--accent-structure);
  border: 1px solid var(--accent-structure);
  text-transform: uppercase;
}

.suggestion-card__severity--critical { color: var(--accent-delete); border-color: var(--accent-delete); background: var(--accent-delete-dim); }
.suggestion-card__severity--high { color: var(--accent-archive); border-color: var(--accent-archive); background: var(--accent-archive-dim); }
.suggestion-card__severity--medium { color: var(--accent-rename); border-color: var(--accent-rename); background: var(--accent-rename-dim); }
.suggestion-card__severity--low { color: var(--text-secondary); border-color: var(--border-default); background: var(--bg-elevated); }

.suggestion-card__path {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.suggestion-card__link {
  color: var(--vertex-blue);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}

.suggestion-card__link:hover {
  color: var(--vertex-gold);
  text-decoration: underline;
}

.suggestion-card__description {
  grid-column: 1 / -1;
  font-size: var(--text-sm);
  color: var(--text-secondary);
  line-height: var(--leading-loose);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-subtle);
  margin-top: var(--space-2);
}

.suggestion-card__rename {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-3);
  background: var(--bg-elevated);
  border-radius: var(--radius-sm);
  margin-top: var(--space-2);
}

.suggestion-card__rename-arrow {
  color: var(--accent-approve);
  font-weight: bold;
  flex-shrink: 0;
}

.suggestion-card__rename-old {
  color: var(--accent-delete);
  text-decoration: line-through;
  opacity: 0.7;
}

.suggestion-card__rename-new {
  color: var(--accent-approve);
}

.suggestion-card__actions {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--border-subtle);
}

.suggestion-card__confidence {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
}

.suggestion-card__buttons {
  display: flex;
  gap: var(--space-2);
}

/* Approved/Rejected states */
.suggestion-card--approved {
  opacity: 0.5;
  border-color: var(--accent-approve);
  background: var(--accent-approve-dim);
}

.suggestion-card--rejected {
  opacity: 0.3;
  filter: grayscale(0.8);
}

.suggestion-card--executed {
  opacity: 0.4;
  border-color: var(--accent-approve);
  background: var(--accent-approve-dim);
}

/* ── Stat Card ── */
.stat-card {
  background: var(--white);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-xl);
  padding: var(--space-6);
  text-align: center;
  box-shadow: var(--shadow-sm);
  transition: all var(--duration-normal) var(--ease-out);
  position: relative;
  overflow: hidden;
}

.stat-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 4px;
  background: var(--gradient-gold);
  transform: scaleX(0);
  transition: transform var(--duration-normal) var(--ease-out);
}

.stat-card:hover {
  transform: translateY(-5px);
  box-shadow: var(--shadow-lg);
}

.stat-card:hover::before {
  transform: scaleX(1);
}

.stat-card__value {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-2xl);
  color: var(--vertex-blue);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.stat-card__label {
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.stat-card--delete .stat-card__value { color: var(--accent-delete); }
.stat-card--delete::before { background: var(--accent-delete); }
.stat-card--archive .stat-card__value { color: var(--vertex-gold); }
.stat-card--archive::before { background: var(--gradient-gold); }
.stat-card--rename .stat-card__value { color: var(--vertex-blue); }
.stat-card--rename::before { background: var(--gradient-hero); }
.stat-card--structure .stat-card__value { color: var(--accent-structure); }
.stat-card--structure::before { background: var(--accent-structure); }

/* ── Category Tabs ── */
.tabs {
  display: flex;
  gap: var(--space-1);
  border-bottom: 2px solid var(--border-subtle);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

.tab {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-base);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  padding: var(--space-3) var(--space-5);
  border: none;
  background: transparent;
  color: var(--text-tertiary);
  cursor: pointer;
  position: relative;
  transition: color var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}

.tab::after {
  content: '';
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  height: 2px;
  background: transparent;
  transition: background var(--duration-fast) var(--ease-out);
}

.tab:hover {
  color: var(--text-secondary);
}

.tab--active {
  color: var(--text-primary);
}

.tab[data-category="delete"].tab--active { color: var(--accent-delete); }
.tab[data-category="delete"].tab--active::after { background: var(--accent-delete); }
.tab[data-category="archive"].tab--active { color: var(--accent-archive); }
.tab[data-category="archive"].tab--active::after { background: var(--accent-archive); }
.tab[data-category="rename"].tab--active { color: var(--accent-rename); }
.tab[data-category="rename"].tab--active::after { background: var(--accent-rename); }
.tab[data-category="structure"].tab--active { color: var(--accent-structure); }
.tab[data-category="structure"].tab--active::after { background: var(--accent-structure); }

.tab__count {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  padding: 1px var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--bg-elevated);
  color: var(--text-secondary);
  min-width: 24px;
  text-align: center;
}

.tab--active .tab__count {
  background: currentColor;
  color: var(--bg-primary);
}

/* ── Badge ── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border-default);
  color: var(--text-secondary);
}

/* ── Progress Bar ── */
.progress {
  width: 100%;
  max-width: 640px;
  margin: 0 auto;
}

.progress__bar-container {
  width: 100%;
  height: 10px;
  background: var(--border-subtle);
  border-radius: var(--radius-full);
  overflow: hidden;
  position: relative;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.progress__bar {
  height: 100%;
  border-radius: var(--radius-full);
  background: linear-gradient(90deg, var(--accent-approve), color-mix(in srgb, var(--accent-approve) 80%, white));
  transition: width var(--duration-slow) var(--ease-out);
  position: relative;
  box-shadow: 0 0 8px color-mix(in srgb, var(--accent-approve) 40%, transparent);
}

.progress__bar--striped {
  background: linear-gradient(90deg, var(--vertex-gold), var(--vertex-gold-light));
  box-shadow: 0 0 10px color-mix(in srgb, var(--vertex-gold) 40%, transparent);
}

.progress__bar--striped::after {
  content: '';
  position: absolute;
  inset: 0;
  background: repeating-linear-gradient(
    -45deg,
    transparent,
    transparent 8px,
    rgba(255, 255, 255, 0.2) 8px,
    rgba(255, 255, 255, 0.2) 16px
  );
  background-size: 200% 100%;
  animation: progress-slide 0.8s linear infinite;
  border-radius: inherit;
}

@keyframes progress-slide {
  0% { background-position: 0 0; }
  100% { background-position: 32px 0; }
}

@keyframes progress-glow {
  0%, 100% { box-shadow: 0 0 8px color-mix(in srgb, var(--vertex-gold) 30%, transparent); }
  50% { box-shadow: 0 0 16px color-mix(in srgb, var(--vertex-gold) 50%, transparent); }
}

.progress__bar--active {
  animation: progress-glow 1.5s ease-in-out infinite;
}

.progress__text {
  display: flex;
  justify-content: space-between;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.progress__status {
  color: var(--text-primary);
  font-weight: 500;
}

/* ── Modal ── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.8);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: var(--z-modal);
  opacity: 0;
  visibility: hidden;
  transition: all var(--duration-normal) var(--ease-out);
}

.modal-overlay--visible {
  opacity: 1;
  visibility: visible;
}

.modal {
  background: var(--bg-surface);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  max-width: 500px;
  width: 90%;
  transform: translateY(20px) scale(0.95);
  transition: transform var(--duration-normal) var(--ease-spring);
}

.modal-overlay--visible .modal {
  transform: translateY(0) scale(1);
}

.modal__title {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-xl);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  margin-bottom: var(--space-4);
}

.modal__body {
  font-size: var(--text-sm);
  color: var(--text-secondary);
  margin-bottom: var(--space-6);
  line-height: var(--leading-loose);
}

.modal__actions {
  display: flex;
  gap: var(--space-3);
  justify-content: flex-end;
}

/* ── Toast ── */
.toast-container {
  position: fixed;
  top: var(--space-6);
  right: var(--space-6);
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.toast {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-5);
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-lg);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  min-width: 280px;
  max-width: 400px;
  transform: translateX(120%);
  transition: transform var(--duration-normal) var(--ease-spring);
}

.toast--visible {
  transform: translateX(0);
}

.toast--success { border-left: 3px solid var(--accent-approve); }
.toast--error { border-left: 3px solid var(--accent-delete); }
.toast--info { border-left: 3px solid var(--accent-rename); }
.toast--warning { border-left: 3px solid var(--accent-archive); }

/* ── Action Queue Bar ── */
.action-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-4) var(--space-6);
  background: var(--bg-surface);
  border-top: 2px solid var(--accent-approve);
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.5);
  z-index: var(--z-sticky);
  transform: translateY(100%);
  transition: transform var(--duration-normal) var(--ease-spring);
}

.action-bar--visible {
  transform: translateY(0);
}

.action-bar__count {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
  letter-spacing: var(--tracking-wide);
  text-transform: uppercase;
}

.action-bar__count span {
  color: var(--accent-approve);
}

/* ── Empty State ── */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: var(--space-16) var(--space-8);
  text-align: center;
}

.empty-state__icon {
  font-size: 3rem;
  margin-bottom: var(--space-4);
  opacity: 0.3;
}

.empty-state__title {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-xl);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: var(--space-2);
}

.empty-state__text {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
}

/* ── Toolbar (sort/filter) ── */
.toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
  padding: var(--space-3) 0;
  flex-wrap: wrap;
}

.toolbar__search {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-4);
  background: var(--bg-input);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  min-width: 200px;
}

.toolbar__search:focus {
  outline: none;
  border-color: var(--accent-rename);
}

.toolbar__sort {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  padding: var(--space-2) var(--space-3);
  background: var(--bg-input);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-sm);
  color: var(--text-primary);
  cursor: pointer;
}

.toolbar__actions {
  display: flex;
  gap: var(--space-2);
}

/* ── Folder Navigation ── */
.folder-nav {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.folder-nav__breadcrumb {
  display: flex;
  align-items: center;
  gap: var(--space-1);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--space-1);
}

.folder-nav__crumb {
  background: none;
  border: none;
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--text-tertiary);
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  transition: color var(--duration-fast) var(--ease-out), background var(--duration-fast) var(--ease-out);
  white-space: nowrap;
}

.folder-nav__crumb:hover {
  color: var(--text-primary);
  background: var(--bg-hover);
}

.folder-nav__crumb--active {
  color: var(--text-primary);
  font-weight: var(--weight-semibold);
  cursor: default;
}

.folder-nav__crumb--active:hover {
  background: transparent;
}

.folder-nav__separator {
  color: var(--text-tertiary);
  opacity: 0.4;
  flex-shrink: 0;
  user-select: none;
}

.folder-nav__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-3);
}

.folder-card {
  background: var(--bg-surface);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-out);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.folder-card:hover {
  border-color: var(--border-default);
  background: var(--bg-hover);
}

.folder-card__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}

.folder-card__name {
  font-family: var(--font-display);
  font-weight: var(--weight-bold);
  font-size: var(--text-sm);
  letter-spacing: var(--tracking-wider);
  text-transform: uppercase;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  flex: 1;
}

.folder-card__icon {
  flex-shrink: 0;
  opacity: 0.5;
}

.folder-card__badge {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  padding: 1px var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--bg-elevated);
  color: var(--text-tertiary);
  flex-shrink: 0;
  min-width: 24px;
  text-align: center;
}

.folder-card__badge--warm {
  background: var(--accent-archive-dim);
  color: var(--accent-archive);
}

.folder-card__badge--hot {
  background: var(--accent-delete-dim);
  color: var(--accent-delete);
}

.folder-card__bar {
  height: 3px;
  border-radius: 2px;
  display: flex;
  overflow: hidden;
  background: var(--bg-elevated);
}

.folder-card__bar-segment {
  height: 100%;
  transition: width var(--duration-fast) var(--ease-out);
}

.folder-card__bar-segment--delete { background: var(--accent-delete); }
.folder-card__bar-segment--archive { background: var(--accent-archive); }
.folder-card__bar-segment--rename { background: var(--accent-rename); }
.folder-card__bar-segment--structure { background: var(--accent-structure); }

.folder-card--clean {
  opacity: 0.5;
}

.folder-card--clean:hover {
  opacity: 0.8;
}

/* ── Skeleton Loading ── */
.skeleton {
  background: linear-gradient(90deg, var(--bg-elevated) 25%, var(--bg-hover) 50%, var(--bg-elevated) 75%);
  background-size: 200% 100%;
  animation: shimmer 1.5s ease-in-out infinite;
  border-radius: var(--radius-sm);
}

.skeleton--text {
  height: 1em;
  width: 80%;
}

.skeleton--card {
  height: 120px;
  width: 100%;
}

/* ── Scrollbar ── */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

::-webkit-scrollbar-track {
  background: var(--bg-primary);
}

::-webkit-scrollbar-thumb {
  background: var(--border-default);
  border-radius: var(--radius-sm);
}

::-webkit-scrollbar-thumb:hover {
  background: var(--border-strong);
}

/* ── File Browser ── */
.file-browser {
  background: var(--white);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}

.file-browser__header {
  padding: var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  background: var(--bg-primary);
}

.file-browser__content {
  display: flex;
  flex-direction: column;
}

.file-browser__breadcrumb {
  padding: var(--space-3) var(--space-4);
  background: var(--bg-primary);
  border-bottom: 1px solid var(--border-subtle);
  font-size: var(--text-sm);
  color: var(--text-secondary);
}

.file-browser__crumb {
  cursor: pointer;
  padding: var(--space-1) var(--space-2);
  border-radius: var(--radius-sm);
  transition: all var(--duration-fast) var(--ease-out);
}

.file-browser__crumb:hover {
  background: var(--border-subtle);
  color: var(--text-primary);
}

.file-browser__list {
  max-height: 400px;
  overflow-y: auto;
}

.file-browser__item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--border-subtle);
  transition: background var(--duration-fast) var(--ease-out);
}

.file-browser__item:last-child {
  border-bottom: none;
}

.file-browser__item--folder {
  cursor: pointer;
}

.file-browser__item--folder:hover {
  background: var(--bg-primary);
}

.file-browser__item-icon {
  font-size: var(--text-lg);
}

.file-browser__item-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.file-browser__item-size {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--text-tertiary);
  white-space: nowrap;
}

.file-browser__actions {
  padding: var(--space-4);
  border-top: 1px solid var(--border-subtle);
  display: flex;
  justify-content: center;
}

.file-browser__loading {
  padding: var(--space-8);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  color: var(--text-secondary);
}

.file-browser__error {
  padding: var(--space-4);
}
