/**
 * AccoZen+ Design Tokens
 * 
 * A centralized design system based on the AccoZen+ brand identity.
 * The golden accent from the logo "+" is carried throughout the UI.
 * 
 * Usage: Import this file first in your CSS, then use var(--token-name)
 */

:root {
  /* ========================================
     BACKGROUND HIERARCHY (Dark Theme)
     ======================================== */
  
  /* Deepest background - page level, sidebar */
  --bg-deep: #0f1419;
  
  /* Elevated surfaces - cards, panels, modals */
  --bg-elevated: #1a1f26;
  
  /* Surface level - inputs, table headers, hover states */
  --bg-surface: #242b33;
  
  /* Raised surface - dropdowns, tooltips */
  --bg-raised: #2d3640;
  
  /* ========================================
     BORDER & DIVIDER COLORS
     ======================================== */
  
  --border-subtle: #2d3640;
  --border-default: #3d4752;
  --border-strong: #4d5762;
  
  /* ========================================
     TEXT COLORS
     ======================================== */
  
  --text-primary: #f1f3f5;
  --text-secondary: #c9d1d9;
  --text-muted: #8b949e;
  --text-disabled: #6e7681;
  
  /* ========================================
     BRAND ACCENT - GOLDEN (from logo "+")
     ======================================== */
  
  --accent-gold: #f5a623;
  --accent-gold-hover: #ffb938;
  --accent-gold-active: #e09000;
  --accent-gold-muted: rgba(245, 166, 35, 0.15);
  --accent-gold-glow: rgba(245, 166, 35, 0.25);
  
  /* ========================================
     SEMANTIC COLORS - FINANCIAL
     ======================================== */
  
  /* Positive: profits, credits, success states */
  --color-positive: #3fb950;
  --color-positive-muted: rgba(63, 185, 80, 0.15);
  --color-positive-text: #56d364;
  
  /* Negative: losses, debits, error states */
  --color-negative: #f85149;
  --color-negative-muted: rgba(248, 81, 73, 0.15);
  --color-negative-text: #ff7b72;
  
  /* Warning states */
  --color-warning: #d29922;
  --color-warning-muted: rgba(210, 153, 34, 0.15);
  
  /* Info states */
  --color-info: #58a6ff;
  --color-info-muted: rgba(88, 166, 255, 0.15);

  /* ========================================
     TOAST ALERT COLORS
     Using semantic color tokens for consistency
     ======================================== */
  
  --toast-success-bg: var(--color-positive-muted);
  --toast-success-border: var(--color-positive);
  --toast-success-icon: var(--color-positive);
  
  --toast-danger-bg: var(--color-negative-muted);
  --toast-danger-border: var(--color-negative);
  --toast-danger-icon: var(--color-negative);
  
  --toast-warning-bg: var(--color-warning-muted);
  --toast-warning-border: var(--color-warning);
  --toast-warning-icon: var(--color-warning);
  
  --toast-info-bg: var(--color-info-muted);
  --toast-info-border: var(--color-info);
  --toast-info-icon: var(--color-info);

  /* ========================================
     INTERACTIVE STATES
     ======================================== */
  
  /* Primary button (golden accent) */
  --btn-primary-bg: var(--accent-gold);
  --btn-primary-bg-hover: var(--accent-gold-hover);
  --btn-primary-bg-active: var(--accent-gold-active);
  --btn-primary-text: #0f1419;
  
  /* Secondary button */
  --btn-secondary-bg: var(--bg-surface);
  --btn-secondary-bg-hover: var(--bg-raised);
  --btn-secondary-text: var(--text-primary);
  --btn-secondary-border: var(--border-default);
  
  /* Ghost/outline button */
  --btn-ghost-text: var(--text-secondary);
  --btn-ghost-text-hover: var(--text-primary);
  --btn-ghost-bg-hover: var(--bg-surface);
  
  /* ========================================
     FORM ELEMENTS
     ======================================== */
  
  --input-bg: var(--bg-surface);
  --input-bg-focus: var(--bg-raised);
  --input-border: var(--border-subtle);
  --input-border-focus: var(--accent-gold);
  --input-text: var(--text-primary);
  --input-placeholder: var(--text-muted);
  
  /* ========================================
     SHADOWS & EFFECTS
     ======================================== */
  
  --shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.3);
  --shadow-md: 0 4px 12px rgba(0, 0, 0, 0.4);
  --shadow-lg: 0 8px 24px rgba(0, 0, 0, 0.5);
  --shadow-glow-gold: 0 0 20px var(--accent-gold-glow);
  
  /* ========================================
     BORDER RADIUS
     ======================================== */
  
  --radius-sm: 4px;
  --radius-md: 8px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-full: 9999px;
  
  /* ========================================
     SPACING SCALE
     ======================================== */
  
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;
  --space-12: 48px;
  
  /* ========================================
     TYPOGRAPHY
     ======================================== */
  
  --font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, sans-serif;
  --font-mono: 'JetBrains Mono', 'Fira Code', Consolas, 'Courier New', monospace;
  
  --font-size-xs: 0.75rem;   /* 12px */
  --font-size-sm: 0.875rem;  /* 14px */
  --font-size-base: 1rem;    /* 16px */
  --font-size-lg: 1.125rem;  /* 18px */
  --font-size-xl: 1.25rem;   /* 20px */
  --font-size-2xl: 1.5rem;   /* 24px */
  --font-size-3xl: 1.875rem; /* 30px */
  
  --font-weight-normal: 400;
  --font-weight-medium: 500;
  --font-weight-semibold: 600;
  --font-weight-bold: 700;
  
  --line-height-tight: 1.25;
  --line-height-normal: 1.5;
  --line-height-relaxed: 1.75;
  
  /* ========================================
     BUTTON SIZING
     ======================================== */
  
  /* Standard toolbar button - filter bars, action rows, modal footers */
  --btn-height: 38px;
  --btn-padding-y: 8px;
  --btn-padding-x: 16px;
  --btn-font-size: 0.875rem;  /* 14px */
  --btn-min-width: 120px;
  --btn-radius: var(--radius-md);  /* 8px */
  
  /* Compact button - inline table actions, pagination, tight spaces */
  --btn-sm-height: 32px;
  --btn-sm-padding-y: 6px;
  --btn-sm-padding-x: 12px;
  --btn-sm-font-size: 0.8125rem;  /* 13px */
  
  /* Large button - primary CTAs, landing pages */
  --btn-lg-height: 44px;
  --btn-lg-padding-y: 10px;
  --btn-lg-padding-x: 24px;
  --btn-lg-font-size: 1rem;  /* 16px */

  /* ========================================
     TRANSITIONS
     ======================================== */
  
  --transition-fast: 0.1s ease;
  --transition-normal: 0.2s ease;
  --transition-slow: 0.3s ease;
  
  /* ========================================
     Z-INDEX SCALE
     ======================================== */
  
  --z-dropdown: 1000;
  --z-sticky: 1020;
  --z-fixed: 1030;
  --z-modal-backdrop: 1040;
  --z-modal: 1050;
  --z-popover: 1060;
  --z-tooltip: 1070;
}

/* ========================================
   UTILITY CLASSES - FINANCIAL INDICATORS
   ======================================== */

/* Positive amounts (green) */
.amount-positive,
.text-positive {
  color: var(--color-positive-text) !important;
}

.badge-positive {
  background-color: var(--color-positive-muted) !important;
  color: var(--color-positive-text) !important;
  border: 1px solid var(--color-positive) !important;
  border-radius: var(--radius-full);
  padding: 0.25em 0.75em;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

/* Negative amounts (red) */
.amount-negative,
.text-negative {
  color: var(--color-negative-text) !important;
}

.badge-negative {
  background-color: var(--color-negative-muted) !important;
  color: var(--color-negative-text) !important;
  border: 1px solid var(--color-negative) !important;
  border-radius: var(--radius-full);
  padding: 0.25em 0.75em;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

/* Neutral amounts */
.amount-neutral,
.text-neutral {
  color: var(--text-secondary) !important;
}

/* ========================================
   UTILITY CLASSES - BACKGROUNDS
   ======================================== */

.bg-deep { background-color: var(--bg-deep) !important; }
.bg-elevated { background-color: var(--bg-elevated) !important; }
.bg-surface { background-color: var(--bg-surface) !important; }
.bg-raised { background-color: var(--bg-raised) !important; }

/* ========================================
   UTILITY CLASSES - TEXT
   ======================================== */

.text-primary-custom { color: var(--text-primary) !important; }
.text-secondary-custom { color: var(--text-secondary) !important; }
.text-muted-custom { color: var(--text-muted) !important; }
.text-accent { color: var(--accent-gold) !important; }

/* ========================================
   UTILITY CLASSES - BORDERS
   ======================================== */

.border-subtle { border-color: var(--border-subtle) !important; }
.border-default { border-color: var(--border-default) !important; }
.border-accent { border-color: var(--accent-gold) !important; }

/* ========================================
   GOLDEN ACCENT BUTTON OVERRIDE
   ======================================== */

.btn-accent,
.btn-gold {
  background-color: var(--btn-primary-bg) !important;
  border-color: var(--btn-primary-bg) !important;
  color: var(--btn-primary-text) !important;
  font-weight: var(--font-weight-semibold);
  transition: all var(--transition-normal);
}

.btn-accent:hover,
.btn-gold:hover {
  background-color: var(--btn-primary-bg-hover) !important;
  border-color: var(--btn-primary-bg-hover) !important;
  color: var(--btn-primary-text) !important;
  box-shadow: var(--shadow-glow-gold);
}

.btn-accent:active,
.btn-gold:active {
  background-color: var(--btn-primary-bg-active) !important;
  border-color: var(--btn-primary-bg-active) !important;
}

.btn-accent:focus,
.btn-gold:focus {
  box-shadow: 0 0 0 3px var(--accent-gold-glow) !important;
}

/* Outline variant */
.btn-outline-accent,
.btn-outline-gold {
  background-color: transparent !important;
  border: 1px solid var(--accent-gold) !important;
  color: var(--accent-gold) !important;
  font-weight: var(--font-weight-medium);
  transition: all var(--transition-normal);
}

.btn-outline-accent:hover,
.btn-outline-gold:hover {
  background-color: var(--accent-gold-muted) !important;
  border-color: var(--accent-gold-hover) !important;
  color: var(--accent-gold-hover) !important;
}

/* ========================================
   BUTTON SIZING UTILITY CLASSES
   ======================================== */

/**
 * Standard toolbar button sizing
 * Use for: filter bars, action rows, modal footers
 * All buttons in the same toolbar should use this for consistent height
 */
.btn-toolbar {
  height: var(--btn-height, 38px) !important;
  padding: var(--btn-padding-y, 8px) var(--btn-padding-x, 16px) !important;
  font-size: var(--btn-font-size, 0.875rem) !important;
  line-height: 1.5 !important;
  min-width: var(--btn-min-width, 120px) !important;
  border-radius: var(--btn-radius, 8px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

/* Icon spacing inside btn-toolbar - only add margin to icons, not gap to all children */
.btn-toolbar > i[class*="bi-"],
.btn-toolbar > i[class*="fa-"],
.btn-toolbar > .bi,
.btn-toolbar > .fas,
.btn-toolbar > .far,
.btn-toolbar > .fab {
  margin-right: 0.375rem !important; /* 6px spacing after icon */
  margin-left: 0 !important;
}

/* Override min-width for icon-only or short-label buttons */
.btn-toolbar.btn-auto-width {
  min-width: auto !important;
}

/**
 * Compact button sizing
 * Use for: table inline actions, pagination controls, tight spaces
 */
.btn-compact {
  height: var(--btn-sm-height, 32px) !important;
  padding: var(--btn-sm-padding-y, 6px) var(--btn-sm-padding-x, 12px) !important;
  font-size: var(--btn-sm-font-size, 0.8125rem) !important;
  line-height: 1.5 !important;
  min-width: auto !important;
  border-radius: var(--radius-sm, 4px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

/* Icon spacing inside btn-compact - only add margin to icons, not gap to all children */
.btn-compact > i[class*="bi-"],
.btn-compact > i[class*="fa-"],
.btn-compact > .bi,
.btn-compact > .fas,
.btn-compact > .far,
.btn-compact > .fab {
  margin-right: 0.25rem !important; /* 4px spacing after icon */
  margin-left: 0 !important;
}

/**
 * Large button sizing
 * Use for: primary CTAs, landing pages, important form submits
 */
.btn-large {
  height: var(--btn-lg-height, 44px) !important;
  padding: var(--btn-lg-padding-y, 10px) var(--btn-lg-padding-x, 24px) !important;
  font-size: var(--btn-lg-font-size, 1rem) !important;
  line-height: 1.5 !important;
  min-width: 140px !important;
  border-radius: var(--btn-radius, 8px) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
}

/* Icon spacing inside btn-large - only add margin to icons, not gap to all children */
.btn-large > i[class*="bi-"],
.btn-large > i[class*="fa-"],
.btn-large > .bi,
.btn-large > .fas,
.btn-large > .far,
.btn-large > .fab {
  margin-right: 0.375rem !important; /* 6px spacing after icon */
  margin-left: 0 !important;
}

/* ========================================
   UTILITY CLASSES
   ======================================== */

/**
 * Info icon styling
 * Use for: tooltip triggers, help icons, informational hints
 * Consistent with "Hur gör jag" buttons and settings page info icons
 */
.info-icon {
  color: var(--color-info, #58a6ff) !important;
  cursor: help;
  opacity: 0.85;
  transition: opacity 0.15s ease;
}
.info-icon:hover {
  opacity: 1;
}

/**
 * Info button override (Hur gör jag? buttons)
 * Replaces Bootstrap's cyan with design system blue for consistency
 * with info icons and help elements throughout the app
 */
.btn-outline-info {
  --bs-btn-color: var(--color-info, #58a6ff) !important;
  --bs-btn-border-color: var(--color-info, #58a6ff) !important;
  --bs-btn-hover-color: #fff !important;
  --bs-btn-hover-bg: var(--color-info, #58a6ff) !important;
  --bs-btn-hover-border-color: var(--color-info, #58a6ff) !important;
  --bs-btn-focus-shadow-rgb: 88, 166, 255 !important;
  --bs-btn-active-color: #fff !important;
  --bs-btn-active-bg: var(--color-info, #58a6ff) !important;
  --bs-btn-active-border-color: var(--color-info, #58a6ff) !important;
  color: var(--color-info, #58a6ff) !important;
  border-color: var(--color-info, #58a6ff) !important;
}
.btn-outline-info:hover {
  color: #fff !important;
  background-color: var(--color-info, #58a6ff) !important;
  border-color: var(--color-info, #58a6ff) !important;
}
.btn-outline-info:focus {
  box-shadow: 0 0 0 0.25rem rgba(88, 166, 255, 0.25) !important;
}

/**
 * Add Row Button - Gold Accent
 * Overrides btn-outline-success for "Lägg till rad" buttons
 * to use gold accent consistent with design system
 */
.btn-add-row,
.btn-add-row.btn-outline-success {
  color: var(--accent-gold, #f5a623) !important;
  border-color: var(--accent-gold, #f5a623) !important;
  background-color: transparent !important;
}
.btn-add-row:hover,
.btn-add-row.btn-outline-success:hover {
  color: var(--accent-gold, #f5a623) !important;
  background-color: var(--accent-gold-muted, rgba(245, 166, 35, 0.15)) !important;
  border-color: var(--accent-gold, #f5a623) !important;
}
.btn-add-row:focus,
.btn-add-row.btn-outline-success:focus {
  box-shadow: 0 0 0 0.25rem var(--accent-gold-glow, rgba(245, 166, 35, 0.25)) !important;
}

/**
 * Remove Row Button (Trash Icon)
 * Consistent styling for delete actions across all modals
 * Default: Muted gray (subtle, non-distracting)
 * Hover: Red (clear destructive action indicator)
 */
.remove-row-btn {
  background: none !important;
  border: none !important;
  padding: 0 4px !important;
  color: var(--text-muted, #8b949e) !important;
  cursor: pointer !important;
  font-size: 0.9rem !important;
  line-height: 1 !important;
  transition: color 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 24px !important;
  height: 24px !important;
  border-radius: 4px !important;
}
.remove-row-btn:hover {
  color: var(--color-negative, #f85149) !important;
  background-color: rgba(248, 81, 73, 0.1) !important;
}
.remove-row-btn i.bi-trash,
.remove-row-btn i.bi-trash3 {
  font-size: 0.95rem !important;
  vertical-align: middle !important;
}

/**
 * Delete Icon Button (.delete-icon-btn, .delete-btn)
 * Alias for .remove-row-btn - use for inline delete actions in tables/lists
 * Consistent styling: muted gray default, red on hover
 */
.delete-icon-btn,
.delete-btn {
  background: none !important;
  border: none !important;
  padding: 0 4px !important;
  color: var(--text-muted, #8b949e) !important;
  cursor: pointer !important;
  font-size: 0.9rem !important;
  line-height: 1 !important;
  transition: color 0.15s ease, background-color 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 24px !important;
  height: 24px !important;
  border-radius: 4px !important;
}
.delete-icon-btn:hover,
.delete-btn:hover {
  color: var(--color-negative, #f85149) !important;
  background-color: var(--color-negative-muted, rgba(248, 81, 73, 0.15)) !important;
}
.delete-icon-btn i.bi-trash,
.delete-icon-btn i.bi-trash3,
.delete-btn i.bi-trash,
.delete-btn i.bi-trash3 {
  font-size: 0.95rem !important;
  vertical-align: middle !important;
}

/**
 * Icon Button (.icon-btn)
 * Generic icon-only button for table row actions
 * Use for: edit, delete, settings icons in action columns
 * Default: muted, Hover: reveals action color
 */
.icon-btn {
  background: none !important;
  border: none !important;
  padding: 4px 6px !important;
  color: var(--text-muted, #8b949e) !important;
  cursor: pointer !important;
  font-size: 1rem !important;
  line-height: 1 !important;
  transition: color 0.15s ease, background-color 0.15s ease !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 28px !important;
  height: 28px !important;
  border-radius: var(--radius-sm, 4px) !important;
}
.icon-btn:hover {
  color: var(--text-primary, #f1f3f5) !important;
  background-color: var(--bg-surface, #242b33) !important;
}

/* Trash icon in .icon-btn becomes red on hover */
.icon-btn:hover i.bi-trash,
.icon-btn:hover i.bi-trash3 {
  color: var(--color-negative, #f85149) !important;
}
.icon-btn:hover {
  background-color: transparent !important;
}
.icon-btn i.bi-trash:hover,
.icon-btn i.bi-trash3:hover {
  color: var(--color-negative, #f85149) !important;
}
/* When hovering .icon-btn with trash, show red background */
.icon-btn:has(i.bi-trash):hover,
.icon-btn:has(i.bi-trash3):hover {
  background-color: var(--color-negative-muted, rgba(248, 81, 73, 0.15)) !important;
}

/* Gear icon in .icon-btn becomes gold on hover */
.icon-btn:hover i.bi-gear,
.icon-btn:hover i.bi-gear-fill {
  color: var(--accent-gold, #f5a623) !important;
}
.icon-btn:has(i.bi-gear):hover,
.icon-btn:has(i.bi-gear-fill):hover {
  background-color: var(--accent-gold-muted, rgba(245, 166, 35, 0.15)) !important;
}

/**
 * Delete Template/Item Button (.btn-delete-item)
 * For outline buttons with trash icon (like delete template/customer)
 * Use with: btn btn-outline-secondary btn-compact btn-delete-item
 * Default: subtle border, muted text
 * Hover: red border, red text, subtle red background
 */
.btn-delete-item,
.btn-delete-item.btn-outline-secondary {
  border-color: var(--border-default, #3d4752) !important;
  color: var(--text-muted, #8b949e) !important;
  transition: all 0.15s ease !important;
}
.btn-delete-item:hover,
.btn-delete-item.btn-outline-secondary:hover,
.btn-delete-item:focus,
.btn-delete-item.btn-outline-secondary:focus {
  border-color: var(--color-negative, #f85149) !important;
  color: var(--color-negative, #f85149) !important;
  background-color: var(--color-negative-muted, rgba(248, 81, 73, 0.15)) !important;
}

/* ========================================
   INFORMATIONAL CALLOUT BOXES
   Standardized styling for info/hint callouts
   ======================================== */

/**
 * Info Callout - Blue themed informational boxes
 * Use for: contextual info, hints, explanations, requirements
 * Semantic: "Here is helpful information" (not actionable)
 */
.info-callout {
  background-color: var(--color-info-muted, rgba(88, 166, 255, 0.08)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-info, #58a6ff) !important;
  border-radius: var(--radius-md, 8px) !important;
  padding: 12px 16px !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.info-callout strong,
.info-callout .info-callout-title {
  color: var(--text-secondary, #c9d1d9) !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
}
.info-callout ul,
.info-callout ol {
  margin-top: 8px !important;
  margin-bottom: 0 !important;
  padding-left: 1.25rem !important;
}
.info-callout li {
  color: var(--text-muted, #8b949e) !important;
  font-size: 0.8125rem !important;
  line-height: 1.6 !important;
}
.info-callout p {
  color: var(--text-secondary, #c9d1d9) !important;
  font-size: 0.875rem !important;
  margin-bottom: 0 !important;
}
.info-callout .info-icon {
  color: var(--color-info, #58a6ff) !important;
}

/**
 * Global .alert-info override - consistent blue info styling
 * For STATIC callout boxes on pages (NOT toast notifications)
 * Toast alerts use .accojoy-alert class with separate styling in alerts.css
 */
.alert-info:not(.accojoy-alert) {
  background-color: var(--color-info-muted, rgba(88, 166, 255, 0.08)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-info, #58a6ff) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.alert-info:not(.accojoy-alert) strong {
  color: var(--color-info, #58a6ff) !important;
  font-weight: 700 !important;
}
.alert-info:not(.accojoy-alert) .bi-info-circle,
.alert-info:not(.accojoy-alert) .bi-info-circle-fill {
  color: var(--color-info, #58a6ff) !important;
}

/**
 * Global .alert-warning override - consistent amber/gold warning styling
 * For STATIC callout boxes (NOT toast notifications)
 */
.alert-warning:not(.accojoy-alert) {
  background-color: var(--color-warning-muted, rgba(210, 153, 34, 0.15)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-warning, #d29922) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.alert-warning:not(.accojoy-alert) strong {
  color: var(--color-warning, #d29922) !important;
  font-weight: 700 !important;
}
.alert-warning:not(.accojoy-alert) .bi-exclamation-triangle,
.alert-warning:not(.accojoy-alert) .bi-exclamation-triangle-fill,
.alert-warning:not(.accojoy-alert) .bi-exclamation-circle,
.alert-warning:not(.accojoy-alert) .bi-exclamation-circle-fill {
  color: var(--color-warning, #d29922) !important;
}

/**
 * Global .alert-danger override - consistent red error/danger styling
 * For STATIC callout boxes (NOT toast notifications)
 */
.alert-danger:not(.accojoy-alert) {
  background-color: rgba(248, 81, 73, 0.15) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-negative, #f85149) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.alert-danger:not(.accojoy-alert) strong {
  color: var(--color-negative, #f85149) !important;
  font-weight: 700 !important;
}

/**
 * Global .alert-success override - consistent green success styling
 * For STATIC callout boxes (NOT toast notifications)
 */
.alert-success:not(.accojoy-alert) {
  background-color: var(--color-positive-muted, rgba(63, 185, 80, 0.15)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-positive, #3fb950) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.alert-success:not(.accojoy-alert) strong {
  color: var(--color-positive, #3fb950) !important;
  font-weight: 700 !important;
}
.alert-success:not(.accojoy-alert) .bi-check-circle,
.alert-success:not(.accojoy-alert) .bi-check-circle-fill {
  color: var(--color-positive, #3fb950) !important;
}

/* ========================================
   TOAST ALERT STYLING (.accojoy-alert)
   Colors for toast notifications using design tokens
   Layout/structure defined in alerts.css
   ======================================== */

/**
 * Success toast - green theme
 */
.accojoy-alert.alert-success {
  background-color: var(--toast-success-bg, rgba(63, 185, 80, 0.15)) !important;
  border-color: var(--toast-success-border, #3fb950) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.accojoy-alert.alert-success .alert-icon {
  color: var(--toast-success-icon, #3fb950) !important;
}

/**
 * Danger toast - red theme
 */
.accojoy-alert.alert-danger {
  background-color: var(--toast-danger-bg, rgba(248, 81, 73, 0.15)) !important;
  border-color: var(--toast-danger-border, #f85149) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.accojoy-alert.alert-danger .alert-icon {
  color: var(--toast-danger-icon, #f85149) !important;
}
.accojoy-alert.alert-danger strong,
.accojoy-alert.alert-danger b {
  color: var(--color-negative-text, #ff7b72) !important;
  font-weight: 700 !important;
}

/**
 * Warning toast - amber theme
 */
.accojoy-alert.alert-warning {
  background-color: var(--toast-warning-bg, rgba(210, 153, 34, 0.15)) !important;
  border-color: var(--toast-warning-border, #d29922) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.accojoy-alert.alert-warning .alert-icon {
  color: var(--toast-warning-icon, #d29922) !important;
}

/**
 * Info toast - blue theme
 */
.accojoy-alert.alert-info {
  background-color: var(--toast-info-bg, rgba(88, 166, 255, 0.15)) !important;
  border-color: var(--toast-info-border, #58a6ff) !important;
  color: var(--text-primary, #f1f3f5) !important;
}
.accojoy-alert.alert-info .alert-icon {
  color: var(--toast-info-icon, #58a6ff) !important;
}

/* ========================================
   MODAL STYLING
   Global modal overrides for consistent dark theme
   ======================================== */

/**
 * Modal positioning - "optical center" placement
 * Positions modals at ~20-25% from top (slightly above mathematical center)
 * This is the natural reading position and feels more balanced
 * Applied globally to all Bootstrap modals for consistency
 * 
 * APPROACH: We use margin-top on .modal-dialog to push the modal down from
 * the top of the viewport. This works more reliably than padding-top.
 */

/* Reset Bootstrap's modal container alignment */
.modal {
  --bs-modal-margin: 1rem !important;
}

/* Modal dialog positioning */
.modal-dialog {
  display: block !important;
  margin-top: calc(15vh) !important; /* Position at ~15% from top */
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.75rem !important;
}

/* Override Bootstrap's modal-dialog-centered - use our optical center instead of true center */
.modal-dialog.modal-dialog-centered {
  display: block !important;
  align-items: unset !important;
  min-height: unset !important;
  margin-top: calc(15vh) !important; /* Same optical center position */
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 1.75rem !important;
}

/* Reset Bootstrap's ::before pseudo-element used for centering */
.modal-dialog-centered::before {
  display: none !important;
  content: none !important;
}

/* For smaller screens, reduce the top offset */
@media (max-width: 575.98px) {
  .modal-dialog,
  .modal-dialog.modal-dialog-centered {
    margin-top: 1rem !important;
    margin-left: 0.5rem !important;
    margin-right: 0.5rem !important;
  }
}

/**
 * Modal content - dark elevated background
 * Applied globally to all Bootstrap modals
 */
.modal-content {
  background-color: var(--bg-elevated, #1a1f26) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-radius: var(--radius-lg, 12px) !important;
  box-shadow: var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, 0.5)) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

/**
 * Modal header - subtle bottom border
 */
.modal-header {
  background-color: transparent !important;
  border-bottom: 1px solid var(--border-subtle, #2d3640) !important;
  padding: 1rem 1.25rem !important;
}

.modal-header .modal-title {
  color: var(--text-primary, #f1f3f5) !important;
  font-weight: var(--font-weight-semibold, 600) !important;
  font-size: 1.1rem !important;
}

.modal-header .btn-close {
  filter: invert(1) grayscale(100%) brightness(200%) !important;
  opacity: 0.7 !important;
}
.modal-header .btn-close:hover {
  opacity: 1 !important;
}

/**
 * Modal body - consistent padding and text
 */
.modal-body {
  padding: 1.25rem !important;
  color: var(--text-primary, #f1f3f5) !important;
}

.modal-body label,
.modal-body .form-label {
  color: var(--text-secondary, #c9d1d9) !important;
  font-weight: var(--font-weight-medium, 500) !important;
  font-size: 0.875rem !important;
  margin-bottom: 0.375rem !important;
}

/**
 * Modal form controls - dark inputs
 */
.modal-content .form-control,
.modal-content .form-select {
  background-color: var(--bg-surface, #242b33) !important;
  border: 1px solid var(--border-default, #3d4752) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
  padding: 0.5rem 0.75rem !important;
}

.modal-content .form-control:focus,
.modal-content .form-select:focus {
  border-color: var(--accent-gold, #f5a623) !important;
  box-shadow: 0 0 0 0.2rem var(--accent-gold-glow, rgba(245, 166, 35, 0.25)) !important;
  background-color: var(--bg-surface, #242b33) !important;
}

.modal-content .form-control::placeholder {
  color: var(--text-muted, #8b949e) !important;
}

/* ========================================
   GLOBAL FORM SELECT DROPDOWN ARROW
   Consistent light arrow for dark theme
   ======================================== */

/**
 * Global dropdown arrow styling for dark theme
 * Uses --text-secondary (#c9d1d9) for visibility on dark backgrounds
 * Applied to ALL form-select elements across the application
 */
.form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23c9d1d9' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 16px 12px !important;
}

/* Also apply to select.form-control for legacy/mixed usage */
select.form-control {
  -webkit-appearance: none !important;
  -moz-appearance: none !important;
  appearance: none !important;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23c9d1d9' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 16px 12px !important;
  padding-right: 2rem !important;
}

/* Remove MS browser default arrow */
select.form-control::-ms-expand,
.form-select::-ms-expand {
  display: none !important;
}

/* ========================================
   DATE INPUT CALENDAR ICON STYLING
   Consistent light icon for dark theme
   ======================================== */

/**
 * Date input calendar picker icon styling for dark theme
 * Hides native black calendar icon and replaces with custom light SVG
 * Uses #c9d1d9 to match dropdown arrow color for visual consistency
 */

/* Global date input styling */
input[type="date"],
input[type="datetime-local"],
input[type="time"],
.form-control[type="date"],
.form-control[type="datetime-local"],
.form-control[type="time"] {
  color-scheme: dark !important;
  /* Custom calendar icon - Bootstrap Icons calendar3 with grid dots */
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' fill='%23c9d1d9' viewBox='0 0 16 16'%3E%3Cpath d='M14 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2zM1 3.857C1 3.384 1.448 3 2 3h12c.552 0 1 .384 1 .857v10.286c0 .473-.448.857-1 .857H2c-.552 0-1-.384-1-.857V3.857z'/%3E%3Cpath d='M6.5 7a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-9 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm-9 3a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2zm3 0a1 1 0 1 0 0-2 1 1 0 0 0 0 2z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 10px center !important;
  background-size: 16px 16px !important;
  padding-right: 35px !important;
}

/* Hide native calendar picker indicator visually but keep it clickable (Chrome, Safari, Edge) */
input[type="date"]::-webkit-calendar-picker-indicator,
input[type="datetime-local"]::-webkit-calendar-picker-indicator,
input[type="time"]::-webkit-calendar-picker-indicator,
.form-control[type="date"]::-webkit-calendar-picker-indicator,
.form-control[type="datetime-local"]::-webkit-calendar-picker-indicator,
.form-control[type="time"]::-webkit-calendar-picker-indicator {
  background: transparent !important;
  color: transparent !important;
  cursor: pointer !important;
  /* Cover the custom icon area without absolute positioning for reliable clickability */
  width: 30px !important;
  height: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Form select dropdown arrow for modals (inherits from global, but keeps specificity) */
.modal-content .form-select {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23c9d1d9' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M2 5l6 6 6-6'/%3e%3c/svg%3e") !important;
  background-repeat: no-repeat !important;
  background-position: right 0.75rem center !important;
  background-size: 16px 12px !important;
}

/**
 * Modal checkboxes and radios
 */
.modal-content .form-check-input {
  background-color: var(--bg-surface, #242b33) !important;
  border-color: var(--border-default, #3d4752) !important;
}

.modal-content .form-check-input:checked {
  background-color: var(--accent-gold, #f5a623) !important;
  border-color: var(--accent-gold, #f5a623) !important;
}

.modal-content .form-check-label {
  color: var(--text-primary, #f1f3f5) !important;
}

/**
 * Checkbox/label vertical alignment fix
 * Bootstrap's default margin-top on .form-check-input causes misalignment
 * when used with flexbox (d-flex align-items-center)
 * 
 * This fix ensures proper centering for the pattern:
 * <div class="d-flex align-items-center">
 *   <input class="form-check-input" type="checkbox">
 *   <label class="form-check-label">Label</label>
 * </div>
 */

/* Reset only VERTICAL margins for checkboxes in flex containers */
/* Preserves horizontal margins (me-2, etc.) for spacing */
[class*="d-flex"] > .form-check-input,
[class*="d-flex"] > input[type="checkbox"],
[class*="d-flex"] > input[type="radio"] {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  flex-shrink: 0 !important;
}

/* Reset only vertical margins for labels in flex containers */
[class*="d-flex"] > .form-check-label {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

/**
 * Modal footer - subtle top border
 */
.modal-footer {
  background-color: transparent !important;
  border-top: 1px solid var(--border-subtle, #2d3640) !important;
  padding: 1rem 1.25rem !important;
  gap: 0.5rem !important;
}

/**
 * Modal section headers (for complex modals)
 */
.modal-content .section-header,
.modal-content h6 {
  color: var(--text-primary, #f1f3f5) !important;
  font-weight: var(--font-weight-semibold, 600) !important;
  border-left: 3px solid var(--accent-gold, #f5a623) !important;
  padding-left: 0.75rem !important;
  margin-bottom: 1rem !important;
}

/**
 * Modal info text and hints
 */
.modal-content .text-muted,
.modal-content small {
  color: var(--text-muted, #8b949e) !important;
}

.modal-content .form-text {
  color: var(--text-muted, #8b949e) !important;
  font-size: 0.8125rem !important;
}

/**
 * Modal tables
 */
.modal-content .table {
  color: var(--text-primary, #f1f3f5) !important;
  --bs-table-bg: transparent !important;
  --bs-table-striped-bg: rgba(255, 255, 255, 0.02) !important;
  --bs-table-hover-bg: rgba(255, 255, 255, 0.04) !important;
}

.modal-content .table th {
  background-color: var(--bg-surface, #242b33) !important;
  color: var(--text-secondary, #c9d1d9) !important;
  font-weight: var(--font-weight-semibold, 600) !important;
  font-size: 0.8125rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.03em !important;
  border-bottom: 1px solid var(--border-subtle, #2d3640) !important;
}

.modal-content .table td {
  border-bottom: 1px solid var(--border-subtle, #2d3640) !important;
  vertical-align: middle !important;
}

/**
 * Modal alerts - inherit from global alert styling
 * These just add specificity for modals, base styling from global .alert-info
 */
.modal-content .alert-info {
  background-color: var(--color-info-muted, rgba(88, 166, 255, 0.08)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-info, #58a6ff) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

.modal-content .alert-warning {
  background-color: var(--color-warning-muted, rgba(210, 153, 34, 0.15)) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-warning, #d29922) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

.modal-content .alert-danger {
  background-color: rgba(248, 81, 73, 0.15) !important;
  border: 1px solid var(--border-subtle, #2d3640) !important;
  border-left: 3px solid var(--color-negative, #f85149) !important;
  border-radius: var(--radius-md, 8px) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

/**
 * Modal horizontal rules
 */
.modal-content hr {
  border-color: var(--border-subtle, #2d3640) !important;
  opacity: 1 !important;
  margin: 1rem 0 !important;
}

/**
 * Modal form sections (grouped fields)
 */
.modal-content .form-section {
  background-color: rgba(255, 255, 255, 0.025) !important;
  border: 1px solid rgba(255, 255, 255, 0.06) !important;
  border-radius: var(--radius-md, 8px) !important;
  padding: 0.75rem !important;
  margin-bottom: 0.75rem !important;
}

.modal-content .form-section-title {
  font-size: 0.95rem !important;
  font-weight: var(--font-weight-semibold, 600) !important;
  color: var(--text-primary, #f1f3f5) !important;
  margin: 0 0 0.5rem 0 !important;
  padding: 0 !important;
  border: none !important;
}

/**
 * Modal list groups
 */
.modal-content .list-group-item {
  background-color: var(--bg-surface, #242b33) !important;
  border-color: var(--border-subtle, #2d3640) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

.modal-content .list-group-item:hover {
  background-color: var(--bg-raised, #2d3640) !important;
}

.modal-content .list-group-item.active {
  background-color: var(--accent-gold-muted, rgba(245, 166, 35, 0.15)) !important;
  border-color: var(--accent-gold, #f5a623) !important;
  color: var(--accent-gold, #f5a623) !important;
}

/**
 * Modal nav tabs (for tabbed modals)
 */
.modal-content .nav-tabs {
  border-bottom-color: var(--border-subtle, #2d3640) !important;
}

.modal-content .nav-tabs .nav-link {
  color: var(--text-secondary, #c9d1d9) !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  background: transparent !important;
}

.modal-content .nav-tabs .nav-link:hover {
  color: var(--text-primary, #f1f3f5) !important;
  border-bottom-color: var(--border-default, #3d4752) !important;
}

.modal-content .nav-tabs .nav-link.active {
  color: var(--accent-gold, #f5a623) !important;
  border-bottom-color: var(--accent-gold, #f5a623) !important;
  background: transparent !important;
}

/**
 * Modal backdrop
 */
.modal-backdrop.show {
  opacity: 0.7 !important;
}

/**
 * Override Bootstrap utility classes on modals
 * These ensure our design system takes precedence over
 * inline Bootstrap classes like .bg-dark, .border-secondary
 */
.modal-content.bg-dark,
.modal-content.bg-dark.text-light,
.modal-content[class*="bg-"] {
  background-color: var(--bg-elevated, #1a1f26) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

.modal-header.border-secondary,
.modal-header[class*="border-"] {
  border-bottom: 1px solid var(--border-subtle, #2d3640) !important;
}

.modal-footer.border-secondary,
.modal-footer[class*="border-"] {
  border-top: 1px solid var(--border-subtle, #2d3640) !important;
}

/**
 * Modal button styling
 * Ensures consistent button appearance in modal footers
 */
.modal-footer .btn-primary {
  background-color: var(--accent-gold, #f5a623) !important;
  border-color: var(--accent-gold, #f5a623) !important;
  color: var(--bg-deep, #0f1419) !important;
  font-weight: var(--font-weight-semibold, 600) !important;
}

.modal-footer .btn-primary:hover {
  background-color: var(--accent-gold-hover, #ffb938) !important;
  border-color: var(--accent-gold-hover, #ffb938) !important;
  box-shadow: 0 0 12px var(--accent-gold-glow, rgba(245, 166, 35, 0.3)) !important;
}

.modal-footer .btn-primary:focus {
  box-shadow: 0 0 0 0.25rem var(--accent-gold-glow, rgba(245, 166, 35, 0.25)) !important;
}

.modal-footer .btn-secondary {
  background-color: var(--bg-surface, #242b33) !important;
  border-color: var(--border-default, #3d4752) !important;
  color: var(--text-secondary, #c9d1d9) !important;
}

.modal-footer .btn-secondary:hover {
  background-color: var(--bg-raised, #2d3640) !important;
  border-color: var(--border-strong, #4d5762) !important;
  color: var(--text-primary, #f1f3f5) !important;
}

/**
 * Danger button variant for destructive actions
 */
.modal-footer .btn-danger {
  background-color: var(--color-negative, #f85149) !important;
  border-color: var(--color-negative, #f85149) !important;
  color: #fff !important;
  font-weight: var(--font-weight-semibold, 600) !important;
}

.modal-footer .btn-danger:hover {
  background-color: #ff6b63 !important;
  border-color: #ff6b63 !important;
  box-shadow: 0 0 12px rgba(248, 81, 73, 0.3) !important;
}

/**
 * Confirmation modal variant
 * Simplified modal for yes/no confirmations
 * No header border for cleaner look on simple dialogs
 */
.modal-confirm .modal-header {
  border-bottom: none !important;
  padding-bottom: 0.5rem !important;
}

.modal-confirm .modal-body {
  padding-top: 0.5rem !important;
  color: var(--text-secondary, #c9d1d9) !important;
  font-size: 0.95rem !important;
  line-height: 1.6 !important;
}

.modal-confirm .modal-footer {
  border-top: none !important;
  padding-top: 0.75rem !important;
}

/* ========================================
   BUTTON ATTENTION EFFECTS (PULSE/GLOW)
   ========================================
   Two variants for drawing user attention to buttons:
   
   1. .btn-pulse-limited - Limited pulse (3 cycles) for momentary attention
      Use for: Confirmation buttons after user selection (e.g., "Välj" after row selected)
   
   2. .btn-pulse-continuous - Infinite pulse for ongoing state alerts
      Use for: Buttons indicating incomplete state requiring action (e.g., partial invoice match)
   ======================================== */

/* Keyframes for gold glow pulse animation */
@keyframes btnGoldGlowPulse {
  0%, 100% { box-shadow: 0 0 8px 4px rgba(245,166,35,.4), 0 0 0 0.2rem rgba(245,166,35,.3); }
  50% { box-shadow: 0 0 16px 8px rgba(245,166,35,.5), 0 0 0 0.4rem rgba(245,166,35,.4); }
}

/* Variant 1: Limited pulse - runs 3 times then stops
   Use for momentary "click me" attention after user action */
.btn-pulse-limited {
  border-color: var(--accent-gold, #f5a623) !important;
  background: linear-gradient(180deg, rgba(245,166,35,0.9), rgba(245,166,35,0.75)) !important;
  color: var(--bg-deep, #1a1d21) !important;
  box-shadow: 0 0 8px 4px rgba(245,166,35,.4), 0 0 0 0.2rem rgba(245,166,35,.3);
  animation: btnGoldGlowPulse 1.5s ease-in-out 3;
}

/* Variant 2: Continuous pulse - runs infinitely
   Use for ongoing state alerts (partial match, incomplete action) */
.btn-pulse-continuous {
  border-color: var(--accent-gold, #f5a623) !important;
  background: linear-gradient(180deg, rgba(245,166,35,0.15), rgba(245,166,35,0.08)) !important;
  color: var(--accent-gold, #f5a623) !important;
  box-shadow: 0 0 0 0.2rem rgba(245,166,35,.25);
  animation: btnGoldGlowPulse 2s ease-in-out infinite;
}

/* Respect users who prefer reduced motion */
@media (prefers-reduced-motion: reduce) {
  .btn-pulse-limited,
  .btn-pulse-continuous {
    animation: none;
  }
}

