/* ============================================================
   Jolle Admin Theme — #712dec purple, clean white design
   ============================================================ */

/* Page background */
html > body {
  background: #f3f4f6 !important;
}

/* ===== TOP NAVBAR — white like Jolle ===== */
.main-content .navbar-top {
  background-color: #ffffff !important;
  backdrop-filter: none !important;
  border-bottom: 1px solid #e5e7eb !important;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06) !important;
}
.lw-guest-page .main-content .navbar-top {
  background-color: #ffffff !important;
}
.navbar#navbar-main .h4 {
  color: #111827 !important;
}
.navbar#navbar-main .nav-link {
  color: #374151 !important;
}
.navbar#navbar-main .nav-link i {
  color: #6b7280 !important;
}
.navbar#navbar-main .media-body span {
  color: #111827 !important;
}
/* Logged-as-vendor bar */
.navbar#navbar-main a.lw-ajax-link-action.px-5 {
  color: #712dec !important;
}

/* ===== SIDEBAR ===== */
nav.lw-sidebar-container {
  background: #ffffff !important;
  border-right: 1px solid #e5e7eb !important;
  box-shadow: 2px 0 12px rgba(0, 0, 0, 0.05) !important;
}

/* Brand area */
nav.lw-sidebar-container .navbar-brand {
  padding: 0.75rem 0.75rem !important;
}

/* Full logo — expanded state */
nav.lw-sidebar-container .navbar-brand img.lw-sidebar-logo-normal {
  display: inline-block !important;
  height: 34px !important;
  width: auto !important;
  max-width: 160px !important;
  min-height: unset !important;
  object-fit: contain !important;
}

/* Hamburger icon — hidden by default */
.lw-logo-icon {
  display: none !important;
  width: 36px !important;
  height: 36px !important;
  background: transparent !important;
  color: #712dec !important;
  border-radius: 8px !important;
  font-size: 20px !important;
  align-items: center !important;
  justify-content: center !important;
  cursor: pointer !important;
}

/* Minimized (collapsed) state: hide full logo, show letter icon */
.lw-minimized-menu .navbar-vertical.navbar-expand-md > .container-fluid img.lw-sidebar-logo-normal {
  display: none !important;
}
.lw-minimized-menu .navbar-vertical.navbar-expand-md > .container-fluid .lw-logo-icon {
  display: inline-flex !important;
}

/* Hovered/focused: show full logo, hide letter icon */
.lw-minimized-menu .navbar-vertical.navbar-expand-md:hover > .container-fluid img.lw-sidebar-logo-normal,
.lw-minimized-menu .navbar-vertical.navbar-expand-md:focus-within > .container-fluid img.lw-sidebar-logo-normal {
  display: inline-block !important;
}
.lw-minimized-menu .navbar-vertical.navbar-expand-md:hover > .container-fluid .lw-logo-icon,
.lw-minimized-menu .navbar-vertical.navbar-expand-md:focus-within > .container-fluid .lw-logo-icon {
  display: none !important;
}

/* Nav wrapper spacing */
nav.lw-sidebar-container .navbar-nav {
  padding: 0.5rem 0.625rem 1rem !important;
}

/* ── Primary nav links ── */
.navbar-light .navbar-nav .nav-link {
  color: #4b5563 !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  border-radius: 0.75rem !important;
  margin: 2px 0 !important;
  padding: 0.625rem 0.875rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  transition: background-color 0.15s, color 0.15s !important;
  position: relative !important;
}
.navbar-light .navbar-nav .nav-link i,
.navbar-light .navbar-nav .nav-link .fa,
.navbar-light .navbar-nav .nav-link .fas,
.navbar-light .navbar-nav .nav-link .fab {
  width: 18px !important;
  text-align: center !important;
  font-size: 0.875rem !important;
  color: #9ca3af !important;
  flex-shrink: 0 !important;
}
.navbar-light .navbar-nav .nav-link:hover {
  background-color: #f3ecff !important;
  color: #712dec !important;
}
.navbar-light .navbar-nav .nav-link:hover i,
.navbar-light .navbar-nav .nav-link:hover .fa,
.navbar-light .navbar-nav .nav-link:hover .fas,
.navbar-light .navbar-nav .nav-link:hover .fab {
  color: #712dec !important;
}

/* ── Active state ── */
.navbar-light .navbar-nav .nav-link.active,
.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.show,
.navbar-light .navbar-nav .show > .nav-link {
  background-color: #f3ecff !important;
  color: #712dec !important;
  font-weight: 600 !important;
}
.navbar-light .navbar-nav .nav-link.active i,
.navbar-light .navbar-nav .active > .nav-link i,
.navbar-light .navbar-nav .nav-link.active .fa,
.navbar-light .navbar-nav .nav-link.active .fas,
.navbar-light .navbar-nav .nav-link.active .fab {
  color: #712dec !important;
}

/* ── Sub-menu links ── */
.navbar-nav .lw-expandable-nav {
  margin-left: 0.5rem !important;
  border-left: 2px solid #f0e8ff !important;
  padding-left: 0.75rem !important;
  margin-top: 2px !important;
  margin-bottom: 4px !important;
}
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link {
  color: #6b7280 !important;
  font-size: 0.83rem !important;
  font-weight: 500 !important;
  border-radius: 0.625rem !important;
  margin: 1px 0 !important;
  padding: 0.5rem 0.75rem !important;
}
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link i,
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link .fa {
  font-size: 0.78rem !important;
  color: #c4b5fd !important;
  width: 16px !important;
}
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link:hover {
  background-color: #f3ecff !important;
  color: #712dec !important;
}
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link:hover i,
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link:hover .fa {
  color: #712dec !important;
}
.navbar-nav .lw-expandable-nav .nav .nav-item .nav-link.active {
  background-color: #f3ecff !important;
  color: #712dec !important;
  font-weight: 600 !important;
}

/* ── Active left border indicator (minimized menu) ── */
.lw-minimized-menu .navbar-vertical.navbar-expand-md .navbar-nav .nav-link.active:before {
  border-left-color: #712dec !important;
}

/* ── Jolle restaurant card in sidebar — remove gradient ── */
nav.lw-sidebar-container .navbar-nav li .mx-2 {
  background: #712dec !important;
  border-radius: 12px !important;
}

/* ── Sidebar divider between sections ── */
nav.lw-sidebar-container .navbar-nav > .nav-item + .nav-item.mt-3,
nav.lw-sidebar-container .navbar-nav .nav-divider {
  border-top: 1px solid #f3f4f6 !important;
  margin-top: 6px !important;
  padding-top: 6px !important;
}

/* ===== CARDS ===== */
.card {
  border-radius: 1rem !important;
  border: 1px solid #e5e7eb !important;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.06) !important;
  background-color: #ffffff !important;
  backdrop-filter: none !important;
}
.card-header {
  border-radius: 1rem 1rem 0 0 !important;
  border-bottom: 1px solid #f3f4f6 !important;
  background-color: #ffffff !important;
}
.card-footer {
  border-radius: 0 0 1rem 1rem !important;
  background-color: #f9fafb !important;
  border-top: 1px solid #f3f4f6 !important;
}
.card.card-stats .card-body {
  border-radius: 1rem !important;
}

/* ===== BUTTONS ===== */
.btn {
  border-radius: 0.625rem !important;
  font-weight: 500 !important;
}
.btn.btn-primary {
  background-color: #712dec !important;
  border-color: #712dec !important;
  color: #fff !important;
}
.btn.btn-primary:hover,
.btn.btn-primary:focus,
.btn.btn-primary:not(:disabled):not(.disabled):active {
  background-color: #5a1eb8 !important;
  border-color: #5a1eb8 !important;
}
.btn.btn-success {
  background-color: #712dec !important;
  border-color: #712dec !important;
  color: #fff !important;
}
.btn.btn-success:hover,
.btn.btn-success:focus {
  background-color: #5a1eb8 !important;
  border-color: #5a1eb8 !important;
}
.btn.btn-outline-primary {
  color: #712dec !important;
  border-color: #712dec !important;
}
.btn.btn-outline-primary:hover {
  background-color: #712dec !important;
  color: #fff !important;
}
.btn.btn-outline-success {
  color: #712dec !important;
  border-color: #712dec !important;
}
.btn.btn-outline-success:hover {
  background-color: #712dec !important;
  color: #fff !important;
}

/* ===== LINKS (fix green) ===== */
a {
  color: #712dec !important;
}
a:hover {
  color: #5a1eb8 !important;
}
/* Nav links inherit their own color system */
.navbar-nav .nav-link,
.nav-tabs .nav-link,
.dropdown-item,
.btn,
.badge,
.breadcrumb-item a,
.pagination .page-link {
  color: inherit !important;
}
.navbar-light .navbar-nav .nav-link {
  color: #4b5563 !important;
}

/* ===== PAGE TITLES ===== */
.lw-page-title {
  color: #712dec !important;
}

/* ===== TEXT UTILITIES ===== */
.text-primary {
  color: #712dec !important;
}
.text-success {
  color: #712dec !important;
}
a.text-primary,
a.text-primary:hover,
a.text-success,
a.text-success:hover {
  color: #712dec !important;
}

/* ===== BACKGROUND UTILITIES ===== */
.bg-primary {
  background-color: #712dec !important;
}
.bg-success {
  background-color: #712dec !important;
}
.bg-gradient-primary {
  background: #712dec !important;
}

/* ===== BADGES ===== */
.badge-primary,
.badge.badge-primary {
  background-color: #712dec !important;
  color: #fff !important;
}
.badge-success,
.badge.badge-success {
  background-color: #712dec !important;
  color: #fff !important;
}

/* ===== PAGINATION ===== */
.page-item.active .page-link {
  background-color: #712dec !important;
  border-color: #712dec !important;
  color: #fff !important;
}
.page-link {
  color: #712dec !important;
}
.page-link:hover {
  color: #5a1eb8 !important;
}

/* ===== NAV TABS ===== */
.nav-tabs .nav-link.active {
  color: #712dec !important;
  border-bottom-color: #712dec !important;
}

/* ===== DROPDOWN ===== */
.dropdown-item.active,
.dropdown-item:active {
  background-color: #712dec !important;
  color: #fff !important;
}
.dropdown-item {
  color: #374151 !important;
}
.dropdown-item:hover {
  color: #712dec !important;
  background-color: #f3ecff !important;
}

/* ===== FORM CONTROLS ===== */
.form-control {
  border-radius: 0.5rem !important;
  border-color: #d1d5db !important;
}
.form-control:focus {
  border-color: #712dec !important;
  box-shadow: 0 0 0 2px rgba(113, 45, 236, 0.15) !important;
}
.input-group-alternative {
  border-color: #d1d5db !important;
}

/* ===== TABLES ===== */
.table thead th {
  background-color: #f9fafb !important;
  color: #6b7280 !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
  border-bottom: 1px solid #e5e7eb !important;
}
.dataTables_wrapper table.dataTable.table thead th {
  background-color: #f9fafb !important;
}

/* ===== ALERTS ===== */
.alert-primary {
  background-color: rgba(113, 45, 236, 0.1) !important;
  border-color: rgba(113, 45, 236, 0.25) !important;
  color: #5a1eb8 !important;
}
.alert-success {
  background-color: rgba(113, 45, 236, 0.1) !important;
  border-color: rgba(113, 45, 236, 0.25) !important;
  color: #5a1eb8 !important;
}
/* Keep danger alerts visually red for error communication */
.alert.alert-danger {
  background-color: #fef2f2 !important;
  border-color: #fca5a5 !important;
  color: #991b1b !important;
}
.alert.alert-warning {
  background-color: #fffbeb !important;
  border-color: #fcd34d !important;
  color: #92400e !important;
}

/* ===== MODALS ===== */
.modal .modal-header {
  border-bottom: 1px solid #e5e7eb !important;
}
.modal-header .close:hover {
  color: #712dec !important;
}

/* ===== SWAL CONFIRM ===== */
div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm {
  background-color: #712dec !important;
  border-left-color: #5a1eb8 !important;
  border-right-color: #5a1eb8 !important;
}
div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm:focus {
  box-shadow: 0 0 0 3px rgba(113, 45, 236, 0.3) !important;
}

/* ===== MDTOAST ===== */
.mdtoast.mdt--primary {
  background-color: #712dec !important;
}
.mdtoast.mdt--success {
  background-color: #712dec !important;
}

/* ===== CHAT COMPONENTS ===== */
.card.lw-whatsapp-chat-block-container .lw-whatsapp-chat-window .user-bar {
  background-color: #3d19a0 !important;
}
.card.lw-whatsapp-chat-block-container .nav-tabs {
  border-color: #712dec !important;
}
.card.lw-whatsapp-chat-block-container .lw-whatsapp-chat-window .conversation-compose .send .circle {
  background-color: #712dec !important;
  border-color: #5a1eb8 !important;
}

/* ===== PROGRESS BARS ===== */
.progress-bar {
  background-color: #712dec !important;
}
.progress-bar-striped {
  background-image: linear-gradient(45deg, rgba(255,255,255,.15) 25%, transparent 25%, transparent 50%, rgba(255,255,255,.15) 50%, rgba(255,255,255,.15) 75%, transparent 75%, transparent) !important;
}

/* ===== BREADCRUMB ===== */
nav.lw-breadcrumb-container {
  background-color: #1e1b4b !important;
  border-radius: 0.75rem !important;
}

/* ===== CUSTOM SELECT ===== */
.custom-select:focus {
  border-color: #712dec !important;
  box-shadow: 0 0 0 2px rgba(113, 45, 236, 0.15) !important;
}

/* ===== UNREAD MESSAGE BADGE ===== */
.badge-success.rounded-pill {
  background-color: #712dec !important;
}

/* ===== FIELDSET LEGEND ===== */
fieldset legend {
  color: #712dec !important;
  border-color: rgba(113, 45, 236, 0.2) !important;
}

/* ===== STAT CARD ICON CIRCLES — all Jolle purple ===== */
.card-stats .icon-shape,
.icon.icon-shape {
  background: #712dec !important;
  border: none !important;
  box-shadow: 0 4px 12px rgba(113, 45, 236, 0.3) !important;
}
.icon.icon-shape.bg-danger,
.icon.icon-shape.bg-warning,
.icon.icon-shape.bg-info,
.icon.icon-shape.bg-success,
.icon.icon-shape.bg-primary,
.icon.icon-shape.bg-default {
  background: #712dec !important;
  box-shadow: 0 4px 12px rgba(113, 45, 236, 0.3) !important;
}

/* ===== STAT CARDS — Jolle-style clean cards ===== */
.card.card-stats {
  border-radius: 1rem !important;
  border: 1px solid #e5e7eb !important;
  box-shadow: 0 1px 4px rgba(0,0,0,0.06) !important;
  background: #ffffff !important;
  transition: box-shadow 0.2s ease, transform 0.2s ease !important;
}
.card.card-stats:hover {
  box-shadow: 0 4px 16px rgba(113, 45, 236, 0.12) !important;
  transform: translateY(-1px) !important;
}
.card.card-stats .card-body {
  border-radius: 1rem !important;
  padding: 1.25rem 1.5rem !important;
}
.card.card-stats .card-title {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  color: #9ca3af !important;
}
.card.card-stats .h2 {
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  color: #111827 !important;
}

/* ===== CHART CARD (dark gradient → white) ===== */
.card.bg-gradient-default,
.card.bg-default {
  background: #ffffff !important;
  color: #111827 !important;
}
.card.bg-gradient-default .card-header,
.card.bg-default .card-header {
  background: #ffffff !important;
  border-bottom: 1px solid #f3f4f6 !important;
}
.card.bg-gradient-default .text-light,
.card.bg-gradient-default .text-white,
.card.bg-default .text-light,
.card.bg-default .text-white {
  color: #6b7280 !important;
}
.card.bg-gradient-default h2.text-white,
.card.bg-default h2.text-white {
  color: #111827 !important;
}

/* ===== BG-DANGER / BG-WARNING OVERRIDE (global) ===== */
.bg-danger {
  background-color: #712dec !important;
}
.bg-info {
  background-color: #712dec !important;
}
/* Keep warning as a warm accent for visual variety */
.bg-warning {
  background-color: #f59e0b !important;
}

/* ===== DATATABLE EXPAND/COLLAPSE BUTTONS ===== */
table.dataTable.dtr-inline.collapsed > tbody > tr > td:first-child:before,
table.dataTable.dtr-inline.collapsed > tbody > tr > th:first-child:before,
table.dataTable.dtr-column > tbody > tr > td.control:before,
table.dataTable.dtr-column > tbody > tr > th.control:before {
  background-color: #712dec !important;
}

/* ===== ACTIVE BUTTON STATES ===== */
.btn.btn-primary:not(:disabled):not(.disabled).active,
.btn.btn-primary:not(:disabled):not(.disabled):active,
.show > .btn.btn-primary.dropdown-toggle {
  background-color: #5a1eb8 !important;
  border-color: #5a1eb8 !important;
}

/* ===== ACTIVE NAV LINK (sidebar) ===== */
.navbar-light .navbar-nav .active > .nav-link,
.navbar-light .navbar-nav .nav-link.active {
  color: #712dec !important;
}

/* ===== MINI SIDEBAR LEFT BORDER ===== */
.lw-minimized-menu .navbar-vertical.navbar-expand-md .navbar-nav .nav-link.active:before {
  border-left: 2px solid #712dec !important;
}
