/* ══════════════════════════════════════════════════════════════════════════════
   IMMOBILIER.FR — BRAND INTEGRATION CSS
   Police: Sora | Thèmes: Light (défaut) & Dark
   Compatible avec Vuexy ASP.NET Core MVC
   ══════════════════════════════════════════════════════════════════════════════ */

/* ══════════════════════════════════════════════════════════════════════════════
   GOOGLE FONTS - SORA
   ══════════════════════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&display=swap');

/* ══════════════════════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES - LIGHT THEME (DEFAULT)
   ══════════════════════════════════════════════════════════════════════════════ */
:root,
[data-theme="light"],
html:not([data-theme="dark"]) {
  /* Brand Colors */
  --immo-bordeaux: #5C2A34;
  --immo-bordeaux-light: #7A3D4A;
  --immo-bordeaux-dark: #3D1A22;
  --immo-or: #C9A96E;
  --immo-or-light: #D9C08E;
  --immo-or-dark: #A88B4E;
  --immo-ivoire: #FAF8F5;
  --immo-marine: #1A2A3A;
  --immo-taupe: #EDE5DC;
  
  /* Bootstrap Overrides Light */
  --bs-primary: #5C2A34;
  --bs-primary-rgb: 92, 42, 52;
  --bs-secondary: #64606B;
  --bs-success: #32A362;
  --bs-info: #3D8EB9;
  --bs-warning: #F5A623;
  --bs-danger: #C94444;
  --bs-light: #FAF8F5;
  --bs-dark: #1A2A3A;
  
  /* Surfaces Light */
  --immo-body-bg: #FAF8F5;
  --immo-card-bg: #FFFFFF;
  --immo-sidebar-bg: #EDE5DC;
  --immo-sidebar-hover: #E0D6CB;
  --immo-sidebar-active: #D4C9BC;
  --immo-border-color: #E8E4E0;
  
  /* Text Light */
  --immo-text-primary: #3D2A2E;
  --immo-text-secondary: #6B5A5E;
  --immo-text-muted: #9A8B8E;
  
  /* Navbar Light */
  --immo-navbar-bg: #FFFFFF;
  --immo-navbar-border: #E8E4E0;
  
  /* Menu Active */
  --immo-menu-active-bg: rgba(92, 42, 52, 0.1);
  --immo-menu-active-color: #5C2A34;
  
  /* Logo colors for light theme */
  --immo-logo-text: #5C2A34;
  --immo-logo-frame: #C9A96E;
}

/* ══════════════════════════════════════════════════════════════════════════════
   CSS CUSTOM PROPERTIES - DARK THEME
   ══════════════════════════════════════════════════════════════════════════════ */
[data-theme="dark"],
html[data-theme="dark"] {
  /* Brand Colors (unchanged) */
  --immo-bordeaux: #5C2A34;
  --immo-bordeaux-light: #7A3D4A;
  --immo-bordeaux-dark: #3D1A22;
  --immo-or: #C9A96E;
  --immo-or-light: #D9C08E;
  --immo-or-dark: #A88B4E;
  --immo-ivoire: #FAF8F5;
  --immo-marine: #1A2A3A;
  --immo-taupe: #EDE5DC;
  
  /* Bootstrap Overrides Dark */
  --bs-primary: #C9A96E;
  --bs-primary-rgb: 201, 169, 110;
  --bs-secondary: #8B949E;
  --bs-success: #3FB950;
  --bs-info: #58A6FF;
  --bs-warning: #D29922;
  --bs-danger: #F85149;
  --bs-light: #F0F6FC;
  --bs-dark: #0D1117;
  
  /* Surfaces Dark */
  --immo-body-bg: #0D1117;
  --immo-card-bg: #161B22;
  --immo-sidebar-bg: #161B22;
  --immo-sidebar-hover: #21262D;
  --immo-sidebar-active: #30363D;
  --immo-border-color: #30363D;
  
  /* Text Dark */
  --immo-text-primary: #F0F6FC;
  --immo-text-secondary: #8B949E;
  --immo-text-muted: #6E7681;
  
  /* Navbar Dark */
  --immo-navbar-bg: #161B22;
  --immo-navbar-border: #30363D;
  
  /* Menu Active Dark */
  --immo-menu-active-bg: rgba(201, 169, 110, 0.15);
  --immo-menu-active-color: #C9A96E;
  
  /* Logo colors for dark theme */
  --immo-logo-text: #FAF8F5;
  --immo-logo-frame: #C9A96E;
}

/* ══════════════════════════════════════════════════════════════════════════════
   TYPOGRAPHY - SORA
   ══════════════════════════════════════════════════════════════════════════════ */
body,
.app-brand-text,
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6,
.btn,
.form-control,
.form-select,
.nav-link,
.dropdown-item,
.card-title,
.table {
  font-family: 'Sora', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   BODY & LAYOUT
   ══════════════════════════════════════════════════════════════════════════════ */
body {
  background-color: var(--immo-body-bg) !important;
  color: var(--immo-text-primary) !important;
}

.layout-wrapper,
.layout-page {
  background-color: var(--immo-body-bg) !important;
}

.content-wrapper {
  background-color: var(--immo-body-bg) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SIDEBAR / MENU
   ══════════════════════════════════════════════════════════════════════════════ */
.menu,
.bg-menu-theme,
.layout-menu {
  background-color: var(--immo-sidebar-bg) !important;
  border-right: 1px solid var(--immo-border-color) !important;
}

.menu-inner > .menu-item > .menu-link {
  color: var(--immo-text-secondary) !important;
}

.menu-inner > .menu-item > .menu-link:hover,
.menu-inner > .menu-item.open > .menu-link {
  background-color: var(--immo-sidebar-hover) !important;
  color: var(--immo-text-primary) !important;
}

.menu-inner > .menu-item.active > .menu-link {
  background-color: var(--immo-menu-active-bg) !important;
  color: var(--immo-menu-active-color) !important;
}

.menu-inner > .menu-item.active > .menu-link .menu-icon {
  color: var(--immo-menu-active-color) !important;
}

/* Menu Sub Items */
.menu-sub > .menu-item > .menu-link {
  color: var(--immo-text-secondary) !important;
}

.menu-sub > .menu-item > .menu-link:hover {
  color: var(--immo-text-primary) !important;
  background-color: var(--immo-sidebar-hover) !important;
}

.menu-sub > .menu-item.active > .menu-link {
  color: var(--immo-menu-active-color) !important;
}

/* Menu Header */
.menu-header {
  color: var(--immo-text-muted) !important;
  text-transform: uppercase;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}

/* Menu Icon */
.menu-icon {
  color: var(--immo-text-muted) !important;
}

.menu-item:hover .menu-icon,
.menu-item.active .menu-icon {
  color: var(--immo-menu-active-color) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   NAVBAR
   ══════════════════════════════════════════════════════════════════════════════ */
.layout-navbar,
.navbar {
  background-color: var(--immo-navbar-bg) !important;
  border-bottom: 1px solid var(--immo-navbar-border) !important;
}

.navbar-nav .nav-link {
  color: var(--immo-text-secondary) !important;
}

.navbar-nav .nav-link:hover {
  color: var(--immo-text-primary) !important;
}

.navbar-search-wrapper .search-input {
  background-color: var(--immo-body-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════════════════════════════════════════ */
.card {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05) !important;
}

[data-theme="dark"] .card {
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.2) !important;
}

.card-header {
  background-color: var(--immo-card-bg) !important;
  border-bottom-color: var(--immo-border-color) !important;
}

.card-footer {
  background-color: var(--immo-card-bg) !important;
  border-top-color: var(--immo-border-color) !important;
}

.card-title {
  color: var(--immo-text-primary) !important;
}

.card-subtitle {
  color: var(--immo-text-secondary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   BUTTONS - PRIMARY (Bordeaux in Light, Or in Dark)
   ══════════════════════════════════════════════════════════════════════════════ */
.btn-primary {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

[data-theme="light"] .btn-primary,
html:not([data-theme="dark"]) .btn-primary {
  color: #FFFFFF !important;
}

[data-theme="dark"] .btn-primary {
  color: #0D1117 !important;
}

.btn-primary:hover,
.btn-primary:focus {
  filter: brightness(1.1);
  box-shadow: 0 4px 12px rgba(var(--bs-primary-rgb), 0.4) !important;
}

/* Outline Primary */
.btn-outline-primary {
  color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  background-color: transparent !important;
}

.btn-outline-primary:hover {
  background-color: var(--bs-primary) !important;
  color: #FFFFFF !important;
}

[data-theme="dark"] .btn-outline-primary:hover {
  color: #0D1117 !important;
}

/* Bordeaux Button */
.btn-bordeaux {
  background-color: var(--immo-bordeaux) !important;
  border-color: var(--immo-bordeaux) !important;
  color: #FFFFFF !important;
}

.btn-bordeaux:hover {
  background-color: var(--immo-bordeaux-light) !important;
  border-color: var(--immo-bordeaux-light) !important;
}

/* Or/Gold Button */
.btn-or,
.btn-gold {
  background-color: var(--immo-or) !important;
  border-color: var(--immo-or) !important;
  color: #1A2A3A !important;
}

.btn-or:hover,
.btn-gold:hover {
  background-color: var(--immo-or-light) !important;
  border-color: var(--immo-or-light) !important;
}

/* Label Buttons */
.btn-label-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.15) !important;
  color: var(--bs-primary) !important;
  border-color: transparent !important;
}

.btn-label-primary:hover {
  background-color: var(--bs-primary) !important;
  color: #FFFFFF !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   BADGES
   ══════════════════════════════════════════════════════════════════════════════ */
.badge.bg-primary {
  background-color: var(--bs-primary) !important;
}

.badge.bg-label-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.15) !important;
  color: var(--bs-primary) !important;
}

/* Custom Badges */
.badge-or,
.badge-gold {
  background-color: rgba(201, 169, 110, 0.15) !important;
  color: var(--immo-or) !important;
}

.badge-bordeaux {
  background-color: rgba(92, 42, 52, 0.15) !important;
  color: var(--immo-bordeaux-light) !important;
}

[data-theme="dark"] .badge-bordeaux {
  color: #E07A8A !important;
}

/* Status Badges */
.badge-status-actif { background-color: rgba(63, 185, 80, 0.15) !important; color: #3FB950 !important; }
.badge-status-inactif { background-color: rgba(139, 148, 158, 0.15) !important; color: #8B949E !important; }
.badge-status-attente { background-color: rgba(210, 153, 34, 0.15) !important; color: #D29922 !important; }
.badge-status-impaye { background-color: rgba(248, 81, 73, 0.15) !important; color: #F85149 !important; }

/* ══════════════════════════════════════════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════════════════════════════════════════ */
.form-control,
.form-select {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

.form-control:focus,
.form-select:focus {
  border-color: var(--bs-primary) !important;
  box-shadow: 0 0 0 0.2rem rgba(var(--bs-primary-rgb), 0.25) !important;
}

.form-control::placeholder {
  color: var(--immo-text-muted) !important;
}

.form-label {
  color: var(--immo-text-primary) !important;
  font-weight: 500;
}

.form-text {
  color: var(--immo-text-muted) !important;
}

/* Input Groups */
.input-group-text {
  background-color: var(--immo-sidebar-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-secondary) !important;
}

/* Form Check */
.form-check-input:checked {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   TABLES
   ══════════════════════════════════════════════════════════════════════════════ */
.table {
  color: var(--immo-text-primary) !important;
}

.table > :not(caption) > * > * {
  background-color: var(--immo-card-bg) !important;
  border-bottom-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

.table-hover > tbody > tr:hover > * {
  background-color: var(--immo-sidebar-hover) !important;
}

.table thead th {
  background-color: var(--immo-sidebar-bg) !important;
  color: var(--immo-text-secondary) !important;
  border-bottom-color: var(--immo-border-color) !important;
  font-weight: 600;
  text-transform: uppercase;
  font-size: 0.75rem;
  letter-spacing: 0.05em;
}

.table-striped > tbody > tr:nth-of-type(odd) > * {
  background-color: rgba(var(--bs-primary-rgb), 0.02) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   DROPDOWNS
   ══════════════════════════════════════════════════════════════════════════════ */
.dropdown-menu {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.1) !important;
}

[data-theme="dark"] .dropdown-menu {
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.3) !important;
}

.dropdown-item {
  color: var(--immo-text-primary) !important;
}

.dropdown-item:hover,
.dropdown-item:focus {
  background-color: var(--immo-sidebar-hover) !important;
  color: var(--immo-text-primary) !important;
}

.dropdown-item.active {
  background-color: var(--immo-menu-active-bg) !important;
  color: var(--immo-menu-active-color) !important;
}

.dropdown-divider {
  border-color: var(--immo-border-color) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   MODALS
   ══════════════════════════════════════════════════════════════════════════════ */
.modal-content {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
}

.modal-header {
  border-bottom-color: var(--immo-border-color) !important;
}

.modal-footer {
  border-top-color: var(--immo-border-color) !important;
}

.modal-title {
  color: var(--immo-text-primary) !important;
}

.btn-close {
  filter: var(--immo-text-primary);
}

[data-theme="dark"] .btn-close {
  filter: invert(1);
}

/* ══════════════════════════════════════════════════════════════════════════════
   PAGINATION
   ══════════════════════════════════════════════════════════════════════════════ */
.page-link {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

.page-link:hover {
  background-color: var(--immo-sidebar-hover) !important;
}

.page-item.active .page-link {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

.page-item.disabled .page-link {
  background-color: var(--immo-sidebar-bg) !important;
  color: var(--immo-text-muted) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   ALERTS
   ══════════════════════════════════════════════════════════════════════════════ */
.alert-primary {
  background-color: rgba(var(--bs-primary-rgb), 0.1) !important;
  border-color: rgba(var(--bs-primary-rgb), 0.2) !important;
  color: var(--bs-primary) !important;
}

.alert-or {
  background-color: rgba(201, 169, 110, 0.1) !important;
  border-color: rgba(201, 169, 110, 0.2) !important;
  color: var(--immo-or) !important;
}

.alert-bordeaux {
  background-color: rgba(92, 42, 52, 0.1) !important;
  border-color: rgba(92, 42, 52, 0.2) !important;
  color: var(--immo-bordeaux) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   PROGRESS BARS
   ══════════════════════════════════════════════════════════════════════════════ */
.progress {
  background-color: var(--immo-sidebar-bg) !important;
}

.progress-bar {
  background-color: var(--bs-primary) !important;
}

.progress-bar-or {
  background-color: var(--immo-or) !important;
}

.progress-bar-bordeaux {
  background-color: var(--immo-bordeaux) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   NAV TABS & PILLS
   ══════════════════════════════════════════════════════════════════════════════ */
.nav-tabs {
  border-bottom-color: var(--immo-border-color) !important;
}

.nav-tabs .nav-link {
  color: var(--immo-text-secondary) !important;
}

.nav-tabs .nav-link:hover {
  border-color: var(--immo-border-color) !important;
}

.nav-tabs .nav-link.active {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) var(--immo-border-color) var(--immo-card-bg) !important;
  color: var(--bs-primary) !important;
}

.nav-pills .nav-link {
  color: var(--immo-text-secondary) !important;
}

.nav-pills .nav-link.active {
  background-color: var(--bs-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   APP BRAND / LOGO
   ══════════════════════════════════════════════════════════════════════════════ */
.app-brand-logo {
  height: 28px;
  width: auto;
}

.app-brand-logo img {
  height: 100%;
  width: auto;
}

/* Logo visibility based on theme */
.logo-light {
  display: block;
}

.logo-dark {
  display: none;
}

[data-theme="dark"] .logo-light {
  display: none;
}

[data-theme="dark"] .logo-dark {
  display: block;
}

/* App Brand Text */
.app-brand-text {
  font-weight: 700;
  font-size: 1.25rem;
  color: var(--immo-text-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   THEME SWITCHER BUTTON
   ══════════════════════════════════════════════════════════════════════════════ */
.theme-switcher {
  cursor: pointer;
  padding: 0.5rem;
  border-radius: 0.375rem;
  transition: background-color 0.2s ease;
  display: flex;
  align-items: center;
  justify-content: center;
}

.theme-switcher:hover {
  background-color: var(--immo-sidebar-hover);
}

.theme-switcher .ti-sun {
  display: none;
  color: var(--immo-or);
}

.theme-switcher .ti-moon {
  display: inline-block;
  color: var(--immo-text-secondary);
}

[data-theme="dark"] .theme-switcher .ti-sun {
  display: inline-block;
}

[data-theme="dark"] .theme-switcher .ti-moon {
  display: none;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SCROLLBAR CUSTOMIZATION
   ══════════════════════════════════════════════════════════════════════════════ */
::-webkit-scrollbar {
  width: 8px;
  height: 8px;
}

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

::-webkit-scrollbar-thumb {
  background: var(--immo-border-color);
  border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
  background: var(--immo-text-muted);
}

/* ══════════════════════════════════════════════════════════════════════════════
   DATATABLE OVERRIDES
   ══════════════════════════════════════════════════════════════════════════════ */
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

.dataTables_wrapper .dataTables_info {
  color: var(--immo-text-secondary) !important;
}

table.dataTable tbody tr {
  background-color: var(--immo-card-bg) !important;
}

table.dataTable tbody tr:hover {
  background-color: var(--immo-sidebar-hover) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SELECT2 OVERRIDES
   ══════════════════════════════════════════════════════════════════════════════ */
.select2-container--default .select2-selection--single,
.select2-container--default .select2-selection--multiple {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
}

.select2-container--default .select2-selection--single .select2-selection__rendered {
  color: var(--immo-text-primary) !important;
}

.select2-dropdown {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
}

.select2-container--default .select2-results__option--highlighted[aria-selected] {
  background-color: var(--bs-primary) !important;
}

.select2-container--default .select2-search--dropdown .select2-search__field {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   FLATPICKR OVERRIDES
   ══════════════════════════════════════════════════════════════════════════════ */
.flatpickr-calendar {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.15) !important;
}

.flatpickr-day {
  color: var(--immo-text-primary) !important;
}

.flatpickr-day:hover {
  background-color: var(--immo-sidebar-hover) !important;
}

.flatpickr-day.selected {
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

.flatpickr-months .flatpickr-month {
  background-color: var(--immo-card-bg) !important;
  color: var(--immo-text-primary) !important;
}

.flatpickr-current-month .flatpickr-monthDropdown-months {
  background-color: var(--immo-card-bg) !important;
  color: var(--immo-text-primary) !important;
}

.flatpickr-weekdays {
  background-color: var(--immo-card-bg) !important;
}

.flatpickr-weekday {
  color: var(--immo-text-secondary) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   APEX CHARTS
   ══════════════════════════════════════════════════════════════════════════════ */
.apexcharts-text {
  fill: var(--immo-text-secondary) !important;
}

.apexcharts-legend-text {
  color: var(--immo-text-primary) !important;
}

.apexcharts-tooltip {
  background-color: var(--immo-card-bg) !important;
  border-color: var(--immo-border-color) !important;
  color: var(--immo-text-primary) !important;
}

.apexcharts-tooltip-title {
  background-color: var(--immo-sidebar-bg) !important;
  border-bottom-color: var(--immo-border-color) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   DASHBOARD SPECIFIC STYLES
   ══════════════════════════════════════════════════════════════════════════════ */

/* Stats Cards */
.stats-card {
  border-left: 4px solid var(--bs-primary);
}

.stats-card.stats-bordeaux {
  border-left-color: var(--immo-bordeaux);
}

.stats-card.stats-or {
  border-left-color: var(--immo-or);
}

.stats-card.stats-success {
  border-left-color: var(--bs-success);
}

.stats-card.stats-warning {
  border-left-color: var(--bs-warning);
}

.stats-card.stats-danger {
  border-left-color: var(--bs-danger);
}

/* Welcome Banner */
.welcome-banner {
  background: linear-gradient(135deg, var(--immo-bordeaux) 0%, var(--immo-marine) 100%);
  color: #FFFFFF;
  border-radius: 0.5rem;
  padding: 2rem;
}

.welcome-banner h4 {
  color: #FFFFFF !important;
}

.welcome-banner p {
  color: rgba(255, 255, 255, 0.8);
}

/* Activity Timeline */
.timeline-item::before {
  background-color: var(--immo-border-color);
}

.timeline-indicator {
  background-color: var(--immo-card-bg);
  border-color: var(--bs-primary);
}

/* ══════════════════════════════════════════════════════════════════════════════
   UTILITIES
   ══════════════════════════════════════════════════════════════════════════════ */
.text-bordeaux { color: var(--immo-bordeaux) !important; }
.text-or, .text-gold { color: var(--immo-or) !important; }
.text-ivoire { color: var(--immo-ivoire) !important; }
.text-marine { color: var(--immo-marine) !important; }

.bg-bordeaux { background-color: var(--immo-bordeaux) !important; }
.bg-or, .bg-gold { background-color: var(--immo-or) !important; }
.bg-ivoire { background-color: var(--immo-ivoire) !important; }
.bg-marine { background-color: var(--immo-marine) !important; }
.bg-taupe { background-color: var(--immo-taupe) !important; }

.border-bordeaux { border-color: var(--immo-bordeaux) !important; }
.border-or, .border-gold { border-color: var(--immo-or) !important; }

/* Gradient backgrounds */
.bg-gradient-bordeaux {
  background: linear-gradient(135deg, var(--immo-bordeaux) 0%, var(--immo-bordeaux-dark) 100%) !important;
}

.bg-gradient-or {
  background: linear-gradient(135deg, var(--immo-or) 0%, var(--immo-or-dark) 100%) !important;
}

.bg-gradient-hero {
  background: linear-gradient(135deg, var(--immo-bordeaux) 0%, var(--immo-marine) 100%) !important;
}

/* ══════════════════════════════════════════════════════════════════════════════
   SMOOTH THEME TRANSITION
   ══════════════════════════════════════════════════════════════════════════════ */
body,
.card,
.menu,
.navbar,
.modal-content,
.dropdown-menu,
.form-control,
.form-select,
.table,
.btn,
.badge,
.alert {
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease, box-shadow 0.3s ease;
}

/* ══════════════════════════════════════════════════════════════════════════════
   PRINT STYLES
   ══════════════════════════════════════════════════════════════════════════════ */
@media print {
  body {
    background-color: #FFFFFF !important;
    color: #000000 !important;
  }
  
  .card {
    border: 1px solid #E0E0E0 !important;
    box-shadow: none !important;
  }
  
  .layout-menu,
  .navbar,
  .theme-switcher {
    display: none !important;
  }
}
