/* Brand Colors - black + chrome yellow */
:root {
  --brand-primary: #FBBF24; /* chrome yellow */
  --brand-primary-light: rgba(251, 191, 36, 0.16);
  --brand-black: #050507;
  --brand-black-soft: #0b0b10;
  --brand-primary-contrast: #0b0b10;
}

/* Admin login page background (match landing page style) */
.leannfitlogin-bg{
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(1100px 820px at 22% 18%, rgba(251, 191, 36, 0.18), transparent 55%),
    radial-gradient(900px 680px at 78% 30%, rgba(255, 255, 255, 0.07), transparent 60%),
    linear-gradient(180deg, #050507, #0b0b10) !important;
}

.dark .leannfitlogin-bg{
  background:
    radial-gradient(1100px 820px at 22% 18%, rgba(251, 191, 36, 0.22), transparent 55%),
    radial-gradient(900px 680px at 78% 30%, rgba(255, 255, 255, 0.06), transparent 60%),
    linear-gradient(180deg, #050507, #0b0b10) !important;
}

/* animated mesh layer */
.leannfitlogin-bg::before{
  content:"";
  position:absolute;
  inset:-20%;
  pointer-events:none;
  background:
    radial-gradient(900px 600px at 22% 20%, rgba(251,191,36,.18), transparent 55%),
    radial-gradient(750px 520px at 85% 28%, rgba(251,191,36,.10), transparent 55%),
    radial-gradient(900px 680px at 50% 85%, rgba(255,255,255,.08), transparent 55%),
    conic-gradient(from 220deg at 45% 55%, rgba(251,191,36,.10), rgba(255,255,255,.05), rgba(251,191,36,.08), rgba(0,0,0,0));
  filter: blur(38px) saturate(125%);
  opacity:.9;
  transform: translate3d(0,0,0);
  animation: leannfitMeshFloat 12s ease-in-out infinite;
  z-index:0;
}

/* subtle animated scanline glow */
.leannfitlogin-bg .leannfitlogin-sheen{
  position: absolute;
  inset: -25%;
  pointer-events: none;
  background: linear-gradient(120deg, transparent 35%, rgba(251,191,36,0.08) 50%, transparent 65%);
  transform: translate3d(-15%, -5%, 0) rotate(8deg);
  animation: leannfitSheen 7.5s ease-in-out infinite;
  mix-blend-mode: screen;
  opacity: 0.8;
}

@keyframes leannfitSheen{
  0%   { transform: translate3d(-18%, -6%, 0) rotate(8deg); opacity: .55; }
  50%  { transform: translate3d( 10%,  4%, 0) rotate(8deg); opacity: .85; }
  100% { transform: translate3d(-18%, -6%, 0) rotate(8deg); opacity: .55; }
}

/* grain + vignette */
.leannfitlogin-bg::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(1200px 900px at 50% 40%, transparent 35%, rgba(0,0,0,.55) 70%, rgba(0,0,0,.72) 100%),
    url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='220' height='220' filter='url(%23n)' opacity='.35'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  opacity:.22;
  z-index:0;
}

/* keep login content above bg layers */
.leannfitlogin-bg > *{
  position: relative;
  z-index: 1;
}

@keyframes leannfitMeshFloat{
  0%   { transform: translate3d(-1.5%, -1.0%, 0) scale(1.02) rotate(-1deg); }
  50%  { transform: translate3d( 2.0%,  1.5%, 0) scale(1.07) rotate( 1deg); }
  100% { transform: translate3d(-1.5%, -1.0%, 0) scale(1.02) rotate(-1deg); }
}

@media (prefers-reduced-motion: reduce){
  .leannfitlogin-bg::before{ animation:none; }
}

/* Admin top menu search bar - wider width */
.admin-top-menu-search-wrap {
  min-width: 220px;
  max-width: 380px;
  width: 100%;
}

/* Custom styles for login form messages */

.error-message {
  animation: slideInDown 0.3s ease-out;
}

.success-message {
  animation: slideInDown 0.3s ease-out;
}

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

/* Loading spinner styles */
.btn:disabled {
  cursor: not-allowed;
  opacity: 0.7;
}

.btn svg.animate-spin {
  animation: spin 1s linear infinite;
}

@keyframes spin {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(360deg);
  }
}

/* Form input focus styles - Using brand red */
.form-input:focus {
  border-color: var(--brand-red);
  box-shadow: 0 0 0 3px var(--brand-red-light);
}

/* Error input styles */
.form-input.error {
  border-color: #dc2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.1);
}

/* Success input styles */
.form-input.success {
  border-color: #059669;
  box-shadow: 0 0 0 3px rgba(5, 150, 105, 0.1);
}

/* Form select focus */
.form-select:focus {
  border-color: var(--brand-red);
  box-shadow: 0 0 0 3px var(--brand-red-light);
}

/* Textarea focus */
.form-textarea:focus {
  border-color: var(--brand-red);
  box-shadow: 0 0 0 3px var(--brand-red-light);
}

/* Multiselect focus */
.form-multiselect:focus {
  border-color: var(--brand-red);
  box-shadow: 0 0 0 3px var(--brand-red-light);
}

/* Active menu item accent */
.sidebar .nav-item > a.active::before,
.sidebar .nav-item > button.active::before {
  background-color: var(--brand-red) !important;
}

/* Active menu item text color */
.sidebar .nav-item > a.active,
.sidebar .nav-item > button.active {
  color: var(--brand-red) !important;
}

/* Side menu icons - Theme colored */
.sidebar .nav-item svg {
  color: var(--brand-red);
}

.sidebar .nav-item > a.active svg,
.sidebar .nav-item > button.active svg {
  color: var(--brand-red) !important;
}

/* LEAN N FIT logo - flat theme color */
.main-logo span,
.dark .main-logo span {
  color: var(--brand-primary) !important;
  -webkit-text-fill-color: var(--brand-primary);
  background: none;
}

/* Breadcrumb styles */
ul.flex.space-x-2 a.text-primary,
ul.flex.space-x-2 li a {
  color: var(--brand-primary) !important;
}

ul.flex.space-x-2 li[class*="before:content"] {
  color: var(--brand-primary) !important;
}

ul.flex.space-x-2 li[class*="before:content"]::before {
  color: var(--brand-primary) !important;
}

/* DataTable borders - theme color */
table.dataTable {
  border: 0.5px solid rgba(230, 21, 75, 0.5) !important;
  border-bottom: 0.5px solid rgba(230, 21, 75, 0.5) !important;
  border-collapse: separate;
  border-spacing: 0;
}

table.dataTable thead th {
  border-bottom: 0.5px solid rgba(230, 21, 75, 0.5) !important;
  border-right: 0.5px solid rgba(230, 21, 75, 0.5) !important;
}

table.dataTable thead th:last-child {
  border-right: none !important;
}

table.dataTable tbody td {
  border-bottom: 0.5px solid rgba(230, 21, 75, 0.5) !important;
  border-right: 0.5px solid rgba(230, 21, 75, 0.5) !important;
}

table.dataTable tbody tr:last-child td {
  border-bottom: 0.5px solid rgba(230, 21, 75, 0.5) !important;
}

table.dataTable tbody tr td:last-child {
  border-right: none !important;
}

/* DataTable action buttons - Keep original styles, no gradient */

/* Staff filter buttons - flat theme */
.filter-btn {
  background: transparent !important;
  border: 1px solid var(--brand-primary) !important;
  color: var(--brand-primary) !important;
  transition: all 0.3s ease;
}

.filter-btn:hover {
  background: var(--brand-primary-light) !important;
  border-color: var(--brand-primary) !important;
  color: var(--brand-primary) !important;
}

.filter-btn.active {
  background: var(--brand-primary) !important;
  border: 1px solid var(--brand-primary) !important;
  color: white !important;
  box-shadow: 0 2px 4px rgba(230, 21, 75, 0.3);
}

.filter-btn.active:hover {
  background: #c91240 !important;
  box-shadow: 0 4px 8px rgba(230, 21, 75, 0.4);
}

/* Primary buttons - chrome yellow */
.btn-primary {
  background: var(--brand-primary) !important;
  border: none !important;
  color: var(--brand-primary-contrast) !important;
  transition: all 0.3s ease;
}

.btn-primary:hover {
  background: #f59e0b !important;
  box-shadow: 0 10px 25px rgba(251, 191, 36, 0.18);
}

.btn-primary:active {
  transform: translateY(0);
}

/* Outline primary button */
.btn-outline-primary {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}

.btn-outline-primary:hover {
  background: var(--brand-primary) !important;
  color: var(--brand-primary-contrast) !important;
}

/* Badge outline primary */
.badge-outline-primary {
  border-color: var(--brand-primary);
  color: var(--brand-primary);
}

/* Brand colors for divider lines */
hr {
  border-color: rgba(215, 27, 54, 0.1);
}

/* Theme for active states in dropdowns */
.dropdown-menu > li > a.active,
.dropdown-menu > li > button.active {
  background-color: var(--brand-primary-light);
  color: var(--brand-primary);
}

/* Warning/attention elements */
.alert-warning,
.badge-warning {
  border-left: 3px solid var(--brand-primary);
}

/* Important notifications */
.alert-danger,
.badge-danger {
  border-left: 3px solid var(--brand-primary);
}

/* Note: Status badges (success, danger, warning, info, primary) keep their original colors unchanged */

/* Pagination active state */
.pagination .active a,
.pagination .active button {
  background-color: var(--brand-primary);
  border-color: var(--brand-primary);
  color: white;
}

/* Tabs */
.tabs-list .tab.active {
  border-bottom-color: var(--brand-primary);
  color: var(--brand-primary);
}

/* Loading spinner */
.screen_loader svg {
  fill: var(--brand-primary);
}

/* Checkbox and radio checked */
input[type="checkbox"]:checked,
input[type="radio"]:checked {
  background-color: var(--brand-primary);
  border-color: var(--brand-primary);
}

/* Range slider */
input[type="range"]::-webkit-slider-thumb {
  background-color: var(--brand-primary);
}

input[type="range"]::-moz-range-thumb {
  background-color: var(--brand-primary);
}

/* Progress bars */
.progress-bar {
  background-color: var(--brand-primary);
}

/* Scrollbar thumb */
::-webkit-scrollbar-thumb {
  background-color: rgba(230, 21, 75, 0.3);
}

/* LEAN N FIT glass text - flat theme */
.leannfitglass-text,
.leannfitglass-text {
  color: var(--brand-primary) !important;
  -webkit-text-fill-color: var(--brand-primary);
  background: none;
}

.dark .leannfitglass-text,
.dark .leannfitglass-text {
  color: var(--brand-primary) !important;
}

.leannfitglass-text::after,
.leannfitglass-text::after {
  content: 'LEAN N FIT';
  display: none;
}

/* Login button - chrome yellow */
.btn-login-theme {
  background: var(--brand-primary);
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  font-size: 16px;
  position: relative;
  overflow: hidden;
  color: var(--brand-primary-contrast);
}

.btn-login-theme:hover {
  background: #f59e0b;
}

.btn-login-theme::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.15), transparent);
  transition: left 0.5s;
}

.btn-login-theme:hover::before {
  left: 100%;
}

.btn-login-theme:hover {
  background: #c91240;
}

.btn-login-theme:active {
  transform: translateY(0);
}

/* Login page logo styling */
.login-logo {
  filter: drop-shadow(0 0 10px rgba(0, 0, 0, 0.2));
  transition: all 0.3s ease;
}

.dark .login-logo {
  filter: drop-shadow(0 0 15px rgba(255, 255, 255, 0.4));
}

.login-logo:hover {
  filter: drop-shadow(0 0 15px rgba(0, 0, 0, 0.3));
  transform: scale(1.03);
}

.dark .login-logo:hover {
  filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.6));
}

/* Login text logo: slow, one-by-one reveal */
.login-logo-text{
  display: inline-flex;
  align-items: baseline;
  justify-content: center;
  font-weight: 900;
  letter-spacing: 0.06em;
  line-height: 1;
  font-size: 2.75rem;
}

@media (min-width: 768px){
  .login-logo-text{ font-size: 3.5rem; }
}

.login-logo-text .logo-char{
  display: inline-block;
  opacity: 0;
  transform: translateY(10px);
  animation: leannfitLogoCharIn 900ms cubic-bezier(0.2, 0.75, 0.15, 1) forwards;
}

.login-logo-text .logo-space{
  width: 0.65ch;
}

.login-logo-text .logo-char:nth-child(1){ animation-delay: 120ms; }
.login-logo-text .logo-char:nth-child(2){ animation-delay: 200ms; }
.login-logo-text .logo-char:nth-child(3){ animation-delay: 280ms; }
.login-logo-text .logo-char:nth-child(4){ animation-delay: 360ms; }
.login-logo-text .logo-char:nth-child(5){ animation-delay: 440ms; }
.login-logo-text .logo-char:nth-child(6){ animation-delay: 520ms; }
.login-logo-text .logo-char:nth-child(7){ animation-delay: 600ms; }
.login-logo-text .logo-char:nth-child(8){ animation-delay: 680ms; }
.login-logo-text .logo-char:nth-child(9){ animation-delay: 760ms; }
.login-logo-text .logo-char:nth-child(10){ animation-delay: 840ms; }

@keyframes leannfitLogoCharIn{
  to{
    opacity: 1;
    transform: translateY(0);
  }
}

@media (prefers-reduced-motion: reduce){
  .login-logo-text .logo-char{
    animation: none;
    opacity: 1;
    transform: none;
  }
}

/* Login form inputs styling - Light and Dark mode support */
.login-form-container .form-input {
  background: rgba(255, 255, 255, 0.9);
  border: 1px solid rgba(0, 0, 0, 0.1);
  color: #1f2937;
  backdrop-filter: blur(10px);
}

.dark .login-form-container .form-input {
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid rgba(255, 255, 255, 0.2);
  color: white;
}

.login-form-container .form-input::placeholder {
  color: rgba(107, 114, 128, 0.7);
}

.dark .login-form-container .form-input::placeholder {
  color: rgba(255, 255, 255, 0.6);
}

.login-form-container .form-input:focus {
  background: rgba(255, 255, 255, 0.95);
  border-color: #E6154B;
  box-shadow: 0 0 0 3px rgba(230, 21, 75, 0.2);
  color: #1f2937;
}

.dark .login-form-container .form-input:focus {
  background: rgba(255, 255, 255, 0.15);
  border-color: #E6154B;
  box-shadow: 0 0 0 3px rgba(230, 21, 75, 0.2);
  color: white;
}

.login-form-container label {
  color: #374151;
  font-weight: 600;
}

.dark .login-form-container label {
  color: rgba(255, 255, 255, 0.9);
}

/* Vendor feature cards (E-commerce, Custom Search, Custom Barcode) – same design, light/dark */
.vendor-feature-card {
  padding: 1rem;
  border-radius: 0.5rem;
  border: 1px solid #e5e7eb;
  background-color: #f9fafb;
}

.dark .vendor-feature-card {
  background-color: #1b2e4b;
  border-color: #1b2e4b;
}

.vendor-feature-card-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: #374151;
  margin: 0;
}

.dark .vendor-feature-card-title {
  color: #d1d5db;
}

.vendor-feature-card-desc {
  font-size: 0.75rem;
  color: #6b7280;
  margin: 0.25rem 0 0 0;
}

.dark .vendor-feature-card-desc {
  color: #9ca3af;
}

/* Vendor feature toggles (E-commerce, Custom Search, Custom Barcode) – light/dark compatible */
.vendor-feature-toggle {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  flex-shrink: 0;
}

.vendor-feature-toggle-input {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
  pointer-events: none;
}

.vendor-feature-toggle-track {
  display: inline-flex;
  align-items: center;
  width: 2.75rem;
  height: 1.5rem;
  padding: 0.125rem;
  border-radius: 9999px;
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
  background-color: #d1d5db;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.05);
}

.dark .vendor-feature-toggle-track {
  background-color: #374151;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
}

.vendor-feature-toggle-input:focus-visible + .vendor-feature-toggle-track {
  outline: 2px solid var(--brand-red, #d71b36);
  outline-offset: 2px;
}

.vendor-feature-toggle-input:checked + .vendor-feature-toggle-track {
  background-color: var(--brand-red, #d71b36);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.1);
}

.dark .vendor-feature-toggle-input:checked + .vendor-feature-toggle-track {
  background-color: var(--brand-red, #d71b36);
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.2);
}

.vendor-feature-toggle-thumb {
  display: block;
  width: 1.25rem;
  height: 1.25rem;
  border-radius: 9999px;
  background-color: #ffffff;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.15);
  transition: transform 0.2s ease;
  pointer-events: none;
}

.dark .vendor-feature-toggle-thumb {
  background-color: #f3f4f6;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.3);
}

.vendor-feature-toggle-input:checked + .vendor-feature-toggle-track .vendor-feature-toggle-thumb {
  transform: translateX(1.25rem);
}

.vendor-feature-toggle-status {
  min-width: 4rem;
  font-weight: 500;
  font-size: 0.875rem;
}

.vendor-feature-toggle-status--on {
  color: #059669;
}

.dark .vendor-feature-toggle-status--on {
  color: #34d399;
}

.vendor-feature-toggle-status--off {
  color: #6b7280;
}

.dark .vendor-feature-toggle-status--off {
  color: #9ca3af;
}

/* Admin Users Management – actions column: same-size buttons in one row */
.admin-action-btn {
  min-width: 5.5rem;
  text-align: center;
  flex-shrink: 0;
}

/* Admin dashboard stat cards (home) - multi-color themes */
.leannfitstat-card{
  --leannfitaccent: 67 97 238; /* indigo-500 */
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 16px;
  background:
    radial-gradient(900px 240px at 18% 10%, rgba(var(--leannfitaccent) / 0.22), transparent 55%),
    linear-gradient(135deg, rgba(var(--leannfitaccent) / 0.11), rgba(var(--leannfitaccent) / 0.04));
  box-shadow: 0 10px 30px -18px rgba(var(--leannfitaccent) / 0.35);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.dark .leannfitstat-card{
  border-color: rgba(148, 163, 184, 0.18);
  background:
    radial-gradient(900px 240px at 18% 10%, rgba(var(--leannfitaccent) / 0.16), transparent 55%),
    linear-gradient(135deg, rgba(var(--leannfitaccent) / 0.14), rgba(var(--leannfitaccent) / 0.05));
}
/* Remove one-sided border strip; keep a soft highlight */
.leannfitstat-card::after{
  content:"";
  position:absolute;
  inset:-40% -30%;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.24), transparent 45%);
  transform: rotate(12deg);
  opacity:.24;
  pointer-events:none;
}
.leannfitstat-card:hover{
  transform: translateY(-2px);
  border-color: rgba(var(--leannfitaccent) / 0.30);
  box-shadow: 0 16px 40px -22px rgba(var(--leannfitaccent) / 0.46);
}
.leannfitstat-title{
  color: rgba(var(--leannfitaccent) / 0.92);
  letter-spacing: .2px;
}
.dark .leannfitstat-title{
  color: rgba(255, 255, 255, 0.88);
}
.leannfitstat-value{
  color: rgb(var(--leannfitaccent));
  letter-spacing: .3px;
}
.dark .leannfitstat-value{
  color: rgba(255, 255, 255, 0.95);
}
.leannfitstat-icon{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(var(--leannfitaccent) / 0.12);
  border: 1px solid rgba(var(--leannfitaccent) / 0.22);
  color: rgb(var(--leannfitaccent));
  box-shadow: 0 10px 20px -14px rgba(var(--leannfitaccent) / 0.40);
}
.dark .leannfitstat-icon{
  background: rgba(var(--leannfitaccent) / 0.16);
  border-color: rgba(var(--leannfitaccent) / 0.28);
  color: rgba(255,255,255,0.92);
}

.leannfitstat-card--indigo{ --leannfitaccent: 67 97 238; }
.leannfitstat-card--emerald{ --leannfitaccent: 16 185 129; }
.leannfitstat-card--amber{ --leannfitaccent: 245 158 11; }
.leannfitstat-card--rose{ --leannfitaccent: 244 63 94; }

/* Override main template primary (#4361ee) with LEAN N FIT theme #E6154B */
.text-primary,
a.text-primary,
.hover\:text-primary:hover,
.group-hover\:\!text-primary.group:hover,
.sidebar .nav-link.group:hover span {
  color: #E6154B !important;
}

.bg-primary,
.hover\:bg-primary:hover {
  background-color: #E6154B !important;
}

.border-primary,
.btn-outline-primary,
.hover\:border-primary:hover {
  border-color: #E6154B !important;
}

.sidebar .nav-item .nav-link.group:hover svg {
  color: #E6154B !important;
}

