/* ═══════════════════════════════════════════════════════════════════
   SAHA EVENTS — Premium Redesign System v1.0
   Load order: base.css → theme.css → ui-system.css → runtime-overrides.css
               → premium-redesign.css  (LAST — wins all conflicts)

   Sections:
   §P1  · Token overrides & corrections
   §P2  · Floating pill bottom navigation
   §P3  · Segmented pill filter tabs
   §P4  · Card system upgrades
   §P5  · Typography utilities
   §P6  · Search bar visibility & styling
   §P7  · Dashboard enhancements
   §P8  · Touch targets & micro-interactions
   §P9  · Bottom sheet & modal upgrades
   §P10 · More menu — native list style
   §P11 · Animations & motion
   §P12 · Page transition polish
   §P13 · Hero & gradient enhancements
   §P14 · Desktop hover & elevation
   §P15 · KPI strip (horizontal scroll)
   §P16 · Premium global polish
   §P17 · Responsive refinements
═══════════════════════════════════════════════════════════════════ */

/* ═══════════════════════════════════════════════════════════════════
   §P1 · TOKEN OVERRIDES — unified brand-correct values
═══════════════════════════════════════════════════════════════════ */
:root {
  /* Single brand color — pure blue, no indigo */
  --pr-primary:        #1A56DB;
  --pr-primary-dark:   #1347C0;
  --pr-primary-light:  #EBF3FF;
  --pr-primary-mid:    rgba(26,86,219,0.12);
  --pr-primary-glow:   rgba(26,86,219,0.20);

  /* Consistent shadow elevations */
  --pr-shadow-card:    0 1px 3px rgba(12,31,61,0.07), 0 2px 8px rgba(12,31,61,0.05);
  --pr-shadow-lift:    0 4px 16px rgba(12,31,61,0.10), 0 2px 6px rgba(12,31,61,0.06);
  --pr-shadow-sheet:   0 -4px 24px rgba(12,31,61,0.12), 0 -1px 6px rgba(12,31,61,0.06);
  --pr-shadow-fab:     0 3px 12px rgba(26,86,219,0.30), 0 1px 4px rgba(26,86,219,0.18);
  --pr-shadow-nav:     0 -1px 0 rgba(0,0,0,0.06), 0 -4px 16px rgba(12,31,61,0.08);

  /* Floating nav dimensions */
  --pr-fnav-height:    62px;
  --pr-fnav-margin:    10px;
  --pr-fnav-radius:    22px;

  /* Motion */
  --pr-ease-spring:    cubic-bezier(0.34, 1.56, 0.64, 1);
  --pr-ease-out:       cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --pr-ease-in-out:    cubic-bezier(0.4, 0, 0.2, 1);
  --pr-dur-fast:       120ms;
  --pr-dur-normal:     220ms;
  --pr-dur-slow:       360ms;
}

/* ═══════════════════════════════════════════════════════════════════
   §P2 · FLOATING PILL BOTTOM NAVIGATION
   Replaces the flat full-width bar with a floating rounded surface.
═══════════════════════════════════════════════════════════════════ */
@media (max-width: 1023px) {
  /* The floating nav container */
  #bottom-nav {
    position: fixed !important;
    bottom: calc(var(--pr-fnav-margin) + var(--safe-bottom)) !important;
    left: 12px !important;
    right: 12px !important;
    width: auto !important;
    height: var(--pr-fnav-height) !important;
    border-radius: var(--pr-fnav-radius) !important;
    background: #FFFFFF !important;
    border: none !important;
    border-top: none !important;
    box-shadow: var(--pr-shadow-nav) !important;
    /* Subtle frosted feel */
    backdrop-filter: saturate(160%) blur(12px) !important;
    -webkit-backdrop-filter: saturate(160%) blur(12px) !important;
    background: rgba(255,255,255,0.96) !important;
    padding: 0 4px !important;
    overflow: hidden !important;
    z-index: 400 !important;
  }

  /* Android: solid white, no blur */
  .plt-android #bottom-nav {
    background: #FFFFFF !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  /* Compensate page bottom padding for floating nav */
  .screen {
    padding-bottom: calc(var(--pr-fnav-height) + var(--pr-fnav-margin) + var(--safe-bottom) + 20px) !important;
  }
  body.mobile-secondary-page .screen {
    padding-bottom: calc(var(--safe-bottom) + 40px) !important;
  }
  body.wizard-open .screen {
    padding-bottom: calc(var(--safe-bottom) + 16px) !important;
  }

  /* Nav items within floating pill */
  .bnav-item {
    border-radius: calc(var(--pr-fnav-radius) - 4px) !important;
  }

  /* Pill indicator — now matches primary blue */
  .bnav-item.active .bnav-icon-wrap {
    background: rgba(26,86,219,0.12) !important;
    transition: background var(--pr-dur-fast) var(--pr-ease-in-out) !important;
  }

  /* Active icon bounce animation */
  .bnav-item.active .bnav-icon {
    color: var(--pr-primary) !important;
    animation: bnavIconBounce 0.35s var(--pr-ease-spring) both;
  }

  @keyframes bnavIconBounce {
    0%   { transform: scale(1); }
    35%  { transform: scale(1.22) translateY(-2px); }
    65%  { transform: scale(0.95); }
    100% { transform: scale(1); }
  }

  /* Tap press feedback */
  .bnav-item:active .bnav-icon-wrap {
    background: rgba(26,86,219,0.18) !important;
    transform: scale(0.90) !important;
    transition: transform 60ms ease, background 60ms ease !important;
  }

  /* Nav items fill height for full touch area */
  #bottom-nav-items {
    height: 100% !important;
    align-items: center !important;
    padding: 0 !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   §P3 · SEGMENTED PILL FILTER TABS
   Modern sliding-indicator tabs to replace KPI card filter rows.
═══════════════════════════════════════════════════════════════════ */

/* Tab strip container */
.seg-tabs {
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  padding: 0 var(--page-pad, 10px) 2px;
  margin-bottom: 10px;
}
.seg-tabs::-webkit-scrollbar { display: none; }

/* Track (the pill container) */
.seg-tab-track {
  display: inline-flex;
  gap: 2px;
  background: rgba(0,0,0,0.055);
  border-radius: 12px;
  padding: 3px;
  position: relative;
  min-width: max-content;
  width: 100%;
  box-sizing: border-box;
}

/* Individual tab */
.seg-tab {
  flex: 1;
  padding: 7px 14px;
  border-radius: 9px;
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text-muted);
  background: transparent;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--pr-dur-fast) var(--pr-ease-in-out);
  position: relative;
  z-index: 1;
  font-family: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  -webkit-tap-highlight-color: transparent;
  min-height: 36px;
}
.seg-tab.active {
  color: var(--text-primary);
  font-weight: 700;
}
.seg-tab:active { opacity: 0.75; }

/* Count badge inside tab */
.seg-tab-count {
  font-size: 10px;
  font-weight: 800;
  background: var(--pr-primary-mid);
  color: var(--pr-primary);
  border-radius: 10px;
  padding: 1px 5px;
  line-height: 1.4;
}
.seg-tab.active .seg-tab-count {
  background: rgba(26,86,219,0.15);
  color: var(--pr-primary);
}

/* Sliding white pill indicator */
.seg-indicator {
  position: absolute;
  top: 3px;
  bottom: 3px;
  background: #FFFFFF;
  border-radius: 9px;
  box-shadow: 0 1px 4px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.06);
  transition: transform var(--pr-dur-normal) var(--pr-ease-in-out),
              width var(--pr-dur-normal) var(--pr-ease-in-out);
  z-index: 0;
  pointer-events: none;
}

/* Quotation status filter tabs — override KPI card grid */
#quot-kpi-strip {
  display: block !important;
  padding: 0 !important;
  gap: 0 !important;
  margin-bottom: 10px;
}

/* Quotation & events filter chip row */
.ev-filter-chip,
.filter-chip,
.lead-filter-chip {
  padding: 6px 14px !important;
  border-radius: 20px !important;
  font-size: 12px !important;
  font-weight: 500 !important;
  min-height: 34px !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 5px !important;
  transition: background var(--pr-dur-fast), color var(--pr-dur-fast),
              transform 80ms ease !important;
}
.ev-filter-chip.active,
.filter-chip.active,
.lead-filter-chip.active {
  background: var(--pr-primary) !important;
  color: #FFFFFF !important;
  font-weight: 700 !important;
  box-shadow: 0 2px 8px rgba(26,86,219,0.28) !important;
}
.ev-filter-chip:active,
.filter-chip:active,
.lead-filter-chip:active {
  transform: scale(0.94) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P4 · CARD SYSTEM UPGRADES
   Differentiated card styles per content domain.
═══════════════════════════════════════════════════════════════════ */

/* ── Quotation card: accent bar always renders ── */
.quot-card-accent {
  width: 4px !important;
  min-width: 4px !important;
  flex-shrink: 0 !important;
  align-self: stretch !important;
  border-radius: 4px 0 0 4px !important;
}
.quot-mobile-card {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  margin-bottom: 10px !important;
  transition: box-shadow var(--pr-dur-normal) var(--pr-ease-out),
              transform var(--pr-dur-fast) var(--pr-ease-out) !important;
}
.quot-mobile-card:active {
  transform: scale(0.98) !important;
  box-shadow: 0 1px 3px rgba(12,31,61,0.06) !important;
}

/* ── Event card: date-first layout ── */
.event-card,
.ev-card-premium {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  margin-bottom: 10px !important;
  background: #FFFFFF !important;
  transition: box-shadow var(--pr-dur-normal) var(--pr-ease-out),
              transform var(--pr-dur-fast) !important;
}
.event-card:active { transform: scale(0.98) !important; }

/* ── Client card: clean list-row feel ── */
.client-card {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  margin-bottom: 8px !important;
  background: #FFFFFF !important;
  transition: box-shadow var(--pr-dur-normal) var(--pr-ease-out),
              transform var(--pr-dur-fast) !important;
}
.client-card:active { transform: scale(0.98) !important; }

/* ── Lead card ── */
.lead-card-v2 {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  margin-bottom: 8px !important;
  background: #FFFFFF !important;
}
.lead-card-v2:active { transform: scale(0.98) !important; }

/* ── Vendor card ── */
.vendor-card {
  border-radius: var(--r-md) !important;
  overflow: hidden !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  margin-bottom: 8px !important;
  background: #FFFFFF !important;
}

/* ── KPI / Stat cards ── */
.stat-card,
.layout-kpi-block,
.crm-kpi-card {
  border-radius: var(--r-md) !important;
  border: 1px solid rgba(12,31,61,0.06) !important;
  box-shadow: 0 1px 4px rgba(12,31,61,0.07), 0 2px 10px rgba(12,31,61,0.04) !important;
  background: #FFFFFF !important;
  transition: box-shadow var(--pr-dur-normal), transform var(--pr-dur-fast) !important;
}
.stat-card.kpi-card-clickable:active,
.layout-kpi-block.kpi-card-clickable:active {
  transform: scale(0.97) !important;
  box-shadow: 0 1px 2px rgba(12,31,61,0.05) !important;
}

/* ── crm-panel / table-card ── */
.crm-panel,
.dash-panel,
.table-card {
  border-radius: var(--r-md) !important;
  border: 1px solid rgba(12,31,61,0.07) !important;
  box-shadow: var(--pr-shadow-card) !important;
  background: #FFFFFF !important;
}

/* Card inner bottom action bar — subtle, not stark */
.quot-card-actions,
.ev-card-actions,
.lead-card__actions,
.cc-card-actions {
  background: rgba(12,31,61,0.025) !important;
  border-top: 1px solid rgba(12,31,61,0.06) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P5 · TYPOGRAPHY UTILITIES
   Semantic classes for all text roles in the app.
═══════════════════════════════════════════════════════════════════ */

/* Primary display — hero titles, page headings */
.t-display { font-size: 26px; font-weight: 800; letter-spacing: -0.5px; line-height: 1.1; color: var(--text-primary); }
.t-headline { font-size: 20px; font-weight: 700; letter-spacing: -0.3px; line-height: 1.2; color: var(--text-primary); }
.t-title    { font-size: 16px; font-weight: 700; letter-spacing: -0.1px; line-height: 1.3; color: var(--text-primary); }
.t-subtitle { font-size: 14px; font-weight: 600; color: var(--text-primary); line-height: 1.4; }
.t-body     { font-size: 14px; font-weight: 400; color: var(--text-primary); line-height: 1.5; }
.t-label    { font-size: 12px; font-weight: 500; color: var(--text-secondary); }
.t-caption  { font-size: 11px; font-weight: 400; color: var(--text-muted); line-height: 1.4; }
.t-micro    { font-size: 10px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.07em; color: var(--text-muted); }

/* Amount formatting */
.t-amount    { font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -0.02em; color: var(--text-primary); }
.t-amount-lg { font-size: 22px; font-weight: 800; font-variant-numeric: tabular-nums; letter-spacing: -0.04em; }
.t-amount-sm { font-size: 12px; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--text-primary); }

/* Text utilities */
.t-truncate    { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.t-clamp-2     { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.t-primary     { color: var(--pr-primary) !important; }
.t-success     { color: var(--success) !important; }
.t-warning     { color: var(--warning) !important; }
.t-error       { color: var(--error) !important; }
.t-muted       { color: var(--text-muted) !important; }

/* KPI value boost — bigger, bolder */
.crm-kpi-value,
.layout-kpi-block__value {
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -0.04em !important;
  line-height: 1.1 !important;
}

/* KPI label — readable minimum */
.crm-kpi-head > span,
.layout-kpi-block__label {
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0.04em !important;
}

/* KPI sub — slightly larger */
.crm-kpi-sub {
  font-size: 11px !important;
  line-height: 1.4 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P6 · SEARCH BAR VISIBILITY & STYLING
   Search bars are now always visible (runtime-overrides bug fixed).
   Enhance their appearance.
═══════════════════════════════════════════════════════════════════ */

/* Page search row — visible, proper spacing */
.page-search-row {
  display: flex !important;
  align-items: center;
  gap: 8px;
  padding: 6px 0 10px;
}

.page-search-bar,
.search-row-tight {
  display: flex !important;
  align-items: center;
  gap: 8px;
  padding: 4px 0 10px;
}

/* Unified search input wrap */
.search-wrap,
.search-bar-wrap,
.search-input-wrap {
  background: rgba(0,0,0,0.05) !important;
  border: 1.5px solid transparent !important;
  border-radius: 14px !important;
  transition: background var(--pr-dur-fast), border-color var(--pr-dur-fast),
              box-shadow var(--pr-dur-fast) !important;
  min-height: 42px !important;
}
.search-wrap:focus-within,
.search-bar-wrap:focus-within,
.search-input-wrap:focus-within {
  background: #FFFFFF !important;
  border-color: var(--pr-primary) !important;
  box-shadow: 0 0 0 3px rgba(26,86,219,0.12) !important;
}

/* Search input text */
.search-input {
  font-size: 14px !important;
  color: var(--text-primary) !important;
}
.search-input::placeholder {
  color: var(--text-muted) !important;
  font-weight: 400 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P7 · DASHBOARD ENHANCEMENTS
   Better hero gradient, improved metric spacing.
═══════════════════════════════════════════════════════════════════ */

/* Hero gradient — deep premium blue */
.crm-hero-native {
  background: linear-gradient(135deg,
    #0F2B6B 0%,
    #1A56DB 45%,
    #2563EB 70%,
    #1E7FC5 100%
  ) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: 0 6px 28px rgba(26,86,219,0.28), 0 2px 8px rgba(12,31,61,0.12) !important;
  position: relative;
  overflow: hidden !important;
}

/* Subtle mesh overlay on hero */
.crm-hero-native::after {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 80% at 100% 0%, rgba(255,255,255,0.06) 0%, transparent 60%),
    radial-gradient(ellipse 40% 60% at 0% 100%, rgba(96,165,250,0.12) 0%, transparent 50%);
  pointer-events: none;
  z-index: 0;
}
.crm-hero-content { position: relative; z-index: 1; }

/* Hero avatar — more polished */
.crm-hero-avatar {
  background: rgba(255,255,255,0.18) !important;
  border: 1.5px solid rgba(255,255,255,0.28) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
}

/* Hero primary action button */
.crm-hero-btn-primary {
  background: #FFFFFF !important;
  color: var(--pr-primary) !important;
  box-shadow: 0 2px 8px rgba(0,0,0,0.15) !important;
  font-weight: 700 !important;
}
.crm-hero-btn-primary:active {
  background: rgba(255,255,255,0.92) !important;
  transform: scale(0.96) !important;
  transition: transform 60ms ease !important;
}

/* Hero secondary action button */
.crm-hero-btn-secondary {
  background: rgba(255,255,255,0.14) !important;
  border: 1px solid rgba(255,255,255,0.22) !important;
  color: rgba(255,255,255,0.95) !important;
}
.crm-hero-btn-secondary:active {
  background: rgba(255,255,255,0.25) !important;
  transform: scale(0.96) !important;
}

/* Dashboard today's events card — premium amber */
.dash-today-card {
  border-radius: var(--r-lg) !important;
  box-shadow: 0 2px 10px rgba(245,158,11,0.14), 0 1px 4px rgba(12,31,61,0.06) !important;
  overflow: hidden !important;
}

/* Dashboard two-col recent quotes/events */
.dash-two-col .crm-panel {
  border-radius: var(--r-md) !important;
}

/* Recent quote rows */
.dash-rq-row {
  min-height: 54px !important;
  padding: 10px 16px !important;
  gap: 12px !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P8 · TOUCH TARGETS & MICRO-INTERACTIONS
   Every interactive element ≥ 44px touch target.
═══════════════════════════════════════════════════════════════════ */

/* Button minimum heights */
.btn-gold,
.btn-primary,
.btn-secondary,
.btn-ghost,
.btn-danger {
  min-height: 44px !important;
  transition: transform var(--pr-dur-fast) var(--pr-ease-out),
              box-shadow var(--pr-dur-normal) var(--pr-ease-out),
              background var(--pr-dur-fast) !important;
}
.btn-sm {
  min-height: 36px !important;
  padding: 0 12px !important;
}

/* Button press scale — premium tactile feel */
.btn-gold:active,
.btn-primary:active {
  transform: scale(0.96) !important;
  box-shadow: 0 1px 3px rgba(12,31,61,0.15) !important;
  transition-duration: 60ms !important;
}
.btn-danger:active {
  transform: scale(0.96) !important;
  transition-duration: 60ms !important;
}

/* Icon buttons — 40px min */
.nav-icon-btn,
.fs-back-btn {
  min-width: 40px !important;
  min-height: 40px !important;
  transition: background var(--pr-dur-fast), transform var(--pr-dur-fast) !important;
}
.nav-icon-btn:active,
.fs-back-btn:active {
  transform: scale(0.88) !important;
  transition-duration: 60ms !important;
}

/* Chips min-height */
.cc-chip,
.quot-chip,
.ev-urgency-chip,
.filter-chip {
  min-height: 26px !important;
  line-height: 1.3 !important;
}

/* Card action buttons min-height */
.cc-card-action-btn {
  min-height: 34px !important;
}

/* Settings rows */
.sn-row {
  min-height: 54px !important;
  transition: background var(--pr-dur-fast) !important;
}
.sn-row:active { background: rgba(26,86,219,0.05) !important; }

/* Sidebar items */
.sidebar-item {
  min-height: 44px !important;
  transition: background var(--pr-dur-fast), color var(--pr-dur-fast) !important;
}
.sidebar-item:active {
  background: rgba(26,86,219,0.08) !important;
  transition-duration: 60ms !important;
}

/* ── Haptic press effect on all card rows ── */
.list-row:active,
.dash-today-card__item:active {
  background: rgba(12,31,61,0.04) !important;
  transition-duration: 60ms !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P9 · BOTTOM SHEET & MODAL UPGRADES
   Premium spring entrance, drag handle, backdrop.
═══════════════════════════════════════════════════════════════════ */

/* Bottom sheet — premium spring entrance */
#bottom-sheet,
#pf-sheet,
#more-menu-sheet {
  border-radius: 24px 24px 0 0 !important;
  background: #FFFFFF !important;
  box-shadow: var(--pr-shadow-sheet) !important;
}

/* Drag handle — larger, more prominent */
.bs-handle,
.more-menu-handle {
  width: 40px !important;
  height: 4px !important;
  background: rgba(12,31,61,0.18) !important;
  border-radius: 4px !important;
  margin: 12px auto 8px !important;
  display: block !important;
  flex-shrink: 0 !important;
}

/* More menu header — never shrinks */
#more-menu-header {
  flex-shrink: 0 !important;
}

/* iOS: rounded corners are larger */
.plt-ios #bottom-sheet,
.plt-ios #pf-sheet,
.plt-ios #more-menu-sheet {
  border-radius: 28px 28px 0 0 !important;
}

/* Modal overlay — darker, more premium */
.modal-overlay.open {
  background: rgba(8,15,30,0.42) !important;
  backdrop-filter: blur(2px) !important;
  -webkit-backdrop-filter: blur(2px) !important;
}
.plt-android .modal-overlay.open {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  background: rgba(8,15,30,0.52) !important;
}

/* Form sheet header */
#pf-header {
  border-bottom: 1px solid rgba(12,31,61,0.07) !important;
  padding: 14px 16px !important;
}
#pf-title-el {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}

/* Close button */
#pf-close {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: rgba(12,31,61,0.06) !important;
  color: var(--text-muted) !important;
  border: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: background var(--pr-dur-fast) !important;
}
#pf-close:active {
  background: rgba(12,31,61,0.12) !important;
  transform: scale(0.92) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P10 · MORE MENU — PREMIUM GRID LAYOUT
   Clean 3-column grid. Icon + label. Native mobile app feel.
═══════════════════════════════════════════════════════════════════ */

/* Sheet: flex column with max-height so the grid can scroll */
#more-menu-sheet {
  display: flex !important;
  flex-direction: column !important;
  max-height: 88vh !important;
  max-height: 88dvh !important;
  background: #f2f2f7 !important;  /* light gray tray — contrasts with white cards */
}

/* Pin every child except the grid */
#more-menu-sheet > *:not(#more-menu-grid) {
  flex-shrink: 0 !important;
}

/* Pin handle + header */
.more-menu-handle {
  flex-shrink: 0 !important;
}
#more-menu-header {
  flex-shrink: 0 !important;
}

/* ── 4-column scrollable grid ──────────────────────────────────── */
#more-menu-grid,
#more-menu-grid.more-menu-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 8px !important;
  padding: 10px !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  flex: 1 1 auto !important;
  -webkit-overflow-scrolling: touch !important;
  min-height: 0 !important;
}

/* ── Each grid cell ───────────────────────────────────────────── */
#more-menu-grid .more-menu-item {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 7px !important;
  padding: 12px 6px 10px !important;
  border-radius: 14px !important;
  background: #ffffff !important;  /* white cards on gray tray */
  border: none !important;
  box-shadow: 0 1px 3px rgba(0,0,0,0.08), 0 0 0 0.5px rgba(0,0,0,0.04) !important;
  min-height: 0 !important;
  width: 100% !important;
  text-align: center !important;
  cursor: pointer !important;
  font-family: inherit !important;
  -webkit-tap-highlight-color: transparent !important;
  transition: transform 80ms ease, box-shadow 60ms !important;
  position: static !important;
}
#more-menu-grid .more-menu-item:not(:last-child)::after {
  display: none !important;
}
#more-menu-grid .more-menu-item:active {
  transform: scale(0.90) !important;
  background: rgba(26,86,219,0.05) !important;
  transition-duration: 40ms !important;
}

/* ── Colored icon box ─────────────────────────────────────────── */
#more-menu-grid .more-menu-icon {
  width: 40px !important;
  height: 40px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  font-size: 18px !important;
}

/* ── Label beneath icon ───────────────────────────────────────── */
#more-menu-grid .more-menu-label {
  font-size: 10.5px !important;
  font-weight: 600 !important;
  color: var(--text-primary) !important;
  line-height: 1.25 !important;
  text-align: center !important;
  word-break: break-word !important;
  letter-spacing: 0 !important;
  flex: unset !important;
  white-space: normal !important;
}

/* ── Hide leftover chevron (safety net) ───────────────────────── */
#more-menu-grid .more-menu-item .more-menu-arrow {
  display: none !important;
}

/* ── Logout row ───────────────────────────────────────────────── */
.more-menu-logout-btn {
  border-radius: 12px !important;
  min-height: 46px !important;
  font-size: 13.5px !important;
  font-weight: 600 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P11 · ANIMATIONS & MOTION SYSTEM
   Premium, performant, reduced-motion aware.
═══════════════════════════════════════════════════════════════════ */

/* List item stagger entrance — only first 6 items */
.stagger-item {
  animation: staggerFadeUp var(--pr-dur-normal) var(--pr-ease-out) both;
}
.stagger-item:nth-child(1) { animation-delay: 0ms; }
.stagger-item:nth-child(2) { animation-delay: 40ms; }
.stagger-item:nth-child(3) { animation-delay: 70ms; }
.stagger-item:nth-child(4) { animation-delay: 95ms; }
.stagger-item:nth-child(5) { animation-delay: 115ms; }
.stagger-item:nth-child(6) { animation-delay: 130ms; }
.stagger-item:nth-child(n+7) { animation: none !important; opacity: 1 !important; }

@keyframes staggerFadeUp {
  from { opacity: 0; transform: translateY(10px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Skeleton loading — premium shimmer */
.skel,
.skeleton,
[class*="skeleton"] {
  background: linear-gradient(90deg,
    rgba(12,31,61,0.06) 0%,
    rgba(12,31,61,0.03) 40%,
    rgba(12,31,61,0.06) 80%
  ) !important;
  background-size: 200% 100% !important;
  animation: premiumShimmer 1.6s ease-in-out infinite !important;
  border-radius: 8px !important;
}
@keyframes premiumShimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Page fade-in */
.fade-in {
  animation: pageFadeIn 0.22s var(--pr-ease-out) both;
}
@keyframes pageFadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Pulse animation for live indicators */
@keyframes livePulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.5; transform: scale(0.78); }
}
.dash-live-dot,
.ev-live-dot {
  animation: livePulse 1.4s ease-in-out infinite !important;
}

/* Spring scale for interactive elements */
@keyframes springPop {
  0%   { transform: scale(0.92); opacity: 0.8; }
  60%  { transform: scale(1.04); opacity: 1; }
  100% { transform: scale(1);    opacity: 1; }
}

/* Toast entrance */
.toast-item,
[class*="toast"] {
  border-radius: 12px !important;
  box-shadow: 0 4px 20px rgba(12,31,61,0.18), 0 1px 6px rgba(12,31,61,0.10) !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  padding: 12px 16px !important;
}

/* Respect reduced motion */
@media (prefers-reduced-motion: reduce) {
  .stagger-item,
  .fade-in,
  .skel, .skeleton {
    animation: none !important;
    opacity: 1 !important;
    transform: none !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   §P12 · PAGE TRANSITION POLISH
   Existing entering-*/leaving-* transitions get GPU hints.
═══════════════════════════════════════════════════════════════════ */

.entering-right,
.entering-left,
.entering-fade,
.leaving-left,
.leaving-right,
.leaving-fade {
  will-change: transform, opacity !important;
  -webkit-backface-visibility: hidden !important;
  backface-visibility: hidden !important;
}

/* iOS nav-shadow effect on forward transitions */
.plt-ios .entering-right {
  box-shadow: -6px 0 24px rgba(0,0,0,0.10) !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P13 · HERO & GRADIENT ENHANCEMENTS
   Expense hero, settings hero, vendor hero.
═══════════════════════════════════════════════════════════════════ */

/* Expense hero card */
.exp-hero-card {
  background: linear-gradient(135deg,
    #0F6B35 0%,
    #0D7A45 50%,
    #0EA861 100%
  ) !important;
  border-radius: var(--r-lg) !important;
  box-shadow: 0 6px 24px rgba(13,122,69,0.25), 0 2px 6px rgba(12,31,61,0.08) !important;
}

/* Reports hero / analytics header */
.rpt-hero,
.reports-hero {
  background: linear-gradient(135deg, #1E3A8A 0%, #1A56DB 60%, #2563EB 100%);
  border-radius: var(--r-lg);
  padding: 20px;
  color: #FFFFFF;
  box-shadow: 0 6px 24px rgba(26,86,219,0.25);
  margin-bottom: 14px;
}

/* App loading screen */
.app-loading-bar {
  background: linear-gradient(90deg, var(--pr-primary), #60A5FA) !important;
  border-radius: 2px !important;
}

/* ═══════════════════════════════════════════════════════════════════
   §P14 · DESKTOP HOVER & ELEVATION
   Card lift on desktop, richer hover states.
═══════════════════════════════════════════════════════════════════ */
@media (hover: hover) {
  .event-card:hover,
  .client-card:hover,
  .quot-mobile-card:hover,
  .lead-card-v2:hover,
  .vendor-card:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--pr-shadow-lift) !important;
    border-color: rgba(26,86,219,0.18) !important;
    transition: transform var(--pr-dur-normal) var(--pr-ease-out),
                box-shadow var(--pr-dur-normal) var(--pr-ease-out),
                border-color var(--pr-dur-normal) !important;
  }

  .stat-card.kpi-card-clickable:hover,
  .layout-kpi-block.kpi-card-clickable:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--pr-shadow-lift) !important;
    border-color: rgba(26,86,219,0.20) !important;
  }

  .dash-rq-row:hover {
    background: rgba(26,86,219,0.04) !important;
  }

  .dash-today-card__item:hover {
    background: rgba(245,158,11,0.05) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   §P15 · KPI METRIC STRIP — horizontal scroll (dashboard)
   Used when dashboard wants compact scrollable metrics.
═══════════════════════════════════════════════════════════════════ */

.dash-metric-strip {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 4px 2px 6px;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 10px;
}
.dash-metric-strip::-webkit-scrollbar { display: none; }

.dash-metric-chip {
  flex-shrink: 0;
  scroll-snap-align: start;
  padding: 10px 16px;
  background: #FFFFFF;
  border-radius: 14px;
  border: 1px solid rgba(12,31,61,0.07);
  box-shadow: 0 1px 3px rgba(12,31,61,0.06);
  min-width: 90px;
  text-align: center;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
  transition: transform var(--pr-dur-fast), box-shadow var(--pr-dur-normal);
}
.dash-metric-chip:active {
  transform: scale(0.95);
  box-shadow: none;
}
.dash-metric-chip__value {
  font-size: 20px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
}
.dash-metric-chip__label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--text-muted);
  margin-top: 3px;
}

/* ═══════════════════════════════════════════════════════════════════
   §P16 · PREMIUM GLOBAL POLISH
   Final-pass improvements across all components.
═══════════════════════════════════════════════════════════════════ */

/* Top navigation — cleaner, no box shadow until scrolled */
.top-nav {
  transition: box-shadow var(--pr-dur-normal) !important;
}
.top-nav.scrolled {
  box-shadow: 0 1px 0 rgba(0,0,0,0.08), 0 2px 12px rgba(12,31,61,0.06) !important;
}

/* Form inputs — better focus ring */
.form-input:focus,
input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="file"]):not(.login-input):focus,
select:not(.login-input):focus,
textarea:not(.login-input):focus {
  border-color: var(--pr-primary) !important;
  box-shadow: 0 0 0 3px rgba(26,86,219,0.14) !important;
  outline: none !important;
}

/* Status badges — consistent style */
.cc-badge {
  border-radius: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 3px 9px !important;
}

/* Empty states — clean */
.empty-state {
  padding: 40px 20px !important;
}
.empty-state-title {
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
}
.empty-state-sub {
  font-size: 13px !important;
  color: var(--text-muted) !important;
  line-height: 1.5 !important;
  margin-top: 4px !important;
}

/* Table header — stronger hierarchy */
.table-card thead th {
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  background: rgba(12,31,61,0.03) !important;
  border-bottom: 2px solid rgba(12,31,61,0.10) !important;
  color: var(--text-muted) !important;
}
.table-card tbody td {
  font-size: 13.5px !important;
  padding: 12px 16px !important;
  border-bottom: 1px solid rgba(12,31,61,0.05) !important;
}
.table-card tbody tr:hover td {
  background: rgba(26,86,219,0.03) !important;
}

/* Notification badge — tighter */
.nav-notif-badge {
  background: var(--error) !important;
  border: 2px solid #FFFFFF !important;
  border-radius: 10px !important;
  min-width: 16px !important;
  height: 16px !important;
  font-size: 9px !important;
  font-weight: 800 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Avatar consistency */
.avatar,
.cc-avatar {
  font-weight: 800 !important;
}

/* Scrollbar — always hidden everywhere */
* { scrollbar-width: none !important; -ms-overflow-style: none !important; }
*::-webkit-scrollbar { display: none !important; }

/* ── Status badge color overrides — blue-corrected ── */
.wiz-step-pill--active {
  background: var(--pr-primary-light) !important;
  border-color: rgba(26,86,219,0.25) !important;
}
.wiz-step-pill--active .wiz-step-pill__dot {
  background: var(--pr-primary) !important;
}
.wiz-step-pill--active .wiz-step-pill__label {
  color: var(--pr-primary) !important;
}

/* ── Focus visible — accessibility ── */
:focus-visible {
  outline: 2px solid var(--pr-primary) !important;
  outline-offset: 2px !important;
  border-radius: 4px !important;
}

/* ── Print ── */
@media print {
  #bottom-nav, .top-nav, #more-menu-sheet { display: none !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   §P17 · RESPONSIVE REFINEMENTS
═══════════════════════════════════════════════════════════════════ */

/* Mobile (≤480px) — tighter spacing */
@media (max-width: 480px) {
  .crm-kpi-grid,
  .layout-kpi-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
  }
  .crm-hero-content { padding: 12px 14px !important; }
  .crm-hero-title { font-size: 14px !important; }
  .dash-two-col { gap: 8px !important; }
  .seg-tab { padding: 7px 10px !important; font-size: 12px !important; }
}

/* Tablet (481–1023px) — intermediate layout */
@media (min-width: 481px) and (max-width: 1023px) {
  .crm-kpi-grid,
  .layout-kpi-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
  #dash-kpi-grid .crm-kpi-grid {
    grid-template-columns: repeat(3, 1fr) !important;
  }
}

/* Desktop (≥1024px) — full sidebar layout */
@media (min-width: 1024px) {
  #bottom-nav { display: none !important; }
  .crm-kpi-grid,
  .layout-kpi-grid {
    grid-template-columns: repeat(5, 1fr) !important;
  }
  #dash-kpi-grid .crm-kpi-grid {
    grid-template-columns: repeat(5, 1fr) !important;
  }
  .screen { padding-bottom: 40px !important; }
}

/* Landscape phone — reduce bottom nav height impact */
@media (max-height: 500px) and (orientation: landscape) {
  #bottom-nav { display: none !important; }
  .screen { padding-bottom: 20px !important; }
}

/* ═══════════════════════════════════════════════════════════════════
   §P18 · EVENT CARD v2 — date-block layout
═══════════════════════════════════════════════════════════════════ */

.ev-card-v2 {
  background: var(--surface) !important;
  border-radius: var(--r-md) !important;
  box-shadow: var(--pr-shadow-card) !important;
  border: 1px solid rgba(0,0,0,0.06) !important;
  margin-bottom: 8px !important;
  overflow: hidden !important;
  transition: box-shadow var(--dur-fast), transform var(--dur-fast) !important;
}
.ev-card-v2:active {
  transform: scale(0.985) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.10) !important;
}

/* — Main row: date block + content ─────────────── */
.ev-card-v2__main {
  display: flex !important;
  align-items: stretch !important;
  gap: 0 !important;
  padding: 12px 13px 10px !important;
}

/* — Date block ─────────────────────────────────── */
.ev-date-block {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  width: 48px !important;
  min-height: 52px !important;
  border-radius: 12px !important;
  margin-right: 12px !important;
  padding: 6px 4px !important;
}
.ev-date-block--upcoming {
  background: linear-gradient(145deg, #1A56DB 0%, #2563EB 100%) !important;
  color: #fff !important;
}
.ev-date-block--today {
  background: linear-gradient(145deg, #F59E0B 0%, #D97706 100%) !important;
  color: #fff !important;
  box-shadow: 0 2px 8px rgba(245,158,11,0.35) !important;
}
.ev-date-block--past {
  background: rgba(0,0,0,0.05) !important;
  color: var(--text-muted) !important;
}
.ev-date-block__day {
  display: block !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  letter-spacing: -0.5px !important;
}
.ev-date-block__mon {
  display: block !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.5px !important;
  opacity: 0.85 !important;
  margin-top: 2px !important;
}

/* — Content area ───────────────────────────────── */
.ev-card-v2__content {
  flex: 1 !important;
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}
.ev-card-v2__top {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 6px !important;
}
.ev-card-v2__title {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  line-height: 1.3 !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.ev-card-v2__badge {
  flex-shrink: 0 !important;
  font-size: 9.5px !important;
  font-weight: 600 !important;
  padding: 2px 7px !important;
  border-radius: 20px !important;
  white-space: nowrap !important;
}
.ev-card-v2__client {
  font-size: 12px !important;
  color: var(--text-secondary) !important;
  font-weight: 500 !important;
}
.ev-card-v2__meta {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
  margin-top: 2px !important;
  flex-wrap: wrap !important;
}
.ev-meta-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  background: rgba(0,0,0,0.04) !important;
  border-radius: 6px !important;
  padding: 2px 7px !important;
}
.ev-meta-pill i { font-size: 9px !important; }
.ev-card-v2__amount {
  margin-left: auto !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--text) !important;
  white-space: nowrap !important;
}

/* — Progress bar ───────────────────────────────── */
.ev-card-v2__progress {
  padding: 0 13px 8px !important;
}
.ev-progress-bar {
  height: 4px !important;
  border-radius: 3px !important;
  background: var(--border-light) !important;
  overflow: hidden !important;
}
.ev-progress-bar__fill {
  height: 100% !important;
  border-radius: 3px !important;
  transition: width 0.5s cubic-bezier(0.4,0,0.2,1) !important;
}
.ev-progress-label {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 4px !important;
}
.ev-progress-label__text {
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--text-muted) !important;
  letter-spacing: 0.3px !important;
}
.ev-progress-label__pct {
  font-size: 10px !important;
  font-weight: 700 !important;
}

/* — Actions row ────────────────────────────────── */
.ev-card-v2__actions {
  display: flex !important;
  gap: 6px !important;
  padding: 6px 10px 8px !important;
  border-top: 1px solid rgba(0,0,0,0.05) !important;
  background: rgba(0,0,0,0.015) !important;
}
.ev-card-v2__actions .btn-sm {
  flex: 1 !important;
  justify-content: center !important;
}

/* — Urgency chips inside date block row ────────── */
.ev-card-v2__urgency {
  display: inline-flex !important;
  align-items: center !important;
  gap: 4px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  padding: 2px 7px !important;
  border-radius: 20px !important;
}
.ev-card-v2__urgency--high {
  background: rgba(239,68,68,0.1) !important;
  color: #DC2626 !important;
}
.ev-card-v2__urgency--today {
  background: rgba(245,158,11,0.12) !important;
  color: #D97706 !important;
}

/* Desktop hover lift for v2 cards */
@media (min-width: 1024px) {
  .ev-card-v2:hover {
    transform: translateY(-2px) !important;
    box-shadow: var(--pr-shadow-lift) !important;
  }
  .ev-card-v2:active {
    transform: translateY(0) scale(0.99) !important;
  }
}

/* ═══════════════════════════════════════════════════════════════════
   §P19 · GALLERY PREMIUM REDESIGN
   Masonry-feel 2-col grid, immersive image cards, polished tabs.
═══════════════════════════════════════════════════════════════════ */

/* ── Gallery page root — no extra top padding ─────────────────── */
.gal-page-root {
  margin-top: 0 !important;
  padding-top: 0 !important;
}

/* Gallery pager page: remove side padding for edge-to-edge grid */
.gal-page-root .gal-pager__page {
  padding: 0 !important;
}

/* Gallery pager/grid wrapper: edge-to-edge */
.gal-page-root .gal-pager {
  margin: 0 calc(-1 * var(--page-pad, 16px)) !important;
  width: calc(100% + 2 * var(--page-pad, 16px)) !important;
}

/* Category headers and chips: restore horizontal padding inside edge-to-edge pager */
.gal-page-root .gal-chips-row,
.gal-page-root .gal-cat-head,
.gal-page-root .gal-cat-section > .gal-cat-head {
  padding-left: var(--page-pad, 16px) !important;
  padding-right: var(--page-pad, 16px) !important;
}

/* ── Service tabs — edge-to-edge, flush under top nav ─────────── */
#gal-tabs-row {
  position: sticky !important;
  top: 0 !important;
  z-index: 30 !important;
  background: rgba(255,255,255,0.96) !important;
  backdrop-filter: saturate(180%) blur(16px) !important;
  -webkit-backdrop-filter: saturate(180%) blur(16px) !important;
  border-bottom: 1px solid rgba(0,0,0,0.08) !important;
  margin: 0 calc(-1 * var(--page-pad, 16px)) !important;
  padding: 0 var(--page-pad, 16px) !important;
}

/* Tab button — more spacious */
.gal-tab-v2 {
  padding: 10px 16px 10px !important;
  font-size: 13px !important;
  font-weight: 600 !important;
  border-radius: 10px !important;
}
.gal-tab-v2.is-active {
  color: var(--primary) !important;
  font-weight: 700 !important;
}
.gal-tab-v2__count {
  font-size: 10.5px !important;
  font-weight: 700 !important;
  padding: 1px 7px !important;
  border-radius: 20px !important;
}
.gal-tab-v2.is-active .gal-tab-v2__count {
  background: rgba(26,86,219,0.12) !important;
  color: var(--primary) !important;
}

/* Tab indicator — clean blue, no purple */
.gal-tabs-v2__indicator {
  background: var(--primary) !important;
  height: 2.5px !important;
  border-radius: 2px !important;
}

/* ── Gallery grid — iPhone Photos style: 3-column, tight ─────── */
.gal-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 2px !important;
}

/* ── Image card — pure photo, no chrome ──────────────────────── */
.gal-thumb-card {
  aspect-ratio: 1 !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  overflow: hidden !important;
  background: #1c1c1e !important;
  transition: opacity 120ms !important;
  position: relative !important;
}
.gal-thumb-card:active {
  opacity: 0.75 !important;
  transform: none !important;
}

/* ── Image area — fills card, uses aspect-ratio from card ────── */
.gal-thumb-media {
  height: 100% !important;
  width: 100% !important;
  padding-bottom: 0 !important;
  position: relative !important;
  background: #2c2c2e !important;
  overflow: hidden !important;
  cursor: pointer !important;
  display: block !important;
}
.gal-thumb-media__img,
.gal-thumb-media__empty,
.gal-thumb-fallback,
.gal-vid-overlay {
  position: absolute !important;
  inset: 0 !important;
  width: 100% !important;
  height: 100% !important;
}
/* Image on top — covers fallback when loaded */
.gal-thumb-media__img {
  object-fit: cover !important;
  display: block !important;
  z-index: 2 !important;
}
/* Fallback behind image — visible only when img fails (onerror hides img) */
.gal-thumb-fallback {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 26px !important;
  background: #2c2c2e !important;
  z-index: 1 !important;
}
/* Empty state (no image at all) — shows category icon + "Add Photo" */
.gal-thumb-media__empty {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 5px !important;
  background: #2c2c2e !important;
  color: rgba(255,255,255,0.4) !important;
  z-index: 1 !important;
}

/* ── Video play overlay ───────────────────────────────────────── */
.gal-vid-overlay {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.gal-vid-overlay__btn {
  width: 32px !important;
  height: 32px !important;
  border-radius: 50% !important;
  background: rgba(0,0,0,0.55) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.gal-vid-overlay__btn i {
  color: #fff !important;
  font-size: 11px !important;
  margin-left: 2px !important;
}

/* ── Name/desc — hidden in photo grid (iPhone-style) ─────────── */
.gal-thumb-meta {
  display: none !important;
}

/* ── Category section header ──────────────────────────────────── */
.gal-cat-section {
  margin-bottom: 20px !important;
}
/* Category top divider row */
.gal-cat-head {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  margin-bottom: 8px !important;
  padding: 14px 0 4px !important;
}
.section-label {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  text-transform: none !important;
  letter-spacing: -0.1px !important;
}
.section-label__sub {
  display: block !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  color: var(--text-muted) !important;
  margin: 2px 0 0 !important;
  letter-spacing: 0 !important;
}

/* ── Add item card — square placeholder in photo grid ────────── */
.gal-add-item-card {
  border: none !important;
  border-radius: 0 !important;
  background: rgba(26,86,219,0.06) !important;
  min-height: 0 !important;
  aspect-ratio: 1 !important;
  gap: 4px !important;
}
.gal-add-item-card:active {
  background: rgba(26,86,219,0.14) !important;
}
.gal-add-item-card__icon {
  font-size: 20px !important;
  color: var(--primary) !important;
  opacity: 0.7 !important;
}
.gal-add-item-card__label {
  font-size: 10px !important;
  font-weight: 600 !important;
  color: var(--primary) !important;
  opacity: 0.8 !important;
}

/* ── Edit/delete overlay buttons ─────────────────────────────── */
.gal-item-edit-btn,
.gal-item-del-btn {
  position: absolute !important;
  z-index: 5 !important;
}
.gal-item-edit-btn {
  top: 4px !important;
  right: 4px !important;
  width: 24px !important;
  height: 24px !important;
  border-radius: 6px !important;
  background: rgba(0,0,0,0.52) !important;
  backdrop-filter: blur(4px) !important;
  border: none !important;
  font-size: 9px !important;
  color: #fff !important;
}
.gal-item-del-btn {
  top: 32px !important;
  right: 4px !important;
  width: 24px !important;
  height: 24px !important;
  border-radius: 6px !important;
  background: rgba(239,68,68,0.82) !important;
  backdrop-filter: blur(4px) !important;
  border: none !important;
  font-size: 9px !important;
  color: #fff !important;
}

/* ── Photo count badge — bottom-right corner ─────────────────── */
.gal-thumb-count {
  position: absolute !important;
  bottom: 4px !important;
  right: 4px !important;
  top: unset !important;
  left: unset !important;
  padding: 1px 5px !important;
  border-radius: 20px !important;
  background: rgba(0,0,0,0.62) !important;
  color: #fff !important;
  font-size: 9.5px !important;
  font-weight: 700 !important;
}

/* ── Video duration badge ─────────────────────────────────────── */
.gal-vid-duration {
  position: absolute !important;
  bottom: 4px !important;
  left: 4px !important;
  font-size: 8.5px !important;
}

/* ── Category action buttons ──────────────────────────────────── */
.gal-cat-mini-btn {
  width: 28px !important;
  height: 28px !important;
  border-radius: 8px !important;
  font-size: 10px !important;
}
.gal-add-item-btn {
  height: 28px !important;
  padding: 0 10px !important;
  border-radius: 8px !important;
  font-size: 11px !important;
}

/* ── Tablet: 4-column grid ────────────────────────────────────── */
@media (min-width: 600px) {
  .gal-grid {
    grid-template-columns: repeat(4, 1fr) !important;
    gap: 3px !important;
  }
}

/* ── Desktop: 5-column grid ───────────────────────────────────── */
@media (min-width: 1024px) {
  .gal-grid {
    grid-template-columns: repeat(5, 1fr) !important;
    gap: 3px !important;
  }
  .gal-thumb-card:hover {
    opacity: 0.85 !important;
  }
  .gal-thumb-card:active {
    opacity: 0.7 !important;
  }
}
