﻿/**
 * Main Stylesheet - Rebelhorn-inspired E-commerce Template
 */

@import url('./variables.css');
@import url('./reset.css');

/* ==========================================================================
   Layout Components
   ========================================================================== */

.container,
.container-fluid,
.container-sm,
.container-md,
.container-lg,
.container-xl,
.container-xxl {
    width: 100%;
    padding-right: var(--page-x-padding-md);
    padding-left: var(--page-x-padding-md);
    margin-right: auto;
    margin-left: auto;
}

.container {
  max-width: var(--container-max-width, 1400px);
}

/* Responsive Containers */
@media (min-width: 576px) {
  .container-sm, .container {
    max-width: 540px;
  }
}

@media (min-width: 768px) {
  .container-sm, .container-md, .container {
    max-width: 720px;
  }
}

@media (min-width: 992px) {
  .container-sm, .container-md, .container-lg, .container {
    max-width: 960px;
  }
}

@media (min-width: 1200px) {
  .container-sm, .container-md, .container-lg, .container-xl, .container {
    max-width: 1140px;
  }
}

@media (min-width: 1400px) {
  .container-sm, .container-md, .container-lg, .container-xl, .container-xxl, .container {
    max-width: 1320px;
  }
}

/* Row */
.row {
  --bs-gutter-x: var(--spacing-md);
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-right: calc(var(--bs-gutter-x) * -0.5);
  margin-left: calc(var(--bs-gutter-x) * -0.5);
  margin-top: calc(var(--bs-gutter-y) * -1);
}

.row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-top: var(--bs-gutter-y);
}

/* Base Column Classes */
.col {
  flex: 1 0 0%;
}

.col-auto {
  flex: 0 0 auto;
  width: auto;
}

/* Fixed Width Columns (work at all sizes) */
.col-1 { flex: 0 0 auto; width: 8.333333%; }
.col-2 { flex: 0 0 auto; width: 16.666667%; }
.col-3 { flex: 0 0 auto; width: 25%; }
.col-4 { flex: 0 0 auto; width: 33.333333%; }
.col-5 { flex: 0 0 auto; width: 41.666667%; }
.col-6 { flex: 0 0 auto; width: 50%; }
.col-7 { flex: 0 0 auto; width: 58.333333%; }
.col-8 { flex: 0 0 auto; width: 66.666667%; }
.col-9 { flex: 0 0 auto; width: 75%; }
.col-10 { flex: 0 0 auto; width: 83.333333%; }
.col-11 { flex: 0 0 auto; width: 91.666667%; }
.col-12 { flex: 0 0 auto; width: 100%; }

/* Row Columns */
.row-cols-auto > * {
  flex: 0 0 auto;
  width: auto;
}

.row-cols-1 > * { flex: 0 0 auto; width: 100%; }
.row-cols-2 > * { flex: 0 0 auto; width: 50%; }
.row-cols-3 > * { flex: 0 0 auto; width: 33.333333%; }
.row-cols-4 > * { flex: 0 0 auto; width: 25%; }
.row-cols-5 > * { flex: 0 0 auto; width: 20%; }
.row-cols-6 > * { flex: 0 0 auto; width: 16.666667%; }

/* Offset Classes */
.offset-1 { margin-left: 8.333333%; }
.offset-2 { margin-left: 16.666667%; }
.offset-3 { margin-left: 25%; }
.offset-4 { margin-left: 33.333333%; }
.offset-5 { margin-left: 41.666667%; }
.offset-6 { margin-left: 50%; }
.offset-7 { margin-left: 58.333333%; }
.offset-8 { margin-left: 66.666667%; }
.offset-9 { margin-left: 75%; }
.offset-10 { margin-left: 83.333333%; }
.offset-11 { margin-left: 91.666667%; }

/* Order Classes */
.order-first { order: -1; }
.order-0 { order: 0; }
.order-1 { order: 1; }
.order-2 { order: 2; }
.order-3 { order: 3; }
.order-4 { order: 4; }
.order-5 { order: 5; }
.order-last { order: 6; }

/* Gutter / Gap Utilities - Bootstrap 5.3 compliant */
.g-0 {
  --bs-gutter-x: 0;
  --bs-gutter-y: 0;
}

.g-1 {
  --bs-gutter-x: var(--spacing-xs);
  --bs-gutter-y: var(--spacing-xs);
}

.g-2 {
  --bs-gutter-x: var(--spacing-sm);
  --bs-gutter-y: var(--spacing-sm);
}

.g-3 {
  --bs-gutter-x: var(--spacing-md);
  --bs-gutter-y: var(--spacing-md);
}

.g-4 {
  --bs-gutter-x: var(--spacing-lg);
  --bs-gutter-y: var(--spacing-lg);
}

.g-5 {
  --bs-gutter-x: var(--spacing-xl);
  --bs-gutter-y: var(--spacing-xl);
}

.gx-0 { --bs-gutter-x: 0; }
.gx-1 { --bs-gutter-x: var(--spacing-xs); }
.gx-2 { --bs-gutter-x: var(--spacing-sm); }
.gx-3 { --bs-gutter-x: var(--spacing-md); }
.gx-4 { --bs-gutter-x: var(--spacing-lg); }
.gx-5 { --bs-gutter-x: var(--spacing-xl); }

.gy-0 { --bs-gutter-y: 0; }
.gy-1 { --bs-gutter-y: var(--spacing-xs); }
.gy-2 { --bs-gutter-y: var(--spacing-sm); }
.gy-3 { --bs-gutter-y: var(--spacing-md); }
.gy-4 { --bs-gutter-y: var(--spacing-lg); }
.gy-5 { --bs-gutter-y: var(--spacing-xl); }


/* Small (sm) - ≥576px */
@media (min-width: 576px) {
  .col-sm { flex: 1 0 0%; }
  .col-sm-auto { flex: 0 0 auto; width: auto; }
  
  .col-sm-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-sm-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-sm-3 { flex: 0 0 auto; width: 25%; }
  .col-sm-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-sm-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-sm-6 { flex: 0 0 auto; width: 50%; }
  .col-sm-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-sm-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-sm-9 { flex: 0 0 auto; width: 75%; }
  .col-sm-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-sm-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-sm-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-sm-0 { margin-left: 0; }
  .offset-sm-1 { margin-left: 8.333333%; }
  .offset-sm-2 { margin-left: 16.666667%; }
  .offset-sm-3 { margin-left: 25%; }
  .offset-sm-4 { margin-left: 33.333333%; }
  .offset-sm-5 { margin-left: 41.666667%; }
  .offset-sm-6 { margin-left: 50%; }
  .offset-sm-7 { margin-left: 58.333333%; }
  .offset-sm-8 { margin-left: 66.666667%; }
  .offset-sm-9 { margin-left: 75%; }
  .offset-sm-10 { margin-left: 83.333333%; }
  .offset-sm-11 { margin-left: 91.666667%; }
  
  .order-sm-first { order: -1; }
  .order-sm-0 { order: 0; }
  .order-sm-1 { order: 1; }
  .order-sm-2 { order: 2; }
  .order-sm-3 { order: 3; }
  .order-sm-4 { order: 4; }
  .order-sm-5 { order: 5; }
  .order-sm-last { order: 6; }
  
  .row-cols-sm-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-sm-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-sm-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-sm-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-sm-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-sm-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-sm-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Medium (md) - ≥768px */
@media (min-width: 768px) {
  .col-md { flex: 1 0 0%; }
  .col-md-auto { flex: 0 0 auto; width: auto; }
  
  .col-md-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-md-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-md-3 { flex: 0 0 auto; width: 25%; }
  .col-md-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-md-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-md-6 { flex: 0 0 auto; width: 50%; }
  .col-md-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-md-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-md-9 { flex: 0 0 auto; width: 75%; }
  .col-md-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-md-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-md-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-md-0 { margin-left: 0; }
  .offset-md-1 { margin-left: 8.333333%; }
  .offset-md-2 { margin-left: 16.666667%; }
  .offset-md-3 { margin-left: 25%; }
  .offset-md-4 { margin-left: 33.333333%; }
  .offset-md-5 { margin-left: 41.666667%; }
  .offset-md-6 { margin-left: 50%; }
  .offset-md-7 { margin-left: 58.333333%; }
  .offset-md-8 { margin-left: 66.666667%; }
  .offset-md-9 { margin-left: 75%; }
  .offset-md-10 { margin-left: 83.333333%; }
  .offset-md-11 { margin-left: 91.666667%; }
  
  .order-md-first { order: -1; }
  .order-md-0 { order: 0; }
  .order-md-1 { order: 1; }
  .order-md-2 { order: 2; }
  .order-md-3 { order: 3; }
  .order-md-4 { order: 4; }
  .order-md-5 { order: 5; }
  .order-md-last { order: 6; }
  
  .row-cols-md-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-md-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-md-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-md-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-md-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-md-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-md-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Large (lg) - ≥992px */
@media (min-width: 992px) {
  .col-lg { flex: 1 0 0%; }
  .col-lg-auto { flex: 0 0 auto; width: auto; }
  
  .col-lg-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-lg-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-lg-3 { flex: 0 0 auto; width: 25%; }
  .col-lg-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-lg-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-lg-6 { flex: 0 0 auto; width: 50%; }
  .col-lg-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-lg-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-lg-9 { flex: 0 0 auto; width: 75%; }
  .col-lg-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-lg-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-lg-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-lg-0 { margin-left: 0; }
  .offset-lg-1 { margin-left: 8.333333%; }
  .offset-lg-2 { margin-left: 16.666667%; }
  .offset-lg-3 { margin-left: 25%; }
  .offset-lg-4 { margin-left: 33.333333%; }
  .offset-lg-5 { margin-left: 41.666667%; }
  .offset-lg-6 { margin-left: 50%; }
  .offset-lg-7 { margin-left: 58.333333%; }
  .offset-lg-8 { margin-left: 66.666667%; }
  .offset-lg-9 { margin-left: 75%; }
  .offset-lg-10 { margin-left: 83.333333%; }
  .offset-lg-11 { margin-left: 91.666667%; }
  
  .order-lg-first { order: -1; }
  .order-lg-0 { order: 0; }
  .order-lg-1 { order: 1; }
  .order-lg-2 { order: 2; }
  .order-lg-3 { order: 3; }
  .order-lg-4 { order: 4; }
  .order-lg-5 { order: 5; }
  .order-lg-last { order: 6; }
  
  .row-cols-lg-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-lg-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-lg-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-lg-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-lg-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-lg-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-lg-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Extra Large (xl) - ≥1200px */
@media (min-width: 1200px) {
  .col-xl { flex: 1 0 0%; }
  .col-xl-auto { flex: 0 0 auto; width: auto; }
  
  .col-xl-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-xl-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-xl-3 { flex: 0 0 auto; width: 25%; }
  .col-xl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xl-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-xl-6 { flex: 0 0 auto; width: 50%; }
  .col-xl-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-xl-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-xl-9 { flex: 0 0 auto; width: 75%; }
  .col-xl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xl-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-xl-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-xl-0 { margin-left: 0; }
  .offset-xl-1 { margin-left: 8.333333%; }
  .offset-xl-2 { margin-left: 16.666667%; }
  .offset-xl-3 { margin-left: 25%; }
  .offset-xl-4 { margin-left: 33.333333%; }
  .offset-xl-5 { margin-left: 41.666667%; }
  .offset-xl-6 { margin-left: 50%; }
  .offset-xl-7 { margin-left: 58.333333%; }
  .offset-xl-8 { margin-left: 66.666667%; }
  .offset-xl-9 { margin-left: 75%; }
  .offset-xl-10 { margin-left: 83.333333%; }
  .offset-xl-11 { margin-left: 91.666667%; }
  
  .order-xl-first { order: -1; }
  .order-xl-0 { order: 0; }
  .order-xl-1 { order: 1; }
  .order-xl-2 { order: 2; }
  .order-xl-3 { order: 3; }
  .order-xl-4 { order: 4; }
  .order-xl-5 { order: 5; }
  .order-xl-last { order: 6; }
  
  .row-cols-xl-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-xl-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-xl-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-xl-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-xl-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-xl-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-xl-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Extra Extra Large (xxl) - ≥1400px */
@media (min-width: 1400px) {
  .col-xxl { flex: 1 0 0%; }
  .col-xxl-auto { flex: 0 0 auto; width: auto; }
  
  .col-xxl-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-xxl-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-xxl-3 { flex: 0 0 auto; width: 25%; }
  .col-xxl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xxl-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-xxl-6 { flex: 0 0 auto; width: 50%; }
  .col-xxl-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-xxl-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-xxl-9 { flex: 0 0 auto; width: 75%; }
  .col-xxl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xxl-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-xxl-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-xxl-0 { margin-left: 0; }
  .offset-xxl-1 { margin-left: 8.333333%; }
  .offset-xxl-2 { margin-left: 16.666667%; }
  .offset-xxl-3 { margin-left: 25%; }
  .offset-xxl-4 { margin-left: 33.333333%; }
  .offset-xxl-5 { margin-left: 41.666667%; }
  .offset-xxl-6 { margin-left: 50%; }
  .offset-xxl-7 { margin-left: 58.333333%; }
  .offset-xxl-8 { margin-left: 66.666667%; }
  .offset-xxl-9 { margin-left: 75%; }
  .offset-xxl-10 { margin-left: 83.333333%; }
  .offset-xxl-11 { margin-left: 91.666667%; }
  
  .order-xxl-first { order: -1; }
  .order-xxl-0 { order: 0; }
  .order-xxl-1 { order: 1; }
  .order-xxl-2 { order: 2; }
  .order-xxl-3 { order: 3; }
  .order-xxl-4 { order: 4; }
  .order-xxl-5 { order: 5; }
  .order-xxl-last { order: 6; }
  
  .row-cols-xxl-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-xxl-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-xxl-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-xxl-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-xxl-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-xxl-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-xxl-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

/* Display */
.d-none { display: none !important; }
.d-block { display: block !important; }
.d-flex { display: flex !important; }
.d-inline-flex { display: inline-flex !important; }

/* Flexbox utilities */
.flex-row { flex-direction: row; }
.flex-column { flex-direction: column; }
.justify-content-start { justify-content: flex-start; }
.justify-content-center { justify-content: center; }
.justify-content-between { justify-content: space-between; }
.justify-content-end { justify-content: flex-end; }
.align-items-start { align-items: flex-start; }
.align-items-center { align-items: center; }
.align-items-end { align-items: flex-end; }
.flex-wrap { flex-wrap: wrap; }

/* Width Utilities - MISSING FROM YOUR CODE */
.w-25 { width: 25% !important; }
.w-50 { width: 50% !important; }
.w-75 { width: 75% !important; }
.w-100 { width: 100% !important; }
.w-auto { width: auto !important; }

/* Spacing utilities */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: var(--spacing-xs) !important; }
.mt-2 { margin-top: var(--spacing-sm) !important; }
.mt-3 { margin-top: var(--spacing-md) !important; }
.mt-4 { margin-top: var(--spacing-lg) !important; }
.mt-5 { margin-top: var(--spacing-xl) !important; }

.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: var(--spacing-xs) !important; }
.mb-2 { margin-bottom: var(--spacing-sm) !important; }
.mb-3 { margin-bottom: var(--spacing-md) !important; }
.mb-4 { margin-bottom: var(--spacing-lg) !important; }
.mb-5 { margin-bottom: var(--spacing-xl) !important; }

.ms-0 { margin-left: 0 !important; }
.ms-1 { margin-left: var(--spacing-xs) !important; }
.ms-2 { margin-left: var(--spacing-sm) !important; }
.ms-3 { margin-left: var(--spacing-md) !important; }
.ms-4 { margin-left: var(--spacing-lg) !important; }
.ms-5 { margin-left: var(--spacing-xl) !important; }

.me-0 { margin-right: 0 !important; }
.me-1 { margin-right: var(--spacing-xs) !important; }
.me-2 { margin-right: var(--spacing-sm) !important; }
.me-3 { margin-right: var(--spacing-md) !important; }
.me-4 { margin-right: var(--spacing-lg) !important; }
.me-5 { margin-right: var(--spacing-xl) !important; }

.mx-0 { margin-left: 0 !important; margin-right: 0 !important; }
.mx-1 { margin-left: var(--spacing-xs) !important; margin-right: var(--spacing-xs) !important; }
.mx-2 { margin-left: var(--spacing-sm) !important; margin-right: var(--spacing-sm) !important; }
.mx-3 { margin-left: var(--spacing-md) !important; margin-right: var(--spacing-md) !important; }
.mx-4 { margin-left: var(--spacing-lg) !important; margin-right: var(--spacing-lg) !important; }
.mx-5 { margin-left: var(--spacing-xl) !important; margin-right: var(--spacing-xl) !important; }

.my-0 { margin-top: 0 !important; margin-bottom: 0 !important; }
.my-1 { margin-top: var(--spacing-xs) !important; margin-bottom: var(--spacing-xs) !important; }
.my-2 { margin-top: var(--spacing-sm) !important; margin-bottom: var(--spacing-sm) !important; }
.my-3 { margin-top: var(--spacing-md) !important; margin-bottom: var(--spacing-md) !important; }
.my-4 { margin-top: var(--spacing-lg) !important; margin-bottom: var(--spacing-lg) !important; }
.my-5 { margin-top: var(--spacing-xl) !important; margin-bottom: var(--spacing-xl) !important; }

.pt-0 { padding-top: 0 !important; }
.pt-1 { padding-top: var(--spacing-xs) !important; }
.pt-2 { padding-top: var(--spacing-sm) !important; }
.pt-3 { padding-top: var(--spacing-md) !important; }
.pt-4 { padding-top: var(--spacing-lg) !important; }
.pt-5 { padding-top: var(--spacing-xl) !important; }

.pb-0 { padding-bottom: 0 !important; }
.pb-1 { padding-bottom: var(--spacing-xs) !important; }
.pb-2 { padding-bottom: var(--spacing-sm) !important; }
.pb-3 { padding-bottom: var(--spacing-md) !important; }
.pb-4 { padding-bottom: var(--spacing-lg) !important; }
.pb-5 { padding-bottom: var(--spacing-xl) !important; }

.ps-0 { padding-left: 0 !important; }
.ps-1 { padding-left: var(--spacing-xs) !important; }
.ps-2 { padding-left: var(--spacing-sm) !important; }
.ps-3 { padding-left: var(--spacing-md) !important; }
.ps-4 { padding-left: var(--spacing-lg) !important; }
.ps-5 { padding-left: var(--spacing-xl) !important; }

.pe-0 { padding-right: 0 !important; }
.pe-1 { padding-right: var(--spacing-xs) !important; }
.pe-2 { padding-right: var(--spacing-sm) !important; }
.pe-3 { padding-right: var(--spacing-md) !important; }
.pe-4 { padding-right: var(--spacing-lg) !important; }
.pe-5 { padding-right: var(--spacing-xl) !important; }

.px-0 { padding-left: 0 !important; padding-right: 0 !important; }
.px-1 { padding-left: var(--spacing-xs) !important; padding-right: var(--spacing-xs) !important; }
.px-2 { padding-left: var(--spacing-sm) !important; padding-right: var(--spacing-sm) !important; }
.px-3 { padding-left: var(--spacing-md) !important; padding-right: var(--spacing-md) !important; }
.px-4 { padding-left: var(--spacing-lg) !important; padding-right: var(--spacing-lg) !important; }
.px-5 { padding-left: var(--spacing-xl) !important; padding-right: var(--spacing-xl) !important; }

.py-0 { padding-top: 0 !important; padding-bottom: 0 !important; }
.py-1 { padding-top: var(--spacing-xs) !important; padding-bottom: var(--spacing-xs) !important; }
.py-2 { padding-top: var(--spacing-sm) !important; padding-bottom: var(--spacing-sm) !important; }
.py-3 { padding-top: var(--spacing-md) !important; padding-bottom: var(--spacing-md) !important; }
.py-4 { padding-top: var(--spacing-lg) !important; padding-bottom: var(--spacing-lg) !important; }
.py-5 { padding-top: var(--spacing-xl) !important; padding-bottom: var(--spacing-xl) !important; }

/* Text utilities */
.text-center { text-align: center; }
.text-left { text-align: left; }       /* Legacy - deprecated in Bootstrap 5 */
.text-right { text-align: right; }     /* Legacy - deprecated in Bootstrap 5 */
.text-start { text-align: left; }
.text-end { text-align: right; } 
.text-uppercase { text-transform: uppercase; }

 /* Text Color Utilities */
.text-primary { color: var(--color-primary) !important; }
.text-secondary { color: var(--color-secondary) !important; }
.text-accent { color: var(--color-accent) !important; }
.text-white { color: var(--color-white) !important; }
.text-black { color: var(--color-black) !important; }
.text-muted { color: var(--color-text-muted) !important; }
.text-dark { color: var(--color-text-dark) !important; }
.text-light { color: var(--color-text-light) !important; }
.text-body { color: var(--color-text) !important; }
.text-success { color: var(--color-success) !important; }
.text-warning { color: var(--color-warning) !important; }
.text-danger { color: var(--color-danger) !important; }
.text-info { color: var(--color-info) !important; }

 /* Background Color Utilities */
.bg-primary { background-color: var(--bg-primary) !important; }
.bg-secondary { background-color: var(--bg-secondary) !important; }
.bg-accent { background-color: var(--bg-accent) !important; }
.bg-white { background-color: var(--bg-white) !important; }
.bg-black { background-color: var(--color-black) !important; }
.bg-light { background-color: var(--bg-light) !important; }
.bg-dark { background-color: var(--bg-dark) !important; }
.bg-light-gray { background-color: var(--color-light-gray) !important; }
.bg-medium-gray { background-color: var(--color-medium-gray) !important; }
.bg-nardo-gray { background-color: var(--color-dark-nardo) !important; }
.bg-dark-gray { background-color: var(--color-dark-gray) !important; }
.bg-success { background-color: var(--color-success) !important; }
.bg-success-light { background-color: var(--color-success-light) !important; }
.bg-warning { background-color: var(--color-warning) !important; }
.bg-warning-light { background-color: var(--color-warning-light) !important; }
.bg-danger { background-color: var(--color-danger) !important; }
.bg-danger-light { background-color: var(--color-danger-light) !important; }
.bg-info { background-color: var(--color-info) !important; }
.bg-info-light { background-color: var(--color-info-light) !important; }
.bg-transparent { background-color: transparent !important; }

/* ==========================================================================
   Image Utilities
   ========================================================================== */

/* Responsive Images */
.img-fluid {
    max-width: 100% !important;
    height: auto !important;
    display: block !important;
}

/* Rounded corners */
.rounded {
    border-radius: var(--border-radius-md);
}

.rounded-sm {
    border-radius: var(--border-radius-sm);
}

.rounded-lg {
    border-radius: var(--border-radius-lg);
}

.rounded-circle {
    border-radius: 50%;
}

.rounded-0 {
    border-radius: 0 !important;
}

.rounded-top {
    border-top-left-radius: var(--border-radius-md);
    border-top-right-radius: var(--border-radius-md);
}

.rounded-end {
    border-top-right-radius: var(--border-radius-md);
    border-bottom-right-radius: var(--border-radius-md);
}

.rounded-bottom {
    border-bottom-right-radius: var(--border-radius-md);
    border-bottom-left-radius: var(--border-radius-md);
}

.rounded-start {
    border-top-left-radius: var(--border-radius-md);
    border-bottom-left-radius: var(--border-radius-md);
}

/* Image Thumbnails */
.img-thumbnail {
    padding: 0.25rem;
    background-color: var(--bg-white);
    border: 1px solid var(--color-border);
    border-radius: var(--border-radius-sm);
    max-width: 100%;
    height: auto;
}

/* Text/Background Combination Classes (for better contrast) */
.text-bg-primary {
  color: var(--color-white) !important;
  background-color: var(--bg-primary) !important;
}

.text-bg-secondary {
  color: var(--color-white) !important;
  background-color: var(--bg-secondary) !important;
}

.text-bg-accent {
  color: var(--color-white) !important;
  background-color: var(--bg-accent) !important;
}

.text-bg-success {
  color: var(--color-white) !important;
  background-color: var(--color-success) !important;
}

.text-bg-warning {
  color: var(--color-text-dark) !important;
  background-color: var(--color-warning) !important;
}

.text-bg-danger {
  color: var(--color-white) !important;
  background-color: var(--color-danger) !important;
}

.text-bg-info {
  color: var(--color-white) !important;
  background-color: var(--color-info) !important;
}

.text-bg-light {
  color: var(--color-text-dark) !important;
  background-color: var(--bg-light) !important;
}

.text-bg-dark {
  color: var(--color-white) !important;
  background-color: var(--bg-dark) !important;
}

/* Font Weight Utilities */
.fw-normal { font-weight: var(--font-weight-normal); }
.fw-medium { font-weight: var(--font-weight-medium); }
.fw-semibold { font-weight: var(--font-weight-semibold); }
.fw-bold { font-weight: var(--font-weight-bold); }

/* Font Size Utilities */
.fs-xs { font-size: var(--font-size-xs) !important; }     /* 12px */
.fs-sm { font-size: var(--font-size-sm) !important; }     /* 14px */
.fs-base { font-size: var(--font-size-base) !important; } /* 16px */
.fs-lg { font-size: var(--font-size-lg) !important; }     /* 18px */
.fs-xl { font-size: var(--font-size-xl) !important; }     /* 20px */
.fs-2xl { font-size: var(--font-size-2xl) !important; }
.fs-3xl { font-size: var(--font-size-3xl) !important; }
.fs-4xl { font-size: var(--font-size-4xl) !important; }
.fs-5xl { font-size: var(--font-size-5xl) !important; }
.fs-6xl { font-size: var(--font-size-6xl) !important; }

/* Display Font Sizes (for large headings/hero text) */
.display-1 { font-size: 80px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }
.display-2 { font-size: 72px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }
.display-3 { font-size: 64px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }
.display-4 { font-size: 56px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }
.display-5 { font-size: 48px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }
.display-6 { font-size: 40px !important; font-weight: var(--font-weight-bold); line-height: 1.1; }

/* ==========================================================================
   Typography Components
   ========================================================================== */

/* Lead Text - For introductory paragraphs or emphasized content */
.lead {
  font-size: var(--font-size-lead);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-relaxed);
  color: var(--color-text);
  margin-bottom: var(--spacing-lg);
}

/* Line Height Utilities */
.lh-tight { line-height: 1.2 !important; }
.lh-base { line-height: var(--line-height-base) !important; }
.lh-relaxed { line-height: var(--line-height-relaxed) !important; }

/* Text Decoration */
.text-decoration-none { text-decoration: none !important; }
.text-decoration-underline { text-decoration: underline !important; }
.text-decoration-line-through { text-decoration: line-through !important; }

/* Text Transform */
.text-lowercase { text-transform: lowercase !important; }
.text-capitalize { text-transform: capitalize !important; }

/* Letter Spacing */
.letter-spacing-tight { letter-spacing: -0.025em !important; }
.letter-spacing-normal { letter-spacing: normal !important; }
.letter-spacing-wide { letter-spacing: 0.025em !important; }
.letter-spacing-wider { letter-spacing: 0.05em !important; }

/* Small Text */
.small,
small {
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-normal);
}

/* Strong/Bold Text */
strong,
.strong {
  font-weight: var(--font-weight-bold);
}

/* Emphasized Text */
em,
.em {
  font-style: italic;
}

/* Blockquote */
blockquote {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-normal);
  line-height: var(--line-height-relaxed);
  padding-left: var(--spacing-lg);
  margin: var(--spacing-lg) 0;
  border-left: 3px solid var(--color-primary);
  color: var(--color-text-light);
}

blockquote cite {
  display: block;
  margin-top: var(--spacing-sm);
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  font-style: normal;
}

/* Code and Pre */
code {
  padding: 2px 6px;
  font-size: 90%;
  color: var(--color-accent);
  background-color: var(--color-light-gray);
  border-radius: var(--border-radius-sm);
  font-family: 'Courier New', Courier, monospace;
}

pre {
  display: block;
  padding: var(--spacing-md);
  margin: var(--spacing-md) 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  color: var(--color-text);
  background-color: var(--color-light-gray);
  border-radius: var(--border-radius-md);
  overflow-x: auto;
}

pre code {
  padding: 0;
  font-size: inherit;
  color: inherit;
  background-color: transparent;
  border-radius: 0;
}

/* ==========================================================================
   Button Components
   ========================================================================== */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 12px 24px;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  line-height: 1;
  text-align: center;
  text-decoration: none;
  white-space: nowrap;
  border: 2px solid transparent;
  border-radius: 0;
  transition: all var(--transition-base);
  cursor: pointer;
  user-select: none;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Solid Button Variants */
.btn-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
  border-color: var(--color-primary);
}

.btn-primary:hover:not(:disabled) {
  background-color: var(--color-secondary);
  border-color: var(--color-secondary);
}

.btn-secondary {
  background-color: var(--color-secondary);
  color: var(--color-white);
  border-color: var(--color-secondary);
}

.btn-secondary:hover:not(:disabled) {
  background-color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-success {
  background-color: var(--color-success);
  color: var(--color-white);
  border-color: var(--color-success);
}

.btn-success:hover:not(:disabled) {
  background-color: #0a5a31;
  border-color: #0a5a31;
}

.btn-danger {
  background-color: var(--color-danger);
  color: var(--color-white);
  border-color: var(--color-danger);
}

.btn-danger:hover:not(:disabled) {
  background-color: #b02a37;
  border-color: #b02a37;
}

.btn-warning {
  background-color: var(--color-warning);
  color: var(--color-text-dark);
  border-color: var(--color-warning);
}

.btn-warning:hover:not(:disabled) {
  background-color: #d39e00;
  border-color: #d39e00;
}

.btn-info {
  background-color: var(--color-info);
  color: var(--color-white);
  border-color: var(--color-info);
}

.btn-info:hover:not(:disabled) {
  background-color: #087990;
  border-color: #087990;
}

.btn-light {
  background-color: var(--bg-light);
  color: var(--color-text-dark);
  border-color: var(--bg-light);
}

.btn-light:hover:not(:disabled) {
  background-color: #e2e6ea;
  border-color: #e2e6ea;
}

.btn-dark {
  background-color: var(--bg-dark);
  color: var(--color-white);
  border-color: var(--bg-dark);
}

.btn-dark:hover:not(:disabled) {
  background-color: #1c1f23;
  border-color: #1c1f23;
}

/* Outlined Button Variants */
.btn-outline-primary {
  background-color: transparent;
  color: var(--color-primary);
  border-color: var(--color-primary);
}

.btn-outline-primary:hover:not(:disabled) {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.btn-outline-secondary {
  background-color: transparent;
  color: var(--color-secondary);
  border-color: var(--color-secondary);
}

.btn-outline-secondary:hover:not(:disabled) {
  background-color: var(--color-secondary);
  color: var(--color-white);
}

.btn-outline-success {
  background-color: transparent;
  color: var(--color-success);
  border-color: var(--color-success);
}

.btn-outline-success:hover:not(:disabled) {
  background-color: var(--color-success);
  color: var(--color-white);
}

.btn-outline-danger {
  background-color: transparent;
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.btn-outline-danger:hover:not(:disabled) {
  background-color: var(--color-danger);
  color: var(--color-white);
}

.btn-outline-warning {
  background-color: transparent;
  color: var(--color-warning);
  border-color: var(--color-warning);
}

.btn-outline-warning:hover:not(:disabled) {
  background-color: var(--color-warning);
  color: var(--color-text-dark);
}

.btn-outline-info {
  background-color: transparent;
  color: var(--color-info);
  border-color: var(--color-info);
}

.btn-outline-info:hover:not(:disabled) {
  background-color: var(--color-info);
  color: var(--color-white);
}

.btn-outline-light {
  background-color: transparent;
  color: var(--color-text);
  border-color: var(--bg-light);
}

.btn-outline-light:hover:not(:disabled) {
  background-color: var(--bg-light);
  color: var(--color-text-dark);
}

.btn-outline-dark {
  background-color: transparent;
  color: var(--bg-dark);
  border-color: var(--bg-dark);
}

.btn-outline-dark:hover:not(:disabled) {
  background-color: var(--bg-dark);
  color: var(--color-white);
}

/* Button Sizes */
.btn-sm {
  padding: 8px 16px;
  font-size: var(--font-size-sm);
}

.btn-lg {
  padding: 16px 32px;
  font-size: var(--font-size-lg);
}

/* Button with icon */
.btn i {
  font-size: 1.1em;
}

/* Block button (full width) */
.btn-block {
  display: flex;
  width: 100%;
}

/* Base button group */
.btn-group,
.btn-group-vertical {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
}

    .btn-group > .btn,
    .btn-group-vertical > .btn {
        position: relative;
        flex: 1 1 auto;
    }

        /* Focus state - ensure focused button is on top */
        .btn-group > .btn:focus,
        .btn-group > .btn:active,
        .btn-group > .btn.active,
        .btn-group-vertical > .btn:focus,
        .btn-group-vertical > .btn:active,
        .btn-group-vertical > .btn.active {
            z-index: 1;
        }

/* Horizontal button group */
.btn-group {
    border-radius: 0;
}

    /* Remove border-radius from middle buttons */
    .btn-group > .btn:not(:first-child),
    .btn-group > .btn-group:not(:first-child) {
        margin-left: -2px; /* Negative margin to prevent double borders */
    }

    /* Rounded corners for first button */
    .btn-group > .btn:first-child:not(:last-child),
    .btn-group > .btn-group:first-child:not(:last-child) > .btn {
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    /* Rounded corners for last button */
    .btn-group > .btn:last-child:not(:first-child),
    .btn-group > .btn-group:last-child:not(:first-child) > .btn {
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }

    /* Remove rounded corners for middle buttons */
    .btn-group > .btn:not(:first-child):not(:last-child),
    .btn-group > .btn-group:not(:first-child):not(:last-child) > .btn {
        border-radius: 0;
    }

/* Vertical button group */
.btn-group-vertical {
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
}

    .btn-group-vertical > .btn,
    .btn-group-vertical > .btn-group {
        width: 100%;
    }

        .btn-group-vertical > .btn:not(:first-child),
        .btn-group-vertical > .btn-group:not(:first-child) {
            margin-top: -2px; /* Negative margin to prevent double borders */
        }

        /* Rounded corners for first button in vertical group */
        .btn-group-vertical > .btn:first-child:not(:last-child),
        .btn-group-vertical > .btn-group:first-child:not(:last-child) > .btn {
            border-bottom-left-radius: 0;
            border-bottom-right-radius: 0;
        }

        /* Rounded corners for last button in vertical group */
        .btn-group-vertical > .btn:last-child:not(:first-child),
        .btn-group-vertical > .btn-group:last-child:not(:first-child) > .btn {
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

        /* Remove rounded corners for middle buttons in vertical group */
        .btn-group-vertical > .btn:not(:first-child):not(:last-child),
        .btn-group-vertical > .btn-group:not(:first-child):not(:last-child) > .btn {
            border-radius: 0;
        }

/* Button group sizing */
.btn-group-sm > .btn {
    padding: 8px 16px;
    font-size: var(--font-size-sm);
}

.btn-group-lg > .btn {
    padding: 16px 32px;
    font-size: var(--font-size-lg);
}

/* ==========================================================================
   Form Components
   ========================================================================== */

.form-group {
    margin-bottom: var(--spacing-md);
}

.form-label {
    display: block;
    margin-bottom: var(--spacing-sm);
    font-weight: var(--font-weight-medium);
    font-size: var(--font-size-sm);
    color: var(--color-text);
}

.form-control {
    display: block;
    width: 100%;
    padding: 12px 16px;
    font-size: var(--font-size-base);
    line-height: var(--line-height-base);
    color: var(--color-text);
    background-color: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: 0;
    transition: border-color var(--transition-fast);
}

    .form-control:focus {
        border-color: var(--color-primary);
        outline: none;
    }

    .form-control::placeholder {
        color: var(--color-text-muted);
    }

    .form-control:disabled,
    .form-control[readonly] {
        background-color: var(--input-disabled-bg);
        border-color: var(--input-disabled-border-color);
        opacity: 1;
        cursor: not-allowed;
    }

.form-control-sm {
    padding: var(--input-padding-y-sm) var(--input-padding-x-sm);
    font-size: var(--input-font-size-sm);
    border-radius: var(--input-border-radius-sm);
}

.form-control-lg {
    padding: var(--input-padding-y-lg) var(--input-padding-x-lg);
    font-size: var(--input-font-size-lg);
    border-radius: var(--input-border-radius-lg);
}

textarea.form-control {
    min-height: calc(var(--input-line-height) * 3em + var(--input-padding-y) * 2);
    resize: vertical;
}

select.form-control {
    appearance: none;
    /*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='%23343a40' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");*/
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23212529' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px center;
    padding-right: 36px;
}

/* Form Select - Bootstrap 5.3 */
.form-select {
    display: block;
    width: 100%;
    padding: var(--form-select-padding-y) var(--form-select-indicator-padding) var(--form-select-padding-y) var(--form-select-padding-x);
    font-family: inherit;
    font-size: var(--form-select-font-size);
    font-weight: var(--font-weight-normal);
    line-height: var(--input-line-height);
    color: var(--input-color);
    background-color: var(--form-select-bg);
    background-image: var(--form-select-indicator);
    background-repeat: no-repeat;
    background-position: var(--form-select-bg-position);
    background-size: var(--form-select-bg-size);
    border: var(--input-border-width) solid var(--input-border-color);
    border-radius: 0;
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
    appearance: none;
}

    .form-select:focus {
        border-color: var(--input-focus-border-color);
        outline: 0;
        box-shadow: var(--input-focus-box-shadow);
    }

    .form-select[multiple],
    .form-select[size]:not([size="1"]) {
        padding-right: var(--form-select-padding-x);
        background-image: none;
    }

    .form-select:disabled {
        color: var(--color-text-muted);
        background-color: var(--form-select-disabled-bg);
        border-color: var(--form-select-disabled-border-color);
        cursor: not-allowed;
    }

.form-select-sm {
    padding-top: var(--input-padding-y-sm);
    padding-bottom: var(--input-padding-y-sm);
    padding-left: var(--input-padding-x-sm);
    font-size: var(--input-font-size-sm);
    border-radius: var(--input-border-radius-sm);
}

.form-select-lg {
    padding-top: var(--input-padding-y-lg);
    padding-bottom: var(--input-padding-y-lg);
    padding-left: var(--input-padding-x-lg);
    font-size: var(--input-font-size-lg);
    border-radius: var(--input-border-radius-lg);
}

/* Form Check - Checkbox & Radio */
.form-check {
    display: block;
    min-height: var(--form-check-min-height);
    padding-left: var(--form-check-padding-start);
    margin-bottom: var(--form-check-margin-bottom);
}

    .form-check .form-check-input {
        float: left;
        margin-left: calc(var(--form-check-padding-start) * -1);
    }

.form-check-input {
    width: var(--form-check-input-width);
    height: var(--form-check-input-width);
    margin-top: calc((var(--input-line-height) * 1em - var(--form-check-input-width)) / 2);
    vertical-align: top;
    background-color: var(--form-check-input-bg);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    border: var(--form-check-input-border);
    appearance: none;
    cursor: var(--form-check-label-cursor);
    transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

    .form-check-input[type="checkbox"] {
        border-radius: var(--form-check-input-border-radius);
    }

    .form-check-input[type="radio"] {
        border-radius: var(--form-check-radio-border-radius);
    }

    .form-check-input:focus {
        border-color: var(--form-check-input-focus-border);
        outline: 0;
        box-shadow: var(--form-check-input-focus-box-shadow);
    }

    .form-check-input:checked {
        background-color: var(--form-check-input-checked-bg-color);
        border-color: var(--form-check-input-checked-border-color);
    }

        .form-check-input:checked[type="checkbox"] {
            background-image: var(--form-check-input-checked-bg-image);
        }

        .form-check-input:checked[type="radio"] {
            background-image: var(--form-check-radio-checked-bg-image);
        }

    .form-check-input[type="checkbox"]:indeterminate {
        background-color: var(--form-check-input-indeterminate-bg-color);
        border-color: var(--form-check-input-indeterminate-border-color);
        background-image: var(--form-check-input-indeterminate-bg-image);
    }

    .form-check-input:disabled {
        pointer-events: none;
        filter: none;
        opacity: 0.5;
        cursor: not-allowed;
    }

        .form-check-input[disabled] ~ .form-check-label,
        .form-check-input:disabled ~ .form-check-label {
            cursor: default;
            opacity: 0.5;
        }

.form-check-label {
    color: var(--form-check-label-color);
    cursor: var(--form-check-label-cursor);
    user-select: none;
}

.form-check-inline {
    display: inline-block;
    margin-right: var(--spacing-md);
}

    .form-check-inline .form-check-input {
        margin-right: 0.3125rem;
        margin-left: 0;
    }*/

/* Form Switch - Toggle */
.form-switch {
    padding-left: var(--form-switch-padding-start);
}

    .form-switch .form-check-input {
        width: var(--form-switch-width);
        margin-left: calc(var(--form-switch-padding-start) * -1);
        background-image: var(--form-switch-bg-image);
        background-position: left center;
        border-radius: var(--form-switch-border-radius);
        transition: background-position 0.15s ease-in-out;
    }

        .form-switch .form-check-input:checked {
            background-position: right center;
            background-image: var(--form-switch-checked-bg-image);
        }

/* Form Validation */
.valid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--form-feedback-margin-top);
    font-size: var(--form-feedback-font-size);
    color: var(--form-feedback-valid-color);
}

.invalid-feedback {
    display: none;
    width: 100%;
    margin-top: var(--form-feedback-margin-top);
    font-size: var(--form-feedback-font-size);
    color: var(--form-feedback-invalid-color);
}

.was-validated :valid ~ .valid-feedback,
.was-validated :valid ~ .valid-tooltip,
.is-valid ~ .valid-feedback,
.is-valid ~ .valid-tooltip {
    display: block;
}

.was-validated :invalid ~ .invalid-feedback,
.was-validated :invalid ~ .invalid-tooltip,
.is-invalid ~ .invalid-feedback,
.is-invalid ~ .invalid-tooltip {
    display: block;
}

.was-validated .form-control:valid,
.form-control.is-valid {
    border-color: var(--form-feedback-valid-color);
    padding-right: calc(var(--input-line-height) * 1em + var(--input-padding-x) * 2);
    background-image: var(--form-feedback-icon-valid);
    background-repeat: no-repeat;
    background-position: right calc(var(--input-line-height) * 0.25em + var(--input-padding-x)) center;
    background-size: calc(var(--input-line-height) * 0.75em) calc(var(--input-line-height) * 0.75em);
}

    .was-validated .form-control:valid:focus,
    .form-control.is-valid:focus {
        border-color: var(--form-feedback-valid-color);
        box-shadow: 0 0 0 0.25rem rgba(40, 167, 69, 0.25);
    }

.was-validated .form-select:valid,
.form-select.is-valid {
    border-color: var(--form-feedback-valid-color);
}

.was-validated .form-check-input:valid,
.form-check-input.is-valid {
    border-color: var(--form-feedback-valid-color);
}

    .was-validated .form-check-input:valid:checked,
    .form-check-input.is-valid:checked {
        background-color: var(--form-feedback-valid-color);
    }

.was-validated .form-control:invalid,
.form-control.is-invalid {
    border-color: var(--form-feedback-invalid-color);
    padding-right: calc(var(--input-line-height) * 1em + var(--input-padding-x) * 2);
    background-image: var(--form-feedback-icon-invalid);
    background-repeat: no-repeat;
    background-position: right calc(var(--input-line-height) * 0.25em + var(--input-padding-x)) center;
    background-size: calc(var(--input-line-height) * 0.75em) calc(var(--input-line-height) * 0.75em);
}

    .was-validated .form-control:invalid:focus,
    .form-control.is-invalid:focus {
        border-color: var(--form-feedback-invalid-color);
        box-shadow: 0 0 0 0.25rem rgba(220, 53, 69, 0.25);
    }

.was-validated .form-select:invalid,
.form-select.is-invalid {
    border-color: var(--form-feedback-invalid-color);
}

.was-validated .form-check-input:invalid,
.form-check-input.is-invalid {
    border-color: var(--form-feedback-invalid-color);
}

    .was-validated .form-check-input:invalid:checked,
    .form-check-input.is-invalid:checked {
        background-color: var(--form-feedback-invalid-color);
    }

.form-text {
    margin-top: var(--form-feedback-margin-top);
    font-size: var(--form-feedback-font-size);
    color: var(--color-text-muted);
}

/* Ensure form-select styling takes precedence */
select.form-select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background-image: var(--form-select-indicator);
    background-repeat: no-repeat;
    background-position: var(--form-select-bg-position);
    background-size: var(--form-select-bg-size);
    border: var(--input-border-width) solid var(--input-border-color);
    /*padding-right: var(--form-select-indicator-padding);*/
    padding: 12px 16px;
}

    select.form-select:disabled {
        background-color: var(--form-select-disabled-bg);
        border-color: var(--form-select-disabled-border-color);
        cursor: not-allowed;
    }

/* ==========================================================================
   Badge Components
   ========================================================================== */

.badge {
  display: inline-block;
  padding: 4px 8px;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semibold);
  line-height: 1;
  text-align: center;
  white-space: nowrap;
  border-radius: var(--border-radius-sm);
}

.badge-primary {
  background-color: var(--color-primary);
  color: var(--color-white);
}

.badge-danger {
  background-color: var(--color-danger);
  color: var(--color-white);
}

.badge-success {
  background-color: var(--color-success);
  color: var(--color-white);
}

.badge-warning {
  background-color: var(--color-warning);
  color: var(--color-text);
}

/* ==========================================================================
   Alert Components
   ========================================================================== */

.alert {
  position: relative;
  padding: 12px 16px;
  margin-bottom: var(--spacing-md);
  border: 1px solid transparent;
  border-radius: var(--border-radius-sm);
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
}

/* Alert variants */
.alert-primary {
  color: #084298;
  background-color: #cfe2ff;
  border-color: #b6d4fe;
}

.alert-secondary {
  color: #41464b;
  background-color: #e2e3e5;
  border-color: #d3d6d8;
}

.alert-success {
  color: #0f5132;
  background-color: var(--color-success-light);
  border-color: #badbcc;
}

.alert-danger {
  color: #842029;
  background-color: var(--color-danger-light);
  border-color: #f5c2c7;
}

.alert-warning {
  color: #664d03;
  background-color: var(--color-warning-light);
  border-color: #ffecb5;
}

.alert-info {
  color: #055160;
  background-color: var(--color-info-light);
  border-color: #b6effb;
}

.alert-light {
  color: #636464;
  background-color: #fefefe;
  border-color: #fdfdfe;
}

.alert-dark {
  color: #141619;
  background-color: #d3d3d4;
  border-color: #bcbebf;
}

/* Alert heading */
.alert-heading {
  color: inherit;
  font-weight: var(--font-weight-semibold);
  margin-bottom: var(--spacing-xs);
}

/* Alert links */
.alert-link {
  font-weight: var(--font-weight-bold);
  text-decoration: underline;
}

.alert-primary .alert-link {
  color: #06357a;
}

.alert-secondary .alert-link {
  color: #2c3034;
}

.alert-success .alert-link {
  color: #0a3622;
}

.alert-danger .alert-link {
  color: #6a1a21;
}

.alert-warning .alert-link {
  color: #523e02;
}

.alert-info .alert-link {
  color: #04414d;
}

.alert-light .alert-link {
  color: #4f5050;
}

.alert-dark .alert-link {
  color: #0f1011;
}

/* Dismissible alerts */
.alert-dismissible {
  padding-right: 48px;
}

.alert-dismissible .btn-close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  padding: 14px 16px;
}

/* Close button */
.btn-close {
  box-sizing: content-box;
  width: 1em;
  height: 1em;
  padding: 0.25em;
  color: #000;
  background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
  border: 0;
  border-radius: 0;
  opacity: 0.5;
  cursor: pointer;
  transition: opacity var(--transition-fast);
}

.btn-close:hover {
  opacity: 0.75;
}

.btn-close:focus {
  outline: none;
  opacity: 1;
}

.btn-close:disabled {
  pointer-events: none;
  user-select: none;
  opacity: 0.25;
}

/* Alert with icon support */
.alert-icon {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
}

    .alert-icon i,
    .alert-icon svg {
        flex-shrink: 0;
        margin-top: 2px;
        font-size: 1.2em;
    }

/* ==========================================================================
   Card Components
   ========================================================================== */

.card {
    position: relative;
    display: flex;
    flex-direction: column;
    min-width: 0;
    word-wrap: break-word;
    background-color: var(--bg-white);
    background-clip: border-box;
    border: 1px solid var(--color-border);
    border-radius: 0;
}

    .card > hr {
        margin-right: 0;
        margin-left: 0;
    }

    .card > .list-group {
        border-top: inherit;
        border-bottom: inherit;
    }

        .card > .list-group:first-child {
            border-top-width: 0;
            border-top-left-radius: 0;
            border-top-right-radius: 0;
        }

        .card > .list-group:last-child {
            border-bottom-width: 0;
            border-bottom-right-radius: 0;
            border-bottom-left-radius: 0;
        }

        .card > .card-header + .list-group,
        .card > .list-group + .card-footer {
            border-top: 0;
        }

/* Card Body */
.card-body {
    flex: 1 1 auto;
    padding: var(--spacing-lg);
}

/* Card Title */
.card-title {
    margin-bottom: var(--spacing-sm);
    font-size: var(--font-size-lg);
    font-weight: var(--font-weight-semibold);
    color: var(--color-text-dark);
    line-height: var(--line-height-heading);
}

/* Card Subtitle */
.card-subtitle {
    margin-top: calc(var(--spacing-sm) * -0.5);
    margin-bottom: 0;
    font-size: var(--font-size-sm);
    font-weight: var(--font-weight-normal);
    color: var(--color-text-muted);
}

/* Card Text */
.card-text:last-child {
    margin-bottom: 0;
}

/* Card Link */
.card-link {
    text-decoration: none;
    color: var(--color-primary);
    transition: color var(--transition-fast);
}

    .card-link:hover {
        color: var(--color-secondary);
        text-decoration: underline;
    }

    .card-link + .card-link {
        margin-left: var(--spacing-md);
    }

/* Card Header */
.card-header {
    padding: var(--spacing-md) var(--spacing-lg);
    margin-bottom: 0;
    background-color: var(--bg-light);
    border-bottom: 1px solid var(--color-border);
    font-weight: var(--font-weight-medium);
}

    .card-header:first-child {
        border-radius: 0;
    }

/* Card Footer */
.card-footer {
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--bg-light);
    border-top: 1px solid var(--color-border);
}

    .card-footer:last-child {
        border-radius: 0;
    }

/* Card Header Tabs */
.card-header-tabs {
    margin-right: calc(var(--spacing-lg) * -0.5);
    margin-bottom: calc(var(--spacing-md) * -1);
    margin-left: calc(var(--spacing-lg) * -0.5);
    border-bottom: 0;
}

    .card-header-tabs .nav-link.active {
        background-color: var(--bg-white);
        border-bottom-color: var(--bg-white);
    }

/* Card Header Pills */
.card-header-pills {
    margin-right: calc(var(--spacing-lg) * -0.5);
    margin-left: calc(var(--spacing-lg) * -0.5);
}

/* Card Image Variants */
.card-img-overlay {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    padding: var(--spacing-lg);
    border-radius: 0;
}

.card-img,
.card-img-top,
.card-img-bottom {
    width: 100%;
}

.card-img,
.card-img-top {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

.card-img,
.card-img-bottom {
    border-bottom-right-radius: 0;
    border-bottom-left-radius: 0;
}

/* Card Groups */
.card-group {
    display: flex;
    flex-flow: row wrap;
}

    .card-group > .card {
        flex: 1 0 0%;
        margin-bottom: 0;
    }

        .card-group > .card + .card {
            margin-left: 0;
            border-left: 0;
        }

        .card-group > .card:not(:last-child) {
            border-top-right-radius: 0;
            border-bottom-right-radius: 0;
        }

            .card-group > .card:not(:last-child) .card-img-top,
            .card-group > .card:not(:last-child) .card-header {
                border-top-right-radius: 0;
            }

            .card-group > .card:not(:last-child) .card-img-bottom,
            .card-group > .card:not(:last-child) .card-footer {
                border-bottom-right-radius: 0;
            }

        .card-group > .card:not(:first-child) {
            border-top-left-radius: 0;
            border-bottom-left-radius: 0;
        }

            .card-group > .card:not(:first-child) .card-img-top,
            .card-group > .card:not(:first-child) .card-header {
                border-top-left-radius: 0;
            }

            .card-group > .card:not(:first-child) .card-img-bottom,
            .card-group > .card:not(:first-child) .card-footer {
                border-bottom-left-radius: 0;
            }

@media (min-width: 576px) {
    .card-deck {
        flex-flow: row wrap;
        margin-right: calc(var(--spacing-md) * -0.5);
        margin-left: calc(var(--spacing-md) * -0.5);
    }

        .card-deck .card {
            flex: 1 0 0%;
            margin-right: calc(var(--spacing-md) * 0.5);
            margin-bottom: 0;
            margin-left: calc(var(--spacing-md) * 0.5);
        }
}

/* Card Columns - deprecated in Bootstrap 5 but included for compatibility */
.card-columns .card {
    margin-bottom: var(--spacing-lg);
}

@media (min-width: 576px) {
    .card-columns {
        column-count: 3;
        column-gap: var(--spacing-lg);
        orphans: 1;
        widows: 1;
    }

        .card-columns .card {
            display: inline-block;
            width: 100%;
        }
}

/* Card Border Utilities */
.card.border-0 {
    border: none;
}

.card.border-primary {
    border-color: var(--color-primary);
}

.card.border-secondary {
    border-color: var(--color-secondary);
}

.card.border-success {
    border-color: var(--color-success);
}

.card.border-danger {
    border-color: var(--color-danger);
}

.card.border-warning {
    border-color: var(--color-warning);
}

.card.border-info {
    border-color: var(--color-info);
}

/* Card Shadow Utilities */
.card.shadow-sm {
    box-shadow: var(--shadow-sm);
}

.card.shadow {
    box-shadow: var(--shadow-md);
}

.card.shadow-lg {
    box-shadow: var(--shadow-lg);
}

/* Card Background Variants */
.card.bg-primary,
.card.bg-success,
.card.bg-info,
.card.bg-warning,
.card.bg-danger,
.card.bg-dark {
    color: var(--color-white);
}

    .card.bg-primary .card-header,
    .card.bg-primary .card-footer {
        background-color: rgba(0, 0, 0, 0.1);
        border-color: rgba(0, 0, 0, 0.1);
    }

.card.bg-secondary .card-header,
.card.bg-secondary .card-footer {
    background-color: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.1);
}

.card.bg-success .card-header,
.card.bg-success .card-footer {
    background-color: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0.1);
}

.card.bg-danger .card-header,
.card.bg-danger .card-footer {
    background-color: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.1);
}

.card.bg-warning .card-header,
.card.bg-warning .card-footer {
    background-color: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.1);
}

.card.bg-info .card-header,
.card.bg-info .card-footer {
    background-color: rgba(0, 0, 0, 0.1);
    border-color: rgba(0, 0, 0, 0.1);
}

.card.bg-dark .card-header,
.card.bg-dark .card-footer {
    background-color: rgba(255, 255, 255, 0.1);
    border-color: rgba(255, 255, 255, 0.1);
}

.card.bg-light {
    color: var(--color-text-dark);
}

/* Accordion - Bootstrap 5 Style */
.accordion {
    --bs-accordion-color: var(--color-text);
    --bs-accordion-bg: var(--bg-white);
    --bs-accordion-border-color: var(--color-border);
    --bs-accordion-border-width: 1px;
    --bs-accordion-border-radius: 0;
    --bs-accordion-inner-border-radius: 0;
    --bs-accordion-btn-padding-x: var(--spacing-lg);
    --bs-accordion-btn-padding-y: var(--spacing-md);
    --bs-accordion-btn-color: var(--color-text);
    --bs-accordion-btn-bg: var(--bg-light);
    --bs-accordion-btn-icon-width: 1.25rem;
    --bs-accordion-btn-focus-border-color: var(--color-primary);
    --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem rgba(0, 0, 0, 0.25);
    --bs-accordion-body-padding-x: var(--spacing-lg);
    --bs-accordion-body-padding-y: var(--spacing-md);
    --bs-accordion-active-color: var(--color-primary);
    --bs-accordion-active-bg: var(--bg-light);
}

.accordion-button {
    position: relative;
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--bs-accordion-btn-padding-y) var(--bs-accordion-btn-padding-x);
    font-size: var(--font-size-base);
    color: var(--bs-accordion-btn-color);
    text-align: left;
    background-color: var(--bs-accordion-btn-bg);
    border: 0;
    border-radius: 0;
    overflow-anchor: none;
    transition: all var(--transition-fast);
    cursor: pointer;
}

    .accordion-button:not(.collapsed) {
        color: var(--bs-accordion-active-color);
        background-color: var(--bs-accordion-active-bg);
        box-shadow: inset 0 calc(var(--bs-accordion-border-width) * -1) 0 var(--bs-accordion-border-color);
    }

    .accordion-button::after {
        flex-shrink: 0;
        width: var(--bs-accordion-btn-icon-width);
        height: var(--bs-accordion-btn-icon-width);
        margin-left: auto;
        content: "";
        background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23212529'%3e%3cpath fill-rule='evenodd' d='M1.646 4.646a.5.5 0 0 1 .708 0L8 10.293l5.646-5.647a.5.5 0 0 1 .708.708l-6 6a.5.5 0 0 1-.708 0l-6-6a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
        background-repeat: no-repeat;
        background-size: var(--bs-accordion-btn-icon-width);
        transition: transform var(--transition-fast);
    }

    .accordion-button:not(.collapsed)::after {
        transform: rotate(-180deg);
    }

.accordion-body {
    padding: var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x);
}

.accordion-item {
    color: var(--bs-accordion-color);
    background-color: var(--bs-accordion-bg);
    border: var(--bs-accordion-border-width) solid var(--bs-accordion-border-color);
}

    .accordion-item:first-of-type {
        border-top-left-radius: var(--bs-accordion-border-radius);
        border-top-right-radius: var(--bs-accordion-border-radius);
    }

        .accordion-item:first-of-type .accordion-button {
            border-top-left-radius: var(--bs-accordion-inner-border-radius);
            border-top-right-radius: var(--bs-accordion-inner-border-radius);
        }

    .accordion-item:not(:first-of-type) {
        border-top: 0;
    }

    .accordion-item:last-of-type {
        border-bottom-right-radius: var(--bs-accordion-border-radius);
        border-bottom-left-radius: var(--bs-accordion-border-radius);
    }

        .accordion-item:last-of-type .accordion-button.collapsed {
            border-bottom-right-radius: var(--bs-accordion-inner-border-radius);
            border-bottom-left-radius: var(--bs-accordion-inner-border-radius);
        }

        .accordion-item:last-of-type .accordion-collapse {
            border-bottom-right-radius: var(--bs-accordion-border-radius);
            border-bottom-left-radius: var(--bs-accordion-border-radius);
        }

.accordion-flush .accordion-item {
    border-right: 0;
    border-left: 0;
    border-radius: 0;
}

    .accordion-flush .accordion-item:first-child {
        border-top: 0;
    }

    .accordion-flush .accordion-item:last-child {
        border-bottom: 0;
    }

@media (max-width: 768px) {
    .card-body {
        padding: var(--spacing-md);
    }

    .card-header,
    .card-footer {
        padding: var(--spacing-sm) var(--spacing-md);
    }

    .card-title {
        font-size: var(--font-size-base);
    }

    .accordion-button {
        padding: var(--spacing-sm) var(--spacing-md);
    }

    .accordion-body {
        padding: var(--spacing-sm) var(--spacing-md);
    }
}

/* ==========================================================================
   Responsive Design
   ========================================================================== */

/* Extra Large screens (xl) - ≥1200px */
@media (min-width: 1200px) {
  .col-xl-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-xl-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-xl-3 { flex: 0 0 25%; max-width: 25%; }
  .col-xl-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-xl-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-xl-6 { flex: 0 0 50%; max-width: 50%; }
  .col-xl-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-xl-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-xl-9 { flex: 0 0 75%; max-width: 75%; }
  .col-xl-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-xl-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-xl-12 { flex: 0 0 100%; max-width: 100%; }
}

/* Large screens (lg) - ≥992px */
@media (min-width: 992px) {
  .col-lg-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-lg-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-lg-3 { flex: 0 0 25%; max-width: 25%; }
  .col-lg-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-lg-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-lg-6 { flex: 0 0 50%; max-width: 50%; }
  .col-lg-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-lg-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-lg-9 { flex: 0 0 75%; max-width: 75%; }
  .col-lg-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-lg-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-lg-12 { flex: 0 0 100%; max-width: 100%; }
}

/* Medium screens (md) - ≥768px */
@media (min-width: 768px) {
  .col-md-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-md-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-md-3 { flex: 0 0 25%; max-width: 25%; }
  .col-md-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-md-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-md-6 { flex: 0 0 50%; max-width: 50%; }
  .col-md-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-md-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-md-9 { flex: 0 0 75%; max-width: 75%; }
  .col-md-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-md-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-md-12 { flex: 0 0 100%; max-width: 100%; }
}

/* Small screens (sm) - ≥576px */
@media (min-width: 576px) {
  .col-sm-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-sm-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-sm-3 { flex: 0 0 25%; max-width: 25%; }
  .col-sm-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-sm-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-sm-6 { flex: 0 0 50%; max-width: 50%; }
  .col-sm-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-sm-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-sm-9 { flex: 0 0 75%; max-width: 75%; }
  .col-sm-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-sm-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-sm-12 { flex: 0 0 100%; max-width: 100%; }
  
  .offset-sm-0 { margin-left: 0; }
  .offset-sm-1 { margin-left: 8.333333%; }
  .offset-sm-2 { margin-left: 16.666667%; }
  .offset-sm-3 { margin-left: 25%; }
  .offset-sm-4 { margin-left: 33.333333%; }
  .offset-sm-5 { margin-left: 41.666667%; }
  .offset-sm-6 { margin-left: 50%; }
  .offset-sm-7 { margin-left: 58.333333%; }
  .offset-sm-8 { margin-left: 66.666667%; }
  .offset-sm-9 { margin-left: 75%; }
  .offset-sm-10 { margin-left: 83.333333%; }
  .offset-sm-11 { margin-left: 91.666667%; }
  
  .order-sm-first { order: -1; }
  .order-sm-0 { order: 0; }
  .order-sm-1 { order: 1; }
  .order-sm-2 { order: 2; }
  .order-sm-3 { order: 3; }
  .order-sm-4 { order: 4; }
  .order-sm-5 { order: 5; }
  .order-sm-last { order: 6; }
  
  .row-cols-sm-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-sm-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-sm-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-sm-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-sm-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-sm-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-sm-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Medium (md) - ≥768px */
@media (min-width: 768px) {
  .col-md { flex: 1 0 0%; }
  .col-md-auto { flex: 0 0 auto; width: auto; }
  
  .col-md-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-md-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-md-3 { flex: 0 0 auto; width: 25%; }
  .col-md-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-md-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-md-6 { flex: 0 0 auto; width: 50%; }
  .col-md-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-md-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-md-9 { flex: 0 0 auto; width: 75%; }
  .col-md-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-md-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-md-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-md-0 { margin-left: 0; }
  .offset-md-1 { margin-left: 8.333333%; }
  .offset-md-2 { margin-left: 16.666667%; }
  .offset-md-3 { margin-left: 25%; }
  .offset-md-4 { margin-left: 33.333333%; }
  .offset-md-5 { margin-left: 41.666667%; }
  .offset-md-6 { margin-left: 50%; }
  .offset-md-7 { margin-left: 58.333333%; }
  .offset-md-8 { margin-left: 66.666667%; }
  .offset-md-9 { margin-left: 75%; }
  .offset-md-10 { margin-left: 83.333333%; }
  .offset-md-11 { margin-left: 91.666667%; }
  
  .order-md-first { order: -1; }
  .order-md-0 { order: 0; }
  .order-md-1 { order: 1; }
  .order-md-2 { order: 2; }
  .order-md-3 { order: 3; }
  .order-md-4 { order: 4; }
  .order-md-5 { order: 5; }
  .order-md-last { order: 6; }
  
  .row-cols-md-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-md-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-md-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-md-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-md-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-md-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-md-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Large (lg) - ≥992px */
@media (min-width: 992px) {
  .col-lg-1 { flex: 0 0 8.333333%; max-width: 8.333333%; }
  .col-lg-2 { flex: 0 0 16.666667%; max-width: 16.666667%; }
  .col-lg-3 { flex: 0 0 25%; max-width: 25%; }
  .col-lg-4 { flex: 0 0 33.333333%; max-width: 33.333333%; }
  .col-lg-5 { flex: 0 0 41.666667%; max-width: 41.666667%; }
  .col-lg-6 { flex: 0 0 50%; max-width: 50%; }
  .col-lg-7 { flex: 0 0 58.333333%; max-width: 58.333333%; }
  .col-lg-8 { flex: 0 0 66.666667%; max-width: 66.666667%; }
  .col-lg-9 { flex: 0 0 75%; max-width: 75%; }
  .col-lg-10 { flex: 0 0 83.333333%; max-width: 83.333333%; }
  .col-lg-11 { flex: 0 0 91.666667%; max-width: 91.666667%; }
  .col-lg-12 { flex: 0 0 100%; max-width: 100%; }
  
  .offset-lg-0 { margin-left: 0; }
  .offset-lg-1 { margin-left: 8.333333%; }
  .offset-lg-2 { margin-left: 16.666667%; }
  .offset-lg-3 { margin-left: 25%; }
  .offset-lg-4 { margin-left: 33.333333%; }
  .offset-lg-5 { margin-left: 41.666667%; }
  .offset-lg-6 { margin-left: 50%; }
  .offset-lg-7 { margin-left: 58.333333%; }
  .offset-lg-8 { margin-left: 66.666667%; }
  .offset-lg-9 { margin-left: 75%; }
  .offset-lg-10 { margin-left: 83.333333%; }
  .offset-lg-11 { margin-left: 91.666667%; }
  
  .order-lg-first { order: -1; }
  .order-lg-0 { order: 0; }
  .order-lg-1 { order: 1; }
  .order-lg-2 { order: 2; }
  .order-lg-3 { order: 3; }
  .order-lg-4 { order: 4; }
  .order-lg-5 { order: 5; }
  .order-lg-last { order: 6; }
  
  .row-cols-lg-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-lg-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-lg-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-lg-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-lg-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-lg-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-lg-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Extra Large (xl) - ≥1200px */
@media (min-width: 1200px) {
  .col-xl { flex: 1 0 0%; }
  .col-xl-auto { flex: 0 0 auto; width: auto; }
  
  .col-xl-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-xl-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-xl-3 { flex: 0 0 auto; width: 25%; }
  .col-xl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xl-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-xl-6 { flex: 0 0 auto; width: 50%; }
  .col-xl-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-xl-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-xl-9 { flex: 0 0 auto; width: 75%; }
  .col-xl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xl-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-xl-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-xl-0 { margin-left: 0; }
  .offset-xl-1 { margin-left: 8.333333%; }
  .offset-xl-2 { margin-left: 16.666667%; }
  .offset-xl-3 { margin-left: 25%; }
  .offset-xl-4 { margin-left: 33.333333%; }
  .offset-xl-5 { margin-left: 41.666667%; }
  .offset-xl-6 { margin-left: 50%; }
  .offset-xl-7 { margin-left: 58.333333%; }
  .offset-xl-8 { margin-left: 66.666667%; }
  .offset-xl-9 { margin-left: 75%; }
  .offset-xl-10 { margin-left: 83.333333%; }
  .offset-xl-11 { margin-left: 91.666667%; }
  
  .order-xl-first { order: -1; }
  .order-xl-0 { order: 0; }
  .order-xl-1 { order: 1; }
  .order-xl-2 { order: 2; }
  .order-xl-3 { order: 3; }
  .order-xl-4 { order: 4; }
  .order-xl-5 { order: 5; }
  .order-xl-last { order: 6; }
  
  .row-cols-xl-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-xl-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-xl-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-xl-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-xl-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-xl-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-xl-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Extra Extra Large (xxl) - ≥1400px */
@media (min-width: 1400px) {
  .col-xxl { flex: 1 0 0%; }
  .col-xxl-auto { flex: 0 0 auto; width: auto; }
  
  .col-xxl-1 { flex: 0 0 auto; width: 8.333333%; }
  .col-xxl-2 { flex: 0 0 auto; width: 16.666667%; }
  .col-xxl-3 { flex: 0 0 auto; width: 25%; }
  .col-xxl-4 { flex: 0 0 auto; width: 33.333333%; }
  .col-xxl-5 { flex: 0 0 auto; width: 41.666667%; }
  .col-xxl-6 { flex: 0 0 auto; width: 50%; }
  .col-xxl-7 { flex: 0 0 auto; width: 58.333333%; }
  .col-xxl-8 { flex: 0 0 auto; width: 66.666667%; }
  .col-xxl-9 { flex: 0 0 auto; width: 75%; }
  .col-xxl-10 { flex: 0 0 auto; width: 83.333333%; }
  .col-xxl-11 { flex: 0 0 auto; width: 91.666667%; }
  .col-xxl-12 { flex: 0 0 auto; width: 100%; }
  
  .offset-xxl-0 { margin-left: 0; }
  .offset-xxl-1 { margin-left: 8.333333%; }
  .offset-xxl-2 { margin-left: 16.666667%; }
  .offset-xxl-3 { margin-left: 25%; }
  .offset-xxl-4 { margin-left: 33.333333%; }
  .offset-xxl-5 { margin-left: 41.666667%; }
  .offset-xxl-6 { margin-left: 50%; }
  .offset-xxl-7 { margin-left: 58.333333%; }
  .offset-xxl-8 { margin-left: 66.666667%; }
  .offset-xxl-9 { margin-left: 75%; }
  .offset-xxl-10 { margin-left: 83.333333%; }
  .offset-xxl-11 { margin-left: 91.666667%; }
  
  .order-xxl-first { order: -1; }
  .order-xxl-0 { order: 0; }
  .order-xxl-1 { order: 1; }
  .order-xxl-2 { order: 2; }
  .order-xxl-3 { order: 3; }
  .order-xxl-4 { order: 4; }
  .order-xxl-5 { order: 5; }
  .order-xxl-last { order: 6; }
  
  .row-cols-xxl-auto > * { flex: 0 0 auto; width: auto; }
  .row-cols-xxl-1 > * { flex: 0 0 auto; width: 100%; }
  .row-cols-xxl-2 > * { flex: 0 0 auto; width: 50%; }
  .row-cols-xxl-3 > * { flex: 0 0 auto; width: 33.333333%; }
  .row-cols-xxl-4 > * { flex: 0 0 auto; width: 25%; }
  .row-cols-xxl-5 > * { flex: 0 0 auto; width: 20%; }
  .row-cols-xxl-6 > * { flex: 0 0 auto; width: 16.666667%; }
}

/* Add to your theme CSS */

/* Star Rating */
.star-rating .bi-star-fill {
    color: #ffc107;
}

.star-rating .bi-star-half {
    color: #ffc107;
}

.star-rating .bi-star {
    color: #dee2e6;
}

/* Rating Number Display */
.rating-number {
    font-size: 3rem;
    font-weight: bold;
    color: #ffc107;
}

/* Star Input */
.star-rating-input .star-btn {
    border: none;
    background: none;
    padding: 0 2px;
    transition: transform 0.2s;
}

    .star-rating-input .star-btn:hover {
        transform: scale(1.1);
    }

/* Review Card */
.review-card {
    transition: box-shadow 0.3s;
}

    .review-card:hover {
        box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    }

/* Store Response */
.store-response {
    border-left: 4px solid var(--bs-primary);
}
/* Top Spacer */
.top-spacer {
    height: 50px;
    display: flex;
    justify-content: center;
    background-color: #ffffff;
}

/* ==========================================================================
   Bootstrap Modal — minimal port for the frontend (no vendor.min.css loaded)
   ========================================================================== */
.modal {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 1055;
    width: 100%;
    height: 100%;
    overflow-x: hidden;
    overflow-y: auto;
    outline: 0;
}

.modal.d-block { display: block !important; }

.modal-dialog {
    position: relative;
    width: auto;
    margin: 0.5rem;
    pointer-events: none;
}

.modal-dialog-centered {
    display: flex;
    align-items: center;
    min-height: calc(100% - 1rem);
}

.modal-dialog-scrollable {
    height: calc(100% - 1rem);
}

.modal-dialog-scrollable .modal-content {
    max-height: 100%;
    overflow: hidden;
}

.modal-dialog-scrollable .modal-body {
    overflow-y: auto;
}

.modal-content {
    position: relative;
    display: flex;
    flex-direction: column;
    width: 100%;
    pointer-events: auto;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid rgba(0, 0, 0, 0.2);
    border-radius: 0.5rem;
    outline: 0;
}

.modal-header {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    justify-content: space-between;
    padding: 1rem;
    border-bottom: 1px solid #dee2e6;
    border-top-left-radius: calc(0.5rem - 1px);
    border-top-right-radius: calc(0.5rem - 1px);
}

.modal-title {
    margin-bottom: 0;
    line-height: 1.5;
}

.modal-body {
    position: relative;
    flex: 1 1 auto;
    padding: 1rem;
}

.modal-footer {
    display: flex;
    flex-wrap: wrap;
    flex-shrink: 0;
    align-items: center;
    justify-content: flex-end;
    padding: 0.75rem;
    border-top: 1px solid #dee2e6;
    border-bottom-right-radius: calc(0.5rem - 1px);
    border-bottom-left-radius: calc(0.5rem - 1px);
}

/* Size modifiers */
@media (min-width: 576px) {
    .modal-dialog { margin: 1.75rem auto; max-width: 500px; }
    .modal-dialog-centered { min-height: calc(100% - 3.5rem); }
    .modal-dialog-scrollable { height: calc(100% - 3.5rem); }
    .modal-sm { max-width: 300px; }
}
@media (min-width: 992px) {
    .modal-lg, .modal-xl { max-width: 800px; }
}
@media (min-width: 1200px) {
    .modal-xl { max-width: 1140px; }
}

.btn-close {
    box-sizing: content-box;
    width: 1em;
    height: 1em;
    padding: 0.25em;
    color: #000;
    background: transparent url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23000'%3e%3cpath d='M.293.293a1 1 0 0 1 1.414 0L8 6.586 14.293.293a1 1 0 1 1 1.414 1.414L9.414 8l6.293 6.293a1 1 0 0 1-1.414 1.414L8 9.414l-6.293 6.293a1 1 0 0 1-1.414-1.414L6.586 8 .293 1.707a1 1 0 0 1 0-1.414z'/%3e%3c/svg%3e") center/1em auto no-repeat;
    border: 0;
    border-radius: 0.375rem;
    opacity: 0.5;
    cursor: pointer;
    appearance: none;
}

.btn-close:hover { opacity: 0.75; }
.btn-close-white { filter: invert(1) grayscale(100%) brightness(200%); }
