/* ================================================================
   AppsPage — Tag-grouped layout with drag-and-drop

   Architecture (2026-03-10, PO decision):
   - Always tag-grouped (no "default" two-column view)
   - Single tag per module (no multi-tag)
   - Default = card view + free-form positioning
   - List view: 1-column within group, groups side-by-side
   - Card view: 2-column within group
   - Inline editable group names
   - Unlimited cross-group drag-and-drop
   ================================================================ */

.apps-page { padding: 24px 40px 40px; }

/* ── Header ──────────────────────────────────────── */
.apps-page__header { display: flex; align-items: center; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.apps-page__header-text { flex: 1; min-width: 0; }
.apps-page__title { font-size: 20px; font-weight: 700; color: var(--color-text, #444); margin: 0 0 2px; }
.apps-page__desc { font-size: 13px; color: var(--color-text-secondary, #557482); margin: 0; }

.apps-page__actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.apps-page__create-btn {
  display: inline-flex; align-items: center; gap: 6px; padding: 8px 16px;
  background: var(--color-primary, #2C5CA3); color: #fff; border: none; border-radius: 8px;
  font-size: 13px; font-weight: 500; cursor: pointer; transition: opacity 0.15s; white-space: nowrap;
}
.apps-page__create-btn:hover { opacity: 0.9; }
.apps-page__create-btn svg { flex-shrink: 0; }

/* Admin toggle: show all employees' apps */
.apps-page__toggle-all-btn {
  display: inline-flex; align-items: center; gap: 5px; padding: 7px 12px;
  background: transparent; color: var(--color-text-secondary, #888); border: 1px solid var(--color-border, #ddd); border-radius: 8px;
  font-size: 12px; font-weight: 500; cursor: pointer; transition: all 0.15s; white-space: nowrap;
}
.apps-page__toggle-all-btn:hover { border-color: var(--color-primary, #2C5CA3); color: var(--color-primary, #2C5CA3); }
.apps-page__toggle-all-btn--active { background: rgba(44,92,163,0.08); border-color: var(--color-primary, #2C5CA3); color: var(--color-primary, #2C5CA3); }
.apps-page__toggle-all-btn svg { flex-shrink: 0; }

/* ── View toggle (list / card only) ──────────────── */
.apps-toolbar__view { display: flex; gap: 2px; background: var(--color-bg-secondary, #f0f2f5); border-radius: 6px; padding: 2px; }
.apps-toolbar__view-btn {
  display: flex; align-items: center; justify-content: center; width: 30px; height: 28px;
  border: none; border-radius: 5px; background: transparent; color: var(--color-text-secondary, #888);
  cursor: pointer; transition: background 0.15s, color 0.15s;
}
.apps-toolbar__view-btn:hover { color: var(--color-primary, #2C5CA3); }
.apps-toolbar__view-btn--active { background: var(--color-bg-card, #fff); color: var(--color-primary, #2C5CA3); box-shadow: 0 1px 3px rgba(0,0,0,0.08); }

/* ── Tag filter & toolbar bar ────────────────────── */
.apps-tagbar {
  display: flex; align-items: center; justify-content: space-between; gap: 10px;
  margin-bottom: 16px; padding: 0 2px;
}

.apps-tagbar__chips {
  display: flex; align-items: center; gap: 6px; flex-wrap: wrap; flex: 1; min-width: 0;
}

.apps-tagbar__chip {
  display: inline-flex; align-items: center; gap: 5px;
  padding: 5px 12px; border-radius: 16px; font-size: 12.5px; font-weight: 500;
  border: 1px solid var(--color-border, #e4e8ec); background: var(--color-bg-card, #fff);
  color: var(--color-text-secondary, #557482); cursor: pointer;
  transition: all 0.15s ease; white-space: nowrap;
}
.apps-tagbar__chip:hover { border-color: var(--color-primary, #2C5CA3); color: var(--color-primary, #2C5CA3); }
.apps-tagbar__chip--active {
  background: var(--color-primary, #2C5CA3); color: #fff;
  border-color: var(--color-primary, #2C5CA3);
}
.apps-tagbar__chip--active:hover { opacity: 0.9; }
.apps-tagbar__chip svg { flex-shrink: 0; }

.apps-tagbar__chip-count {
  font-size: 10px; font-weight: 600; opacity: 0.7;
  background: rgba(0,0,0,0.08); padding: 0 5px; border-radius: 8px; line-height: 1.6;
}
.apps-tagbar__chip--active .apps-tagbar__chip-count { background: rgba(255,255,255,0.25); }

/* ── Add group button (mobile-only) ──────────── */
.apps-tagbar__add-group {
  display: none; /* hidden on desktop — new group via drag-and-drop */
  border-style: dashed; border-color: var(--color-primary, #2C5CA3);
  color: var(--color-primary, #2C5CA3); background: transparent;
  gap: 3px; font-weight: 600;
}
.apps-tagbar__add-group:hover { background: rgba(44, 92, 163, 0.06); }
[data-theme="dark"] .apps-tagbar__add-group { border-color: #5b9bd5; color: #5b9bd5; }
[data-theme="dark"] .apps-tagbar__add-group:hover { background: rgba(91, 155, 213, 0.1); }

/* ── Auto-sort checkbox ────────────────────────── */
.apps-tagbar__autosort {
  display: inline-flex; align-items: center; gap: 5px; font-size: 12px; font-weight: 500;
  color: var(--color-text-secondary, #557482); cursor: pointer; white-space: nowrap;
  padding: 4px 10px; border-radius: 6px; transition: background 0.15s; flex-shrink: 0;
}
.apps-tagbar__autosort:hover { background: var(--color-bg-secondary, #f0f2f5); }
.apps-tagbar__autosort-cb { accent-color: var(--color-primary, #2C5CA3); margin: 0; cursor: pointer; }
.apps-tagbar__autosort svg { flex-shrink: 0; }

/* ── Tag group container (CSS Grid for auto-sort) ── */
.apps-tag-groups {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 20px;
  align-items: start;
}

.apps-tag-group { margin-bottom: 0; }

.apps-tag-group__header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
  padding-bottom: 6px; border-bottom: 1px solid var(--color-border-light, #f0f2f5);
}
.apps-tag-group__header--draggable { user-select: none; }
.apps-tag-group__grip {
  color: var(--color-text-tertiary, #ccc); margin-left: auto; display: flex; align-items: center;
  cursor: grab; padding: 4px 2px; border-radius: 4px; transition: color 0.15s, background 0.15s;
}
.apps-tag-group__grip:hover { color: var(--color-primary, #2C5CA3); background: rgba(44, 92, 163, 0.08); }
.apps-tag-group__grip:active { cursor: grabbing; }

.apps-tag-group__dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.apps-section__count {
  font-size: 12px; font-weight: 500; color: var(--color-text-secondary, #888);
  background: var(--color-bg-secondary, #f0f2f5); padding: 1px 8px; border-radius: 10px;
  margin-left: 2px;
}
.apps-tag-group__title {
  font-size: 14px; font-weight: 600; color: var(--color-text, #444); margin: 0;
  cursor: pointer; border-radius: 4px; padding: 1px 4px; transition: background 0.15s;
}
.apps-tag-group__title:hover { background: rgba(44, 92, 163, 0.06); }

/* ── Card view: auto-fill columns based on group width (1~5+) ── */
.apps-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}

/* ── List view: 1-column within group (NO multi-column) ── */
.apps-list {
  display: flex;
  flex-direction: column;
  gap: 5px;
  width: 100%;
}

/* ── Tile card ──────────────────────────────────── */
.apps-tile {
  display: flex; flex-direction: column; padding: 12px 12px 10px;
  background: var(--color-bg-card, #fff); border: 1px solid var(--color-border, #e4e8ec);
  border-radius: 10px; text-decoration: none; color: inherit; cursor: pointer; position: relative;
  transition: box-shadow 0.2s ease, transform 0.2s ease; min-height: 0;
}
.apps-tile:hover { box-shadow: var(--shadow-md, 0 4px 16px rgba(0,0,0,0.08)); transform: translateY(-1px); }

.apps-tile__drag-handle {
  position: absolute; top: 6px; left: 6px; padding: 2px; cursor: grab;
  color: var(--color-text-tertiary, #ccc); opacity: 0;
  transition: opacity 0.15s; display: flex; align-items: center;
}
.apps-tile:hover .apps-tile__drag-handle { opacity: 1; }
.apps-tile__drag-handle:active { cursor: grabbing; }

.apps-tile__icon {
  width: 36px; height: 36px; display: flex; align-items: center; justify-content: center;
  border-radius: 9px; margin-bottom: 8px; flex-shrink: 0;
}
.apps-tile__icon-svg { display: flex; align-items: center; justify-content: center; }
.apps-tile__icon-svg svg, .apps-tile__icon svg { width: 18px; height: 18px; }

.apps-tile__text { flex: 1; min-width: 0; }
.apps-tile__name { font-size: 13px; font-weight: 600; color: var(--color-text, #444); margin: 0 0 2px; line-height: 1.3; }
.apps-tile__desc { font-size: 11px; color: var(--color-text-secondary, #557482); margin: 0; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }

/* ── Tile footer: sharing tag ──────────────────── */
.apps-tile__footer {
  display: flex; align-items: center; justify-content: space-between; gap: 4px;
  margin-top: 6px; min-height: 20px;
}
.apps-tile__footer .apps-tile__tag { margin-top: 0; }

/* ── Color-coded sharing tag ────────────────────── */
.apps-tile__tag {
  display: inline-flex; align-items: center; font-size: 10px; font-weight: 600; letter-spacing: 0.01em;
  margin-top: 6px; padding: 1px 7px; border-radius: 10px; align-self: flex-start; line-height: 1.5; white-space: nowrap;
}
.apps-tile__tag--mine          { background: rgba(44, 92, 163, 0.1);  color: #2C5CA3; }
.apps-tile__tag--mine-shared   { background: rgba(32, 182, 133, 0.1); color: #0f7b5f; }
.apps-tile__tag--mine-partial  { background: rgba(124, 58, 237, 0.1); color: #6d28d9; }
.apps-tile__tag--collab        { background: rgba(217, 119, 6, 0.1);  color: #b45309; }
.apps-tile__tag--shared        { background: rgba(32, 182, 133, 0.1); color: #0f7b5f; }
.apps-tile__tag--shared-specific { background: rgba(124, 58, 237, 0.1); color: #6d28d9; }
.apps-tile__tag--designated     { background: rgba(6, 182, 212, 0.1);   color: #0891b2; }
.apps-tile__tag--public        { background: rgba(107, 114, 128, 0.08); color: #6b7280; }
.apps-tile__tag--private       { background: rgba(107, 114, 128, 0.06); color: #9ca3af; }

/* ── List item (wide, no truncation) ──────────── */
.apps-list-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 14px; min-width: 0;
  background: var(--color-bg-card, #fff); border: 1px solid var(--color-border, #e4e8ec);
  border-radius: 8px; text-decoration: none; color: inherit; cursor: pointer;
  transition: box-shadow 0.15s ease, background 0.12s ease; position: relative;
}
.apps-list-item:hover { box-shadow: 0 2px 8px rgba(0,0,0,0.06); background: rgba(44, 92, 163, 0.02); }

.apps-list-item__drag-handle {
  flex-shrink: 0; padding: 2px; cursor: grab;
  color: var(--color-text-tertiary, #ccc); opacity: 0;
  transition: opacity 0.15s; display: flex; align-items: center;
}
.apps-list-item:hover .apps-list-item__drag-handle { opacity: 1; }
.apps-list-item__drag-handle:active { cursor: grabbing; }

.apps-list-item__icon {
  width: 28px; height: 28px; display: flex; align-items: center; justify-content: center;
  border-radius: 7px; flex-shrink: 0;
}
.apps-list-item__icon svg { width: 14px; height: 14px; }

/* Body: NO truncation — full text visible */
.apps-list-item__body { flex: 1; min-width: 0; }
.apps-list-item__name {
  font-size: 13px; font-weight: 600; color: var(--color-text, #444);
  display: block; line-height: 1.4;
}
.apps-list-item__desc {
  font-size: 11px; color: var(--color-text-tertiary, #aaa);
  display: block; margin-top: 1px; line-height: 1.4;
}

.apps-list-item .apps-tile__tag { margin-top: 0; flex-shrink: 0; font-size: 9.5px; padding: 1px 6px; }

.apps-list-item__actions { display: flex; align-items: center; gap: 2px; flex-shrink: 0; }

.apps-list-item__gear {
  background: none; border: none; padding: 2px; cursor: pointer;
  color: var(--color-text-tertiary, #999); opacity: 0;
  transition: opacity 0.15s, color 0.15s; display: flex; align-items: center; flex-shrink: 0;
}
.apps-list-item:hover .apps-list-item__gear { opacity: 1; }
.apps-list-item__gear:hover { color: var(--color-primary, #2C5CA3); }

/* ── Top actions wrapper (pin + gear in card view) ── */
.apps-tile__actions-top {
  position: absolute; top: 8px; right: 8px; display: flex; gap: 4px; z-index: 2;
}

/* ── Pin button (card view) ─────────────────────── */
.apps-tile__pin {
  background: var(--color-bg-card, #fff); border: 1px solid var(--color-border, #e4e8ec);
  border-radius: 6px; padding: 4px; cursor: pointer;
  color: var(--color-text-tertiary, #999); opacity: 0; transition: opacity 0.15s, color 0.15s;
  display: flex; align-items: center;
}
.apps-tile:hover .apps-tile__pin { opacity: 1; }
.apps-tile__pin:hover { color: var(--color-primary, #2C5CA3); border-color: var(--color-primary, #2C5CA3); }
.apps-tile__pin--active { opacity: 1; color: var(--color-primary, #2C5CA3); border-color: var(--color-primary, #2C5CA3); }

/* ── Pin button (list view) ─────────────────────── */
.apps-list-item__pin {
  background: none; border: none; padding: 4px; cursor: pointer;
  color: var(--color-text-tertiary, #999); opacity: 0;
  transition: opacity 0.15s, color 0.15s; display: flex; align-items: center; flex-shrink: 0;
}
.apps-list-item:hover .apps-list-item__pin { opacity: 1; }
.apps-list-item__pin:hover { color: var(--color-primary, #2C5CA3); }
.apps-list-item__pin--active { opacity: 1; color: var(--color-primary, #2C5CA3); }

/* ── Gear (card view) ────────────────────────────── */
.apps-tile__gear {
  background: var(--color-bg-card, #fff);
  border: 1px solid var(--color-border, #e4e8ec); border-radius: 6px; padding: 4px; cursor: pointer;
  color: var(--color-text-tertiary, #999); opacity: 0; transition: opacity 0.15s, color 0.15s;
  display: flex; align-items: center;
}
.apps-tile:hover .apps-tile__gear { opacity: 1; }
.apps-tile__gear:hover { color: var(--color-primary, #2C5CA3); border-color: var(--color-primary, #2C5CA3); }

/* ── Drag & Drop states ─────────────────────────── */
.apps-dragging { opacity: 0.4; }
.apps-drag-over { box-shadow: 0 0 0 2px var(--color-primary, #2C5CA3) !important; border-radius: 12px; }
.apps-drag-grip { pointer-events: none; }

.apps-tag-group--drag-target {
  outline: 2px dashed var(--color-accent, #20B685); outline-offset: 2px;
  background: rgba(32, 182, 133, 0.04); transition: outline 0.15s, background 0.15s;
}

/* ── New group drop zone (fixed floating bar at viewport bottom) ── */
.apps-new-group-dropzone {
  position: fixed; bottom: 32px; left: 50%; transform: translateX(-50%);
  border: 2px dashed var(--color-primary, #2C5CA3);
  border-radius: 12px; padding: 10px 28px;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  color: var(--color-primary, #2C5CA3); font-size: 13px; font-weight: 500;
  background: rgba(255, 255, 255, 0.95); backdrop-filter: blur(8px);
  box-shadow: 0 4px 24px rgba(0,0,0,0.12);
  z-index: 100; white-space: nowrap; pointer-events: none;
  animation: appsFadeIn 0.15s ease;
}

/* ── Free-form mode ────────────────────────────── */
.apps-tag-groups--freeform {
  display: block; position: relative; overflow: visible;
  min-height: calc(100vh - 220px);
}
.apps-tag-groups--freeform .apps-tag-group {
  position: absolute; margin-bottom: 0;
  background: var(--color-bg-card, #fff); border: 1px solid var(--color-border, #e4e8ec);
  border-radius: 10px; padding: 10px 12px; box-shadow: 0 1px 4px rgba(0,0,0,0.04);
  transition: box-shadow 0.15s; overflow: visible;
}
/* Inside tag groups: list=1col, grid=auto-fill (1~5+ cols based on width) */
.apps-tag-group .apps-list { flex-direction: column; width: 100%; }
.apps-tag-group .apps-grid { grid-template-columns: repeat(auto-fill, minmax(120px, 1fr)); width: 100%; }
.apps-tag-groups--freeform .apps-tag-group:hover { box-shadow: 0 2px 10px rgba(0,0,0,0.08); }
.apps-tag-group--dragging { z-index: 10; box-shadow: 0 6px 24px rgba(0,0,0,0.15) !important; opacity: 0.9; }

/* ── Resize handle (right edge of free-form group) ── */
.apps-tag-group__resize {
  position: absolute; top: 0; right: -4px; width: 8px; height: 100%;
  cursor: ew-resize; z-index: 3; user-select: none;
}
.apps-tag-group__resize::after {
  content: ''; position: absolute; top: 50%; right: 2px;
  transform: translateY(-50%);
  width: 3px; height: 28px; border-radius: 2px;
  background: var(--color-text-tertiary, #ccc); opacity: 0;
  transition: opacity 0.15s, background 0.15s;
}
.apps-tag-group:hover .apps-tag-group__resize::after,
.apps-tag-group--resizing .apps-tag-group__resize::after { opacity: 1; }
.apps-tag-group__resize:hover::after,
.apps-tag-group--resizing .apps-tag-group__resize::after { background: var(--color-primary, #2C5CA3); opacity: 1; }

/* ── Multi-select rectangle ────────────────────── */
.apps-freeform-select-rect {
  position: absolute; border: 1.5px dashed var(--color-primary, #2C5CA3);
  background: rgba(44, 92, 163, 0.06); z-index: 5; pointer-events: none; border-radius: 3px;
}
.apps-tag-group--selected { outline: 2px solid var(--color-primary, #2C5CA3); outline-offset: 2px; }

/* ── Empty state ─────────────────────────────────── */
.apps-empty { text-align: center; padding: 28px 20px; color: var(--color-text-secondary, #557482); border: 1px dashed var(--color-border, #e4e8ec); border-radius: 10px; background: var(--color-bg-secondary, #fafbfc); }
.apps-empty__icon { margin: 0 auto 12px; width: 40px; height: 40px; display: flex; align-items: center; justify-content: center; background: rgba(44, 92, 163, 0.08); border-radius: 12px; }
.apps-empty__icon svg { width: 20px; height: 20px; color: var(--color-primary, #2C5CA3); }
.apps-empty__text { margin: 0 0 4px; font-size: 14px; font-weight: 500; color: var(--color-text, #444); }
.apps-empty__sub { margin: 0 0 16px; font-size: 12.5px; color: var(--color-text-secondary, #888); }
.apps-empty__cta {
  display: inline-flex; align-items: center; gap: 6px; padding: 9px 20px;
  background: var(--color-primary, #2C5CA3); color: #fff; border: none; border-radius: 8px;
  font-size: 13px; font-weight: 500; cursor: pointer;
}
.apps-empty__cta:hover { opacity: 0.9; }

/* ── Modal ───────────────────────────────────────── */
.apps-modal-backdrop { position: fixed; inset: 0; background: rgba(0,0,0,0.4); display: flex; align-items: center; justify-content: center; z-index: 1000; animation: apps-fade 0.15s ease; }
@keyframes apps-fade { from { opacity: 0; } to { opacity: 1; } }
.apps-modal { background: var(--color-bg-card, #fff); border-radius: 14px; width: 440px; max-width: 90vw; max-height: 90vh; overflow-y: auto; box-shadow: 0 12px 40px rgba(0,0,0,0.18); animation: apps-pop 0.2s ease; }
@keyframes apps-pop { from { opacity: 0; transform: scale(0.96) translateY(8px); } to { opacity: 1; transform: none; } }
.apps-modal--wide { max-width: 560px; }
.apps-modal__header { display: flex; align-items: center; justify-content: space-between; padding: 18px 24px; border-bottom: 1px solid var(--color-border, #e4e8ec); }
.apps-modal__title { font-size: 18px; font-weight: 600; color: var(--color-text, #444); margin: 0; }
.apps-modal__close { background: none; border: none; font-size: 22px; color: #888; cursor: pointer; padding: 0 4px; line-height: 1; }
.apps-modal__close:hover { color: #333; }
.apps-modal__body { padding: 20px 24px; }
.apps-modal__subtitle { color: #666; margin: 0 0 16px; font-size: 14px; }
.apps-modal__error { padding: 10px 14px; background: rgba(197,48,48,0.08); color: #c53030; border-radius: 6px; font-size: 13px; margin-bottom: 16px; }
.apps-modal__field { margin-bottom: 18px; }
.apps-modal__label { display: block; font-size: 13px; font-weight: 500; color: var(--color-text, #444); margin-bottom: 6px; }
.apps-modal__required { color: #c53030; }
.apps-modal__input { width: 100%; padding: 10px 12px; border: 1px solid var(--color-border, #ddd); border-radius: 8px; font-size: 14px; color: var(--color-text, #444); background: var(--color-bg, #fff); box-sizing: border-box; }
.apps-modal__input:focus { outline: none; border-color: var(--color-primary, #2C5CA3); box-shadow: 0 0 0 2px rgba(44,92,163,0.1); }
.apps-modal__hint { display: block; font-size: 11px; color: #888; margin-top: 4px; }
.apps-modal__footer { display: flex; justify-content: flex-end; gap: 10px; padding: 16px 24px; border-top: 1px solid var(--color-border, #e4e8ec); }
.apps-modal__btn { padding: 9px 20px; border-radius: 8px; font-size: 14px; font-weight: 500; cursor: pointer; border: none; transition: background 0.15s, opacity 0.15s; }
.apps-modal__btn--cancel { background: var(--color-bg-secondary, #f0f2f5); color: var(--color-text-secondary, #557482); }
.apps-modal__btn--cancel:hover { background: var(--color-border, #e4e8ec); }
.apps-modal__btn--create { background: var(--color-primary, #2C5CA3); color: #fff; }
.apps-modal__btn--create:hover { opacity: 0.9; }
.apps-modal__btn--create:disabled { opacity: 0.6; cursor: not-allowed; }

.apps-template-grid { display: flex; flex-direction: column; gap: 8px; }
.apps-template-card { display: flex; align-items: center; gap: 14px; padding: 14px 16px; border: 1px solid var(--color-border, #e0e0e0); border-radius: 10px; background: var(--color-bg-card, #fff); cursor: pointer; text-align: left; font-family: inherit; font-size: inherit; color: inherit; transition: border-color 0.15s, background 0.15s; }
.apps-template-card:hover { box-shadow: var(--shadow-md, 0 4px 12px rgba(0,0,0,0.08)); background: rgba(44,92,163,0.03); }
.apps-template-card__icon { width: 40px; height: 40px; flex-shrink: 0; display: flex; align-items: center; justify-content: center; border-radius: 10px; }
.apps-template-card__icon svg { width: 22px; height: 22px; }
.apps-template-card__body { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.apps-template-card__name { font-weight: 600; font-size: 14px; color: var(--color-text, #222); }
.apps-template-card__desc { font-size: 12.5px; color: var(--color-text-secondary, #888); line-height: 1.4; }
.apps-template-card__badge { display: inline-block; background: var(--color-accent, #20B685); color: #fff; font-size: 10px; font-weight: 600; padding: 1px 6px; border-radius: 8px; margin-left: 6px; vertical-align: middle; }
.apps-modal__back { background: none; border: none; cursor: pointer; padding: 4px; color: #666; display: inline-flex; align-items: center; border-radius: 4px; }
.apps-modal__back:hover { background: #f0f0f0; color: #333; }
.apps-template-safety { display: flex; align-items: center; gap: 8px; margin-top: 16px; padding: 10px 14px; background: rgba(32,182,133,0.08); border-radius: 8px; font-size: 12.5px; color: var(--color-text-secondary, #557482); line-height: 1.5; }
.apps-template-safety svg { flex-shrink: 0; stroke: var(--color-accent, #20B685); }

/* ── Entrance animation ─────────────────────────── */
@keyframes appsFadeIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

.apps-page__header {
  opacity: 0;
  animation: appsFadeIn 0.35s var(--ease-out, ease-out) 0.05s forwards;
}

.apps-tag-groups {
  opacity: 0;
  animation: appsFadeIn 0.35s var(--ease-out, ease-out) 0.1s forwards;
}

@media (prefers-reduced-motion: reduce) {
  .apps-page__header,
  .apps-tag-groups {
    opacity: 1;
    animation: none;
  }
}

/* ── Dark theme ──────────────────────────────────── */
[data-theme="dark"] .apps-page__desc { color: #888; }

[data-theme="dark"] .apps-tile { background: var(--color-surface, #1e1e1e); border-color: #333; }
[data-theme="dark"] .apps-tile:hover { box-shadow: 0 4px 16px rgba(255,255,255,0.04); }
[data-theme="dark"] .apps-tile__name { color: #e0e0e0; }
[data-theme="dark"] .apps-tile__desc { color: #888; }
[data-theme="dark"] .apps-tile__drag-handle { color: #555; }

[data-theme="dark"] .apps-list-item { background: var(--color-surface, #1e1e1e); border-color: #333; }
[data-theme="dark"] .apps-list-item:hover { box-shadow: 0 2px 8px rgba(255,255,255,0.03); background: rgba(91, 155, 213, 0.05); }
[data-theme="dark"] .apps-list-item__name { color: #e0e0e0; }
[data-theme="dark"] .apps-list-item__desc { color: #666; }
[data-theme="dark"] .apps-list-item__drag-handle { color: #555; }
[data-theme="dark"] .apps-list-item__gear { color: #666; }
[data-theme="dark"] .apps-list-item__gear:hover { color: #5b9bd5; }

[data-theme="dark"] .apps-tile__tag--mine          { background: rgba(91, 155, 213, 0.15); color: #7db8e8; }
[data-theme="dark"] .apps-tile__tag--mine-shared    { background: rgba(32, 182, 133, 0.15); color: #4dd8a8; }
[data-theme="dark"] .apps-tile__tag--mine-partial   { background: rgba(124, 58, 237, 0.15); color: #a78bfa; }
[data-theme="dark"] .apps-tile__tag--collab         { background: rgba(217, 119, 6, 0.15);  color: #f0a94e; }
[data-theme="dark"] .apps-tile__tag--shared         { background: rgba(32, 182, 133, 0.15); color: #4dd8a8; }
[data-theme="dark"] .apps-tile__tag--shared-specific { background: rgba(124, 58, 237, 0.15); color: #a78bfa; }
[data-theme="dark"] .apps-tile__tag--designated      { background: rgba(6, 182, 212, 0.15);  color: #67e8f9; }
[data-theme="dark"] .apps-tile__tag--public         { background: rgba(156, 163, 175, 0.1); color: #9ca3af; }
[data-theme="dark"] .apps-tile__tag--private        { background: rgba(156, 163, 175, 0.06); color: #6b7280; }

[data-theme="dark"] .apps-toolbar__view { background: #2a2a2a; }
[data-theme="dark"] .apps-toolbar__view-btn { color: #777; }
[data-theme="dark"] .apps-toolbar__view-btn:hover { color: #5b9bd5; }
[data-theme="dark"] .apps-toolbar__view-btn--active { background: #333; color: #5b9bd5; box-shadow: none; }

[data-theme="dark"] .apps-dragging { opacity: 0.3; }
[data-theme="dark"] .apps-drag-over { box-shadow: 0 0 0 2px #5b9bd5 !important; }

[data-theme="dark"] .apps-tile__pin { background: #1e1e1e; border-color: #444; color: #777; }
[data-theme="dark"] .apps-tile__pin:hover { color: #5b9bd5; border-color: #5b9bd5; }
[data-theme="dark"] .apps-tile__pin--active { color: #5b9bd5; border-color: #5b9bd5; }
[data-theme="dark"] .apps-list-item__pin { color: #666; }
[data-theme="dark"] .apps-list-item__pin:hover { color: #5b9bd5; }
[data-theme="dark"] .apps-list-item__pin--active { color: #5b9bd5; }

[data-theme="dark"] .apps-tile__gear { background: #1e1e1e; border-color: #444; color: #777; }
[data-theme="dark"] .apps-tile__gear:hover { color: #5b9bd5; border-color: #5b9bd5; }

[data-theme="dark"] .apps-empty { border-color: #333; background: #1a1a1a; }
[data-theme="dark"] .apps-empty__text { color: #ccc; }
[data-theme="dark"] .apps-empty__sub { color: #777; }
[data-theme="dark"] .apps-empty__icon { background: rgba(91, 155, 213, 0.12); }
[data-theme="dark"] .apps-empty__icon svg { color: #5b9bd5; }

[data-theme="dark"] .apps-modal { background: var(--color-surface, #1e1e1e); }
[data-theme="dark"] .apps-modal__header { border-bottom-color: #333; }
[data-theme="dark"] .apps-modal__close { color: #aaa; }
[data-theme="dark"] .apps-modal__close:hover { color: #fff; }
[data-theme="dark"] .apps-modal__subtitle { color: #999; }
[data-theme="dark"] .apps-modal__input { background: #252525; border-color: #444; color: #e0e0e0; }
[data-theme="dark"] .apps-modal__footer { border-top-color: #333; }
[data-theme="dark"] .apps-modal__btn--cancel { background: #2a2a2a; color: #aaa; }
[data-theme="dark"] .apps-template-card { background: #252525; border-color: #444; color: #e0e0e0; }
[data-theme="dark"] .apps-template-card:hover { box-shadow: 0 4px 12px rgba(255,255,255,0.04); background: rgba(91,155,213,0.08); }
[data-theme="dark"] .apps-template-card__name { color: #e0e0e0; }
[data-theme="dark"] .apps-template-card__desc { color: #888; }
[data-theme="dark"] .apps-modal__back { color: #999; }
[data-theme="dark"] .apps-modal__back:hover { background: #333; color: #e0e0e0; }
[data-theme="dark"] .apps-template-safety { background: rgba(32,182,133,0.1); color: #999; }

[data-theme="dark"] .apps-tagbar__chip { background: #252525; border-color: #444; color: #999; }
[data-theme="dark"] .apps-tagbar__chip:hover { border-color: #5b9bd5; color: #5b9bd5; }
[data-theme="dark"] .apps-tagbar__chip--active { background: #2C5CA3; color: #fff; border-color: #2C5CA3; }
[data-theme="dark"] .apps-tagbar__chip-count { background: rgba(255,255,255,0.1); }
[data-theme="dark"] .apps-tag-group__header { border-bottom-color: #333; }
[data-theme="dark"] .apps-tag-group__title { color: #e0e0e0; }
[data-theme="dark"] .apps-tag-group__title:hover { background: rgba(91, 155, 213, 0.1); }
[data-theme="dark"] .apps-tag-group__grip { color: #555; }
[data-theme="dark"] .apps-tag-groups--freeform .apps-tag-group { background: var(--color-surface, #1e1e1e); border-color: #333; }
[data-theme="dark"] .apps-tag-group--selected { outline-color: #5b9bd5; }
[data-theme="dark"] .apps-tag-group__resize::after { background: #555; }
[data-theme="dark"] .apps-tag-group__resize:hover::after,
[data-theme="dark"] .apps-tag-group--resizing .apps-tag-group__resize::after { background: #5b9bd5; }
[data-theme="dark"] .apps-tag-group--drag-target { outline-color: #20B685; background: rgba(32, 182, 133, 0.08); }
[data-theme="dark"] .apps-freeform-select-rect { border-color: #5b9bd5; background: rgba(91,155,213,0.08); }
[data-theme="dark"] .apps-tagbar__autosort { color: #999; }
[data-theme="dark"] .apps-tagbar__autosort:hover { background: #2a2a2a; }
[data-theme="dark"] .apps-new-group-dropzone { border-color: #5b9bd5; color: #5b9bd5; background: rgba(30,30,30,0.95); box-shadow: 0 4px 24px rgba(0,0,0,0.3); }
[data-theme="dark"] .apps-section__count { background: #2a2a2a; color: #888; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 1024px) {
  .apps-tagbar__add-group { display: inline-flex; }
}

@media (max-width: 768px) {
  .apps-tag-groups { grid-template-columns: 1fr; }
  .apps-grid { grid-template-columns: repeat(2, 1fr); }
  /* Mobile: always auto-sort, hide free-form controls */
  .apps-tagbar__autosort { display: none !important; }
  .apps-tag-groups--freeform { display: grid !important; position: static !important; overflow: visible !important; min-height: auto !important; grid-template-columns: 1fr; }
  .apps-tag-groups--freeform .apps-tag-group {
    position: static !important; width: auto !important;
    left: auto !important; top: auto !important;
  }
  .apps-tag-groups--freeform .apps-tag-group__header--draggable { cursor: default; }
  .apps-tag-groups--freeform .apps-tag-group__grip { display: none; }
  .apps-tag-group__resize { display: none !important; }
}

@media (max-width: 640px) {
  .apps-page { padding: 16px 12px 32px; }
  .apps-page__header { flex-direction: column; gap: 10px; }
  .apps-page__actions { align-self: stretch; justify-content: space-between; }
  .apps-page__create-btn { flex: 1; justify-content: center; }
  .apps-grid { grid-template-columns: repeat(2, 1fr); gap: 6px; }
  .apps-tile { padding: 10px 10px 8px; }
  .apps-tile__gear { opacity: 1; }
  .apps-tile__pin { opacity: 1; }
  .apps-tile__drag-handle { opacity: 0.6; }
  .apps-list-item { width: 100%; box-sizing: border-box; }
  .apps-list-item__drag-handle { opacity: 0.6; }
  .apps-list-item__gear { opacity: 1; }
  .apps-list-item__pin { opacity: 1; }
  .apps-tagbar { flex-wrap: wrap; gap: 6px; }
  .apps-tagbar__chips { gap: 4px; }
  .apps-tagbar__chip { padding: 3px 8px; font-size: 11px; }
}

@media (max-width: 380px) {
  .apps-grid { grid-template-columns: repeat(2, 1fr); gap: 4px; }
  .apps-tile { padding: 8px 8px 6px; }
  .apps-tile__icon { width: 30px; height: 30px; margin-bottom: 6px; }
  .apps-tile__name { font-size: 12px; }
  .apps-tile__desc { font-size: 10.5px; -webkit-line-clamp: 1; }
  .apps-tile__tag { font-size: 9px; padding: 1px 5px; }
}

/* ── Inactive sections: Archived & Trashed ── */
.apps-inactive-sections {
  margin-top: 32px;
  border-top: 1px solid var(--color-border, #e5e7eb);
  padding-top: 16px;
}

.apps-inactive-section {
  margin-bottom: 8px;
}

.apps-inactive-section__toggle {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-secondary, #6b7280);
  border-radius: 6px;
  width: 100%;
  text-align: left;
  transition: background 0.15s;
}
.apps-inactive-section__toggle:hover {
  background: var(--color-bg-hover, rgba(0,0,0,0.04));
}

.apps-inactive-section__chevron {
  transition: transform 0.2s;
  flex-shrink: 0;
}
.apps-inactive-section__chevron--open {
  transform: rotate(90deg);
}

.apps-inactive-section__count {
  font-size: 11px;
  font-weight: 500;
  background: var(--color-bg-tertiary, #f3f4f6);
  color: var(--color-text-secondary, #6b7280);
  padding: 1px 7px;
  border-radius: 10px;
}

.apps-inactive-section__body {
  padding: 8px 12px 12px;
}

.apps-inactive-section__notice {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  line-height: 1.5;
  padding: 10px 14px;
  border-radius: 8px;
  margin-bottom: 12px;
}
.apps-inactive-section__notice svg { flex-shrink: 0; margin-top: 1px; }

.apps-inactive-section__notice--archive {
  background: rgba(59, 130, 246, 0.06);
  color: #3b82f6;
  border: 1px solid rgba(59, 130, 246, 0.15);
}

.apps-inactive-section__notice--trash {
  background: rgba(245, 158, 11, 0.06);
  color: #d97706;
  border: 1px solid rgba(245, 158, 11, 0.15);
}

.apps-inactive-grid {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.apps-inactive-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--color-border, #e5e7eb);
  background: var(--color-bg, #fff);
  transition: background 0.15s;
}

.apps-inactive-card--archived {
  opacity: 0.65;
  filter: grayscale(0.4);
}
.apps-inactive-card--trashed {
  opacity: 0.55;
  filter: grayscale(0.6);
}
.apps-inactive-card:hover {
  opacity: 1;
  filter: none;
  background: var(--color-bg-hover, rgba(0,0,0,0.02));
}
.apps-inactive-card--clickable {
  cursor: pointer;
}
.apps-inactive-card--clickable:hover {
  box-shadow: 0 2px 8px rgba(0,0,0,0.08);
}

.apps-inactive-card__icon {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.apps-inactive-card__icon svg {
  width: 16px;
  height: 16px;
}

.apps-inactive-card__body {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.apps-inactive-card__name {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text, #374151);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.apps-inactive-card__meta {
  font-size: 11px;
  color: var(--color-text-secondary, #9ca3af);
}

.apps-inactive-card__actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
  opacity: 0;
  transition: opacity 0.15s;
}
.apps-inactive-card:hover .apps-inactive-card__actions {
  opacity: 1;
}

.apps-inactive-card__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border: none;
  border-radius: 6px;
  cursor: pointer;
  transition: background 0.15s;
}

.apps-inactive-card__btn--restore {
  background: rgba(16, 185, 129, 0.1);
  color: #10b981;
}
.apps-inactive-card__btn--restore:hover {
  background: rgba(16, 185, 129, 0.2);
}

.apps-inactive-card__btn--delete {
  background: rgba(239, 68, 68, 0.08);
  color: #ef4444;
}
.apps-inactive-card__btn--delete:hover {
  background: rgba(239, 68, 68, 0.18);
}

/* ── Trash Bulk Selection ──────────────────────── */
.apps-trash-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.apps-trash-toolbar__select-all {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--color-text-secondary, #64748b);
  cursor: pointer;
  user-select: none;
}
.apps-trash-toolbar__select-all input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--color-primary, #3b82f6);
  cursor: pointer;
}
.apps-trash-toolbar__btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 5px 12px;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 6px;
  font-size: 12px;
  cursor: pointer;
  background: var(--color-bg, #fff);
  color: var(--color-text-secondary, #64748b);
  transition: all 0.15s ease;
}
.apps-trash-toolbar__btn:hover {
  background: var(--color-bg-hover, #f8fafc);
}
.apps-trash-toolbar__btn--select {
  color: var(--color-text-secondary, #64748b);
}
.apps-trash-toolbar__btn--select:hover {
  color: var(--color-text, #1e293b);
  border-color: var(--color-text-secondary, #94a3b8);
}
.apps-trash-toolbar__btn--delete {
  color: #dc2626;
  border-color: rgba(220, 38, 38, 0.3);
}
.apps-trash-toolbar__btn--delete:hover:not(:disabled) {
  background: rgba(220, 38, 38, 0.08);
  border-color: #dc2626;
}
.apps-trash-toolbar__btn--delete:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}
.apps-trash-toolbar__btn--cancel {
  color: var(--color-text-secondary, #64748b);
}

/* Card checkbox in select mode */
.apps-inactive-card__checkbox {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  cursor: pointer;
}
.apps-inactive-card__checkbox input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--color-primary, #3b82f6);
  cursor: pointer;
}
.apps-inactive-card--selected {
  opacity: 1 !important;
  filter: none !important;
  background: rgba(59, 130, 246, 0.06);
  border-color: var(--color-primary, #3b82f6) !important;
}

/* ── Gear Dropdown ──────────────────────────────── */
.apps-gear-dropdown {
  z-index: 9999;
  background: var(--color-bg, #fff);
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 8px;
  box-shadow: 0 4px 16px rgba(0,0,0,0.12);
  padding: 4px;
  min-width: 140px;
  animation: apps-dropdown-in 0.12s ease-out;
}
@keyframes apps-dropdown-in {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
.apps-gear-dropdown__item {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 8px 12px;
  border: none;
  background: none;
  font-size: 13px;
  color: var(--color-text, #444);
  cursor: pointer;
  border-radius: 6px;
  transition: background 0.1s;
  white-space: nowrap;
}
.apps-gear-dropdown__item:hover {
  background: var(--color-bg-hover, #f1f5f9);
}
.apps-gear-dropdown__item svg {
  flex-shrink: 0;
  opacity: 0.6;
}
.apps-gear-dropdown__item--archive {
  color: var(--color-text-secondary, #557482);
}
.apps-gear-dropdown__item--archive:hover {
  background: rgba(245, 158, 11, 0.08);
  color: #d97706;
}
.apps-gear-dropdown__item--archive:hover svg {
  opacity: 1;
  stroke: #d97706;
}
.apps-gear-dropdown__divider {
  height: 1px;
  background: var(--color-border, #e5e7eb);
  margin: 4px 0;
}
.apps-gear-dropdown__item--delete {
  color: var(--color-text-secondary, #557482);
}
.apps-gear-dropdown__item--delete:hover {
  background: rgba(239, 68, 68, 0.08);
  color: #dc2626;
}
.apps-gear-dropdown__item--delete:hover svg {
  opacity: 1;
  stroke: #dc2626;
}

/* ── Touch devices: always show pin & gear (no hover available) ── */
@media (hover: none) {
  .apps-tile__pin { opacity: 1; }
  .apps-tile__gear { opacity: 1; }
  .apps-tile__drag-handle { opacity: 0.6; }
  .apps-list-item__pin { opacity: 1; }
  .apps-list-item__gear { opacity: 1; }
  .apps-list-item__drag-handle { opacity: 0.6; }
}


/* ==========================================================================
   Custom Confirm Dialog — Self-contained overlay (no .modal-overlay reuse)
   Avoids cascade conflicts with modal.css / admin.css / team.css.
   ========================================================================== */

/* Backdrop: covers screen, just for dimming/blur */
.rdx-confirm-overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 99998;
  background: rgba(0, 0, 0, 0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  opacity: 0;
  transition:
    background-color 350ms cubic-bezier(0.32, 0.72, 0, 1),
    backdrop-filter 350ms cubic-bezier(0.32, 0.72, 0, 1),
    -webkit-backdrop-filter 350ms cubic-bezier(0.32, 0.72, 0, 1),
    opacity 350ms cubic-bezier(0.32, 0.72, 0, 1);
}
.rdx-confirm-overlay.visible {
  opacity: 1;
  background: rgba(0, 0, 0, 0.35);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}
:root[data-theme="dark"] .rdx-confirm-overlay.visible {
  background: rgba(0, 0, 0, 0.55);
}
.rdx-confirm-overlay.closing {
  opacity: 0;
  background: rgba(0, 0, 0, 0);
  backdrop-filter: blur(0px);
  -webkit-backdrop-filter: blur(0px);
  transition:
    background-color 200ms cubic-bezier(0.32, 0, 0.67, 0),
    backdrop-filter 200ms cubic-bezier(0.32, 0, 0.67, 0),
    -webkit-backdrop-filter 200ms cubic-bezier(0.32, 0, 0.67, 0),
    opacity 200ms cubic-bezier(0.32, 0, 0.67, 0);
}

/* Card: self-centering via position fixed + transform (immune to parent layout) */
.rdx-confirm-dialog {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 99999;
  transform: translate(-50%, -50%) scale(0.92) translateY(12px);
  background: var(--color-surface, #fff);
  width: calc(100% - 32px);
  max-width: 360px;
  overflow: hidden;
  opacity: 0;
  transition:
    transform 500ms cubic-bezier(0.32, 0.72, 0, 1),
    opacity 350ms cubic-bezier(0.32, 0.72, 0, 1);
  border-radius: var(--radius-xl, 16px);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.12),
    0 2px 8px rgba(0, 0, 0, 0.06);
}
:root[data-theme="dark"] .rdx-confirm-dialog {
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.5),
    0 2px 8px rgba(0, 0, 0, 0.3);
}
.rdx-confirm-dialog.visible {
  transform: translate(-50%, -50%) scale(1) translateY(0);
  opacity: 1;
}

/* Exit: slightly faster, ease-in feel */
.rdx-confirm-dialog.closing {
  transform: translate(-50%, -50%) scale(0.96) translateY(4px);
  opacity: 0;
  transition:
    transform 200ms cubic-bezier(0.32, 0, 0.67, 0),
    opacity 180ms cubic-bezier(0.32, 0, 0.67, 0);
}

/* Body: tighter spacing */
.rdx-confirm-body {
  padding: 28px 24px 16px;
  text-align: center;
}
.rdx-confirm-dialog .confirm-icon {
  width: 44px;
  height: 44px;
  margin: 0 auto 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.rdx-confirm-dialog .confirm-icon svg {
  width: 22px;
  height: 22px;
}
.rdx-confirm-dialog .confirm-icon--warning {
  background: rgba(245, 158, 11, 0.12);
  color: #d97706;
}
.rdx-confirm-dialog .confirm-icon--danger {
  background: rgba(239, 68, 68, 0.12);
  color: #dc2626;
}
.rdx-confirm-dialog .confirm-icon--success {
  background: rgba(59, 130, 246, 0.12);
  color: #2563eb;
}
.rdx-confirm-dialog .confirm-title {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
  margin-bottom: 8px;
  color: var(--color-text, #111);
}
.rdx-confirm-dialog .confirm-message {
  font-size: 14px;
  line-height: 1.55;
  color: var(--color-text-secondary, #666);
}
.rdx-confirm-dialog .confirm-message strong {
  color: var(--color-text, #111);
  font-weight: 600;
}

/* Footer */
.rdx-confirm-footer {
  padding: 12px 24px 20px;
  display: flex;
  gap: 10px;
  justify-content: center;
}
.rdx-confirm-footer--single {
  justify-content: center;
}
.rdx-confirm-footer .btn {
  min-width: 88px;
  padding: 9px 20px;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--radius-md, 8px);
  transition:
    background-color 150ms cubic-bezier(0.32, 0.72, 0, 1),
    transform 150ms cubic-bezier(0.32, 0.72, 0, 1),
    box-shadow 150ms cubic-bezier(0.32, 0.72, 0, 1);
}
.rdx-confirm-footer .btn:active {
  transform: scale(0.97);
}

/* ── Icon Picker Modal ── */
.apps-icon-picker-overlay {
  position: fixed;
  inset: 0;
  z-index: 10000;
  background: rgba(0,0,0,0.4);
  display: flex;
  align-items: center;
  justify-content: center;
  animation: apps-icon-picker-fade-in 0.15s ease-out;
}
@keyframes apps-icon-picker-fade-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.apps-icon-picker {
  background: var(--color-bg, #fff);
  border-radius: 12px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.18);
  width: 480px;
  max-width: 92vw;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  animation: apps-icon-picker-slide-in 0.15s ease-out;
}
@keyframes apps-icon-picker-slide-in {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
.apps-icon-picker__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid var(--color-border, #e5e7eb);
}
.apps-icon-picker__header h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text, #1e293b);
}
.apps-icon-picker__close {
  background: none;
  border: none;
  font-size: 20px;
  color: var(--color-text-secondary, #94a3b8);
  cursor: pointer;
  padding: 0 4px;
  line-height: 1;
}
.apps-icon-picker__close:hover {
  color: var(--color-text, #1e293b);
}
.apps-icon-picker__search {
  padding: 12px 20px 8px;
}
.apps-icon-picker__search-input {
  width: 100%;
  padding: 8px 12px;
  border: 1px solid var(--color-border, #e2e8f0);
  border-radius: 8px;
  font-size: 13px;
  background: var(--color-bg-secondary, #f8fafc);
  color: var(--color-text, #1e293b);
  outline: none;
  box-sizing: border-box;
}
.apps-icon-picker__search-input:focus {
  border-color: var(--color-primary, #3b82f6);
  box-shadow: 0 0 0 2px rgba(59,130,246,0.15);
}
.apps-icon-picker__body {
  overflow-y: auto;
  padding: 8px 20px 20px;
  flex: 1;
}
.apps-icon-picker__category {
  margin-bottom: 12px;
}
.apps-icon-picker__category-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--color-text-secondary, #94a3b8);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}
.apps-icon-picker__grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(40px, 1fr));
  gap: 4px;
}
.apps-icon-picker__item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px;
  border: 2px solid transparent;
  border-radius: 8px;
  background: none;
  cursor: pointer;
  transition: border-color 0.1s, background 0.1s;
}
.apps-icon-picker__item:hover {
  background: var(--color-bg-hover, #f1f5f9);
  border-color: var(--color-border, #e2e8f0);
}
.apps-icon-picker__item--active {
  border-color: var(--color-primary, #3b82f6) !important;
  background: rgba(59,130,246,0.06);
}
.apps-icon-picker__icon-wrap {
  width: 32px;
  height: 32px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.apps-icon-picker__icon-wrap svg {
  width: 18px;
  height: 18px;
}
