@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@200;300;400;500;600&display=swap');
@import url("https://cdn.jsdelivr.net/npm/bootstrap-icons@1.11.3/font/bootstrap-icons.css");
/* Entry point - CSS Puro */
/* GreatFood CSS - Arquitectura SMACSS */
/* ==========================================================================
   1. Fonts and Icons
   ========================================================================== */
/* ==========================================================================
   2. Vendors FIRST (Bootstrap, etc.)
   ========================================================================== */
/*!
 * Bootstrap  v5.3.5 (https://getbootstrap.com/)
 * Copyright 2011-2025 The Bootstrap Authors
 * Licensed under MIT (https://github.com/twbs/bootstrap/blob/main/LICENSE)
 */
:root,
[data-bs-theme=light] {
  --bs-blue: #0d6efd;
  --bs-indigo: #6610f2;
  --bs-purple: #6f42c1;
  --bs-pink: #d63384;
  --bs-red: #dc3545;
  --bs-orange: #fd7e14;
  --bs-yellow: #ffc107;
  --bs-green: #198754;
  --bs-teal: #20c997;
  --bs-cyan: #0dcaf0;
  --bs-black: #000;
  --bs-white: #fff;
  --bs-gray: #6c757d;
  --bs-gray-dark: #343a40;
  --bs-gray-100: #f8f9fa;
  --bs-gray-200: #e9ecef;
  --bs-gray-300: #dee2e6;
  --bs-gray-400: #ced4da;
  --bs-gray-500: #adb5bd;
  --bs-gray-600: #6c757d;
  --bs-gray-700: #495057;
  --bs-gray-800: #343a40;
  --bs-gray-900: #212529;
  --bs-primary: #0d6efd;
  --bs-secondary: #6c757d;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  --bs-dark: #212529;
  --bs-primary-rgb: 13, 110, 253;
  --bs-secondary-rgb: 108, 117, 125;
  --bs-success-rgb: 25, 135, 84;
  --bs-info-rgb: 13, 202, 240;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger-rgb: 220, 53, 69;
  --bs-light-rgb: 248, 249, 250;
  --bs-dark-rgb: 33, 37, 41;
  --bs-primary-text-emphasis: #052c65;
  --bs-secondary-text-emphasis: #2b2f32;
  --bs-success-text-emphasis: #0a3622;
  --bs-info-text-emphasis: #055160;
  --bs-warning-text-emphasis: #664d03;
  --bs-danger-text-emphasis: #58151c;
  --bs-light-text-emphasis: #495057;
  --bs-dark-text-emphasis: #495057;
  --bs-primary-bg-subtle: #cfe2ff;
  --bs-secondary-bg-subtle: #e2e3e5;
  --bs-success-bg-subtle: #d1e7dd;
  --bs-info-bg-subtle: #cff4fc;
  --bs-warning-bg-subtle: #fff3cd;
  --bs-danger-bg-subtle: #f8d7da;
  --bs-light-bg-subtle: #fcfcfd;
  --bs-dark-bg-subtle: #ced4da;
  --bs-primary-border-subtle: #9ec5fe;
  --bs-secondary-border-subtle: #c4c8cb;
  --bs-success-border-subtle: #a3cfbb;
  --bs-info-border-subtle: #9eeaf9;
  --bs-warning-border-subtle: #ffe69c;
  --bs-danger-border-subtle: #f1aeb5;
  --bs-light-border-subtle: #e9ecef;
  --bs-dark-border-subtle: #adb5bd;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-font-sans-serif: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --bs-font-monospace: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --bs-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  --bs-body-font-family: var(--bs-font-sans-serif);
  --bs-body-font-size: 1rem;
  --bs-body-font-weight: 400;
  --bs-body-line-height: 1.5;
  --bs-body-color: #212529;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg: #fff;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-emphasis-color: #000;
  --bs-emphasis-color-rgb: 0, 0, 0;
  --bs-secondary-color: rgba(33, 37, 41, 0.75);
  --bs-secondary-color-rgb: 33, 37, 41;
  --bs-secondary-bg: #e9ecef;
  --bs-secondary-bg-rgb: 233, 236, 239;
  --bs-tertiary-color: rgba(33, 37, 41, 0.5);
  --bs-tertiary-color-rgb: 33, 37, 41;
  --bs-tertiary-bg: #f8f9fa;
  --bs-tertiary-bg-rgb: 248, 249, 250;
  --bs-heading-color: inherit;
  --bs-link-color: #0d6efd;
  --bs-link-color-rgb: 13, 110, 253;
  --bs-link-decoration: underline;
  --bs-link-hover-color: #0a58ca;
  --bs-link-hover-color-rgb: 10, 88, 202;
  --bs-code-color: #d63384;
  --bs-highlight-color: #212529;
  --bs-highlight-bg: #fff3cd;
  --bs-border-width: 1px;
  --bs-border-style: solid;
  --bs-border-color: #dee2e6;
  --bs-border-color-translucent: rgba(0, 0, 0, 0.175);
  --bs-border-radius: 0.375rem;
  --bs-border-radius-sm: 0.25rem;
  --bs-border-radius-lg: 0.5rem;
  --bs-border-radius-xl: 1rem;
  --bs-border-radius-xxl: 2rem;
  --bs-border-radius-2xl: var(--bs-border-radius-xxl);
  --bs-border-radius-pill: 50rem;
  --bs-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --bs-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --bs-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --bs-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --bs-focus-ring-width: 0.25rem;
  --bs-focus-ring-opacity: 0.25;
  --bs-focus-ring-color: rgba(13, 110, 253, 0.25);
  --bs-form-valid-color: #198754;
  --bs-form-valid-border-color: #198754;
  --bs-form-invalid-color: #dc3545;
  --bs-form-invalid-border-color: #dc3545;
}
[data-bs-theme=dark] {
  color-scheme: dark;
  --bs-body-color: #dee2e6;
  --bs-body-color-rgb: 222, 226, 230;
  --bs-body-bg: #212529;
  --bs-body-bg-rgb: 33, 37, 41;
  --bs-emphasis-color: #fff;
  --bs-emphasis-color-rgb: 255, 255, 255;
  --bs-secondary-color: rgba(222, 226, 230, 0.75);
  --bs-secondary-color-rgb: 222, 226, 230;
  --bs-secondary-bg: #343a40;
  --bs-secondary-bg-rgb: 52, 58, 64;
  --bs-tertiary-color: rgba(222, 226, 230, 0.5);
  --bs-tertiary-color-rgb: 222, 226, 230;
  --bs-tertiary-bg: #2b3035;
  --bs-tertiary-bg-rgb: 43, 48, 53;
  --bs-primary-text-emphasis: #6ea8fe;
  --bs-secondary-text-emphasis: #a7acb1;
  --bs-success-text-emphasis: #75b798;
  --bs-info-text-emphasis: #6edff6;
  --bs-warning-text-emphasis: #ffda6a;
  --bs-danger-text-emphasis: #ea868f;
  --bs-light-text-emphasis: #f8f9fa;
  --bs-dark-text-emphasis: #dee2e6;
  --bs-primary-bg-subtle: #031633;
  --bs-secondary-bg-subtle: #161719;
  --bs-success-bg-subtle: #051b11;
  --bs-info-bg-subtle: #032830;
  --bs-warning-bg-subtle: #332701;
  --bs-danger-bg-subtle: #2c0b0e;
  --bs-light-bg-subtle: #343a40;
  --bs-dark-bg-subtle: #1a1d20;
  --bs-primary-border-subtle: #084298;
  --bs-secondary-border-subtle: #41464b;
  --bs-success-border-subtle: #0f5132;
  --bs-info-border-subtle: #087990;
  --bs-warning-border-subtle: #997404;
  --bs-danger-border-subtle: #842029;
  --bs-light-border-subtle: #495057;
  --bs-dark-border-subtle: #343a40;
  --bs-heading-color: inherit;
  --bs-link-color: #6ea8fe;
  --bs-link-hover-color: #8bb9fe;
  --bs-link-color-rgb: 110, 168, 254;
  --bs-link-hover-color-rgb: 139, 185, 254;
  --bs-code-color: #e685b5;
  --bs-highlight-color: #dee2e6;
  --bs-highlight-bg: #664d03;
  --bs-border-color: #495057;
  --bs-border-color-translucent: rgba(255, 255, 255, 0.15);
  --bs-form-valid-color: #75b798;
  --bs-form-valid-border-color: #75b798;
  --bs-form-invalid-color: #ea868f;
  --bs-form-invalid-border-color: #ea868f;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}
body {
  margin: 0;
  font-family: var(--bs-body-font-family);
  font-size: var(--bs-body-font-size);
  font-weight: var(--bs-body-font-weight);
  line-height: var(--bs-body-line-height);
  color: var(--bs-body-color);
  text-align: var(--bs-body-text-align);
  background-color: var(--bs-body-bg);
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
hr {
  margin: 1rem 0;
  color: inherit;
  border: 0;
  border-top: var(--bs-border-width) solid;
  opacity: 0.25;
}
h6, .h6, h5, .h5, h4, .h4, h3, .h3, h2, .h2, h1, .h1 {
  margin-top: 0;
  margin-bottom: 0.5rem;
  font-weight: 500;
  line-height: 1.2;
  color: var(--bs-heading-color);
}
h1, .h1 {
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  h1, .h1 {
    font-size: 2.5rem;
  }
}
h2, .h2 {
  font-size: calc(1.325rem + 0.9vw);
}
@media (min-width: 1200px) {
  h2, .h2 {
    font-size: 2rem;
  }
}
h3, .h3 {
  font-size: calc(1.3rem + 0.6vw);
}
@media (min-width: 1200px) {
  h3, .h3 {
    font-size: 1.75rem;
  }
}
h4, .h4 {
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  h4, .h4 {
    font-size: 1.5rem;
  }
}
h5, .h5 {
  font-size: 1.25rem;
}
h6, .h6 {
  font-size: 1rem;
}
p {
  margin-top: 0;
  margin-bottom: 1rem;
}
abbr[title] {
  -webkit-text-decoration: underline dotted;
  text-decoration: underline dotted;
  cursor: help;
  -webkit-text-decoration-skip-ink: none;
  text-decoration-skip-ink: none;
}
address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit;
}
ol,
ul {
  padding-left: 2rem;
}
ol,
ul,
dl {
  margin-top: 0;
  margin-bottom: 1rem;
}
ol ol,
ul ul,
ol ul,
ul ol {
  margin-bottom: 0;
}
dt {
  font-weight: 700;
}
dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}
blockquote {
  margin: 0 0 1rem;
}
b,
strong {
  font-weight: bolder;
}
small, .small {
  font-size: 0.875em;
}
mark, .mark {
  padding: 0.1875em;
  color: var(--bs-highlight-color);
  background-color: var(--bs-highlight-bg);
}
sub,
sup {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
}
sub {
  bottom: -0.25em;
}
sup {
  top: -0.5em;
}
a {
  color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 1));
  text-decoration: underline;
}
a:hover {
  --bs-link-color-rgb: var(--bs-link-hover-color-rgb);
}
a:not([href]):not([class]), a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}
pre,
code,
kbd,
samp {
  font-family: var(--bs-font-monospace);
  font-size: 1em;
}
pre {
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: 0.875em;
}
pre code {
  font-size: inherit;
  color: inherit;
  word-break: normal;
}
code {
  font-size: 0.875em;
  color: var(--bs-code-color);
  word-wrap: break-word;
}
a > code {
  color: inherit;
}
kbd {
  padding: 0.1875rem 0.375rem;
  font-size: 0.875em;
  color: var(--bs-body-bg);
  background-color: var(--bs-body-color);
  border-radius: 0.25rem;
}
kbd kbd {
  padding: 0;
  font-size: 1em;
}
figure {
  margin: 0 0 1rem;
}
img,
svg {
  vertical-align: middle;
}
table {
  caption-side: bottom;
  border-collapse: collapse;
}
caption {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: var(--bs-secondary-color);
  text-align: left;
}
th {
  text-align: inherit;
  text-align: -webkit-match-parent;
}
thead,
tbody,
tfoot,
tr,
td,
th {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}
label {
  display: inline-block;
}
button {
  border-radius: 0;
}
button:focus:not(:focus-visible) {
  outline: 0;
}
input,
button,
select,
optgroup,
textarea {
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}
button,
select {
  text-transform: none;
}
[role=button] {
  cursor: pointer;
}
select {
  word-wrap: normal;
}
select:disabled {
  opacity: 1;
}
[list]:not([type=date]):not([type=datetime-local]):not([type=month]):not([type=week]):not([type=time])::-webkit-calendar-picker-indicator {
  display: none !important;
}
button,
[type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}
button:not(:disabled),
[type=button]:not(:disabled),
[type=reset]:not(:disabled),
[type=submit]:not(:disabled) {
  cursor: pointer;
}
::-moz-focus-inner {
  padding: 0;
  border-style: none;
}
textarea {
  resize: vertical;
}
fieldset {
  min-width: 0;
  padding: 0;
  margin: 0;
  border: 0;
}
legend {
  float: left;
  width: 100%;
  padding: 0;
  margin-bottom: 0.5rem;
  line-height: inherit;
  font-size: calc(1.275rem + 0.3vw);
}
@media (min-width: 1200px) {
  legend {
    font-size: 1.5rem;
  }
}
legend + * {
  clear: left;
}
::-webkit-datetime-edit-fields-wrapper,
::-webkit-datetime-edit-text,
::-webkit-datetime-edit-minute,
::-webkit-datetime-edit-hour-field,
::-webkit-datetime-edit-day-field,
::-webkit-datetime-edit-month-field,
::-webkit-datetime-edit-year-field {
  padding: 0;
}
::-webkit-inner-spin-button {
  height: auto;
}
[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}
/* rtl:raw:
[type="tel"],
[type="url"],
[type="email"],
[type="number"] {
  direction: ltr;
}
*/
::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-color-swatch-wrapper {
  padding: 0;
}
::file-selector-button {
  font: inherit;
  -webkit-appearance: button;
}
output {
  display: inline-block;
}
iframe {
  border: 0;
}
summary {
  display: list-item;
  cursor: pointer;
}
progress {
  vertical-align: baseline;
}
[hidden] {
  display: none !important;
}
.lead {
  font-size: 1.25rem;
  font-weight: 300;
}
.display-1 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.625rem + 4.5vw);
}
@media (min-width: 1200px) {
  .display-1 {
    font-size: 5rem;
  }
}
.display-2 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.575rem + 3.9vw);
}
@media (min-width: 1200px) {
  .display-2 {
    font-size: 4.5rem;
  }
}
.display-3 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.525rem + 3.3vw);
}
@media (min-width: 1200px) {
  .display-3 {
    font-size: 4rem;
  }
}
.display-4 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.475rem + 2.7vw);
}
@media (min-width: 1200px) {
  .display-4 {
    font-size: 3.5rem;
  }
}
.display-5 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.425rem + 2.1vw);
}
@media (min-width: 1200px) {
  .display-5 {
    font-size: 3rem;
  }
}
.display-6 {
  font-weight: 300;
  line-height: 1.2;
  font-size: calc(1.375rem + 1.5vw);
}
@media (min-width: 1200px) {
  .display-6 {
    font-size: 2.5rem;
  }
}
.list-unstyled {
  padding-left: 0;
  list-style: none;
}
.list-inline {
  padding-left: 0;
  list-style: none;
}
.list-inline-item {
  display: inline-block;
}
.list-inline-item:not(:last-child) {
  margin-right: 0.5rem;
}
.initialism {
  font-size: 0.875em;
  text-transform: uppercase;
}
.blockquote {
  margin-bottom: 1rem;
  font-size: 1.25rem;
}
.blockquote > :last-child {
  margin-bottom: 0;
}
.blockquote-footer {
  margin-top: -1rem;
  margin-bottom: 1rem;
  font-size: 0.875em;
  color: #6c757d;
}
.blockquote-footer::before {
  content: "— ";
}
.img-fluid {
  max-width: 100%;
  height: auto;
}
.img-thumbnail {
  padding: 0.25rem;
  background-color: var(--bs-body-bg);
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  max-width: 100%;
  height: auto;
}
.figure {
  display: inline-block;
}
.figure-img {
  margin-bottom: 0.5rem;
  line-height: 1;
}
.figure-caption {
  font-size: 0.875em;
  color: var(--bs-secondary-color);
}
.container,
.container-fluid,
.container-xxl,
.container-xl,
.container-lg,
.container-md,
.container-sm {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  width: 100%;
  padding-right: calc(var(--bs-gutter-x) * 0.5);
  padding-left: calc(var(--bs-gutter-x) * 0.5);
  margin-right: auto;
  margin-left: auto;
}
@media (min-width: 576px) {
  .container-sm, .container {
    max-width: 540px;
  }
}
@media (min-width: 768px) {
  .container-md, .container-sm, .container {
    max-width: 720px;
  }
}
@media (min-width: 992px) {
  .container-lg, .container-md, .container-sm, .container {
    max-width: 960px;
  }
}
@media (min-width: 1200px) {
  .container-xl, .container-lg, .container-md, .container-sm, .container {
    max-width: 1140px;
  }
}
@media (min-width: 1400px) {
  .container-xxl, .container-xl, .container-lg, .container-md, .container-sm, .container {
    max-width: 1320px;
  }
}
:root {
  --bs-breakpoint-xs: 0;
  --bs-breakpoint-sm: 576px;
  --bs-breakpoint-md: 768px;
  --bs-breakpoint-lg: 992px;
  --bs-breakpoint-xl: 1200px;
  --bs-breakpoint-xxl: 1400px;
}
.row {
  --bs-gutter-x: 1.5rem;
  --bs-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-top: calc(-1 * var(--bs-gutter-y));
  margin-right: calc(-0.5 * var(--bs-gutter-x));
  margin-left: calc(-0.5 * var(--bs-gutter-x));
}
.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);
}
.col {
  flex: 1 0 0;
}
.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.33333333%;
}
.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.66666667%;
}
.col-auto {
  flex: 0 0 auto;
  width: auto;
}
.col-1 {
  flex: 0 0 auto;
  width: 8.33333333%;
}
.col-2 {
  flex: 0 0 auto;
  width: 16.66666667%;
}
.col-3 {
  flex: 0 0 auto;
  width: 25%;
}
.col-4 {
  flex: 0 0 auto;
  width: 33.33333333%;
}
.col-5 {
  flex: 0 0 auto;
  width: 41.66666667%;
}
.col-6 {
  flex: 0 0 auto;
  width: 50%;
}
.col-7 {
  flex: 0 0 auto;
  width: 58.33333333%;
}
.col-8 {
  flex: 0 0 auto;
  width: 66.66666667%;
}
.col-9 {
  flex: 0 0 auto;
  width: 75%;
}
.col-10 {
  flex: 0 0 auto;
  width: 83.33333333%;
}
.col-11 {
  flex: 0 0 auto;
  width: 91.66666667%;
}
.col-12 {
  flex: 0 0 auto;
  width: 100%;
}
.offset-1 {
  margin-left: 8.33333333%;
}
.offset-2 {
  margin-left: 16.66666667%;
}
.offset-3 {
  margin-left: 25%;
}
.offset-4 {
  margin-left: 33.33333333%;
}
.offset-5 {
  margin-left: 41.66666667%;
}
.offset-6 {
  margin-left: 50%;
}
.offset-7 {
  margin-left: 58.33333333%;
}
.offset-8 {
  margin-left: 66.66666667%;
}
.offset-9 {
  margin-left: 75%;
}
.offset-10 {
  margin-left: 83.33333333%;
}
.offset-11 {
  margin-left: 91.66666667%;
}
.g-0,
.gx-0 {
  --bs-gutter-x: 0;
}
.g-0,
.gy-0 {
  --bs-gutter-y: 0;
}
.g-1,
.gx-1 {
  --bs-gutter-x: 0.25rem;
}
.g-1,
.gy-1 {
  --bs-gutter-y: 0.25rem;
}
.g-2,
.gx-2 {
  --bs-gutter-x: 0.5rem;
}
.g-2,
.gy-2 {
  --bs-gutter-y: 0.5rem;
}
.g-3,
.gx-3 {
  --bs-gutter-x: 1rem;
}
.g-3,
.gy-3 {
  --bs-gutter-y: 1rem;
}
.g-4,
.gx-4 {
  --bs-gutter-x: 1.5rem;
}
.g-4,
.gy-4 {
  --bs-gutter-y: 1.5rem;
}
.g-5,
.gx-5 {
  --bs-gutter-x: 3rem;
}
.g-5,
.gy-5 {
  --bs-gutter-y: 3rem;
}
@media (min-width: 576px) {
  .col-sm {
    flex: 1 0 0;
  }
  .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.33333333%;
  }
  .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.66666667%;
  }
  .col-sm-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-sm-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-sm-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-sm-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-sm-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-sm-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-sm-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-sm-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-sm-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-sm-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-sm-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-sm-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-sm-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-sm-0 {
    margin-left: 0;
  }
  .offset-sm-1 {
    margin-left: 8.33333333%;
  }
  .offset-sm-2 {
    margin-left: 16.66666667%;
  }
  .offset-sm-3 {
    margin-left: 25%;
  }
  .offset-sm-4 {
    margin-left: 33.33333333%;
  }
  .offset-sm-5 {
    margin-left: 41.66666667%;
  }
  .offset-sm-6 {
    margin-left: 50%;
  }
  .offset-sm-7 {
    margin-left: 58.33333333%;
  }
  .offset-sm-8 {
    margin-left: 66.66666667%;
  }
  .offset-sm-9 {
    margin-left: 75%;
  }
  .offset-sm-10 {
    margin-left: 83.33333333%;
  }
  .offset-sm-11 {
    margin-left: 91.66666667%;
  }
  .g-sm-0,
  .gx-sm-0 {
    --bs-gutter-x: 0;
  }
  .g-sm-0,
  .gy-sm-0 {
    --bs-gutter-y: 0;
  }
  .g-sm-1,
  .gx-sm-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-sm-1,
  .gy-sm-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-sm-2,
  .gx-sm-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-sm-2,
  .gy-sm-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-sm-3,
  .gx-sm-3 {
    --bs-gutter-x: 1rem;
  }
  .g-sm-3,
  .gy-sm-3 {
    --bs-gutter-y: 1rem;
  }
  .g-sm-4,
  .gx-sm-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-sm-4,
  .gy-sm-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-sm-5,
  .gx-sm-5 {
    --bs-gutter-x: 3rem;
  }
  .g-sm-5,
  .gy-sm-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 768px) {
  .col-md {
    flex: 1 0 0;
  }
  .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.33333333%;
  }
  .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.66666667%;
  }
  .col-md-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-md-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-md-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-md-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-md-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-md-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-md-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-md-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-md-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-md-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-md-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-md-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-md-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-md-0 {
    margin-left: 0;
  }
  .offset-md-1 {
    margin-left: 8.33333333%;
  }
  .offset-md-2 {
    margin-left: 16.66666667%;
  }
  .offset-md-3 {
    margin-left: 25%;
  }
  .offset-md-4 {
    margin-left: 33.33333333%;
  }
  .offset-md-5 {
    margin-left: 41.66666667%;
  }
  .offset-md-6 {
    margin-left: 50%;
  }
  .offset-md-7 {
    margin-left: 58.33333333%;
  }
  .offset-md-8 {
    margin-left: 66.66666667%;
  }
  .offset-md-9 {
    margin-left: 75%;
  }
  .offset-md-10 {
    margin-left: 83.33333333%;
  }
  .offset-md-11 {
    margin-left: 91.66666667%;
  }
  .g-md-0,
  .gx-md-0 {
    --bs-gutter-x: 0;
  }
  .g-md-0,
  .gy-md-0 {
    --bs-gutter-y: 0;
  }
  .g-md-1,
  .gx-md-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-md-1,
  .gy-md-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-md-2,
  .gx-md-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-md-2,
  .gy-md-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-md-3,
  .gx-md-3 {
    --bs-gutter-x: 1rem;
  }
  .g-md-3,
  .gy-md-3 {
    --bs-gutter-y: 1rem;
  }
  .g-md-4,
  .gx-md-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-md-4,
  .gy-md-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-md-5,
  .gx-md-5 {
    --bs-gutter-x: 3rem;
  }
  .g-md-5,
  .gy-md-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 992px) {
  .col-lg {
    flex: 1 0 0;
  }
  .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.33333333%;
  }
  .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.66666667%;
  }
  .col-lg-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-lg-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-lg-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-lg-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-lg-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-lg-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-lg-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-lg-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-lg-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-lg-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-lg-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-lg-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-lg-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-lg-0 {
    margin-left: 0;
  }
  .offset-lg-1 {
    margin-left: 8.33333333%;
  }
  .offset-lg-2 {
    margin-left: 16.66666667%;
  }
  .offset-lg-3 {
    margin-left: 25%;
  }
  .offset-lg-4 {
    margin-left: 33.33333333%;
  }
  .offset-lg-5 {
    margin-left: 41.66666667%;
  }
  .offset-lg-6 {
    margin-left: 50%;
  }
  .offset-lg-7 {
    margin-left: 58.33333333%;
  }
  .offset-lg-8 {
    margin-left: 66.66666667%;
  }
  .offset-lg-9 {
    margin-left: 75%;
  }
  .offset-lg-10 {
    margin-left: 83.33333333%;
  }
  .offset-lg-11 {
    margin-left: 91.66666667%;
  }
  .g-lg-0,
  .gx-lg-0 {
    --bs-gutter-x: 0;
  }
  .g-lg-0,
  .gy-lg-0 {
    --bs-gutter-y: 0;
  }
  .g-lg-1,
  .gx-lg-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-lg-1,
  .gy-lg-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-lg-2,
  .gx-lg-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-lg-2,
  .gy-lg-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-lg-3,
  .gx-lg-3 {
    --bs-gutter-x: 1rem;
  }
  .g-lg-3,
  .gy-lg-3 {
    --bs-gutter-y: 1rem;
  }
  .g-lg-4,
  .gx-lg-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-lg-4,
  .gy-lg-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-lg-5,
  .gx-lg-5 {
    --bs-gutter-x: 3rem;
  }
  .g-lg-5,
  .gy-lg-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 1200px) {
  .col-xl {
    flex: 1 0 0;
  }
  .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.33333333%;
  }
  .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.66666667%;
  }
  .col-xl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xl-0 {
    margin-left: 0;
  }
  .offset-xl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xl-3 {
    margin-left: 25%;
  }
  .offset-xl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xl-6 {
    margin-left: 50%;
  }
  .offset-xl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xl-9 {
    margin-left: 75%;
  }
  .offset-xl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xl-11 {
    margin-left: 91.66666667%;
  }
  .g-xl-0,
  .gx-xl-0 {
    --bs-gutter-x: 0;
  }
  .g-xl-0,
  .gy-xl-0 {
    --bs-gutter-y: 0;
  }
  .g-xl-1,
  .gx-xl-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-xl-1,
  .gy-xl-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-xl-2,
  .gx-xl-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-xl-2,
  .gy-xl-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-xl-3,
  .gx-xl-3 {
    --bs-gutter-x: 1rem;
  }
  .g-xl-3,
  .gy-xl-3 {
    --bs-gutter-y: 1rem;
  }
  .g-xl-4,
  .gx-xl-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-xl-4,
  .gy-xl-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-xl-5,
  .gx-xl-5 {
    --bs-gutter-x: 3rem;
  }
  .g-xl-5,
  .gy-xl-5 {
    --bs-gutter-y: 3rem;
  }
}
@media (min-width: 1400px) {
  .col-xxl {
    flex: 1 0 0;
  }
  .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.33333333%;
  }
  .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.66666667%;
  }
  .col-xxl-auto {
    flex: 0 0 auto;
    width: auto;
  }
  .col-xxl-1 {
    flex: 0 0 auto;
    width: 8.33333333%;
  }
  .col-xxl-2 {
    flex: 0 0 auto;
    width: 16.66666667%;
  }
  .col-xxl-3 {
    flex: 0 0 auto;
    width: 25%;
  }
  .col-xxl-4 {
    flex: 0 0 auto;
    width: 33.33333333%;
  }
  .col-xxl-5 {
    flex: 0 0 auto;
    width: 41.66666667%;
  }
  .col-xxl-6 {
    flex: 0 0 auto;
    width: 50%;
  }
  .col-xxl-7 {
    flex: 0 0 auto;
    width: 58.33333333%;
  }
  .col-xxl-8 {
    flex: 0 0 auto;
    width: 66.66666667%;
  }
  .col-xxl-9 {
    flex: 0 0 auto;
    width: 75%;
  }
  .col-xxl-10 {
    flex: 0 0 auto;
    width: 83.33333333%;
  }
  .col-xxl-11 {
    flex: 0 0 auto;
    width: 91.66666667%;
  }
  .col-xxl-12 {
    flex: 0 0 auto;
    width: 100%;
  }
  .offset-xxl-0 {
    margin-left: 0;
  }
  .offset-xxl-1 {
    margin-left: 8.33333333%;
  }
  .offset-xxl-2 {
    margin-left: 16.66666667%;
  }
  .offset-xxl-3 {
    margin-left: 25%;
  }
  .offset-xxl-4 {
    margin-left: 33.33333333%;
  }
  .offset-xxl-5 {
    margin-left: 41.66666667%;
  }
  .offset-xxl-6 {
    margin-left: 50%;
  }
  .offset-xxl-7 {
    margin-left: 58.33333333%;
  }
  .offset-xxl-8 {
    margin-left: 66.66666667%;
  }
  .offset-xxl-9 {
    margin-left: 75%;
  }
  .offset-xxl-10 {
    margin-left: 83.33333333%;
  }
  .offset-xxl-11 {
    margin-left: 91.66666667%;
  }
  .g-xxl-0,
  .gx-xxl-0 {
    --bs-gutter-x: 0;
  }
  .g-xxl-0,
  .gy-xxl-0 {
    --bs-gutter-y: 0;
  }
  .g-xxl-1,
  .gx-xxl-1 {
    --bs-gutter-x: 0.25rem;
  }
  .g-xxl-1,
  .gy-xxl-1 {
    --bs-gutter-y: 0.25rem;
  }
  .g-xxl-2,
  .gx-xxl-2 {
    --bs-gutter-x: 0.5rem;
  }
  .g-xxl-2,
  .gy-xxl-2 {
    --bs-gutter-y: 0.5rem;
  }
  .g-xxl-3,
  .gx-xxl-3 {
    --bs-gutter-x: 1rem;
  }
  .g-xxl-3,
  .gy-xxl-3 {
    --bs-gutter-y: 1rem;
  }
  .g-xxl-4,
  .gx-xxl-4 {
    --bs-gutter-x: 1.5rem;
  }
  .g-xxl-4,
  .gy-xxl-4 {
    --bs-gutter-y: 1.5rem;
  }
  .g-xxl-5,
  .gx-xxl-5 {
    --bs-gutter-x: 3rem;
  }
  .g-xxl-5,
  .gy-xxl-5 {
    --bs-gutter-y: 3rem;
  }
}
.table {
  --bs-table-color-type: initial;
  --bs-table-bg-type: initial;
  --bs-table-color-state: initial;
  --bs-table-bg-state: initial;
  --bs-table-color: var(--bs-emphasis-color);
  --bs-table-bg: var(--bs-body-bg);
  --bs-table-border-color: var(--bs-border-color);
  --bs-table-accent-bg: transparent;
  --bs-table-striped-color: var(--bs-emphasis-color);
  --bs-table-striped-bg: rgba(var(--bs-emphasis-color-rgb), 0.05);
  --bs-table-active-color: var(--bs-emphasis-color);
  --bs-table-active-bg: rgba(var(--bs-emphasis-color-rgb), 0.1);
  --bs-table-hover-color: var(--bs-emphasis-color);
  --bs-table-hover-bg: rgba(var(--bs-emphasis-color-rgb), 0.075);
  width: 100%;
  margin-bottom: 1rem;
  vertical-align: top;
  border-color: var(--bs-table-border-color);
}
.table > :not(caption) > * > * {
  padding: 0.5rem 0.5rem;
  color: var(--bs-table-color-state, var(--bs-table-color-type, var(--bs-table-color)));
  background-color: var(--bs-table-bg);
  border-bottom-width: var(--bs-border-width);
  box-shadow: inset 0 0 0 9999px var(--bs-table-bg-state, var(--bs-table-bg-type, var(--bs-table-accent-bg)));
}
.table > tbody {
  vertical-align: inherit;
}
.table > thead {
  vertical-align: bottom;
}
.table-group-divider {
  border-top: calc(var(--bs-border-width) * 2) solid currentcolor;
}
.caption-top {
  caption-side: top;
}
.table-sm > :not(caption) > * > * {
  padding: 0.25rem 0.25rem;
}
.table-bordered > :not(caption) > * {
  border-width: var(--bs-border-width) 0;
}
.table-bordered > :not(caption) > * > * {
  border-width: 0 var(--bs-border-width);
}
.table-borderless > :not(caption) > * > * {
  border-bottom-width: 0;
}
.table-borderless > :not(:first-child) {
  border-top-width: 0;
}
.table-striped > tbody > tr:nth-of-type(odd) > * {
  --bs-table-color-type: var(--bs-table-striped-color);
  --bs-table-bg-type: var(--bs-table-striped-bg);
}
.table-striped-columns > :not(caption) > tr > :nth-child(even) {
  --bs-table-color-type: var(--bs-table-striped-color);
  --bs-table-bg-type: var(--bs-table-striped-bg);
}
.table-active {
  --bs-table-color-state: var(--bs-table-active-color);
  --bs-table-bg-state: var(--bs-table-active-bg);
}
.table-hover > tbody > tr:hover > * {
  --bs-table-color-state: var(--bs-table-hover-color);
  --bs-table-bg-state: var(--bs-table-hover-bg);
}
.table-primary {
  --bs-table-color: #000;
  --bs-table-bg: #cfe2ff;
  --bs-table-border-color: #a6b5cc;
  --bs-table-striped-bg: #c5d7f2;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #bacbe6;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #bfd1ec;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-secondary {
  --bs-table-color: #000;
  --bs-table-bg: #e2e3e5;
  --bs-table-border-color: #b5b6b7;
  --bs-table-striped-bg: #d7d8da;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #cbccce;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #d1d2d4;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-success {
  --bs-table-color: #000;
  --bs-table-bg: #d1e7dd;
  --bs-table-border-color: #a7b9b1;
  --bs-table-striped-bg: #c7dbd2;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #bcd0c7;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #c1d6cc;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-info {
  --bs-table-color: #000;
  --bs-table-bg: #cff4fc;
  --bs-table-border-color: #a6c3ca;
  --bs-table-striped-bg: #c5e8ef;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #badce3;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #bfe2e9;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-warning {
  --bs-table-color: #000;
  --bs-table-bg: #fff3cd;
  --bs-table-border-color: #ccc2a4;
  --bs-table-striped-bg: #f2e7c3;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #e6dbb9;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #ece1be;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-danger {
  --bs-table-color: #000;
  --bs-table-bg: #f8d7da;
  --bs-table-border-color: #c6acae;
  --bs-table-striped-bg: #eccccf;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #dfc2c4;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #e5c7ca;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-light {
  --bs-table-color: #000;
  --bs-table-bg: #f8f9fa;
  --bs-table-border-color: #c6c7c8;
  --bs-table-striped-bg: #ecedee;
  --bs-table-striped-color: #000;
  --bs-table-active-bg: #dfe0e1;
  --bs-table-active-color: #000;
  --bs-table-hover-bg: #e5e6e7;
  --bs-table-hover-color: #000;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-dark {
  --bs-table-color: #fff;
  --bs-table-bg: #212529;
  --bs-table-border-color: #4d5154;
  --bs-table-striped-bg: #2c3034;
  --bs-table-striped-color: #fff;
  --bs-table-active-bg: #373b3e;
  --bs-table-active-color: #fff;
  --bs-table-hover-bg: #323539;
  --bs-table-hover-color: #fff;
  color: var(--bs-table-color);
  border-color: var(--bs-table-border-color);
}
.table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
@media (max-width: 575.98px) {
  .table-responsive-sm {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 767.98px) {
  .table-responsive-md {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 991.98px) {
  .table-responsive-lg {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 1199.98px) {
  .table-responsive-xl {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 1399.98px) {
  .table-responsive-xxl {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.form-label {
  margin-bottom: 0.5rem;
}
.col-form-label {
  padding-top: calc(0.375rem + var(--bs-border-width));
  padding-bottom: calc(0.375rem + var(--bs-border-width));
  margin-bottom: 0;
  font-size: inherit;
  line-height: 1.5;
}
.col-form-label-lg {
  padding-top: calc(0.5rem + var(--bs-border-width));
  padding-bottom: calc(0.5rem + var(--bs-border-width));
  font-size: 1.25rem;
}
.col-form-label-sm {
  padding-top: calc(0.25rem + var(--bs-border-width));
  padding-bottom: calc(0.25rem + var(--bs-border-width));
  font-size: 0.875rem;
}
.form-text {
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: var(--bs-secondary-color);
}
.form-control {
  display: block;
  width: 100%;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: var(--bs-body-bg);
  background-clip: padding-box;
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-control {
    transition: none;
  }
}
.form-control[type=file] {
  overflow: hidden;
}
.form-control[type=file]:not(:disabled):not([readonly]) {
  cursor: pointer;
}
.form-control:focus {
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-control::-webkit-date-and-time-value {
  min-width: 85px;
  height: 1.5em;
  margin: 0;
}
.form-control::-webkit-datetime-edit {
  display: block;
  padding: 0;
}
.form-control::-moz-placeholder {
  color: var(--bs-secondary-color);
  opacity: 1;
}
.form-control::placeholder {
  color: var(--bs-secondary-color);
  opacity: 1;
}
.form-control:disabled {
  background-color: var(--bs-secondary-bg);
  opacity: 1;
}
.form-control::file-selector-button {
  padding: 0.375rem 0.75rem;
  margin: -0.375rem -0.75rem;
  margin-inline-end: 0.75rem;
  color: var(--bs-body-color);
  background-color: var(--bs-tertiary-bg);
  pointer-events: none;
  border-color: inherit;
  border-style: solid;
  border-width: 0;
  border-inline-end-width: var(--bs-border-width);
  border-radius: 0;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-control::file-selector-button {
    transition: none;
  }
}
.form-control:hover:not(:disabled):not([readonly])::file-selector-button {
  background-color: var(--bs-secondary-bg);
}
.form-control-plaintext {
  display: block;
  width: 100%;
  padding: 0.375rem 0;
  margin-bottom: 0;
  line-height: 1.5;
  color: var(--bs-body-color);
  background-color: transparent;
  border: solid transparent;
  border-width: var(--bs-border-width) 0;
}
.form-control-plaintext:focus {
  outline: 0;
}
.form-control-plaintext.form-control-sm, .form-control-plaintext.form-control-lg {
  padding-right: 0;
  padding-left: 0;
}
.form-control-sm {
  min-height: calc(1.5em + 0.5rem + calc(var(--bs-border-width) * 2));
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  border-radius: var(--bs-border-radius-sm);
}
.form-control-sm::file-selector-button {
  padding: 0.25rem 0.5rem;
  margin: -0.25rem -0.5rem;
  margin-inline-end: 0.5rem;
}
.form-control-lg {
  min-height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
  padding: 0.5rem 1rem;
  font-size: 1.25rem;
  border-radius: var(--bs-border-radius-lg);
}
.form-control-lg::file-selector-button {
  padding: 0.5rem 1rem;
  margin: -0.5rem -1rem;
  margin-inline-end: 1rem;
}
textarea.form-control {
  min-height: calc(1.5em + 0.75rem + calc(var(--bs-border-width) * 2));
}
textarea.form-control-sm {
  min-height: calc(1.5em + 0.5rem + calc(var(--bs-border-width) * 2));
}
textarea.form-control-lg {
  min-height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
}
.form-control-color {
  width: 3rem;
  height: calc(1.5em + 0.75rem + calc(var(--bs-border-width) * 2));
  padding: 0.375rem;
}
.form-control-color:not(:disabled):not([readonly]) {
  cursor: pointer;
}
.form-control-color::-moz-color-swatch {
  border: 0 !important;
  border-radius: var(--bs-border-radius);
}
.form-control-color::-webkit-color-swatch {
  border: 0 !important;
  border-radius: var(--bs-border-radius);
}
.form-control-color.form-control-sm {
  height: calc(1.5em + 0.5rem + calc(var(--bs-border-width) * 2));
}
.form-control-color.form-control-lg {
  height: calc(1.5em + 1rem + calc(var(--bs-border-width) * 2));
}
.form-select {
  --bs-form-select-bg-img: 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");
  display: block;
  width: 100%;
  padding: 0.375rem 2.25rem 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: var(--bs-body-bg);
  background-image: var(--bs-form-select-bg-img), var(--bs-form-select-bg-icon, none);
  background-repeat: no-repeat;
  background-position: right 0.75rem center;
  background-size: 16px 12px;
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-select {
    transition: none;
  }
}
.form-select:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-select[multiple], .form-select[size]:not([size="1"]) {
  padding-right: 0.75rem;
  background-image: none;
}
.form-select:disabled {
  background-color: var(--bs-secondary-bg);
}
.form-select:-moz-focusring {
  color: transparent;
  text-shadow: 0 0 0 var(--bs-body-color);
}
.form-select-sm {
  padding-top: 0.25rem;
  padding-bottom: 0.25rem;
  padding-left: 0.5rem;
  font-size: 0.875rem;
  border-radius: var(--bs-border-radius-sm);
}
.form-select-lg {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  padding-left: 1rem;
  font-size: 1.25rem;
  border-radius: var(--bs-border-radius-lg);
}
[data-bs-theme=dark] .form-select {
  --bs-form-select-bg-img: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3e%3cpath fill='none' stroke='%23dee2e6' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
}
.form-check {
  display: block;
  min-height: 1.5rem;
  padding-left: 1.5em;
  margin-bottom: 0.125rem;
}
.form-check .form-check-input {
  float: left;
  margin-left: -1.5em;
}
.form-check-reverse {
  padding-right: 1.5em;
  padding-left: 0;
  text-align: right;
}
.form-check-reverse .form-check-input {
  float: right;
  margin-right: -1.5em;
  margin-left: 0;
}
.form-check-input {
  --bs-form-check-bg: var(--bs-body-bg);
  flex-shrink: 0;
  width: 1em;
  height: 1em;
  margin-top: 0.25em;
  vertical-align: top;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: var(--bs-form-check-bg);
  background-image: var(--bs-form-check-bg-image);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  border: var(--bs-border-width) solid var(--bs-border-color);
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}
.form-check-input[type=checkbox] {
  border-radius: 0.25em;
}
.form-check-input[type=radio] {
  border-radius: 50%;
}
.form-check-input:active {
  filter: brightness(90%);
}
.form-check-input:focus {
  border-color: #86b7fe;
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-check-input:checked {
  background-color: #0d6efd;
  border-color: #0d6efd;
}
.form-check-input:checked[type=checkbox] {
  --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='m6 10 3 3 6-6'/%3e%3c/svg%3e");
}
.form-check-input:checked[type=radio] {
  --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='2' fill='%23fff'/%3e%3c/svg%3e");
}
.form-check-input[type=checkbox]:indeterminate {
  background-color: #0d6efd;
  border-color: #0d6efd;
  --bs-form-check-bg-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'%3e%3cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='3' d='M6 10h8'/%3e%3c/svg%3e");
}
.form-check-input:disabled {
  pointer-events: none;
  filter: none;
  opacity: 0.5;
}
.form-check-input[disabled] ~ .form-check-label, .form-check-input:disabled ~ .form-check-label {
  cursor: default;
  opacity: 0.5;
}
.form-switch {
  padding-left: 2.5em;
}
.form-switch .form-check-input {
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%280, 0, 0, 0.25%29'/%3e%3c/svg%3e");
  width: 2em;
  margin-left: -2.5em;
  background-image: var(--bs-form-switch-bg);
  background-position: left center;
  border-radius: 2em;
  transition: background-position 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-switch .form-check-input {
    transition: none;
  }
}
.form-switch .form-check-input:focus {
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%2386b7fe'/%3e%3c/svg%3e");
}
.form-switch .form-check-input:checked {
  background-position: right center;
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e");
}
.form-switch.form-check-reverse {
  padding-right: 2.5em;
  padding-left: 0;
}
.form-switch.form-check-reverse .form-check-input {
  margin-right: -2.5em;
  margin-left: 0;
}
.form-check-inline {
  display: inline-block;
  margin-right: 1rem;
}
.btn-check {
  position: absolute;
  clip: rect(0, 0, 0, 0);
  pointer-events: none;
}
.btn-check[disabled] + .btn, .btn-check:disabled + .btn {
  pointer-events: none;
  filter: none;
  opacity: 0.65;
}
[data-bs-theme=dark] .form-switch .form-check-input:not(:checked):not(:focus) {
  --bs-form-switch-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='rgba%28255, 255, 255, 0.25%29'/%3e%3c/svg%3e");
}
.form-range {
  width: 100%;
  height: 1.5rem;
  padding: 0;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: transparent;
}
.form-range:focus {
  outline: 0;
}
.form-range:focus::-webkit-slider-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-range:focus::-moz-range-thumb {
  box-shadow: 0 0 0 1px #fff, 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.form-range::-moz-focus-outer {
  border: 0;
}
.form-range::-webkit-slider-thumb {
  width: 1rem;
  height: 1rem;
  margin-top: -0.25rem;
  -webkit-appearance: none;
  appearance: none;
  background-color: #0d6efd;
  border: 0;
  border-radius: 1rem;
  -webkit-transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-range::-webkit-slider-thumb {
    -webkit-transition: none;
    transition: none;
  }
}
.form-range::-webkit-slider-thumb:active {
  background-color: #b6d4fe;
}
.form-range::-webkit-slider-runnable-track {
  width: 100%;
  height: 0.5rem;
  color: transparent;
  cursor: pointer;
  background-color: var(--bs-secondary-bg);
  border-color: transparent;
  border-radius: 1rem;
}
.form-range::-moz-range-thumb {
  width: 1rem;
  height: 1rem;
  -moz-appearance: none;
  appearance: none;
  background-color: #0d6efd;
  border: 0;
  border-radius: 1rem;
  -moz-transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
  transition: background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-range::-moz-range-thumb {
    -moz-transition: none;
    transition: none;
  }
}
.form-range::-moz-range-thumb:active {
  background-color: #b6d4fe;
}
.form-range::-moz-range-track {
  width: 100%;
  height: 0.5rem;
  color: transparent;
  cursor: pointer;
  background-color: var(--bs-secondary-bg);
  border-color: transparent;
  border-radius: 1rem;
}
.form-range:disabled {
  pointer-events: none;
}
.form-range:disabled::-webkit-slider-thumb {
  background-color: var(--bs-secondary-color);
}
.form-range:disabled::-moz-range-thumb {
  background-color: var(--bs-secondary-color);
}
.form-floating {
  position: relative;
}
.form-floating > .form-control,
.form-floating > .form-control-plaintext,
.form-floating > .form-select {
  height: calc(3.5rem + calc(var(--bs-border-width) * 2));
  min-height: calc(3.5rem + calc(var(--bs-border-width) * 2));
  line-height: 1.25;
}
.form-floating > label {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  max-width: 100%;
  height: 100%;
  padding: 1rem 0.75rem;
  overflow: hidden;
  color: rgba(var(--bs-body-color-rgb), 0.65);
  text-align: start;
  text-overflow: ellipsis;
  white-space: nowrap;
  pointer-events: none;
  border: var(--bs-border-width) solid transparent;
  transform-origin: 0 0;
  transition: opacity 0.1s ease-in-out, transform 0.1s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .form-floating > label {
    transition: none;
  }
}
.form-floating > .form-control,
.form-floating > .form-control-plaintext {
  padding: 1rem 0.75rem;
}
.form-floating > .form-control::-moz-placeholder, .form-floating > .form-control-plaintext::-moz-placeholder {
  color: transparent;
}
.form-floating > .form-control::placeholder,
.form-floating > .form-control-plaintext::placeholder {
  color: transparent;
}
.form-floating > .form-control:not(:-moz-placeholder), .form-floating > .form-control-plaintext:not(:-moz-placeholder) {
  padding-top: 1.625rem;
  padding-bottom: 0.625rem;
}
.form-floating > .form-control:focus, .form-floating > .form-control:not(:placeholder-shown),
.form-floating > .form-control-plaintext:focus,
.form-floating > .form-control-plaintext:not(:placeholder-shown) {
  padding-top: 1.625rem;
  padding-bottom: 0.625rem;
}
.form-floating > .form-control:-webkit-autofill,
.form-floating > .form-control-plaintext:-webkit-autofill {
  padding-top: 1.625rem;
  padding-bottom: 0.625rem;
}
.form-floating > .form-select {
  padding-top: 1.625rem;
  padding-bottom: 0.625rem;
  padding-left: 0.75rem;
}
.form-floating > .form-control:not(:-moz-placeholder) ~ label {
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}
.form-floating > .form-control:focus ~ label,
.form-floating > .form-control:not(:placeholder-shown) ~ label,
.form-floating > .form-control-plaintext ~ label,
.form-floating > .form-select ~ label {
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}
.form-floating > .form-control:-webkit-autofill ~ label {
  transform: scale(0.85) translateY(-0.5rem) translateX(0.15rem);
}
.form-floating > textarea:not(:-moz-placeholder) ~ label::after {
  position: absolute;
  inset: 1rem 0.375rem;
  z-index: -1;
  height: 1.5em;
  content: "";
  background-color: var(--bs-body-bg);
  border-radius: var(--bs-border-radius);
}
.form-floating > textarea:focus ~ label::after,
.form-floating > textarea:not(:placeholder-shown) ~ label::after {
  position: absolute;
  inset: 1rem 0.375rem;
  z-index: -1;
  height: 1.5em;
  content: "";
  background-color: var(--bs-body-bg);
  border-radius: var(--bs-border-radius);
}
.form-floating > textarea:disabled ~ label::after {
  background-color: var(--bs-secondary-bg);
}
.form-floating > .form-control-plaintext ~ label {
  border-width: var(--bs-border-width) 0;
}
.form-floating > :disabled ~ label,
.form-floating > .form-control:disabled ~ label {
  color: #6c757d;
}
.input-group {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  width: 100%;
}
.input-group > .form-control,
.input-group > .form-select,
.input-group > .form-floating {
  position: relative;
  flex: 1 1 auto;
  width: 1%;
  min-width: 0;
}
.input-group > .form-control:focus,
.input-group > .form-select:focus,
.input-group > .form-floating:focus-within {
  z-index: 5;
}
.input-group .btn {
  position: relative;
  z-index: 2;
}
.input-group .btn:focus {
  z-index: 5;
}
.input-group-text {
  display: flex;
  align-items: center;
  padding: 0.375rem 0.75rem;
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.5;
  color: var(--bs-body-color);
  text-align: center;
  white-space: nowrap;
  background-color: var(--bs-tertiary-bg);
  border: var(--bs-border-width) solid var(--bs-border-color);
  border-radius: var(--bs-border-radius);
}
.input-group-lg > .form-control,
.input-group-lg > .form-select,
.input-group-lg > .input-group-text,
.input-group-lg > .btn {
  padding: 0.5rem 1rem;
  font-size: 1.25rem;
  border-radius: var(--bs-border-radius-lg);
}
.input-group-sm > .form-control,
.input-group-sm > .form-select,
.input-group-sm > .input-group-text,
.input-group-sm > .btn {
  padding: 0.25rem 0.5rem;
  font-size: 0.875rem;
  border-radius: var(--bs-border-radius-sm);
}
.input-group-lg > .form-select,
.input-group-sm > .form-select {
  padding-right: 3rem;
}
.input-group:not(.has-validation) > :not(:last-child):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),
.input-group:not(.has-validation) > .dropdown-toggle:nth-last-child(n+3),
.input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-control,
.input-group:not(.has-validation) > .form-floating:not(:last-child) > .form-select {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group.has-validation > :nth-last-child(n+3):not(.dropdown-toggle):not(.dropdown-menu):not(.form-floating),
.input-group.has-validation > .dropdown-toggle:nth-last-child(n+4),
.input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-control,
.input-group.has-validation > .form-floating:nth-last-child(n+3) > .form-select {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.input-group > :not(:first-child):not(.dropdown-menu):not(.valid-tooltip):not(.valid-feedback):not(.invalid-tooltip):not(.invalid-feedback) {
  margin-left: calc(-1 * var(--bs-border-width));
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.input-group > .form-floating:not(:first-child) > .form-control,
.input-group > .form-floating:not(:first-child) > .form-select {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.valid-feedback {
  display: none;
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: var(--bs-form-valid-color);
}
.valid-tooltip {
  position: absolute;
  top: 100%;
  z-index: 5;
  display: none;
  max-width: 100%;
  padding: 0.25rem 0.5rem;
  margin-top: 0.1rem;
  font-size: 0.875rem;
  color: #fff;
  background-color: var(--bs-success);
  border-radius: var(--bs-border-radius);
}
.was-validated :valid ~ .valid-feedback,
.was-validated :valid ~ .valid-tooltip,
.is-valid ~ .valid-feedback,
.is-valid ~ .valid-tooltip {
  display: block;
}
.was-validated .form-control:valid, .form-control.is-valid {
  border-color: var(--bs-form-valid-border-color);
  padding-right: calc(1.5em + 0.75rem);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .form-control:valid:focus, .form-control.is-valid:focus {
  border-color: var(--bs-form-valid-border-color);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
}
.was-validated textarea.form-control:valid, textarea.form-control.is-valid {
  padding-right: calc(1.5em + 0.75rem);
  background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}
.was-validated .form-select:valid, .form-select.is-valid {
  border-color: var(--bs-form-valid-border-color);
}
.was-validated .form-select:valid:not([multiple]):not([size]), .was-validated .form-select:valid:not([multiple])[size="1"], .form-select.is-valid:not([multiple]):not([size]), .form-select.is-valid:not([multiple])[size="1"] {
  --bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 8 8'%3e%3cpath fill='%23198754' d='M2.3 6.73.6 4.53c-.4-1.04.46-1.4 1.1-.8l1.1 1.4 3.4-3.8c.6-.63 1.6-.27 1.2.7l-4 4.6c-.43.5-.8.4-1.1.1'/%3e%3c/svg%3e");
  padding-right: 4.125rem;
  background-position: right 0.75rem center, center right 2.25rem;
  background-size: 16px 12px, calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .form-select:valid:focus, .form-select.is-valid:focus {
  border-color: var(--bs-form-valid-border-color);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
}
.was-validated .form-control-color:valid, .form-control-color.is-valid {
  width: calc(3rem + calc(1.5em + 0.75rem));
}
.was-validated .form-check-input:valid, .form-check-input.is-valid {
  border-color: var(--bs-form-valid-border-color);
}
.was-validated .form-check-input:valid:checked, .form-check-input.is-valid:checked {
  background-color: var(--bs-form-valid-color);
}
.was-validated .form-check-input:valid:focus, .form-check-input.is-valid:focus {
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-success-rgb), 0.25);
}
.was-validated .form-check-input:valid ~ .form-check-label, .form-check-input.is-valid ~ .form-check-label {
  color: var(--bs-form-valid-color);
}
.form-check-inline .form-check-input ~ .valid-feedback {
  margin-left: 0.5em;
}
.was-validated .input-group > .form-control:not(:focus):valid, .input-group > .form-control:not(:focus).is-valid,
.was-validated .input-group > .form-select:not(:focus):valid,
.input-group > .form-select:not(:focus).is-valid,
.was-validated .input-group > .form-floating:not(:focus-within):valid,
.input-group > .form-floating:not(:focus-within).is-valid {
  z-index: 3;
}
.invalid-feedback {
  display: none;
  width: 100%;
  margin-top: 0.25rem;
  font-size: 0.875em;
  color: var(--bs-form-invalid-color);
}
.invalid-tooltip {
  position: absolute;
  top: 100%;
  z-index: 5;
  display: none;
  max-width: 100%;
  padding: 0.25rem 0.5rem;
  margin-top: 0.1rem;
  font-size: 0.875rem;
  color: #fff;
  background-color: var(--bs-danger);
  border-radius: var(--bs-border-radius);
}
.was-validated :invalid ~ .invalid-feedback,
.was-validated :invalid ~ .invalid-tooltip,
.is-invalid ~ .invalid-feedback,
.is-invalid ~ .invalid-tooltip {
  display: block;
}
.was-validated .form-control:invalid, .form-control.is-invalid {
  border-color: var(--bs-form-invalid-border-color);
  padding-right: calc(1.5em + 0.75rem);
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right calc(0.375em + 0.1875rem) center;
  background-size: calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .form-control:invalid:focus, .form-control.is-invalid:focus {
  border-color: var(--bs-form-invalid-border-color);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-danger-rgb), 0.25);
}
.was-validated textarea.form-control:invalid, textarea.form-control.is-invalid {
  padding-right: calc(1.5em + 0.75rem);
  background-position: top calc(0.375em + 0.1875rem) right calc(0.375em + 0.1875rem);
}
.was-validated .form-select:invalid, .form-select.is-invalid {
  border-color: var(--bs-form-invalid-border-color);
}
.was-validated .form-select:invalid:not([multiple]):not([size]), .was-validated .form-select:invalid:not([multiple])[size="1"], .form-select.is-invalid:not([multiple]):not([size]), .form-select.is-invalid:not([multiple])[size="1"] {
  --bs-form-select-bg-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12' width='12' height='12' fill='none' stroke='%23dc3545'%3e%3ccircle cx='6' cy='6' r='4.5'/%3e%3cpath stroke-linejoin='round' d='M5.8 3.6h.4L6 6.5z'/%3e%3ccircle cx='6' cy='8.2' r='.6' fill='%23dc3545' stroke='none'/%3e%3c/svg%3e");
  padding-right: 4.125rem;
  background-position: right 0.75rem center, center right 2.25rem;
  background-size: 16px 12px, calc(0.75em + 0.375rem) calc(0.75em + 0.375rem);
}
.was-validated .form-select:invalid:focus, .form-select.is-invalid:focus {
  border-color: var(--bs-form-invalid-border-color);
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-danger-rgb), 0.25);
}
.was-validated .form-control-color:invalid, .form-control-color.is-invalid {
  width: calc(3rem + calc(1.5em + 0.75rem));
}
.was-validated .form-check-input:invalid, .form-check-input.is-invalid {
  border-color: var(--bs-form-invalid-border-color);
}
.was-validated .form-check-input:invalid:checked, .form-check-input.is-invalid:checked {
  background-color: var(--bs-form-invalid-color);
}
.was-validated .form-check-input:invalid:focus, .form-check-input.is-invalid:focus {
  box-shadow: 0 0 0 0.25rem rgba(var(--bs-danger-rgb), 0.25);
}
.was-validated .form-check-input:invalid ~ .form-check-label, .form-check-input.is-invalid ~ .form-check-label {
  color: var(--bs-form-invalid-color);
}
.form-check-inline .form-check-input ~ .invalid-feedback {
  margin-left: 0.5em;
}
.was-validated .input-group > .form-control:not(:focus):invalid, .input-group > .form-control:not(:focus).is-invalid,
.was-validated .input-group > .form-select:not(:focus):invalid,
.input-group > .form-select:not(:focus).is-invalid,
.was-validated .input-group > .form-floating:not(:focus-within):invalid,
.input-group > .form-floating:not(:focus-within).is-invalid {
  z-index: 4;
}
.btn {
  --bs-btn-padding-x: 0.75rem;
  --bs-btn-padding-y: 0.375rem;
  --bs-btn-font-family: ;
  --bs-btn-font-size: 1rem;
  --bs-btn-font-weight: 400;
  --bs-btn-line-height: 1.5;
  --bs-btn-color: var(--bs-body-color);
  --bs-btn-bg: transparent;
  --bs-btn-border-width: var(--bs-border-width);
  --bs-btn-border-color: transparent;
  --bs-btn-border-radius: var(--bs-border-radius);
  --bs-btn-hover-border-color: transparent;
  --bs-btn-box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.15), 0 1px 1px rgba(0, 0, 0, 0.075);
  --bs-btn-disabled-opacity: 0.65;
  --bs-btn-focus-box-shadow: 0 0 0 0.25rem rgba(var(--bs-btn-focus-shadow-rgb), .5);
  display: inline-block;
  padding: var(--bs-btn-padding-y) var(--bs-btn-padding-x);
  font-family: var(--bs-btn-font-family);
  font-size: var(--bs-btn-font-size);
  font-weight: var(--bs-btn-font-weight);
  line-height: var(--bs-btn-line-height);
  color: var(--bs-btn-color);
  text-align: center;
  text-decoration: none;
  vertical-align: middle;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  border: var(--bs-btn-border-width) solid var(--bs-btn-border-color);
  border-radius: var(--bs-btn-border-radius);
  background-color: var(--bs-btn-bg);
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .btn {
    transition: none;
  }
}
.btn:hover {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
}
.btn-check + .btn:hover {
  color: var(--bs-btn-color);
  background-color: var(--bs-btn-bg);
  border-color: var(--bs-btn-border-color);
}
.btn:focus-visible {
  color: var(--bs-btn-hover-color);
  background-color: var(--bs-btn-hover-bg);
  border-color: var(--bs-btn-hover-border-color);
  outline: 0;
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:focus-visible + .btn {
  border-color: var(--bs-btn-hover-border-color);
  outline: 0;
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:checked + .btn, :not(.btn-check) + .btn:active, .btn:first-child:active, .btn.active, .btn.show {
  color: var(--bs-btn-active-color);
  background-color: var(--bs-btn-active-bg);
  border-color: var(--bs-btn-active-border-color);
}
.btn-check:checked + .btn:focus-visible, :not(.btn-check) + .btn:active:focus-visible, .btn:first-child:active:focus-visible, .btn.active:focus-visible, .btn.show:focus-visible {
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn-check:checked:focus-visible + .btn {
  box-shadow: var(--bs-btn-focus-box-shadow);
}
.btn:disabled, .btn.disabled, fieldset:disabled .btn {
  color: var(--bs-btn-disabled-color);
  pointer-events: none;
  background-color: var(--bs-btn-disabled-bg);
  border-color: var(--bs-btn-disabled-border-color);
  opacity: var(--bs-btn-disabled-opacity);
}
.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #0d6efd;
  --bs-btn-border-color: #0d6efd;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #0b5ed7;
  --bs-btn-hover-border-color: #0a58ca;
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #0a58ca;
  --bs-btn-active-border-color: #0a53be;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #0d6efd;
  --bs-btn-disabled-border-color: #0d6efd;
}
.btn-secondary {
  --bs-btn-color: #fff;
  --bs-btn-bg: #6c757d;
  --bs-btn-border-color: #6c757d;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #5c636a;
  --bs-btn-hover-border-color: #565e64;
  --bs-btn-focus-shadow-rgb: 130, 138, 145;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #565e64;
  --bs-btn-active-border-color: #51585e;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #6c757d;
  --bs-btn-disabled-border-color: #6c757d;
}
.btn-success {
  --bs-btn-color: #fff;
  --bs-btn-bg: #198754;
  --bs-btn-border-color: #198754;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #157347;
  --bs-btn-hover-border-color: #146c43;
  --bs-btn-focus-shadow-rgb: 60, 153, 110;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #146c43;
  --bs-btn-active-border-color: #13653f;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #198754;
  --bs-btn-disabled-border-color: #198754;
}
.btn-info {
  --bs-btn-color: #000;
  --bs-btn-bg: #0dcaf0;
  --bs-btn-border-color: #0dcaf0;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #31d2f2;
  --bs-btn-hover-border-color: #25cff2;
  --bs-btn-focus-shadow-rgb: 11, 172, 204;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #3dd5f3;
  --bs-btn-active-border-color: #25cff2;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #0dcaf0;
  --bs-btn-disabled-border-color: #0dcaf0;
}
.btn-warning {
  --bs-btn-color: #000;
  --bs-btn-bg: #ffc107;
  --bs-btn-border-color: #ffc107;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #ffca2c;
  --bs-btn-hover-border-color: #ffc720;
  --bs-btn-focus-shadow-rgb: 217, 164, 6;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #ffcd39;
  --bs-btn-active-border-color: #ffc720;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #ffc107;
  --bs-btn-disabled-border-color: #ffc107;
}
.btn-danger {
  --bs-btn-color: #fff;
  --bs-btn-bg: #dc3545;
  --bs-btn-border-color: #dc3545;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #bb2d3b;
  --bs-btn-hover-border-color: #b02a37;
  --bs-btn-focus-shadow-rgb: 225, 83, 97;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #b02a37;
  --bs-btn-active-border-color: #a52834;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #dc3545;
  --bs-btn-disabled-border-color: #dc3545;
}
.btn-light {
  --bs-btn-color: #000;
  --bs-btn-bg: #f8f9fa;
  --bs-btn-border-color: #f8f9fa;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #d3d4d5;
  --bs-btn-hover-border-color: #c6c7c8;
  --bs-btn-focus-shadow-rgb: 211, 212, 213;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #c6c7c8;
  --bs-btn-active-border-color: #babbbc;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #000;
  --bs-btn-disabled-bg: #f8f9fa;
  --bs-btn-disabled-border-color: #f8f9fa;
}
.btn-dark {
  --bs-btn-color: #fff;
  --bs-btn-bg: #212529;
  --bs-btn-border-color: #212529;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #424649;
  --bs-btn-hover-border-color: #373b3e;
  --bs-btn-focus-shadow-rgb: 66, 70, 73;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #4d5154;
  --bs-btn-active-border-color: #373b3e;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: #212529;
  --bs-btn-disabled-border-color: #212529;
}
.btn-outline-primary {
  --bs-btn-color: #0d6efd;
  --bs-btn-border-color: #0d6efd;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #0d6efd;
  --bs-btn-hover-border-color: #0d6efd;
  --bs-btn-focus-shadow-rgb: 13, 110, 253;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #0d6efd;
  --bs-btn-active-border-color: #0d6efd;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #0d6efd;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #0d6efd;
  --bs-gradient: none;
}
.btn-outline-secondary {
  --bs-btn-color: #6c757d;
  --bs-btn-border-color: #6c757d;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #6c757d;
  --bs-btn-hover-border-color: #6c757d;
  --bs-btn-focus-shadow-rgb: 108, 117, 125;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #6c757d;
  --bs-btn-active-border-color: #6c757d;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #6c757d;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #6c757d;
  --bs-gradient: none;
}
.btn-outline-success {
  --bs-btn-color: #198754;
  --bs-btn-border-color: #198754;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #198754;
  --bs-btn-hover-border-color: #198754;
  --bs-btn-focus-shadow-rgb: 25, 135, 84;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #198754;
  --bs-btn-active-border-color: #198754;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #198754;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #198754;
  --bs-gradient: none;
}
.btn-outline-info {
  --bs-btn-color: #0dcaf0;
  --bs-btn-border-color: #0dcaf0;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #0dcaf0;
  --bs-btn-hover-border-color: #0dcaf0;
  --bs-btn-focus-shadow-rgb: 13, 202, 240;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #0dcaf0;
  --bs-btn-active-border-color: #0dcaf0;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #0dcaf0;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #0dcaf0;
  --bs-gradient: none;
}
.btn-outline-warning {
  --bs-btn-color: #ffc107;
  --bs-btn-border-color: #ffc107;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #ffc107;
  --bs-btn-hover-border-color: #ffc107;
  --bs-btn-focus-shadow-rgb: 255, 193, 7;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #ffc107;
  --bs-btn-active-border-color: #ffc107;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #ffc107;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #ffc107;
  --bs-gradient: none;
}
.btn-outline-danger {
  --bs-btn-color: #dc3545;
  --bs-btn-border-color: #dc3545;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #dc3545;
  --bs-btn-hover-border-color: #dc3545;
  --bs-btn-focus-shadow-rgb: 220, 53, 69;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #dc3545;
  --bs-btn-active-border-color: #dc3545;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #dc3545;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #dc3545;
  --bs-gradient: none;
}
.btn-outline-light {
  --bs-btn-color: #f8f9fa;
  --bs-btn-border-color: #f8f9fa;
  --bs-btn-hover-color: #000;
  --bs-btn-hover-bg: #f8f9fa;
  --bs-btn-hover-border-color: #f8f9fa;
  --bs-btn-focus-shadow-rgb: 248, 249, 250;
  --bs-btn-active-color: #000;
  --bs-btn-active-bg: #f8f9fa;
  --bs-btn-active-border-color: #f8f9fa;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #f8f9fa;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #f8f9fa;
  --bs-gradient: none;
}
.btn-outline-dark {
  --bs-btn-color: #212529;
  --bs-btn-border-color: #212529;
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #212529;
  --bs-btn-hover-border-color: #212529;
  --bs-btn-focus-shadow-rgb: 33, 37, 41;
  --bs-btn-active-color: #fff;
  --bs-btn-active-bg: #212529;
  --bs-btn-active-border-color: #212529;
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #212529;
  --bs-btn-disabled-bg: transparent;
  --bs-btn-disabled-border-color: #212529;
  --bs-gradient: none;
}
.btn-link {
  --bs-btn-font-weight: 400;
  --bs-btn-color: var(--bs-link-color);
  --bs-btn-bg: transparent;
  --bs-btn-border-color: transparent;
  --bs-btn-hover-color: var(--bs-link-hover-color);
  --bs-btn-hover-border-color: transparent;
  --bs-btn-active-color: var(--bs-link-hover-color);
  --bs-btn-active-border-color: transparent;
  --bs-btn-disabled-color: #6c757d;
  --bs-btn-disabled-border-color: transparent;
  --bs-btn-box-shadow: 0 0 0 #000;
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  text-decoration: underline;
}
.btn-link:focus-visible {
  color: var(--bs-btn-color);
}
.btn-link:hover {
  color: var(--bs-btn-hover-color);
}
.btn-lg, .btn-group-lg > .btn {
  --bs-btn-padding-y: 0.5rem;
  --bs-btn-padding-x: 1rem;
  --bs-btn-font-size: 1.25rem;
  --bs-btn-border-radius: var(--bs-border-radius-lg);
}
.btn-sm, .btn-group-sm > .btn {
  --bs-btn-padding-y: 0.25rem;
  --bs-btn-padding-x: 0.5rem;
  --bs-btn-font-size: 0.875rem;
  --bs-btn-border-radius: var(--bs-border-radius-sm);
}
.fade {
  transition: opacity 0.15s linear;
}
@media (prefers-reduced-motion: reduce) {
  .fade {
    transition: none;
  }
}
.fade:not(.show) {
  opacity: 0;
}
.collapse:not(.show) {
  display: none;
}
.collapsing {
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .collapsing {
    transition: none;
  }
}
.collapsing.collapse-horizontal {
  width: 0;
  height: auto;
  transition: width 0.35s ease;
}
@media (prefers-reduced-motion: reduce) {
  .collapsing.collapse-horizontal {
    transition: none;
  }
}
.dropup,
.dropend,
.dropdown,
.dropstart,
.dropup-center,
.dropdown-center {
  position: relative;
}
.dropdown-toggle {
  white-space: nowrap;
}
.dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid;
  border-right: 0.3em solid transparent;
  border-bottom: 0;
  border-left: 0.3em solid transparent;
}
.dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropdown-menu {
  --bs-dropdown-zindex: 1000;
  --bs-dropdown-min-width: 10rem;
  --bs-dropdown-padding-x: 0;
  --bs-dropdown-padding-y: 0.5rem;
  --bs-dropdown-spacer: 0.125rem;
  --bs-dropdown-font-size: 1rem;
  --bs-dropdown-color: var(--bs-body-color);
  --bs-dropdown-bg: var(--bs-body-bg);
  --bs-dropdown-border-color: var(--bs-border-color-translucent);
  --bs-dropdown-border-radius: var(--bs-border-radius);
  --bs-dropdown-border-width: var(--bs-border-width);
  --bs-dropdown-inner-border-radius: calc(var(--bs-border-radius) - var(--bs-border-width));
  --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
  --bs-dropdown-divider-margin-y: 0.5rem;
  --bs-dropdown-box-shadow: var(--bs-box-shadow);
  --bs-dropdown-link-color: var(--bs-body-color);
  --bs-dropdown-link-hover-color: var(--bs-body-color);
  --bs-dropdown-link-hover-bg: var(--bs-tertiary-bg);
  --bs-dropdown-link-active-color: #fff;
  --bs-dropdown-link-active-bg: #0d6efd;
  --bs-dropdown-link-disabled-color: var(--bs-tertiary-color);
  --bs-dropdown-item-padding-x: 1rem;
  --bs-dropdown-item-padding-y: 0.25rem;
  --bs-dropdown-header-color: #6c757d;
  --bs-dropdown-header-padding-x: 1rem;
  --bs-dropdown-header-padding-y: 0.5rem;
  position: absolute;
  z-index: var(--bs-dropdown-zindex);
  display: none;
  min-width: var(--bs-dropdown-min-width);
  padding: var(--bs-dropdown-padding-y) var(--bs-dropdown-padding-x);
  margin: 0;
  font-size: var(--bs-dropdown-font-size);
  color: var(--bs-dropdown-color);
  text-align: left;
  list-style: none;
  background-color: var(--bs-dropdown-bg);
  background-clip: padding-box;
  border: var(--bs-dropdown-border-width) solid var(--bs-dropdown-border-color);
  border-radius: var(--bs-dropdown-border-radius);
}
.dropdown-menu[data-bs-popper] {
  top: 100%;
  left: 0;
  margin-top: var(--bs-dropdown-spacer);
}
.dropdown-menu-start {
  --bs-position: start;
}
.dropdown-menu-start[data-bs-popper] {
  right: auto;
  left: 0;
}
.dropdown-menu-end {
  --bs-position: end;
}
.dropdown-menu-end[data-bs-popper] {
  right: 0;
  left: auto;
}
@media (min-width: 576px) {
  .dropdown-menu-sm-start {
    --bs-position: start;
  }
  .dropdown-menu-sm-start[data-bs-popper] {
    right: auto;
    left: 0;
  }
  .dropdown-menu-sm-end {
    --bs-position: end;
  }
  .dropdown-menu-sm-end[data-bs-popper] {
    right: 0;
    left: auto;
  }
}
@media (min-width: 768px) {
  .dropdown-menu-md-start {
    --bs-position: start;
  }
  .dropdown-menu-md-start[data-bs-popper] {
    right: auto;
    left: 0;
  }
  .dropdown-menu-md-end {
    --bs-position: end;
  }
  .dropdown-menu-md-end[data-bs-popper] {
    right: 0;
    left: auto;
  }
}
@media (min-width: 992px) {
  .dropdown-menu-lg-start {
    --bs-position: start;
  }
  .dropdown-menu-lg-start[data-bs-popper] {
    right: auto;
    left: 0;
  }
  .dropdown-menu-lg-end {
    --bs-position: end;
  }
  .dropdown-menu-lg-end[data-bs-popper] {
    right: 0;
    left: auto;
  }
}
@media (min-width: 1200px) {
  .dropdown-menu-xl-start {
    --bs-position: start;
  }
  .dropdown-menu-xl-start[data-bs-popper] {
    right: auto;
    left: 0;
  }
  .dropdown-menu-xl-end {
    --bs-position: end;
  }
  .dropdown-menu-xl-end[data-bs-popper] {
    right: 0;
    left: auto;
  }
}
@media (min-width: 1400px) {
  .dropdown-menu-xxl-start {
    --bs-position: start;
  }
  .dropdown-menu-xxl-start[data-bs-popper] {
    right: auto;
    left: 0;
  }
  .dropdown-menu-xxl-end {
    --bs-position: end;
  }
  .dropdown-menu-xxl-end[data-bs-popper] {
    right: 0;
    left: auto;
  }
}
.dropup .dropdown-menu[data-bs-popper] {
  top: auto;
  bottom: 100%;
  margin-top: 0;
  margin-bottom: var(--bs-dropdown-spacer);
}
.dropup .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0;
  border-right: 0.3em solid transparent;
  border-bottom: 0.3em solid;
  border-left: 0.3em solid transparent;
}
.dropup .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropend .dropdown-menu[data-bs-popper] {
  top: 0;
  right: auto;
  left: 100%;
  margin-top: 0;
  margin-left: var(--bs-dropdown-spacer);
}
.dropend .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0;
  border-bottom: 0.3em solid transparent;
  border-left: 0.3em solid;
}
.dropend .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropend .dropdown-toggle::after {
  vertical-align: 0;
}
.dropstart .dropdown-menu[data-bs-popper] {
  top: 0;
  right: 100%;
  left: auto;
  margin-top: 0;
  margin-right: var(--bs-dropdown-spacer);
}
.dropstart .dropdown-toggle::after {
  display: inline-block;
  margin-left: 0.255em;
  vertical-align: 0.255em;
  content: "";
}
.dropstart .dropdown-toggle::after {
  display: none;
}
.dropstart .dropdown-toggle::before {
  display: inline-block;
  margin-right: 0.255em;
  vertical-align: 0.255em;
  content: "";
  border-top: 0.3em solid transparent;
  border-right: 0.3em solid;
  border-bottom: 0.3em solid transparent;
}
.dropstart .dropdown-toggle:empty::after {
  margin-left: 0;
}
.dropstart .dropdown-toggle::before {
  vertical-align: 0;
}
.dropdown-divider {
  height: 0;
  margin: var(--bs-dropdown-divider-margin-y) 0;
  overflow: hidden;
  border-top: 1px solid var(--bs-dropdown-divider-bg);
  opacity: 1;
}
.dropdown-item {
  display: block;
  width: 100%;
  padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
  clear: both;
  font-weight: 400;
  color: var(--bs-dropdown-link-color);
  text-align: inherit;
  text-decoration: none;
  white-space: nowrap;
  background-color: transparent;
  border: 0;
  border-radius: var(--bs-dropdown-item-border-radius, 0);
}
.dropdown-item:hover, .dropdown-item:focus {
  color: var(--bs-dropdown-link-hover-color);
  background-color: var(--bs-dropdown-link-hover-bg);
}
.dropdown-item.active, .dropdown-item:active {
  color: var(--bs-dropdown-link-active-color);
  text-decoration: none;
  background-color: var(--bs-dropdown-link-active-bg);
}
.dropdown-item.disabled, .dropdown-item:disabled {
  color: var(--bs-dropdown-link-disabled-color);
  pointer-events: none;
  background-color: transparent;
}
.dropdown-menu.show {
  display: block;
}
.dropdown-header {
  display: block;
  padding: var(--bs-dropdown-header-padding-y) var(--bs-dropdown-header-padding-x);
  margin-bottom: 0;
  font-size: 0.875rem;
  color: var(--bs-dropdown-header-color);
  white-space: nowrap;
}
.dropdown-item-text {
  display: block;
  padding: var(--bs-dropdown-item-padding-y) var(--bs-dropdown-item-padding-x);
  color: var(--bs-dropdown-link-color);
}
.dropdown-menu-dark {
  --bs-dropdown-color: #dee2e6;
  --bs-dropdown-bg: #343a40;
  --bs-dropdown-border-color: var(--bs-border-color-translucent);
  --bs-dropdown-box-shadow: ;
  --bs-dropdown-link-color: #dee2e6;
  --bs-dropdown-link-hover-color: #fff;
  --bs-dropdown-divider-bg: var(--bs-border-color-translucent);
  --bs-dropdown-link-hover-bg: rgba(255, 255, 255, 0.15);
  --bs-dropdown-link-active-color: #fff;
  --bs-dropdown-link-active-bg: #0d6efd;
  --bs-dropdown-link-disabled-color: #adb5bd;
  --bs-dropdown-header-color: #adb5bd;
}
.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;
}
.btn-group > .btn-check:checked + .btn,
.btn-group > .btn-check:focus + .btn,
.btn-group > .btn:hover,
.btn-group > .btn:focus,
.btn-group > .btn:active,
.btn-group > .btn.active,
.btn-group-vertical > .btn-check:checked + .btn,
.btn-group-vertical > .btn-check:focus + .btn,
.btn-group-vertical > .btn:hover,
.btn-group-vertical > .btn:focus,
.btn-group-vertical > .btn:active,
.btn-group-vertical > .btn.active {
  z-index: 1;
}
.btn-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.btn-toolbar .input-group {
  width: auto;
}
.btn-group {
  border-radius: var(--bs-border-radius);
}
.btn-group > :not(.btn-check:first-child) + .btn,
.btn-group > .btn-group:not(:first-child) {
  margin-left: calc(-1 * var(--bs-border-width));
}
.btn-group > .btn:not(:last-child):not(.dropdown-toggle),
.btn-group > .btn.dropdown-toggle-split:first-child,
.btn-group > .btn-group:not(:last-child) > .btn {
  border-top-right-radius: 0;
  border-bottom-right-radius: 0;
}
.btn-group > .btn:nth-child(n+3),
.btn-group > :not(.btn-check) + .btn,
.btn-group > .btn-group:not(:first-child) > .btn {
  border-top-left-radius: 0;
  border-bottom-left-radius: 0;
}
.dropdown-toggle-split {
  padding-right: 0.5625rem;
  padding-left: 0.5625rem;
}
.dropdown-toggle-split::after, .dropup .dropdown-toggle-split::after, .dropend .dropdown-toggle-split::after {
  margin-left: 0;
}
.dropstart .dropdown-toggle-split::before {
  margin-right: 0;
}
.btn-sm + .dropdown-toggle-split, .btn-group-sm > .btn + .dropdown-toggle-split {
  padding-right: 0.375rem;
  padding-left: 0.375rem;
}
.btn-lg + .dropdown-toggle-split, .btn-group-lg > .btn + .dropdown-toggle-split {
  padding-right: 0.75rem;
  padding-left: 0.75rem;
}
.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: calc(-1 * var(--bs-border-width));
}
.btn-group-vertical > .btn:not(:last-child):not(.dropdown-toggle),
.btn-group-vertical > .btn-group:not(:last-child) > .btn {
  border-bottom-right-radius: 0;
  border-bottom-left-radius: 0;
}
.btn-group-vertical > .btn:nth-child(n+3),
.btn-group-vertical > :not(.btn-check) + .btn,
.btn-group-vertical > .btn-group:not(:first-child) > .btn {
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.nav {
  --bs-nav-link-padding-x: 1rem;
  --bs-nav-link-padding-y: 0.5rem;
  --bs-nav-link-font-weight: ;
  --bs-nav-link-color: var(--bs-link-color);
  --bs-nav-link-hover-color: var(--bs-link-hover-color);
  --bs-nav-link-disabled-color: var(--bs-secondary-color);
  display: flex;
  flex-wrap: wrap;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.nav-link {
  display: block;
  padding: var(--bs-nav-link-padding-y) var(--bs-nav-link-padding-x);
  font-size: var(--bs-nav-link-font-size);
  font-weight: var(--bs-nav-link-font-weight);
  color: var(--bs-nav-link-color);
  text-decoration: none;
  background: none;
  border: 0;
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .nav-link {
    transition: none;
  }
}
.nav-link:hover, .nav-link:focus {
  color: var(--bs-nav-link-hover-color);
}
.nav-link:focus-visible {
  outline: 0;
  box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
}
.nav-link.disabled, .nav-link:disabled {
  color: var(--bs-nav-link-disabled-color);
  pointer-events: none;
  cursor: default;
}
.nav-tabs {
  --bs-nav-tabs-border-width: var(--bs-border-width);
  --bs-nav-tabs-border-color: var(--bs-border-color);
  --bs-nav-tabs-border-radius: var(--bs-border-radius);
  --bs-nav-tabs-link-hover-border-color: var(--bs-secondary-bg) var(--bs-secondary-bg) var(--bs-border-color);
  --bs-nav-tabs-link-active-color: var(--bs-emphasis-color);
  --bs-nav-tabs-link-active-bg: var(--bs-body-bg);
  --bs-nav-tabs-link-active-border-color: var(--bs-border-color) var(--bs-border-color) var(--bs-body-bg);
  border-bottom: var(--bs-nav-tabs-border-width) solid var(--bs-nav-tabs-border-color);
}
.nav-tabs .nav-link {
  margin-bottom: calc(-1 * var(--bs-nav-tabs-border-width));
  border: var(--bs-nav-tabs-border-width) solid transparent;
  border-top-left-radius: var(--bs-nav-tabs-border-radius);
  border-top-right-radius: var(--bs-nav-tabs-border-radius);
}
.nav-tabs .nav-link:hover, .nav-tabs .nav-link:focus {
  isolation: isolate;
  border-color: var(--bs-nav-tabs-link-hover-border-color);
}
.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
  color: var(--bs-nav-tabs-link-active-color);
  background-color: var(--bs-nav-tabs-link-active-bg);
  border-color: var(--bs-nav-tabs-link-active-border-color);
}
.nav-tabs .dropdown-menu {
  margin-top: calc(-1 * var(--bs-nav-tabs-border-width));
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}
.nav-pills {
  --bs-nav-pills-border-radius: var(--bs-border-radius);
  --bs-nav-pills-link-active-color: #fff;
  --bs-nav-pills-link-active-bg: #0d6efd;
}
.nav-pills .nav-link {
  border-radius: var(--bs-nav-pills-border-radius);
}
.nav-pills .nav-link.active,
.nav-pills .show > .nav-link {
  color: var(--bs-nav-pills-link-active-color);
  background-color: var(--bs-nav-pills-link-active-bg);
}
.nav-underline {
  --bs-nav-underline-gap: 1rem;
  --bs-nav-underline-border-width: 0.125rem;
  --bs-nav-underline-link-active-color: var(--bs-emphasis-color);
  gap: var(--bs-nav-underline-gap);
}
.nav-underline .nav-link {
  padding-right: 0;
  padding-left: 0;
  border-bottom: var(--bs-nav-underline-border-width) solid transparent;
}
.nav-underline .nav-link:hover, .nav-underline .nav-link:focus {
  border-bottom-color: currentcolor;
}
.nav-underline .nav-link.active,
.nav-underline .show > .nav-link {
  font-weight: 700;
  color: var(--bs-nav-underline-link-active-color);
  border-bottom-color: currentcolor;
}
.nav-fill > .nav-link,
.nav-fill .nav-item {
  flex: 1 1 auto;
  text-align: center;
}
.nav-justified > .nav-link,
.nav-justified .nav-item {
  flex-grow: 1;
  flex-basis: 0;
  text-align: center;
}
.nav-fill .nav-item .nav-link,
.nav-justified .nav-item .nav-link {
  width: 100%;
}
.tab-content > .tab-pane {
  display: none;
}
.tab-content > .active {
  display: block;
}
.navbar {
  --bs-navbar-padding-x: 0;
  --bs-navbar-padding-y: 0.5rem;
  --bs-navbar-color: rgba(var(--bs-emphasis-color-rgb), 0.65);
  --bs-navbar-hover-color: rgba(var(--bs-emphasis-color-rgb), 0.8);
  --bs-navbar-disabled-color: rgba(var(--bs-emphasis-color-rgb), 0.3);
  --bs-navbar-active-color: rgba(var(--bs-emphasis-color-rgb), 1);
  --bs-navbar-brand-padding-y: 0.3125rem;
  --bs-navbar-brand-margin-end: 1rem;
  --bs-navbar-brand-font-size: 1.25rem;
  --bs-navbar-brand-color: rgba(var(--bs-emphasis-color-rgb), 1);
  --bs-navbar-brand-hover-color: rgba(var(--bs-emphasis-color-rgb), 1);
  --bs-navbar-nav-link-padding-x: 0.5rem;
  --bs-navbar-toggler-padding-y: 0.25rem;
  --bs-navbar-toggler-padding-x: 0.75rem;
  --bs-navbar-toggler-font-size: 1.25rem;
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%2833, 37, 41, 0.75%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
  --bs-navbar-toggler-border-color: rgba(var(--bs-emphasis-color-rgb), 0.15);
  --bs-navbar-toggler-border-radius: var(--bs-border-radius);
  --bs-navbar-toggler-focus-width: 0.25rem;
  --bs-navbar-toggler-transition: box-shadow 0.15s ease-in-out;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  padding: var(--bs-navbar-padding-y) var(--bs-navbar-padding-x);
}
.navbar > .container,
.navbar > .container-fluid,
.navbar > .container-sm,
.navbar > .container-md,
.navbar > .container-lg,
.navbar > .container-xl,
.navbar > .container-xxl {
  display: flex;
  flex-wrap: inherit;
  align-items: center;
  justify-content: space-between;
}
.navbar-brand {
  padding-top: var(--bs-navbar-brand-padding-y);
  padding-bottom: var(--bs-navbar-brand-padding-y);
  margin-right: var(--bs-navbar-brand-margin-end);
  font-size: var(--bs-navbar-brand-font-size);
  color: var(--bs-navbar-brand-color);
  text-decoration: none;
  white-space: nowrap;
}
.navbar-brand:hover, .navbar-brand:focus {
  color: var(--bs-navbar-brand-hover-color);
}
.navbar-nav {
  --bs-nav-link-padding-x: 0;
  --bs-nav-link-padding-y: 0.5rem;
  --bs-nav-link-font-weight: ;
  --bs-nav-link-color: var(--bs-navbar-color);
  --bs-nav-link-hover-color: var(--bs-navbar-hover-color);
  --bs-nav-link-disabled-color: var(--bs-navbar-disabled-color);
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  list-style: none;
}
.navbar-nav .nav-link.active, .navbar-nav .nav-link.show {
  color: var(--bs-navbar-active-color);
}
.navbar-nav .dropdown-menu {
  position: static;
}
.navbar-text {
  padding-top: 0.5rem;
  padding-bottom: 0.5rem;
  color: var(--bs-navbar-color);
}
.navbar-text a,
.navbar-text a:hover,
.navbar-text a:focus {
  color: var(--bs-navbar-active-color);
}
.navbar-collapse {
  flex-grow: 1;
  flex-basis: 100%;
  align-items: center;
}
.navbar-toggler {
  padding: var(--bs-navbar-toggler-padding-y) var(--bs-navbar-toggler-padding-x);
  font-size: var(--bs-navbar-toggler-font-size);
  line-height: 1;
  color: var(--bs-navbar-color);
  background-color: transparent;
  border: var(--bs-border-width) solid var(--bs-navbar-toggler-border-color);
  border-radius: var(--bs-navbar-toggler-border-radius);
  transition: var(--bs-navbar-toggler-transition);
}
@media (prefers-reduced-motion: reduce) {
  .navbar-toggler {
    transition: none;
  }
}
.navbar-toggler:hover {
  text-decoration: none;
}
.navbar-toggler:focus {
  text-decoration: none;
  outline: 0;
  box-shadow: 0 0 0 var(--bs-navbar-toggler-focus-width);
}
.navbar-toggler-icon {
  display: inline-block;
  width: 1.5em;
  height: 1.5em;
  vertical-align: middle;
  background-image: var(--bs-navbar-toggler-icon-bg);
  background-repeat: no-repeat;
  background-position: center;
  background-size: 100%;
}
.navbar-nav-scroll {
  max-height: var(--bs-scroll-height, 75vh);
  overflow-y: auto;
}
@media (min-width: 576px) {
  .navbar-expand-sm {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-sm .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-sm .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-sm .navbar-nav .nav-link {
    padding-right: var(--bs-navbar-nav-link-padding-x);
    padding-left: var(--bs-navbar-nav-link-padding-x);
  }
  .navbar-expand-sm .navbar-nav-scroll {
    overflow: visible;
  }
  .navbar-expand-sm .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-sm .navbar-toggler {
    display: none;
  }
  .navbar-expand-sm .offcanvas {
    position: static;
    z-index: auto;
    flex-grow: 1;
    width: auto !important;
    height: auto !important;
    visibility: visible !important;
    background-color: transparent !important;
    border: 0 !important;
    transform: none !important;
    transition: none;
  }
  .navbar-expand-sm .offcanvas .offcanvas-header {
    display: none;
  }
  .navbar-expand-sm .offcanvas .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
  }
}
@media (min-width: 768px) {
  .navbar-expand-md {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-md .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-md .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-md .navbar-nav .nav-link {
    padding-right: var(--bs-navbar-nav-link-padding-x);
    padding-left: var(--bs-navbar-nav-link-padding-x);
  }
  .navbar-expand-md .navbar-nav-scroll {
    overflow: visible;
  }
  .navbar-expand-md .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-md .navbar-toggler {
    display: none;
  }
  .navbar-expand-md .offcanvas {
    position: static;
    z-index: auto;
    flex-grow: 1;
    width: auto !important;
    height: auto !important;
    visibility: visible !important;
    background-color: transparent !important;
    border: 0 !important;
    transform: none !important;
    transition: none;
  }
  .navbar-expand-md .offcanvas .offcanvas-header {
    display: none;
  }
  .navbar-expand-md .offcanvas .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
  }
}
@media (min-width: 992px) {
  .navbar-expand-lg {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-lg .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-lg .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-lg .navbar-nav .nav-link {
    padding-right: var(--bs-navbar-nav-link-padding-x);
    padding-left: var(--bs-navbar-nav-link-padding-x);
  }
  .navbar-expand-lg .navbar-nav-scroll {
    overflow: visible;
  }
  .navbar-expand-lg .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-lg .navbar-toggler {
    display: none;
  }
  .navbar-expand-lg .offcanvas {
    position: static;
    z-index: auto;
    flex-grow: 1;
    width: auto !important;
    height: auto !important;
    visibility: visible !important;
    background-color: transparent !important;
    border: 0 !important;
    transform: none !important;
    transition: none;
  }
  .navbar-expand-lg .offcanvas .offcanvas-header {
    display: none;
  }
  .navbar-expand-lg .offcanvas .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
  }
}
@media (min-width: 1200px) {
  .navbar-expand-xl {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-xl .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-xl .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-xl .navbar-nav .nav-link {
    padding-right: var(--bs-navbar-nav-link-padding-x);
    padding-left: var(--bs-navbar-nav-link-padding-x);
  }
  .navbar-expand-xl .navbar-nav-scroll {
    overflow: visible;
  }
  .navbar-expand-xl .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-xl .navbar-toggler {
    display: none;
  }
  .navbar-expand-xl .offcanvas {
    position: static;
    z-index: auto;
    flex-grow: 1;
    width: auto !important;
    height: auto !important;
    visibility: visible !important;
    background-color: transparent !important;
    border: 0 !important;
    transform: none !important;
    transition: none;
  }
  .navbar-expand-xl .offcanvas .offcanvas-header {
    display: none;
  }
  .navbar-expand-xl .offcanvas .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
  }
}
@media (min-width: 1400px) {
  .navbar-expand-xxl {
    flex-wrap: nowrap;
    justify-content: flex-start;
  }
  .navbar-expand-xxl .navbar-nav {
    flex-direction: row;
  }
  .navbar-expand-xxl .navbar-nav .dropdown-menu {
    position: absolute;
  }
  .navbar-expand-xxl .navbar-nav .nav-link {
    padding-right: var(--bs-navbar-nav-link-padding-x);
    padding-left: var(--bs-navbar-nav-link-padding-x);
  }
  .navbar-expand-xxl .navbar-nav-scroll {
    overflow: visible;
  }
  .navbar-expand-xxl .navbar-collapse {
    display: flex !important;
    flex-basis: auto;
  }
  .navbar-expand-xxl .navbar-toggler {
    display: none;
  }
  .navbar-expand-xxl .offcanvas {
    position: static;
    z-index: auto;
    flex-grow: 1;
    width: auto !important;
    height: auto !important;
    visibility: visible !important;
    background-color: transparent !important;
    border: 0 !important;
    transform: none !important;
    transition: none;
  }
  .navbar-expand-xxl .offcanvas .offcanvas-header {
    display: none;
  }
  .navbar-expand-xxl .offcanvas .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
  }
}
.navbar-expand {
  flex-wrap: nowrap;
  justify-content: flex-start;
}
.navbar-expand .navbar-nav {
  flex-direction: row;
}
.navbar-expand .navbar-nav .dropdown-menu {
  position: absolute;
}
.navbar-expand .navbar-nav .nav-link {
  padding-right: var(--bs-navbar-nav-link-padding-x);
  padding-left: var(--bs-navbar-nav-link-padding-x);
}
.navbar-expand .navbar-nav-scroll {
  overflow: visible;
}
.navbar-expand .navbar-collapse {
  display: flex !important;
  flex-basis: auto;
}
.navbar-expand .navbar-toggler {
  display: none;
}
.navbar-expand .offcanvas {
  position: static;
  z-index: auto;
  flex-grow: 1;
  width: auto !important;
  height: auto !important;
  visibility: visible !important;
  background-color: transparent !important;
  border: 0 !important;
  transform: none !important;
  transition: none;
}
.navbar-expand .offcanvas .offcanvas-header {
  display: none;
}
.navbar-expand .offcanvas .offcanvas-body {
  display: flex;
  flex-grow: 0;
  padding: 0;
  overflow-y: visible;
}
.navbar-dark,
.navbar[data-bs-theme=dark] {
  --bs-navbar-color: rgba(255, 255, 255, 0.55);
  --bs-navbar-hover-color: rgba(255, 255, 255, 0.75);
  --bs-navbar-disabled-color: rgba(255, 255, 255, 0.25);
  --bs-navbar-active-color: #fff;
  --bs-navbar-brand-color: #fff;
  --bs-navbar-brand-hover-color: #fff;
  --bs-navbar-toggler-border-color: rgba(255, 255, 255, 0.1);
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
[data-bs-theme=dark] .navbar-toggler-icon {
  --bs-navbar-toggler-icon-bg: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba%28255, 255, 255, 0.55%29' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");
}
.card {
  --bs-card-spacer-y: 1rem;
  --bs-card-spacer-x: 1rem;
  --bs-card-title-spacer-y: 0.5rem;
  --bs-card-title-color: ;
  --bs-card-subtitle-color: ;
  --bs-card-border-width: var(--bs-border-width);
  --bs-card-border-color: var(--bs-border-color-translucent);
  --bs-card-border-radius: var(--bs-border-radius);
  --bs-card-box-shadow: ;
  --bs-card-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
  --bs-card-cap-padding-y: 0.5rem;
  --bs-card-cap-padding-x: 1rem;
  --bs-card-cap-bg: rgba(var(--bs-body-color-rgb), 0.03);
  --bs-card-cap-color: ;
  --bs-card-height: ;
  --bs-card-color: ;
  --bs-card-bg: var(--bs-body-bg);
  --bs-card-img-overlay-padding: 1rem;
  --bs-card-group-margin: 0.75rem;
  position: relative;
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: var(--bs-card-height);
  color: var(--bs-body-color);
  word-wrap: break-word;
  background-color: var(--bs-card-bg);
  background-clip: border-box;
  border: var(--bs-card-border-width) solid var(--bs-card-border-color);
  border-radius: var(--bs-card-border-radius);
}
.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: var(--bs-card-inner-border-radius);
  border-top-right-radius: var(--bs-card-inner-border-radius);
}
.card > .list-group:last-child {
  border-bottom-width: 0;
  border-bottom-right-radius: var(--bs-card-inner-border-radius);
  border-bottom-left-radius: var(--bs-card-inner-border-radius);
}
.card > .card-header + .list-group,
.card > .list-group + .card-footer {
  border-top: 0;
}
.card-body {
  flex: 1 1 auto;
  padding: var(--bs-card-spacer-y) var(--bs-card-spacer-x);
  color: var(--bs-card-color);
}
.card-title {
  margin-bottom: var(--bs-card-title-spacer-y);
  color: var(--bs-card-title-color);
}
.card-subtitle {
  margin-top: calc(-0.5 * var(--bs-card-title-spacer-y));
  margin-bottom: 0;
  color: var(--bs-card-subtitle-color);
}
.card-text:last-child {
  margin-bottom: 0;
}
.card-link + .card-link {
  margin-left: var(--bs-card-spacer-x);
}
.card-header {
  padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
  margin-bottom: 0;
  color: var(--bs-card-cap-color);
  background-color: var(--bs-card-cap-bg);
  border-bottom: var(--bs-card-border-width) solid var(--bs-card-border-color);
}
.card-header:first-child {
  border-radius: var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius) 0 0;
}
.card-footer {
  padding: var(--bs-card-cap-padding-y) var(--bs-card-cap-padding-x);
  color: var(--bs-card-cap-color);
  background-color: var(--bs-card-cap-bg);
  border-top: var(--bs-card-border-width) solid var(--bs-card-border-color);
}
.card-footer:last-child {
  border-radius: 0 0 var(--bs-card-inner-border-radius) var(--bs-card-inner-border-radius);
}
.card-header-tabs {
  margin-right: calc(-0.5 * var(--bs-card-cap-padding-x));
  margin-bottom: calc(-1 * var(--bs-card-cap-padding-y));
  margin-left: calc(-0.5 * var(--bs-card-cap-padding-x));
  border-bottom: 0;
}
.card-header-tabs .nav-link.active {
  background-color: var(--bs-card-bg);
  border-bottom-color: var(--bs-card-bg);
}
.card-header-pills {
  margin-right: calc(-0.5 * var(--bs-card-cap-padding-x));
  margin-left: calc(-0.5 * var(--bs-card-cap-padding-x));
}
.card-img-overlay {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: var(--bs-card-img-overlay-padding);
  border-radius: var(--bs-card-inner-border-radius);
}
.card-img,
.card-img-top,
.card-img-bottom {
  width: 100%;
}
.card-img,
.card-img-top {
  border-top-left-radius: var(--bs-card-inner-border-radius);
  border-top-right-radius: var(--bs-card-inner-border-radius);
}
.card-img,
.card-img-bottom {
  border-bottom-right-radius: var(--bs-card-inner-border-radius);
  border-bottom-left-radius: var(--bs-card-inner-border-radius);
}
.card-group > .card {
  margin-bottom: var(--bs-card-group-margin);
}
@media (min-width: 576px) {
  .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;
  }
}
.accordion {
  --bs-accordion-color: var(--bs-body-color);
  --bs-accordion-bg: var(--bs-body-bg);
  --bs-accordion-transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out, border-radius 0.15s ease;
  --bs-accordion-border-color: var(--bs-border-color);
  --bs-accordion-border-width: var(--bs-border-width);
  --bs-accordion-border-radius: var(--bs-border-radius);
  --bs-accordion-inner-border-radius: calc(var(--bs-border-radius) - (var(--bs-border-width)));
  --bs-accordion-btn-padding-x: 1.25rem;
  --bs-accordion-btn-padding-y: 1rem;
  --bs-accordion-btn-color: var(--bs-body-color);
  --bs-accordion-btn-bg: var(--bs-accordion-bg);
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23212529' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  --bs-accordion-btn-icon-width: 1.25rem;
  --bs-accordion-btn-icon-transform: rotate(-180deg);
  --bs-accordion-btn-icon-transition: transform 0.2s ease-in-out;
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23052c65' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='m2 5 6 6 6-6'/%3e%3c/svg%3e");
  --bs-accordion-btn-focus-box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  --bs-accordion-body-padding-x: 1.25rem;
  --bs-accordion-body-padding-y: 1rem;
  --bs-accordion-active-color: var(--bs-primary-text-emphasis);
  --bs-accordion-active-bg: var(--bs-primary-bg-subtle);
}
.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: 1rem;
  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: var(--bs-accordion-transition);
}
@media (prefers-reduced-motion: reduce) {
  .accordion-button {
    transition: none;
  }
}
.accordion-button:not(.collapsed) {
  color: var(--bs-accordion-active-color);
  background-color: var(--bs-accordion-active-bg);
  box-shadow: inset 0 calc(-1 * var(--bs-accordion-border-width)) 0 var(--bs-accordion-border-color);
}
.accordion-button:not(.collapsed)::after {
  background-image: var(--bs-accordion-btn-active-icon);
  transform: var(--bs-accordion-btn-icon-transform);
}
.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: var(--bs-accordion-btn-icon);
  background-repeat: no-repeat;
  background-size: var(--bs-accordion-btn-icon-width);
  transition: var(--bs-accordion-btn-icon-transition);
}
@media (prefers-reduced-motion: reduce) {
  .accordion-button::after {
    transition: none;
  }
}
.accordion-button:hover {
  z-index: 2;
}
.accordion-button:focus {
  z-index: 3;
  outline: 0;
  box-shadow: var(--bs-accordion-btn-focus-box-shadow);
}
.accordion-header {
  margin-bottom: 0;
}
.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-header .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-header .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-body {
  padding: var(--bs-accordion-body-padding-y) var(--bs-accordion-body-padding-x);
}
.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;
}
.accordion-flush > .accordion-item > .accordion-collapse,
.accordion-flush > .accordion-item > .accordion-header .accordion-button,
.accordion-flush > .accordion-item > .accordion-header .accordion-button.collapsed {
  border-radius: 0;
}
[data-bs-theme=dark] .accordion-button::after {
  --bs-accordion-btn-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%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-.708'/%3e%3c/svg%3e");
  --bs-accordion-btn-active-icon: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%236ea8fe'%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-.708'/%3e%3c/svg%3e");
}
.breadcrumb {
  --bs-breadcrumb-padding-x: 0;
  --bs-breadcrumb-padding-y: 0;
  --bs-breadcrumb-margin-bottom: 1rem;
  --bs-breadcrumb-bg: ;
  --bs-breadcrumb-border-radius: ;
  --bs-breadcrumb-divider-color: var(--bs-secondary-color);
  --bs-breadcrumb-item-padding-x: 0.5rem;
  --bs-breadcrumb-item-active-color: var(--bs-secondary-color);
  display: flex;
  flex-wrap: wrap;
  padding: var(--bs-breadcrumb-padding-y) var(--bs-breadcrumb-padding-x);
  margin-bottom: var(--bs-breadcrumb-margin-bottom);
  font-size: var(--bs-breadcrumb-font-size);
  list-style: none;
  background-color: var(--bs-breadcrumb-bg);
  border-radius: var(--bs-breadcrumb-border-radius);
}
.breadcrumb-item + .breadcrumb-item {
  padding-left: var(--bs-breadcrumb-item-padding-x);
}
.breadcrumb-item + .breadcrumb-item::before {
  float: left;
  padding-right: var(--bs-breadcrumb-item-padding-x);
  color: var(--bs-breadcrumb-divider-color);
  content: var(--bs-breadcrumb-divider, "/") /* rtl: var(--bs-breadcrumb-divider, "/") */;
}
.breadcrumb-item.active {
  color: var(--bs-breadcrumb-item-active-color);
}
.pagination {
  --bs-pagination-padding-x: 0.75rem;
  --bs-pagination-padding-y: 0.375rem;
  --bs-pagination-font-size: 1rem;
  --bs-pagination-color: var(--bs-link-color);
  --bs-pagination-bg: var(--bs-body-bg);
  --bs-pagination-border-width: var(--bs-border-width);
  --bs-pagination-border-color: var(--bs-border-color);
  --bs-pagination-border-radius: var(--bs-border-radius);
  --bs-pagination-hover-color: var(--bs-link-hover-color);
  --bs-pagination-hover-bg: var(--bs-tertiary-bg);
  --bs-pagination-hover-border-color: var(--bs-border-color);
  --bs-pagination-focus-color: var(--bs-link-hover-color);
  --bs-pagination-focus-bg: var(--bs-secondary-bg);
  --bs-pagination-focus-box-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  --bs-pagination-active-color: #fff;
  --bs-pagination-active-bg: #0d6efd;
  --bs-pagination-active-border-color: #0d6efd;
  --bs-pagination-disabled-color: var(--bs-secondary-color);
  --bs-pagination-disabled-bg: var(--bs-secondary-bg);
  --bs-pagination-disabled-border-color: var(--bs-border-color);
  display: flex;
  padding-left: 0;
  list-style: none;
}
.page-link {
  position: relative;
  display: block;
  padding: var(--bs-pagination-padding-y) var(--bs-pagination-padding-x);
  font-size: var(--bs-pagination-font-size);
  color: var(--bs-pagination-color);
  text-decoration: none;
  background-color: var(--bs-pagination-bg);
  border: var(--bs-pagination-border-width) solid var(--bs-pagination-border-color);
  transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .page-link {
    transition: none;
  }
}
.page-link:hover {
  z-index: 2;
  color: var(--bs-pagination-hover-color);
  background-color: var(--bs-pagination-hover-bg);
  border-color: var(--bs-pagination-hover-border-color);
}
.page-link:focus {
  z-index: 3;
  color: var(--bs-pagination-focus-color);
  background-color: var(--bs-pagination-focus-bg);
  outline: 0;
  box-shadow: var(--bs-pagination-focus-box-shadow);
}
.page-link.active, .active > .page-link {
  z-index: 3;
  color: var(--bs-pagination-active-color);
  background-color: var(--bs-pagination-active-bg);
  border-color: var(--bs-pagination-active-border-color);
}
.page-link.disabled, .disabled > .page-link {
  color: var(--bs-pagination-disabled-color);
  pointer-events: none;
  background-color: var(--bs-pagination-disabled-bg);
  border-color: var(--bs-pagination-disabled-border-color);
}
.page-item:not(:first-child) .page-link {
  margin-left: calc(-1 * var(--bs-border-width));
}
.page-item:first-child .page-link {
  border-top-left-radius: var(--bs-pagination-border-radius);
  border-bottom-left-radius: var(--bs-pagination-border-radius);
}
.page-item:last-child .page-link {
  border-top-right-radius: var(--bs-pagination-border-radius);
  border-bottom-right-radius: var(--bs-pagination-border-radius);
}
.pagination-lg {
  --bs-pagination-padding-x: 1.5rem;
  --bs-pagination-padding-y: 0.75rem;
  --bs-pagination-font-size: 1.25rem;
  --bs-pagination-border-radius: var(--bs-border-radius-lg);
}
.pagination-sm {
  --bs-pagination-padding-x: 0.5rem;
  --bs-pagination-padding-y: 0.25rem;
  --bs-pagination-font-size: 0.875rem;
  --bs-pagination-border-radius: var(--bs-border-radius-sm);
}
.badge {
  --bs-badge-padding-x: 0.65em;
  --bs-badge-padding-y: 0.35em;
  --bs-badge-font-size: 0.75em;
  --bs-badge-font-weight: 700;
  --bs-badge-color: #fff;
  --bs-badge-border-radius: var(--bs-border-radius);
  display: inline-block;
  padding: var(--bs-badge-padding-y) var(--bs-badge-padding-x);
  font-size: var(--bs-badge-font-size);
  font-weight: var(--bs-badge-font-weight);
  line-height: 1;
  color: var(--bs-badge-color);
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: var(--bs-badge-border-radius);
}
.badge:empty {
  display: none;
}
.btn .badge {
  position: relative;
  top: -1px;
}
.alert {
  --bs-alert-bg: transparent;
  --bs-alert-padding-x: 1rem;
  --bs-alert-padding-y: 1rem;
  --bs-alert-margin-bottom: 1rem;
  --bs-alert-color: inherit;
  --bs-alert-border-color: transparent;
  --bs-alert-border: var(--bs-border-width) solid var(--bs-alert-border-color);
  --bs-alert-border-radius: var(--bs-border-radius);
  --bs-alert-link-color: inherit;
  position: relative;
  padding: var(--bs-alert-padding-y) var(--bs-alert-padding-x);
  margin-bottom: var(--bs-alert-margin-bottom);
  color: var(--bs-alert-color);
  background-color: var(--bs-alert-bg);
  border: var(--bs-alert-border);
  border-radius: var(--bs-alert-border-radius);
}
.alert-heading {
  color: inherit;
}
.alert-link {
  font-weight: 700;
  color: var(--bs-alert-link-color);
}
.alert-dismissible {
  padding-right: 3rem;
}
.alert-dismissible .btn-close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  padding: 1.25rem 1rem;
}
.alert-primary {
  --bs-alert-color: var(--bs-primary-text-emphasis);
  --bs-alert-bg: var(--bs-primary-bg-subtle);
  --bs-alert-border-color: var(--bs-primary-border-subtle);
  --bs-alert-link-color: var(--bs-primary-text-emphasis);
}
.alert-secondary {
  --bs-alert-color: var(--bs-secondary-text-emphasis);
  --bs-alert-bg: var(--bs-secondary-bg-subtle);
  --bs-alert-border-color: var(--bs-secondary-border-subtle);
  --bs-alert-link-color: var(--bs-secondary-text-emphasis);
}
.alert-success {
  --bs-alert-color: var(--bs-success-text-emphasis);
  --bs-alert-bg: var(--bs-success-bg-subtle);
  --bs-alert-border-color: var(--bs-success-border-subtle);
  --bs-alert-link-color: var(--bs-success-text-emphasis);
}
.alert-info {
  --bs-alert-color: var(--bs-info-text-emphasis);
  --bs-alert-bg: var(--bs-info-bg-subtle);
  --bs-alert-border-color: var(--bs-info-border-subtle);
  --bs-alert-link-color: var(--bs-info-text-emphasis);
}
.alert-warning {
  --bs-alert-color: var(--bs-warning-text-emphasis);
  --bs-alert-bg: var(--bs-warning-bg-subtle);
  --bs-alert-border-color: var(--bs-warning-border-subtle);
  --bs-alert-link-color: var(--bs-warning-text-emphasis);
}
.alert-danger {
  --bs-alert-color: var(--bs-danger-text-emphasis);
  --bs-alert-bg: var(--bs-danger-bg-subtle);
  --bs-alert-border-color: var(--bs-danger-border-subtle);
  --bs-alert-link-color: var(--bs-danger-text-emphasis);
}
.alert-light {
  --bs-alert-color: var(--bs-light-text-emphasis);
  --bs-alert-bg: var(--bs-light-bg-subtle);
  --bs-alert-border-color: var(--bs-light-border-subtle);
  --bs-alert-link-color: var(--bs-light-text-emphasis);
}
.alert-dark {
  --bs-alert-color: var(--bs-dark-text-emphasis);
  --bs-alert-bg: var(--bs-dark-bg-subtle);
  --bs-alert-border-color: var(--bs-dark-border-subtle);
  --bs-alert-link-color: var(--bs-dark-text-emphasis);
}
@keyframes progress-bar-stripes {
  0% {
    background-position-x: var(--bs-progress-height);
  }
}
.progress,
.progress-stacked {
  --bs-progress-height: 1rem;
  --bs-progress-font-size: 0.75rem;
  --bs-progress-bg: var(--bs-secondary-bg);
  --bs-progress-border-radius: var(--bs-border-radius);
  --bs-progress-box-shadow: var(--bs-box-shadow-inset);
  --bs-progress-bar-color: #fff;
  --bs-progress-bar-bg: #0d6efd;
  --bs-progress-bar-transition: width 0.6s ease;
  display: flex;
  height: var(--bs-progress-height);
  overflow: hidden;
  font-size: var(--bs-progress-font-size);
  background-color: var(--bs-progress-bg);
  border-radius: var(--bs-progress-border-radius);
}
.progress-bar {
  display: flex;
  flex-direction: column;
  justify-content: center;
  overflow: hidden;
  color: var(--bs-progress-bar-color);
  text-align: center;
  white-space: nowrap;
  background-color: var(--bs-progress-bar-bg);
  transition: var(--bs-progress-bar-transition);
}
@media (prefers-reduced-motion: reduce) {
  .progress-bar {
    transition: none;
  }
}
.progress-bar-striped {
  background-image: linear-gradient(45deg, rgba(255, 255, 255, 0.15) 25%, transparent 25%, transparent 50%, rgba(255, 255, 255, 0.15) 50%, rgba(255, 255, 255, 0.15) 75%, transparent 75%, transparent);
  background-size: var(--bs-progress-height) var(--bs-progress-height);
}
.progress-stacked > .progress {
  overflow: visible;
}
.progress-stacked > .progress > .progress-bar {
  width: 100%;
}
.progress-bar-animated {
  animation: 1s linear infinite progress-bar-stripes;
}
@media (prefers-reduced-motion: reduce) {
  .progress-bar-animated {
    animation: none;
  }
}
.list-group {
  --bs-list-group-color: var(--bs-body-color);
  --bs-list-group-bg: var(--bs-body-bg);
  --bs-list-group-border-color: var(--bs-border-color);
  --bs-list-group-border-width: var(--bs-border-width);
  --bs-list-group-border-radius: var(--bs-border-radius);
  --bs-list-group-item-padding-x: 1rem;
  --bs-list-group-item-padding-y: 0.5rem;
  --bs-list-group-action-color: var(--bs-secondary-color);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-tertiary-bg);
  --bs-list-group-action-active-color: var(--bs-body-color);
  --bs-list-group-action-active-bg: var(--bs-secondary-bg);
  --bs-list-group-disabled-color: var(--bs-secondary-color);
  --bs-list-group-disabled-bg: var(--bs-body-bg);
  --bs-list-group-active-color: #fff;
  --bs-list-group-active-bg: #0d6efd;
  --bs-list-group-active-border-color: #0d6efd;
  display: flex;
  flex-direction: column;
  padding-left: 0;
  margin-bottom: 0;
  border-radius: var(--bs-list-group-border-radius);
}
.list-group-numbered {
  list-style-type: none;
  counter-reset: section;
}
.list-group-numbered > .list-group-item::before {
  content: counters(section, ".") ". ";
  counter-increment: section;
}
.list-group-item {
  position: relative;
  display: block;
  padding: var(--bs-list-group-item-padding-y) var(--bs-list-group-item-padding-x);
  color: var(--bs-list-group-color);
  text-decoration: none;
  background-color: var(--bs-list-group-bg);
  border: var(--bs-list-group-border-width) solid var(--bs-list-group-border-color);
}
.list-group-item:first-child {
  border-top-left-radius: inherit;
  border-top-right-radius: inherit;
}
.list-group-item:last-child {
  border-bottom-right-radius: inherit;
  border-bottom-left-radius: inherit;
}
.list-group-item.disabled, .list-group-item:disabled {
  color: var(--bs-list-group-disabled-color);
  pointer-events: none;
  background-color: var(--bs-list-group-disabled-bg);
}
.list-group-item.active {
  z-index: 2;
  color: var(--bs-list-group-active-color);
  background-color: var(--bs-list-group-active-bg);
  border-color: var(--bs-list-group-active-border-color);
}
.list-group-item + .list-group-item {
  border-top-width: 0;
}
.list-group-item + .list-group-item.active {
  margin-top: calc(-1 * var(--bs-list-group-border-width));
  border-top-width: var(--bs-list-group-border-width);
}
.list-group-item-action {
  width: 100%;
  color: var(--bs-list-group-action-color);
  text-align: inherit;
}
.list-group-item-action:not(.active):hover, .list-group-item-action:not(.active):focus {
  z-index: 1;
  color: var(--bs-list-group-action-hover-color);
  text-decoration: none;
  background-color: var(--bs-list-group-action-hover-bg);
}
.list-group-item-action:not(.active):active {
  color: var(--bs-list-group-action-active-color);
  background-color: var(--bs-list-group-action-active-bg);
}
.list-group-horizontal {
  flex-direction: row;
}
.list-group-horizontal > .list-group-item:first-child:not(:last-child) {
  border-bottom-left-radius: var(--bs-list-group-border-radius);
  border-top-right-radius: 0;
}
.list-group-horizontal > .list-group-item:last-child:not(:first-child) {
  border-top-right-radius: var(--bs-list-group-border-radius);
  border-bottom-left-radius: 0;
}
.list-group-horizontal > .list-group-item.active {
  margin-top: 0;
}
.list-group-horizontal > .list-group-item + .list-group-item {
  border-top-width: var(--bs-list-group-border-width);
  border-left-width: 0;
}
.list-group-horizontal > .list-group-item + .list-group-item.active {
  margin-left: calc(-1 * var(--bs-list-group-border-width));
  border-left-width: var(--bs-list-group-border-width);
}
@media (min-width: 576px) {
  .list-group-horizontal-sm {
    flex-direction: row;
  }
  .list-group-horizontal-sm > .list-group-item:first-child:not(:last-child) {
    border-bottom-left-radius: var(--bs-list-group-border-radius);
    border-top-right-radius: 0;
  }
  .list-group-horizontal-sm > .list-group-item:last-child:not(:first-child) {
    border-top-right-radius: var(--bs-list-group-border-radius);
    border-bottom-left-radius: 0;
  }
  .list-group-horizontal-sm > .list-group-item.active {
    margin-top: 0;
  }
  .list-group-horizontal-sm > .list-group-item + .list-group-item {
    border-top-width: var(--bs-list-group-border-width);
    border-left-width: 0;
  }
  .list-group-horizontal-sm > .list-group-item + .list-group-item.active {
    margin-left: calc(-1 * var(--bs-list-group-border-width));
    border-left-width: var(--bs-list-group-border-width);
  }
}
@media (min-width: 768px) {
  .list-group-horizontal-md {
    flex-direction: row;
  }
  .list-group-horizontal-md > .list-group-item:first-child:not(:last-child) {
    border-bottom-left-radius: var(--bs-list-group-border-radius);
    border-top-right-radius: 0;
  }
  .list-group-horizontal-md > .list-group-item:last-child:not(:first-child) {
    border-top-right-radius: var(--bs-list-group-border-radius);
    border-bottom-left-radius: 0;
  }
  .list-group-horizontal-md > .list-group-item.active {
    margin-top: 0;
  }
  .list-group-horizontal-md > .list-group-item + .list-group-item {
    border-top-width: var(--bs-list-group-border-width);
    border-left-width: 0;
  }
  .list-group-horizontal-md > .list-group-item + .list-group-item.active {
    margin-left: calc(-1 * var(--bs-list-group-border-width));
    border-left-width: var(--bs-list-group-border-width);
  }
}
@media (min-width: 992px) {
  .list-group-horizontal-lg {
    flex-direction: row;
  }
  .list-group-horizontal-lg > .list-group-item:first-child:not(:last-child) {
    border-bottom-left-radius: var(--bs-list-group-border-radius);
    border-top-right-radius: 0;
  }
  .list-group-horizontal-lg > .list-group-item:last-child:not(:first-child) {
    border-top-right-radius: var(--bs-list-group-border-radius);
    border-bottom-left-radius: 0;
  }
  .list-group-horizontal-lg > .list-group-item.active {
    margin-top: 0;
  }
  .list-group-horizontal-lg > .list-group-item + .list-group-item {
    border-top-width: var(--bs-list-group-border-width);
    border-left-width: 0;
  }
  .list-group-horizontal-lg > .list-group-item + .list-group-item.active {
    margin-left: calc(-1 * var(--bs-list-group-border-width));
    border-left-width: var(--bs-list-group-border-width);
  }
}
@media (min-width: 1200px) {
  .list-group-horizontal-xl {
    flex-direction: row;
  }
  .list-group-horizontal-xl > .list-group-item:first-child:not(:last-child) {
    border-bottom-left-radius: var(--bs-list-group-border-radius);
    border-top-right-radius: 0;
  }
  .list-group-horizontal-xl > .list-group-item:last-child:not(:first-child) {
    border-top-right-radius: var(--bs-list-group-border-radius);
    border-bottom-left-radius: 0;
  }
  .list-group-horizontal-xl > .list-group-item.active {
    margin-top: 0;
  }
  .list-group-horizontal-xl > .list-group-item + .list-group-item {
    border-top-width: var(--bs-list-group-border-width);
    border-left-width: 0;
  }
  .list-group-horizontal-xl > .list-group-item + .list-group-item.active {
    margin-left: calc(-1 * var(--bs-list-group-border-width));
    border-left-width: var(--bs-list-group-border-width);
  }
}
@media (min-width: 1400px) {
  .list-group-horizontal-xxl {
    flex-direction: row;
  }
  .list-group-horizontal-xxl > .list-group-item:first-child:not(:last-child) {
    border-bottom-left-radius: var(--bs-list-group-border-radius);
    border-top-right-radius: 0;
  }
  .list-group-horizontal-xxl > .list-group-item:last-child:not(:first-child) {
    border-top-right-radius: var(--bs-list-group-border-radius);
    border-bottom-left-radius: 0;
  }
  .list-group-horizontal-xxl > .list-group-item.active {
    margin-top: 0;
  }
  .list-group-horizontal-xxl > .list-group-item + .list-group-item {
    border-top-width: var(--bs-list-group-border-width);
    border-left-width: 0;
  }
  .list-group-horizontal-xxl > .list-group-item + .list-group-item.active {
    margin-left: calc(-1 * var(--bs-list-group-border-width));
    border-left-width: var(--bs-list-group-border-width);
  }
}
.list-group-flush {
  border-radius: 0;
}
.list-group-flush > .list-group-item {
  border-width: 0 0 var(--bs-list-group-border-width);
}
.list-group-flush > .list-group-item:last-child {
  border-bottom-width: 0;
}
.list-group-item-primary {
  --bs-list-group-color: var(--bs-primary-text-emphasis);
  --bs-list-group-bg: var(--bs-primary-bg-subtle);
  --bs-list-group-border-color: var(--bs-primary-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-primary-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-primary-border-subtle);
  --bs-list-group-active-color: var(--bs-primary-bg-subtle);
  --bs-list-group-active-bg: var(--bs-primary-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-primary-text-emphasis);
}
.list-group-item-secondary {
  --bs-list-group-color: var(--bs-secondary-text-emphasis);
  --bs-list-group-bg: var(--bs-secondary-bg-subtle);
  --bs-list-group-border-color: var(--bs-secondary-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-secondary-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-secondary-border-subtle);
  --bs-list-group-active-color: var(--bs-secondary-bg-subtle);
  --bs-list-group-active-bg: var(--bs-secondary-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-secondary-text-emphasis);
}
.list-group-item-success {
  --bs-list-group-color: var(--bs-success-text-emphasis);
  --bs-list-group-bg: var(--bs-success-bg-subtle);
  --bs-list-group-border-color: var(--bs-success-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-success-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-success-border-subtle);
  --bs-list-group-active-color: var(--bs-success-bg-subtle);
  --bs-list-group-active-bg: var(--bs-success-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-success-text-emphasis);
}
.list-group-item-info {
  --bs-list-group-color: var(--bs-info-text-emphasis);
  --bs-list-group-bg: var(--bs-info-bg-subtle);
  --bs-list-group-border-color: var(--bs-info-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-info-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-info-border-subtle);
  --bs-list-group-active-color: var(--bs-info-bg-subtle);
  --bs-list-group-active-bg: var(--bs-info-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-info-text-emphasis);
}
.list-group-item-warning {
  --bs-list-group-color: var(--bs-warning-text-emphasis);
  --bs-list-group-bg: var(--bs-warning-bg-subtle);
  --bs-list-group-border-color: var(--bs-warning-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-warning-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-warning-border-subtle);
  --bs-list-group-active-color: var(--bs-warning-bg-subtle);
  --bs-list-group-active-bg: var(--bs-warning-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-warning-text-emphasis);
}
.list-group-item-danger {
  --bs-list-group-color: var(--bs-danger-text-emphasis);
  --bs-list-group-bg: var(--bs-danger-bg-subtle);
  --bs-list-group-border-color: var(--bs-danger-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-danger-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-danger-border-subtle);
  --bs-list-group-active-color: var(--bs-danger-bg-subtle);
  --bs-list-group-active-bg: var(--bs-danger-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-danger-text-emphasis);
}
.list-group-item-light {
  --bs-list-group-color: var(--bs-light-text-emphasis);
  --bs-list-group-bg: var(--bs-light-bg-subtle);
  --bs-list-group-border-color: var(--bs-light-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-light-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-light-border-subtle);
  --bs-list-group-active-color: var(--bs-light-bg-subtle);
  --bs-list-group-active-bg: var(--bs-light-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-light-text-emphasis);
}
.list-group-item-dark {
  --bs-list-group-color: var(--bs-dark-text-emphasis);
  --bs-list-group-bg: var(--bs-dark-bg-subtle);
  --bs-list-group-border-color: var(--bs-dark-border-subtle);
  --bs-list-group-action-hover-color: var(--bs-emphasis-color);
  --bs-list-group-action-hover-bg: var(--bs-dark-border-subtle);
  --bs-list-group-action-active-color: var(--bs-emphasis-color);
  --bs-list-group-action-active-bg: var(--bs-dark-border-subtle);
  --bs-list-group-active-color: var(--bs-dark-bg-subtle);
  --bs-list-group-active-bg: var(--bs-dark-text-emphasis);
  --bs-list-group-active-border-color: var(--bs-dark-text-emphasis);
}
.btn-close {
  --bs-btn-close-color: #000;
  --bs-btn-close-bg: 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.414'/%3e%3c/svg%3e");
  --bs-btn-close-opacity: 0.5;
  --bs-btn-close-hover-opacity: 0.75;
  --bs-btn-close-focus-shadow: 0 0 0 0.25rem rgba(13, 110, 253, 0.25);
  --bs-btn-close-focus-opacity: 1;
  --bs-btn-close-disabled-opacity: 0.25;
  box-sizing: content-box;
  width: 1em;
  height: 1em;
  padding: 0.25em 0.25em;
  color: var(--bs-btn-close-color);
  background: transparent var(--bs-btn-close-bg) center/1em auto no-repeat;
  filter: var(--bs-btn-close-filter);
  border: 0;
  border-radius: 0.375rem;
  opacity: var(--bs-btn-close-opacity);
}
.btn-close:hover {
  color: var(--bs-btn-close-color);
  text-decoration: none;
  opacity: var(--bs-btn-close-hover-opacity);
}
.btn-close:focus {
  outline: 0;
  box-shadow: var(--bs-btn-close-focus-shadow);
  opacity: var(--bs-btn-close-focus-opacity);
}
.btn-close:disabled, .btn-close.disabled {
  pointer-events: none;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
  opacity: var(--bs-btn-close-disabled-opacity);
}
.btn-close-white {
  --bs-btn-close-filter: invert(1) grayscale(100%) brightness(200%);
}
:root,
[data-bs-theme=light] {
  --bs-btn-close-filter: ;
}
[data-bs-theme=dark] {
  --bs-btn-close-filter: invert(1) grayscale(100%) brightness(200%);
}
.toast {
  --bs-toast-zindex: 1090;
  --bs-toast-padding-x: 0.75rem;
  --bs-toast-padding-y: 0.5rem;
  --bs-toast-spacing: 1.5rem;
  --bs-toast-max-width: 350px;
  --bs-toast-font-size: 0.875rem;
  --bs-toast-color: ;
  --bs-toast-bg: rgba(var(--bs-body-bg-rgb), 0.85);
  --bs-toast-border-width: var(--bs-border-width);
  --bs-toast-border-color: var(--bs-border-color-translucent);
  --bs-toast-border-radius: var(--bs-border-radius);
  --bs-toast-box-shadow: var(--bs-box-shadow);
  --bs-toast-header-color: var(--bs-secondary-color);
  --bs-toast-header-bg: rgba(var(--bs-body-bg-rgb), 0.85);
  --bs-toast-header-border-color: var(--bs-border-color-translucent);
  width: var(--bs-toast-max-width);
  max-width: 100%;
  font-size: var(--bs-toast-font-size);
  color: var(--bs-toast-color);
  pointer-events: auto;
  background-color: var(--bs-toast-bg);
  background-clip: padding-box;
  border: var(--bs-toast-border-width) solid var(--bs-toast-border-color);
  box-shadow: var(--bs-toast-box-shadow);
  border-radius: var(--bs-toast-border-radius);
}
.toast.showing {
  opacity: 0;
}
.toast:not(.show) {
  display: none;
}
.toast-container {
  --bs-toast-zindex: 1090;
  position: absolute;
  z-index: var(--bs-toast-zindex);
  width: -moz-max-content;
  width: max-content;
  max-width: 100%;
  pointer-events: none;
}
.toast-container > :not(:last-child) {
  margin-bottom: var(--bs-toast-spacing);
}
.toast-header {
  display: flex;
  align-items: center;
  padding: var(--bs-toast-padding-y) var(--bs-toast-padding-x);
  color: var(--bs-toast-header-color);
  background-color: var(--bs-toast-header-bg);
  background-clip: padding-box;
  border-bottom: var(--bs-toast-border-width) solid var(--bs-toast-header-border-color);
  border-top-left-radius: calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));
  border-top-right-radius: calc(var(--bs-toast-border-radius) - var(--bs-toast-border-width));
}
.toast-header .btn-close {
  margin-right: calc(-0.5 * var(--bs-toast-padding-x));
  margin-left: var(--bs-toast-padding-x);
}
.toast-body {
  padding: var(--bs-toast-padding-x);
  word-wrap: break-word;
}
.modal {
  --bs-modal-zindex: 1055;
  --bs-modal-width: 500px;
  --bs-modal-padding: 1rem;
  --bs-modal-margin: 0.5rem;
  --bs-modal-color: var(--bs-body-color);
  --bs-modal-bg: var(--bs-body-bg);
  --bs-modal-border-color: var(--bs-border-color-translucent);
  --bs-modal-border-width: var(--bs-border-width);
  --bs-modal-border-radius: var(--bs-border-radius-lg);
  --bs-modal-box-shadow: var(--bs-box-shadow-sm);
  --bs-modal-inner-border-radius: calc(var(--bs-border-radius-lg) - (var(--bs-border-width)));
  --bs-modal-header-padding-x: 1rem;
  --bs-modal-header-padding-y: 1rem;
  --bs-modal-header-padding: 1rem 1rem;
  --bs-modal-header-border-color: var(--bs-border-color);
  --bs-modal-header-border-width: var(--bs-border-width);
  --bs-modal-title-line-height: 1.5;
  --bs-modal-footer-gap: 0.5rem;
  --bs-modal-footer-bg: ;
  --bs-modal-footer-border-color: var(--bs-border-color);
  --bs-modal-footer-border-width: var(--bs-border-width);
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-modal-zindex);
  display: none;
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  outline: 0;
}
.modal-dialog {
  position: relative;
  width: auto;
  margin: var(--bs-modal-margin);
  pointer-events: none;
}
.modal.fade .modal-dialog {
  transform: translate(0, -50px);
  transition: transform 0.3s ease-out;
}
@media (prefers-reduced-motion: reduce) {
  .modal.fade .modal-dialog {
    transition: none;
  }
}
.modal.show .modal-dialog {
  transform: none;
}
.modal.modal-static .modal-dialog {
  transform: scale(1.02);
}
.modal-dialog-scrollable {
  height: calc(100% - var(--bs-modal-margin) * 2);
}
.modal-dialog-scrollable .modal-content {
  max-height: 100%;
  overflow: hidden;
}
.modal-dialog-scrollable .modal-body {
  overflow-y: auto;
}
.modal-dialog-centered {
  display: flex;
  align-items: center;
  min-height: calc(100% - var(--bs-modal-margin) * 2);
}
.modal-content {
  position: relative;
  display: flex;
  flex-direction: column;
  width: 100%;
  color: var(--bs-modal-color);
  pointer-events: auto;
  background-color: var(--bs-modal-bg);
  background-clip: padding-box;
  border: var(--bs-modal-border-width) solid var(--bs-modal-border-color);
  border-radius: var(--bs-modal-border-radius);
  outline: 0;
}
.modal-backdrop {
  --bs-backdrop-zindex: 1050;
  --bs-backdrop-bg: #000;
  --bs-backdrop-opacity: 0.5;
  position: fixed;
  top: 0;
  left: 0;
  z-index: var(--bs-backdrop-zindex);
  width: 100vw;
  height: 100vh;
  background-color: var(--bs-backdrop-bg);
}
.modal-backdrop.fade {
  opacity: 0;
}
.modal-backdrop.show {
  opacity: var(--bs-backdrop-opacity);
}
.modal-header {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  padding: var(--bs-modal-header-padding);
  border-bottom: var(--bs-modal-header-border-width) solid var(--bs-modal-header-border-color);
  border-top-left-radius: var(--bs-modal-inner-border-radius);
  border-top-right-radius: var(--bs-modal-inner-border-radius);
}
.modal-header .btn-close {
  padding: calc(var(--bs-modal-header-padding-y) * 0.5) calc(var(--bs-modal-header-padding-x) * 0.5);
  margin-top: calc(-0.5 * var(--bs-modal-header-padding-y));
  margin-right: calc(-0.5 * var(--bs-modal-header-padding-x));
  margin-bottom: calc(-0.5 * var(--bs-modal-header-padding-y));
  margin-left: auto;
}
.modal-title {
  margin-bottom: 0;
  line-height: var(--bs-modal-title-line-height);
}
.modal-body {
  position: relative;
  flex: 1 1 auto;
  padding: var(--bs-modal-padding);
}
.modal-footer {
  display: flex;
  flex-shrink: 0;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  padding: calc(var(--bs-modal-padding) - var(--bs-modal-footer-gap) * 0.5);
  background-color: var(--bs-modal-footer-bg);
  border-top: var(--bs-modal-footer-border-width) solid var(--bs-modal-footer-border-color);
  border-bottom-right-radius: var(--bs-modal-inner-border-radius);
  border-bottom-left-radius: var(--bs-modal-inner-border-radius);
}
.modal-footer > * {
  margin: calc(var(--bs-modal-footer-gap) * 0.5);
}
@media (min-width: 576px) {
  .modal {
    --bs-modal-margin: 1.75rem;
    --bs-modal-box-shadow: var(--bs-box-shadow);
  }
  .modal-dialog {
    max-width: var(--bs-modal-width);
    margin-right: auto;
    margin-left: auto;
  }
  .modal-sm {
    --bs-modal-width: 300px;
  }
}
@media (min-width: 992px) {
  .modal-lg,
  .modal-xl {
    --bs-modal-width: 800px;
  }
}
@media (min-width: 1200px) {
  .modal-xl {
    --bs-modal-width: 1140px;
  }
}
.modal-fullscreen {
  width: 100vw;
  max-width: none;
  height: 100%;
  margin: 0;
}
.modal-fullscreen .modal-content {
  height: 100%;
  border: 0;
  border-radius: 0;
}
.modal-fullscreen .modal-header,
.modal-fullscreen .modal-footer {
  border-radius: 0;
}
.modal-fullscreen .modal-body {
  overflow-y: auto;
}
@media (max-width: 575.98px) {
  .modal-fullscreen-sm-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-sm-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-sm-down .modal-header,
  .modal-fullscreen-sm-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-sm-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 767.98px) {
  .modal-fullscreen-md-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-md-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-md-down .modal-header,
  .modal-fullscreen-md-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-md-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 991.98px) {
  .modal-fullscreen-lg-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-lg-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-lg-down .modal-header,
  .modal-fullscreen-lg-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-lg-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 1199.98px) {
  .modal-fullscreen-xl-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-xl-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-xl-down .modal-header,
  .modal-fullscreen-xl-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-xl-down .modal-body {
    overflow-y: auto;
  }
}
@media (max-width: 1399.98px) {
  .modal-fullscreen-xxl-down {
    width: 100vw;
    max-width: none;
    height: 100%;
    margin: 0;
  }
  .modal-fullscreen-xxl-down .modal-content {
    height: 100%;
    border: 0;
    border-radius: 0;
  }
  .modal-fullscreen-xxl-down .modal-header,
  .modal-fullscreen-xxl-down .modal-footer {
    border-radius: 0;
  }
  .modal-fullscreen-xxl-down .modal-body {
    overflow-y: auto;
  }
}
.tooltip {
  --bs-tooltip-zindex: 1080;
  --bs-tooltip-max-width: 200px;
  --bs-tooltip-padding-x: 0.5rem;
  --bs-tooltip-padding-y: 0.25rem;
  --bs-tooltip-margin: ;
  --bs-tooltip-font-size: 0.875rem;
  --bs-tooltip-color: var(--bs-body-bg);
  --bs-tooltip-bg: var(--bs-emphasis-color);
  --bs-tooltip-border-radius: var(--bs-border-radius);
  --bs-tooltip-opacity: 0.9;
  --bs-tooltip-arrow-width: 0.8rem;
  --bs-tooltip-arrow-height: 0.4rem;
  z-index: var(--bs-tooltip-zindex);
  display: block;
  margin: var(--bs-tooltip-margin);
  font-family: var(--bs-font-sans-serif);
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  white-space: normal;
  word-spacing: normal;
  line-break: auto;
  font-size: var(--bs-tooltip-font-size);
  word-wrap: break-word;
  opacity: 0;
}
.tooltip.show {
  opacity: var(--bs-tooltip-opacity);
}
.tooltip .tooltip-arrow {
  display: block;
  width: var(--bs-tooltip-arrow-width);
  height: var(--bs-tooltip-arrow-height);
}
.tooltip .tooltip-arrow::before {
  position: absolute;
  content: "";
  border-color: transparent;
  border-style: solid;
}
.bs-tooltip-top .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow {
  bottom: calc(-1 * var(--bs-tooltip-arrow-height));
}
.bs-tooltip-top .tooltip-arrow::before, .bs-tooltip-auto[data-popper-placement^=top] .tooltip-arrow::before {
  top: -1px;
  border-width: var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * 0.5) 0;
  border-top-color: var(--bs-tooltip-bg);
}
/* rtl:begin:ignore */
.bs-tooltip-end .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow {
  left: calc(-1 * var(--bs-tooltip-arrow-height));
  width: var(--bs-tooltip-arrow-height);
  height: var(--bs-tooltip-arrow-width);
}
.bs-tooltip-end .tooltip-arrow::before, .bs-tooltip-auto[data-popper-placement^=right] .tooltip-arrow::before {
  right: -1px;
  border-width: calc(var(--bs-tooltip-arrow-width) * 0.5) var(--bs-tooltip-arrow-height) calc(var(--bs-tooltip-arrow-width) * 0.5) 0;
  border-right-color: var(--bs-tooltip-bg);
}
/* rtl:end:ignore */
.bs-tooltip-bottom .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow {
  top: calc(-1 * var(--bs-tooltip-arrow-height));
}
.bs-tooltip-bottom .tooltip-arrow::before, .bs-tooltip-auto[data-popper-placement^=bottom] .tooltip-arrow::before {
  bottom: -1px;
  border-width: 0 calc(var(--bs-tooltip-arrow-width) * 0.5) var(--bs-tooltip-arrow-height);
  border-bottom-color: var(--bs-tooltip-bg);
}
/* rtl:begin:ignore */
.bs-tooltip-start .tooltip-arrow, .bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow {
  right: calc(-1 * var(--bs-tooltip-arrow-height));
  width: var(--bs-tooltip-arrow-height);
  height: var(--bs-tooltip-arrow-width);
}
.bs-tooltip-start .tooltip-arrow::before, .bs-tooltip-auto[data-popper-placement^=left] .tooltip-arrow::before {
  left: -1px;
  border-width: calc(var(--bs-tooltip-arrow-width) * 0.5) 0 calc(var(--bs-tooltip-arrow-width) * 0.5) var(--bs-tooltip-arrow-height);
  border-left-color: var(--bs-tooltip-bg);
}
/* rtl:end:ignore */
.tooltip-inner {
  max-width: var(--bs-tooltip-max-width);
  padding: var(--bs-tooltip-padding-y) var(--bs-tooltip-padding-x);
  color: var(--bs-tooltip-color);
  text-align: center;
  background-color: var(--bs-tooltip-bg);
  border-radius: var(--bs-tooltip-border-radius);
}
.popover {
  --bs-popover-zindex: 1070;
  --bs-popover-max-width: 276px;
  --bs-popover-font-size: 0.875rem;
  --bs-popover-bg: var(--bs-body-bg);
  --bs-popover-border-width: var(--bs-border-width);
  --bs-popover-border-color: var(--bs-border-color-translucent);
  --bs-popover-border-radius: var(--bs-border-radius-lg);
  --bs-popover-inner-border-radius: calc(var(--bs-border-radius-lg) - var(--bs-border-width));
  --bs-popover-box-shadow: var(--bs-box-shadow);
  --bs-popover-header-padding-x: 1rem;
  --bs-popover-header-padding-y: 0.5rem;
  --bs-popover-header-font-size: 1rem;
  --bs-popover-header-color: inherit;
  --bs-popover-header-bg: var(--bs-secondary-bg);
  --bs-popover-body-padding-x: 1rem;
  --bs-popover-body-padding-y: 1rem;
  --bs-popover-body-color: var(--bs-body-color);
  --bs-popover-arrow-width: 1rem;
  --bs-popover-arrow-height: 0.5rem;
  --bs-popover-arrow-border: var(--bs-popover-border-color);
  z-index: var(--bs-popover-zindex);
  display: block;
  max-width: var(--bs-popover-max-width);
  font-family: var(--bs-font-sans-serif);
  font-style: normal;
  font-weight: 400;
  line-height: 1.5;
  text-align: left;
  text-align: start;
  text-decoration: none;
  text-shadow: none;
  text-transform: none;
  letter-spacing: normal;
  word-break: normal;
  white-space: normal;
  word-spacing: normal;
  line-break: auto;
  font-size: var(--bs-popover-font-size);
  word-wrap: break-word;
  background-color: var(--bs-popover-bg);
  background-clip: padding-box;
  border: var(--bs-popover-border-width) solid var(--bs-popover-border-color);
  border-radius: var(--bs-popover-border-radius);
}
.popover .popover-arrow {
  display: block;
  width: var(--bs-popover-arrow-width);
  height: var(--bs-popover-arrow-height);
}
.popover .popover-arrow::before, .popover .popover-arrow::after {
  position: absolute;
  display: block;
  content: "";
  border-color: transparent;
  border-style: solid;
  border-width: 0;
}
.bs-popover-top > .popover-arrow, .bs-popover-auto[data-popper-placement^=top] > .popover-arrow {
  bottom: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
}
.bs-popover-top > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=top] > .popover-arrow::before, .bs-popover-top > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=top] > .popover-arrow::after {
  border-width: var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * 0.5) 0;
}
.bs-popover-top > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=top] > .popover-arrow::before {
  bottom: 0;
  border-top-color: var(--bs-popover-arrow-border);
}
.bs-popover-top > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=top] > .popover-arrow::after {
  bottom: var(--bs-popover-border-width);
  border-top-color: var(--bs-popover-bg);
}
/* rtl:begin:ignore */
.bs-popover-end > .popover-arrow, .bs-popover-auto[data-popper-placement^=right] > .popover-arrow {
  left: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
  width: var(--bs-popover-arrow-height);
  height: var(--bs-popover-arrow-width);
}
.bs-popover-end > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=right] > .popover-arrow::before, .bs-popover-end > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=right] > .popover-arrow::after {
  border-width: calc(var(--bs-popover-arrow-width) * 0.5) var(--bs-popover-arrow-height) calc(var(--bs-popover-arrow-width) * 0.5) 0;
}
.bs-popover-end > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=right] > .popover-arrow::before {
  left: 0;
  border-right-color: var(--bs-popover-arrow-border);
}
.bs-popover-end > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=right] > .popover-arrow::after {
  left: var(--bs-popover-border-width);
  border-right-color: var(--bs-popover-bg);
}
/* rtl:end:ignore */
.bs-popover-bottom > .popover-arrow, .bs-popover-auto[data-popper-placement^=bottom] > .popover-arrow {
  top: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
}
.bs-popover-bottom > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=bottom] > .popover-arrow::before, .bs-popover-bottom > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=bottom] > .popover-arrow::after {
  border-width: 0 calc(var(--bs-popover-arrow-width) * 0.5) var(--bs-popover-arrow-height);
}
.bs-popover-bottom > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=bottom] > .popover-arrow::before {
  top: 0;
  border-bottom-color: var(--bs-popover-arrow-border);
}
.bs-popover-bottom > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=bottom] > .popover-arrow::after {
  top: var(--bs-popover-border-width);
  border-bottom-color: var(--bs-popover-bg);
}
.bs-popover-bottom .popover-header::before, .bs-popover-auto[data-popper-placement^=bottom] .popover-header::before {
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  width: var(--bs-popover-arrow-width);
  margin-left: calc(-0.5 * var(--bs-popover-arrow-width));
  content: "";
  border-bottom: var(--bs-popover-border-width) solid var(--bs-popover-header-bg);
}
/* rtl:begin:ignore */
.bs-popover-start > .popover-arrow, .bs-popover-auto[data-popper-placement^=left] > .popover-arrow {
  right: calc(-1 * (var(--bs-popover-arrow-height)) - var(--bs-popover-border-width));
  width: var(--bs-popover-arrow-height);
  height: var(--bs-popover-arrow-width);
}
.bs-popover-start > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=left] > .popover-arrow::before, .bs-popover-start > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=left] > .popover-arrow::after {
  border-width: calc(var(--bs-popover-arrow-width) * 0.5) 0 calc(var(--bs-popover-arrow-width) * 0.5) var(--bs-popover-arrow-height);
}
.bs-popover-start > .popover-arrow::before, .bs-popover-auto[data-popper-placement^=left] > .popover-arrow::before {
  right: 0;
  border-left-color: var(--bs-popover-arrow-border);
}
.bs-popover-start > .popover-arrow::after, .bs-popover-auto[data-popper-placement^=left] > .popover-arrow::after {
  right: var(--bs-popover-border-width);
  border-left-color: var(--bs-popover-bg);
}
/* rtl:end:ignore */
.popover-header {
  padding: var(--bs-popover-header-padding-y) var(--bs-popover-header-padding-x);
  margin-bottom: 0;
  font-size: var(--bs-popover-header-font-size);
  color: var(--bs-popover-header-color);
  background-color: var(--bs-popover-header-bg);
  border-bottom: var(--bs-popover-border-width) solid var(--bs-popover-border-color);
  border-top-left-radius: var(--bs-popover-inner-border-radius);
  border-top-right-radius: var(--bs-popover-inner-border-radius);
}
.popover-header:empty {
  display: none;
}
.popover-body {
  padding: var(--bs-popover-body-padding-y) var(--bs-popover-body-padding-x);
  color: var(--bs-popover-body-color);
}
.carousel {
  position: relative;
}
.carousel.pointer-event {
  touch-action: pan-y;
}
.carousel-inner {
  position: relative;
  width: 100%;
  overflow: hidden;
}
.carousel-inner::after {
  display: block;
  clear: both;
  content: "";
}
.carousel-item {
  position: relative;
  display: none;
  float: left;
  width: 100%;
  margin-right: -100%;
  backface-visibility: hidden;
  transition: transform 0.6s ease-in-out;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-item {
    transition: none;
  }
}
.carousel-item.active,
.carousel-item-next,
.carousel-item-prev {
  display: block;
}
.carousel-item-next:not(.carousel-item-start),
.active.carousel-item-end {
  transform: translateX(100%);
}
.carousel-item-prev:not(.carousel-item-end),
.active.carousel-item-start {
  transform: translateX(-100%);
}
.carousel-fade .carousel-item {
  opacity: 0;
  transition-property: opacity;
  transform: none;
}
.carousel-fade .carousel-item.active,
.carousel-fade .carousel-item-next.carousel-item-start,
.carousel-fade .carousel-item-prev.carousel-item-end {
  z-index: 1;
  opacity: 1;
}
.carousel-fade .active.carousel-item-start,
.carousel-fade .active.carousel-item-end {
  z-index: 0;
  opacity: 0;
  transition: opacity 0s 0.6s;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-fade .active.carousel-item-start,
  .carousel-fade .active.carousel-item-end {
    transition: none;
  }
}
.carousel-control-prev,
.carousel-control-next {
  position: absolute;
  top: 0;
  bottom: 0;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 15%;
  padding: 0;
  color: #fff;
  text-align: center;
  background: none;
  filter: var(--bs-carousel-control-icon-filter);
  border: 0;
  opacity: 0.5;
  transition: opacity 0.15s ease;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-control-prev,
  .carousel-control-next {
    transition: none;
  }
}
.carousel-control-prev:hover, .carousel-control-prev:focus,
.carousel-control-next:hover,
.carousel-control-next:focus {
  color: #fff;
  text-decoration: none;
  outline: 0;
  opacity: 0.9;
}
.carousel-control-prev {
  left: 0;
}
.carousel-control-next {
  right: 0;
}
.carousel-control-prev-icon,
.carousel-control-next-icon {
  display: inline-block;
  width: 2rem;
  height: 2rem;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: 100% 100%;
}
.carousel-control-prev-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0'/%3e%3c/svg%3e") /*rtl:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e")*/;
}
.carousel-control-next-icon {
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708'/%3e%3c/svg%3e") /*rtl:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23fff'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0'/%3e%3c/svg%3e")*/;
}
.carousel-indicators {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
  display: flex;
  justify-content: center;
  padding: 0;
  margin-right: 15%;
  margin-bottom: 1rem;
  margin-left: 15%;
}
.carousel-indicators [data-bs-target] {
  box-sizing: content-box;
  flex: 0 1 auto;
  width: 30px;
  height: 3px;
  padding: 0;
  margin-right: 3px;
  margin-left: 3px;
  text-indent: -999px;
  cursor: pointer;
  background-color: var(--bs-carousel-indicator-active-bg);
  background-clip: padding-box;
  border: 0;
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  opacity: 0.5;
  transition: opacity 0.6s ease;
}
@media (prefers-reduced-motion: reduce) {
  .carousel-indicators [data-bs-target] {
    transition: none;
  }
}
.carousel-indicators .active {
  opacity: 1;
}
.carousel-caption {
  position: absolute;
  right: 15%;
  bottom: 1.25rem;
  left: 15%;
  padding-top: 1.25rem;
  padding-bottom: 1.25rem;
  color: var(--bs-carousel-caption-color);
  text-align: center;
}
.carousel-dark {
  --bs-carousel-indicator-active-bg: #000;
  --bs-carousel-caption-color: #000;
  --bs-carousel-control-icon-filter: invert(1) grayscale(100);
}
:root,
[data-bs-theme=light] {
  --bs-carousel-indicator-active-bg: #fff;
  --bs-carousel-caption-color: #fff;
  --bs-carousel-control-icon-filter: ;
}
[data-bs-theme=dark] {
  --bs-carousel-indicator-active-bg: #000;
  --bs-carousel-caption-color: #000;
  --bs-carousel-control-icon-filter: invert(1) grayscale(100);
}
.spinner-grow,
.spinner-border {
  display: inline-block;
  width: var(--bs-spinner-width);
  height: var(--bs-spinner-height);
  vertical-align: var(--bs-spinner-vertical-align);
  border-radius: 50%;
  animation: var(--bs-spinner-animation-speed) linear infinite var(--bs-spinner-animation-name);
}
@keyframes spinner-border {
  to {
    transform: rotate(360deg) /* rtl:ignore */;
  }
}
.spinner-border {
  --bs-spinner-width: 2rem;
  --bs-spinner-height: 2rem;
  --bs-spinner-vertical-align: -0.125em;
  --bs-spinner-border-width: 0.25em;
  --bs-spinner-animation-speed: 0.75s;
  --bs-spinner-animation-name: spinner-border;
  border: var(--bs-spinner-border-width) solid currentcolor;
  border-right-color: transparent;
}
.spinner-border-sm {
  --bs-spinner-width: 1rem;
  --bs-spinner-height: 1rem;
  --bs-spinner-border-width: 0.2em;
}
@keyframes spinner-grow {
  0% {
    transform: scale(0);
  }
  50% {
    opacity: 1;
    transform: none;
  }
}
.spinner-grow {
  --bs-spinner-width: 2rem;
  --bs-spinner-height: 2rem;
  --bs-spinner-vertical-align: -0.125em;
  --bs-spinner-animation-speed: 0.75s;
  --bs-spinner-animation-name: spinner-grow;
  background-color: currentcolor;
  opacity: 0;
}
.spinner-grow-sm {
  --bs-spinner-width: 1rem;
  --bs-spinner-height: 1rem;
}
@media (prefers-reduced-motion: reduce) {
  .spinner-border,
  .spinner-grow {
    --bs-spinner-animation-speed: 1.5s;
  }
}
.offcanvas, .offcanvas-xxl, .offcanvas-xl, .offcanvas-lg, .offcanvas-md, .offcanvas-sm {
  --bs-offcanvas-zindex: 1045;
  --bs-offcanvas-width: 400px;
  --bs-offcanvas-height: 30vh;
  --bs-offcanvas-padding-x: 1rem;
  --bs-offcanvas-padding-y: 1rem;
  --bs-offcanvas-color: var(--bs-body-color);
  --bs-offcanvas-bg: var(--bs-body-bg);
  --bs-offcanvas-border-width: var(--bs-border-width);
  --bs-offcanvas-border-color: var(--bs-border-color-translucent);
  --bs-offcanvas-box-shadow: var(--bs-box-shadow-sm);
  --bs-offcanvas-transition: transform 0.3s ease-in-out;
  --bs-offcanvas-title-line-height: 1.5;
}
@media (max-width: 575.98px) {
  .offcanvas-sm {
    position: fixed;
    bottom: 0;
    z-index: var(--bs-offcanvas-zindex);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    background-clip: padding-box;
    outline: 0;
    transition: var(--bs-offcanvas-transition);
  }
}
@media (max-width: 575.98px) and (prefers-reduced-motion: reduce) {
  .offcanvas-sm {
    transition: none;
  }
}
@media (max-width: 575.98px) {
  .offcanvas-sm.offcanvas-start {
    top: 0;
    left: 0;
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(-100%);
  }
  .offcanvas-sm.offcanvas-end {
    top: 0;
    right: 0;
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(100%);
  }
  .offcanvas-sm.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(-100%);
  }
  .offcanvas-sm.offcanvas-bottom {
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(100%);
  }
  .offcanvas-sm.showing, .offcanvas-sm.show:not(.hiding) {
    transform: none;
  }
  .offcanvas-sm.showing, .offcanvas-sm.hiding, .offcanvas-sm.show {
    visibility: visible;
  }
}
@media (min-width: 576px) {
  .offcanvas-sm {
    --bs-offcanvas-height: auto;
    --bs-offcanvas-border-width: 0;
    background-color: transparent !important;
  }
  .offcanvas-sm .offcanvas-header {
    display: none;
  }
  .offcanvas-sm .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
    background-color: transparent !important;
  }
}
@media (max-width: 767.98px) {
  .offcanvas-md {
    position: fixed;
    bottom: 0;
    z-index: var(--bs-offcanvas-zindex);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    background-clip: padding-box;
    outline: 0;
    transition: var(--bs-offcanvas-transition);
  }
}
@media (max-width: 767.98px) and (prefers-reduced-motion: reduce) {
  .offcanvas-md {
    transition: none;
  }
}
@media (max-width: 767.98px) {
  .offcanvas-md.offcanvas-start {
    top: 0;
    left: 0;
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(-100%);
  }
  .offcanvas-md.offcanvas-end {
    top: 0;
    right: 0;
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(100%);
  }
  .offcanvas-md.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(-100%);
  }
  .offcanvas-md.offcanvas-bottom {
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(100%);
  }
  .offcanvas-md.showing, .offcanvas-md.show:not(.hiding) {
    transform: none;
  }
  .offcanvas-md.showing, .offcanvas-md.hiding, .offcanvas-md.show {
    visibility: visible;
  }
}
@media (min-width: 768px) {
  .offcanvas-md {
    --bs-offcanvas-height: auto;
    --bs-offcanvas-border-width: 0;
    background-color: transparent !important;
  }
  .offcanvas-md .offcanvas-header {
    display: none;
  }
  .offcanvas-md .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
    background-color: transparent !important;
  }
}
@media (max-width: 991.98px) {
  .offcanvas-lg {
    position: fixed;
    bottom: 0;
    z-index: var(--bs-offcanvas-zindex);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    background-clip: padding-box;
    outline: 0;
    transition: var(--bs-offcanvas-transition);
  }
}
@media (max-width: 991.98px) and (prefers-reduced-motion: reduce) {
  .offcanvas-lg {
    transition: none;
  }
}
@media (max-width: 991.98px) {
  .offcanvas-lg.offcanvas-start {
    top: 0;
    left: 0;
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(-100%);
  }
  .offcanvas-lg.offcanvas-end {
    top: 0;
    right: 0;
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(100%);
  }
  .offcanvas-lg.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(-100%);
  }
  .offcanvas-lg.offcanvas-bottom {
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(100%);
  }
  .offcanvas-lg.showing, .offcanvas-lg.show:not(.hiding) {
    transform: none;
  }
  .offcanvas-lg.showing, .offcanvas-lg.hiding, .offcanvas-lg.show {
    visibility: visible;
  }
}
@media (min-width: 992px) {
  .offcanvas-lg {
    --bs-offcanvas-height: auto;
    --bs-offcanvas-border-width: 0;
    background-color: transparent !important;
  }
  .offcanvas-lg .offcanvas-header {
    display: none;
  }
  .offcanvas-lg .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
    background-color: transparent !important;
  }
}
@media (max-width: 1199.98px) {
  .offcanvas-xl {
    position: fixed;
    bottom: 0;
    z-index: var(--bs-offcanvas-zindex);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    background-clip: padding-box;
    outline: 0;
    transition: var(--bs-offcanvas-transition);
  }
}
@media (max-width: 1199.98px) and (prefers-reduced-motion: reduce) {
  .offcanvas-xl {
    transition: none;
  }
}
@media (max-width: 1199.98px) {
  .offcanvas-xl.offcanvas-start {
    top: 0;
    left: 0;
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(-100%);
  }
  .offcanvas-xl.offcanvas-end {
    top: 0;
    right: 0;
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(100%);
  }
  .offcanvas-xl.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(-100%);
  }
  .offcanvas-xl.offcanvas-bottom {
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(100%);
  }
  .offcanvas-xl.showing, .offcanvas-xl.show:not(.hiding) {
    transform: none;
  }
  .offcanvas-xl.showing, .offcanvas-xl.hiding, .offcanvas-xl.show {
    visibility: visible;
  }
}
@media (min-width: 1200px) {
  .offcanvas-xl {
    --bs-offcanvas-height: auto;
    --bs-offcanvas-border-width: 0;
    background-color: transparent !important;
  }
  .offcanvas-xl .offcanvas-header {
    display: none;
  }
  .offcanvas-xl .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
    background-color: transparent !important;
  }
}
@media (max-width: 1399.98px) {
  .offcanvas-xxl {
    position: fixed;
    bottom: 0;
    z-index: var(--bs-offcanvas-zindex);
    display: flex;
    flex-direction: column;
    max-width: 100%;
    color: var(--bs-offcanvas-color);
    visibility: hidden;
    background-color: var(--bs-offcanvas-bg);
    background-clip: padding-box;
    outline: 0;
    transition: var(--bs-offcanvas-transition);
  }
}
@media (max-width: 1399.98px) and (prefers-reduced-motion: reduce) {
  .offcanvas-xxl {
    transition: none;
  }
}
@media (max-width: 1399.98px) {
  .offcanvas-xxl.offcanvas-start {
    top: 0;
    left: 0;
    width: var(--bs-offcanvas-width);
    border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(-100%);
  }
  .offcanvas-xxl.offcanvas-end {
    top: 0;
    right: 0;
    width: var(--bs-offcanvas-width);
    border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateX(100%);
  }
  .offcanvas-xxl.offcanvas-top {
    top: 0;
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(-100%);
  }
  .offcanvas-xxl.offcanvas-bottom {
    right: 0;
    left: 0;
    height: var(--bs-offcanvas-height);
    max-height: 100%;
    border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
    transform: translateY(100%);
  }
  .offcanvas-xxl.showing, .offcanvas-xxl.show:not(.hiding) {
    transform: none;
  }
  .offcanvas-xxl.showing, .offcanvas-xxl.hiding, .offcanvas-xxl.show {
    visibility: visible;
  }
}
@media (min-width: 1400px) {
  .offcanvas-xxl {
    --bs-offcanvas-height: auto;
    --bs-offcanvas-border-width: 0;
    background-color: transparent !important;
  }
  .offcanvas-xxl .offcanvas-header {
    display: none;
  }
  .offcanvas-xxl .offcanvas-body {
    display: flex;
    flex-grow: 0;
    padding: 0;
    overflow-y: visible;
    background-color: transparent !important;
  }
}
.offcanvas {
  position: fixed;
  bottom: 0;
  z-index: var(--bs-offcanvas-zindex);
  display: flex;
  flex-direction: column;
  max-width: 100%;
  color: var(--bs-offcanvas-color);
  visibility: hidden;
  background-color: var(--bs-offcanvas-bg);
  background-clip: padding-box;
  outline: 0;
  transition: var(--bs-offcanvas-transition);
}
@media (prefers-reduced-motion: reduce) {
  .offcanvas {
    transition: none;
  }
}
.offcanvas.offcanvas-start {
  top: 0;
  left: 0;
  width: var(--bs-offcanvas-width);
  border-right: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
  transform: translateX(-100%);
}
.offcanvas.offcanvas-end {
  top: 0;
  right: 0;
  width: var(--bs-offcanvas-width);
  border-left: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
  transform: translateX(100%);
}
.offcanvas.offcanvas-top {
  top: 0;
  right: 0;
  left: 0;
  height: var(--bs-offcanvas-height);
  max-height: 100%;
  border-bottom: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
  transform: translateY(-100%);
}
.offcanvas.offcanvas-bottom {
  right: 0;
  left: 0;
  height: var(--bs-offcanvas-height);
  max-height: 100%;
  border-top: var(--bs-offcanvas-border-width) solid var(--bs-offcanvas-border-color);
  transform: translateY(100%);
}
.offcanvas.showing, .offcanvas.show:not(.hiding) {
  transform: none;
}
.offcanvas.showing, .offcanvas.hiding, .offcanvas.show {
  visibility: visible;
}
.offcanvas-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1040;
  width: 100vw;
  height: 100vh;
  background-color: #000;
}
.offcanvas-backdrop.fade {
  opacity: 0;
}
.offcanvas-backdrop.show {
  opacity: 0.5;
}
.offcanvas-header {
  display: flex;
  align-items: center;
  padding: var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);
}
.offcanvas-header .btn-close {
  padding: calc(var(--bs-offcanvas-padding-y) * 0.5) calc(var(--bs-offcanvas-padding-x) * 0.5);
  margin-top: calc(-0.5 * var(--bs-offcanvas-padding-y));
  margin-right: calc(-0.5 * var(--bs-offcanvas-padding-x));
  margin-bottom: calc(-0.5 * var(--bs-offcanvas-padding-y));
  margin-left: auto;
}
.offcanvas-title {
  margin-bottom: 0;
  line-height: var(--bs-offcanvas-title-line-height);
}
.offcanvas-body {
  flex-grow: 1;
  padding: var(--bs-offcanvas-padding-y) var(--bs-offcanvas-padding-x);
  overflow-y: auto;
}
.placeholder {
  display: inline-block;
  min-height: 1em;
  vertical-align: middle;
  cursor: wait;
  background-color: currentcolor;
  opacity: 0.5;
}
.placeholder.btn::before {
  display: inline-block;
  content: "";
}
.placeholder-xs {
  min-height: 0.6em;
}
.placeholder-sm {
  min-height: 0.8em;
}
.placeholder-lg {
  min-height: 1.2em;
}
.placeholder-glow .placeholder {
  animation: placeholder-glow 2s ease-in-out infinite;
}
@keyframes placeholder-glow {
  50% {
    opacity: 0.2;
  }
}
.placeholder-wave {
  -webkit-mask-image: linear-gradient(130deg, #000 55%, rgba(0, 0, 0, 0.8) 75%, #000 95%);
  mask-image: linear-gradient(130deg, #000 55%, rgba(0, 0, 0, 0.8) 75%, #000 95%);
  -webkit-mask-size: 200% 100%;
  mask-size: 200% 100%;
  animation: placeholder-wave 2s linear infinite;
}
@keyframes placeholder-wave {
  100% {
    -webkit-mask-position: -200% 0%;
    mask-position: -200% 0%;
  }
}
.clearfix::after {
  display: block;
  clear: both;
  content: "";
}
.text-bg-primary {
  color: #fff !important;
  background-color: RGBA(var(--bs-primary-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-secondary {
  color: #fff !important;
  background-color: RGBA(var(--bs-secondary-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-success {
  color: #fff !important;
  background-color: RGBA(var(--bs-success-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-info {
  color: #000 !important;
  background-color: RGBA(var(--bs-info-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-warning {
  color: #000 !important;
  background-color: RGBA(var(--bs-warning-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-danger {
  color: #fff !important;
  background-color: RGBA(var(--bs-danger-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-light {
  color: #000 !important;
  background-color: RGBA(var(--bs-light-rgb), var(--bs-bg-opacity, 1)) !important;
}
.text-bg-dark {
  color: #fff !important;
  background-color: RGBA(var(--bs-dark-rgb), var(--bs-bg-opacity, 1)) !important;
}
.link-primary {
  color: RGBA(var(--bs-primary-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-primary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-primary:hover, .link-primary:focus {
  color: RGBA(10, 88, 202, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(10, 88, 202, var(--bs-link-underline-opacity, 1)) !important;
}
.link-secondary {
  color: RGBA(var(--bs-secondary-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-secondary-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-secondary:hover, .link-secondary:focus {
  color: RGBA(86, 94, 100, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(86, 94, 100, var(--bs-link-underline-opacity, 1)) !important;
}
.link-success {
  color: RGBA(var(--bs-success-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-success-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-success:hover, .link-success:focus {
  color: RGBA(20, 108, 67, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(20, 108, 67, var(--bs-link-underline-opacity, 1)) !important;
}
.link-info {
  color: RGBA(var(--bs-info-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-info-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-info:hover, .link-info:focus {
  color: RGBA(61, 213, 243, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(61, 213, 243, var(--bs-link-underline-opacity, 1)) !important;
}
.link-warning {
  color: RGBA(var(--bs-warning-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-warning-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-warning:hover, .link-warning:focus {
  color: RGBA(255, 205, 57, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(255, 205, 57, var(--bs-link-underline-opacity, 1)) !important;
}
.link-danger {
  color: RGBA(var(--bs-danger-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-danger-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-danger:hover, .link-danger:focus {
  color: RGBA(176, 42, 55, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(176, 42, 55, var(--bs-link-underline-opacity, 1)) !important;
}
.link-light {
  color: RGBA(var(--bs-light-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-light-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-light:hover, .link-light:focus {
  color: RGBA(249, 250, 251, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(249, 250, 251, var(--bs-link-underline-opacity, 1)) !important;
}
.link-dark {
  color: RGBA(var(--bs-dark-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-dark-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-dark:hover, .link-dark:focus {
  color: RGBA(26, 30, 33, var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(26, 30, 33, var(--bs-link-underline-opacity, 1)) !important;
}
.link-body-emphasis {
  color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 1)) !important;
  text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-body-emphasis:hover, .link-body-emphasis:focus {
  color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-opacity, 0.75)) !important;
  text-decoration-color: RGBA(var(--bs-emphasis-color-rgb), var(--bs-link-underline-opacity, 0.75)) !important;
}
.focus-ring:focus {
  outline: 0;
  box-shadow: var(--bs-focus-ring-x, 0) var(--bs-focus-ring-y, 0) var(--bs-focus-ring-blur, 0) var(--bs-focus-ring-width) var(--bs-focus-ring-color);
}
.icon-link {
  display: inline-flex;
  gap: 0.375rem;
  align-items: center;
  text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-opacity, 0.5));
  text-underline-offset: 0.25em;
  backface-visibility: hidden;
}
.icon-link > .bi {
  flex-shrink: 0;
  width: 1em;
  height: 1em;
  fill: currentcolor;
  transition: 0.2s ease-in-out transform;
}
@media (prefers-reduced-motion: reduce) {
  .icon-link > .bi {
    transition: none;
  }
}
.icon-link-hover:hover > .bi, .icon-link-hover:focus-visible > .bi {
  transform: var(--bs-icon-link-transform, translate3d(0.25em, 0, 0));
}
.ratio {
  position: relative;
  width: 100%;
}
.ratio::before {
  display: block;
  padding-top: var(--bs-aspect-ratio);
  content: "";
}
.ratio > * {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.ratio-1x1 {
  --bs-aspect-ratio: 100%;
}
.ratio-4x3 {
  --bs-aspect-ratio: 75%;
}
.ratio-16x9 {
  --bs-aspect-ratio: 56.25%;
}
.ratio-21x9 {
  --bs-aspect-ratio: 42.8571428571%;
}
.fixed-top {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 1030;
}
.fixed-bottom {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1030;
}
.sticky-top {
  position: sticky;
  top: 0;
  z-index: 1020;
}
.sticky-bottom {
  position: sticky;
  bottom: 0;
  z-index: 1020;
}
@media (min-width: 576px) {
  .sticky-sm-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-sm-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 768px) {
  .sticky-md-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-md-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 992px) {
  .sticky-lg-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-lg-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 1200px) {
  .sticky-xl-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-xl-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
@media (min-width: 1400px) {
  .sticky-xxl-top {
    position: sticky;
    top: 0;
    z-index: 1020;
  }
  .sticky-xxl-bottom {
    position: sticky;
    bottom: 0;
    z-index: 1020;
  }
}
.hstack {
  display: flex;
  flex-direction: row;
  align-items: center;
  align-self: stretch;
}
.vstack {
  display: flex;
  flex: 1 1 auto;
  flex-direction: column;
  align-self: stretch;
}
.visually-hidden,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.visually-hidden:not(caption),
.visually-hidden-focusable:not(:focus):not(:focus-within):not(caption) {
  position: absolute !important;
}
.stretched-link::after {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 1;
  content: "";
}
.text-truncate {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vr {
  display: inline-block;
  align-self: stretch;
  width: var(--bs-border-width);
  min-height: 1em;
  background-color: currentcolor;
  opacity: 0.25;
}
.align-baseline {
  vertical-align: baseline !important;
}
.align-top {
  vertical-align: top !important;
}
.align-middle {
  vertical-align: middle !important;
}
.align-bottom {
  vertical-align: bottom !important;
}
.align-text-bottom {
  vertical-align: text-bottom !important;
}
.align-text-top {
  vertical-align: text-top !important;
}
.float-start {
  float: left !important;
}
.float-end {
  float: right !important;
}
.float-none {
  float: none !important;
}
.object-fit-contain {
  -o-object-fit: contain !important;
  object-fit: contain !important;
}
.object-fit-cover {
  -o-object-fit: cover !important;
  object-fit: cover !important;
}
.object-fit-fill {
  -o-object-fit: fill !important;
  object-fit: fill !important;
}
.object-fit-scale {
  -o-object-fit: scale-down !important;
  object-fit: scale-down !important;
}
.object-fit-none {
  -o-object-fit: none !important;
  object-fit: none !important;
}
.opacity-0 {
  opacity: 0 !important;
}
.opacity-25 {
  opacity: 0.25 !important;
}
.opacity-50 {
  opacity: 0.5 !important;
}
.opacity-75 {
  opacity: 0.75 !important;
}
.opacity-100 {
  opacity: 1 !important;
}
.overflow-auto {
  overflow: auto !important;
}
.overflow-hidden {
  overflow: hidden !important;
}
.overflow-visible {
  overflow: visible !important;
}
.overflow-scroll {
  overflow: scroll !important;
}
.overflow-x-auto {
  overflow-x: auto !important;
}
.overflow-x-hidden {
  overflow-x: hidden !important;
}
.overflow-x-visible {
  overflow-x: visible !important;
}
.overflow-x-scroll {
  overflow-x: scroll !important;
}
.overflow-y-auto {
  overflow-y: auto !important;
}
.overflow-y-hidden {
  overflow-y: hidden !important;
}
.overflow-y-visible {
  overflow-y: visible !important;
}
.overflow-y-scroll {
  overflow-y: scroll !important;
}
.d-inline {
  display: inline !important;
}
.d-inline-block {
  display: inline-block !important;
}
.d-block {
  display: block !important;
}
.d-grid {
  display: grid !important;
}
.d-inline-grid {
  display: inline-grid !important;
}
.d-table {
  display: table !important;
}
.d-table-row {
  display: table-row !important;
}
.d-table-cell {
  display: table-cell !important;
}
.d-flex {
  display: flex !important;
}
.d-inline-flex {
  display: inline-flex !important;
}
.d-none {
  display: none !important;
}
.shadow {
  box-shadow: var(--bs-box-shadow) !important;
}
.shadow-sm {
  box-shadow: var(--bs-box-shadow-sm) !important;
}
.shadow-lg {
  box-shadow: var(--bs-box-shadow-lg) !important;
}
.shadow-none {
  box-shadow: none !important;
}
.focus-ring-primary {
  --bs-focus-ring-color: rgba(var(--bs-primary-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-secondary {
  --bs-focus-ring-color: rgba(var(--bs-secondary-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-success {
  --bs-focus-ring-color: rgba(var(--bs-success-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-info {
  --bs-focus-ring-color: rgba(var(--bs-info-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-warning {
  --bs-focus-ring-color: rgba(var(--bs-warning-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-danger {
  --bs-focus-ring-color: rgba(var(--bs-danger-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-light {
  --bs-focus-ring-color: rgba(var(--bs-light-rgb), var(--bs-focus-ring-opacity));
}
.focus-ring-dark {
  --bs-focus-ring-color: rgba(var(--bs-dark-rgb), var(--bs-focus-ring-opacity));
}
.position-static {
  position: static !important;
}
.position-relative {
  position: relative !important;
}
.position-absolute {
  position: absolute !important;
}
.position-fixed {
  position: fixed !important;
}
.position-sticky {
  position: sticky !important;
}
.top-0 {
  top: 0 !important;
}
.top-50 {
  top: 50% !important;
}
.top-100 {
  top: 100% !important;
}
.bottom-0 {
  bottom: 0 !important;
}
.bottom-50 {
  bottom: 50% !important;
}
.bottom-100 {
  bottom: 100% !important;
}
.start-0 {
  left: 0 !important;
}
.start-50 {
  left: 50% !important;
}
.start-100 {
  left: 100% !important;
}
.end-0 {
  right: 0 !important;
}
.end-50 {
  right: 50% !important;
}
.end-100 {
  right: 100% !important;
}
.translate-middle {
  transform: translate(-50%, -50%) !important;
}
.translate-middle-x {
  transform: translateX(-50%) !important;
}
.translate-middle-y {
  transform: translateY(-50%) !important;
}
.border {
  border: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-0 {
  border: 0 !important;
}
.border-top {
  border-top: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-top-0 {
  border-top: 0 !important;
}
.border-end {
  border-right: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-end-0 {
  border-right: 0 !important;
}
.border-bottom {
  border-bottom: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-bottom-0 {
  border-bottom: 0 !important;
}
.border-start {
  border-left: var(--bs-border-width) var(--bs-border-style) var(--bs-border-color) !important;
}
.border-start-0 {
  border-left: 0 !important;
}
.border-primary {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-primary-rgb), var(--bs-border-opacity)) !important;
}
.border-secondary {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-secondary-rgb), var(--bs-border-opacity)) !important;
}
.border-success {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-success-rgb), var(--bs-border-opacity)) !important;
}
.border-info {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-info-rgb), var(--bs-border-opacity)) !important;
}
.border-warning {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-warning-rgb), var(--bs-border-opacity)) !important;
}
.border-danger {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-danger-rgb), var(--bs-border-opacity)) !important;
}
.border-light {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-light-rgb), var(--bs-border-opacity)) !important;
}
.border-dark {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-dark-rgb), var(--bs-border-opacity)) !important;
}
.border-black {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-black-rgb), var(--bs-border-opacity)) !important;
}
.border-white {
  --bs-border-opacity: 1;
  border-color: rgba(var(--bs-white-rgb), var(--bs-border-opacity)) !important;
}
.border-primary-subtle {
  border-color: var(--bs-primary-border-subtle) !important;
}
.border-secondary-subtle {
  border-color: var(--bs-secondary-border-subtle) !important;
}
.border-success-subtle {
  border-color: var(--bs-success-border-subtle) !important;
}
.border-info-subtle {
  border-color: var(--bs-info-border-subtle) !important;
}
.border-warning-subtle {
  border-color: var(--bs-warning-border-subtle) !important;
}
.border-danger-subtle {
  border-color: var(--bs-danger-border-subtle) !important;
}
.border-light-subtle {
  border-color: var(--bs-light-border-subtle) !important;
}
.border-dark-subtle {
  border-color: var(--bs-dark-border-subtle) !important;
}
.border-1 {
  border-width: 1px !important;
}
.border-2 {
  border-width: 2px !important;
}
.border-3 {
  border-width: 3px !important;
}
.border-4 {
  border-width: 4px !important;
}
.border-5 {
  border-width: 5px !important;
}
.border-opacity-10 {
  --bs-border-opacity: 0.1;
}
.border-opacity-25 {
  --bs-border-opacity: 0.25;
}
.border-opacity-50 {
  --bs-border-opacity: 0.5;
}
.border-opacity-75 {
  --bs-border-opacity: 0.75;
}
.border-opacity-100 {
  --bs-border-opacity: 1;
}
.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;
}
.mw-100 {
  max-width: 100% !important;
}
.vw-100 {
  width: 100vw !important;
}
.min-vw-100 {
  min-width: 100vw !important;
}
.h-25 {
  height: 25% !important;
}
.h-50 {
  height: 50% !important;
}
.h-75 {
  height: 75% !important;
}
.h-100 {
  height: 100% !important;
}
.h-auto {
  height: auto !important;
}
.mh-100 {
  max-height: 100% !important;
}
.vh-100 {
  height: 100vh !important;
}
.min-vh-100 {
  min-height: 100vh !important;
}
.flex-fill {
  flex: 1 1 auto !important;
}
.flex-row {
  flex-direction: row !important;
}
.flex-column {
  flex-direction: column !important;
}
.flex-row-reverse {
  flex-direction: row-reverse !important;
}
.flex-column-reverse {
  flex-direction: column-reverse !important;
}
.flex-grow-0 {
  flex-grow: 0 !important;
}
.flex-grow-1 {
  flex-grow: 1 !important;
}
.flex-shrink-0 {
  flex-shrink: 0 !important;
}
.flex-shrink-1 {
  flex-shrink: 1 !important;
}
.flex-wrap {
  flex-wrap: wrap !important;
}
.flex-nowrap {
  flex-wrap: nowrap !important;
}
.flex-wrap-reverse {
  flex-wrap: wrap-reverse !important;
}
.justify-content-start {
  justify-content: flex-start !important;
}
.justify-content-end {
  justify-content: flex-end !important;
}
.justify-content-center {
  justify-content: center !important;
}
.justify-content-between {
  justify-content: space-between !important;
}
.justify-content-around {
  justify-content: space-around !important;
}
.justify-content-evenly {
  justify-content: space-evenly !important;
}
.align-items-start {
  align-items: flex-start !important;
}
.align-items-end {
  align-items: flex-end !important;
}
.align-items-center {
  align-items: center !important;
}
.align-items-baseline {
  align-items: baseline !important;
}
.align-items-stretch {
  align-items: stretch !important;
}
.align-content-start {
  align-content: flex-start !important;
}
.align-content-end {
  align-content: flex-end !important;
}
.align-content-center {
  align-content: center !important;
}
.align-content-between {
  align-content: space-between !important;
}
.align-content-around {
  align-content: space-around !important;
}
.align-content-stretch {
  align-content: stretch !important;
}
.align-self-auto {
  align-self: auto !important;
}
.align-self-start {
  align-self: flex-start !important;
}
.align-self-end {
  align-self: flex-end !important;
}
.align-self-center {
  align-self: center !important;
}
.align-self-baseline {
  align-self: baseline !important;
}
.align-self-stretch {
  align-self: stretch !important;
}
.order-first {
  order: -1 !important;
}
.order-0 {
  order: 0 !important;
}
.order-1 {
  order: 1 !important;
}
.order-2 {
  order: 2 !important;
}
.order-3 {
  order: 3 !important;
}
.order-4 {
  order: 4 !important;
}
.order-5 {
  order: 5 !important;
}
.order-last {
  order: 6 !important;
}
.m-0 {
  margin: 0 !important;
}
.m-1 {
  margin: 0.25rem !important;
}
.m-2 {
  margin: 0.5rem !important;
}
.m-3 {
  margin: 1rem !important;
}
.m-4 {
  margin: 1.5rem !important;
}
.m-5 {
  margin: 3rem !important;
}
.m-auto {
  margin: auto !important;
}
.mx-0 {
  margin-right: 0 !important;
  margin-left: 0 !important;
}
.mx-1 {
  margin-right: 0.25rem !important;
  margin-left: 0.25rem !important;
}
.mx-2 {
  margin-right: 0.5rem !important;
  margin-left: 0.5rem !important;
}
.mx-3 {
  margin-right: 1rem !important;
  margin-left: 1rem !important;
}
.mx-4 {
  margin-right: 1.5rem !important;
  margin-left: 1.5rem !important;
}
.mx-5 {
  margin-right: 3rem !important;
  margin-left: 3rem !important;
}
.mx-auto {
  margin-right: auto !important;
  margin-left: auto !important;
}
.my-0 {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}
.my-1 {
  margin-top: 0.25rem !important;
  margin-bottom: 0.25rem !important;
}
.my-2 {
  margin-top: 0.5rem !important;
  margin-bottom: 0.5rem !important;
}
.my-3 {
  margin-top: 1rem !important;
  margin-bottom: 1rem !important;
}
.my-4 {
  margin-top: 1.5rem !important;
  margin-bottom: 1.5rem !important;
}
.my-5 {
  margin-top: 3rem !important;
  margin-bottom: 3rem !important;
}
.my-auto {
  margin-top: auto !important;
  margin-bottom: auto !important;
}
.mt-0 {
  margin-top: 0 !important;
}
.mt-1 {
  margin-top: 0.25rem !important;
}
.mt-2 {
  margin-top: 0.5rem !important;
}
.mt-3 {
  margin-top: 1rem !important;
}
.mt-4 {
  margin-top: 1.5rem !important;
}
.mt-5 {
  margin-top: 3rem !important;
}
.mt-auto {
  margin-top: auto !important;
}
.me-0 {
  margin-right: 0 !important;
}
.me-1 {
  margin-right: 0.25rem !important;
}
.me-2 {
  margin-right: 0.5rem !important;
}
.me-3 {
  margin-right: 1rem !important;
}
.me-4 {
  margin-right: 1.5rem !important;
}
.me-5 {
  margin-right: 3rem !important;
}
.me-auto {
  margin-right: auto !important;
}
.mb-0 {
  margin-bottom: 0 !important;
}
.mb-1 {
  margin-bottom: 0.25rem !important;
}
.mb-2 {
  margin-bottom: 0.5rem !important;
}
.mb-3 {
  margin-bottom: 1rem !important;
}
.mb-4 {
  margin-bottom: 1.5rem !important;
}
.mb-5 {
  margin-bottom: 3rem !important;
}
.mb-auto {
  margin-bottom: auto !important;
}
.ms-0 {
  margin-left: 0 !important;
}
.ms-1 {
  margin-left: 0.25rem !important;
}
.ms-2 {
  margin-left: 0.5rem !important;
}
.ms-3 {
  margin-left: 1rem !important;
}
.ms-4 {
  margin-left: 1.5rem !important;
}
.ms-5 {
  margin-left: 3rem !important;
}
.ms-auto {
  margin-left: auto !important;
}
.p-0 {
  padding: 0 !important;
}
.p-1 {
  padding: 0.25rem !important;
}
.p-2 {
  padding: 0.5rem !important;
}
.p-3 {
  padding: 1rem !important;
}
.p-4 {
  padding: 1.5rem !important;
}
.p-5 {
  padding: 3rem !important;
}
.px-0 {
  padding-right: 0 !important;
  padding-left: 0 !important;
}
.px-1 {
  padding-right: 0.25rem !important;
  padding-left: 0.25rem !important;
}
.px-2 {
  padding-right: 0.5rem !important;
  padding-left: 0.5rem !important;
}
.px-3 {
  padding-right: 1rem !important;
  padding-left: 1rem !important;
}
.px-4 {
  padding-right: 1.5rem !important;
  padding-left: 1.5rem !important;
}
.px-5 {
  padding-right: 3rem !important;
  padding-left: 3rem !important;
}
.py-0 {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.py-1 {
  padding-top: 0.25rem !important;
  padding-bottom: 0.25rem !important;
}
.py-2 {
  padding-top: 0.5rem !important;
  padding-bottom: 0.5rem !important;
}
.py-3 {
  padding-top: 1rem !important;
  padding-bottom: 1rem !important;
}
.py-4 {
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
}
.py-5 {
  padding-top: 3rem !important;
  padding-bottom: 3rem !important;
}
.pt-0 {
  padding-top: 0 !important;
}
.pt-1 {
  padding-top: 0.25rem !important;
}
.pt-2 {
  padding-top: 0.5rem !important;
}
.pt-3 {
  padding-top: 1rem !important;
}
.pt-4 {
  padding-top: 1.5rem !important;
}
.pt-5 {
  padding-top: 3rem !important;
}
.pe-0 {
  padding-right: 0 !important;
}
.pe-1 {
  padding-right: 0.25rem !important;
}
.pe-2 {
  padding-right: 0.5rem !important;
}
.pe-3 {
  padding-right: 1rem !important;
}
.pe-4 {
  padding-right: 1.5rem !important;
}
.pe-5 {
  padding-right: 3rem !important;
}
.pb-0 {
  padding-bottom: 0 !important;
}
.pb-1 {
  padding-bottom: 0.25rem !important;
}
.pb-2 {
  padding-bottom: 0.5rem !important;
}
.pb-3 {
  padding-bottom: 1rem !important;
}
.pb-4 {
  padding-bottom: 1.5rem !important;
}
.pb-5 {
  padding-bottom: 3rem !important;
}
.ps-0 {
  padding-left: 0 !important;
}
.ps-1 {
  padding-left: 0.25rem !important;
}
.ps-2 {
  padding-left: 0.5rem !important;
}
.ps-3 {
  padding-left: 1rem !important;
}
.ps-4 {
  padding-left: 1.5rem !important;
}
.ps-5 {
  padding-left: 3rem !important;
}
.gap-0 {
  gap: 0 !important;
}
.gap-1 {
  gap: 0.25rem !important;
}
.gap-2 {
  gap: 0.5rem !important;
}
.gap-3 {
  gap: 1rem !important;
}
.gap-4 {
  gap: 1.5rem !important;
}
.gap-5 {
  gap: 3rem !important;
}
.row-gap-0 {
  row-gap: 0 !important;
}
.row-gap-1 {
  row-gap: 0.25rem !important;
}
.row-gap-2 {
  row-gap: 0.5rem !important;
}
.row-gap-3 {
  row-gap: 1rem !important;
}
.row-gap-4 {
  row-gap: 1.5rem !important;
}
.row-gap-5 {
  row-gap: 3rem !important;
}
.column-gap-0 {
  -moz-column-gap: 0 !important;
  column-gap: 0 !important;
}
.column-gap-1 {
  -moz-column-gap: 0.25rem !important;
  column-gap: 0.25rem !important;
}
.column-gap-2 {
  -moz-column-gap: 0.5rem !important;
  column-gap: 0.5rem !important;
}
.column-gap-3 {
  -moz-column-gap: 1rem !important;
  column-gap: 1rem !important;
}
.column-gap-4 {
  -moz-column-gap: 1.5rem !important;
  column-gap: 1.5rem !important;
}
.column-gap-5 {
  -moz-column-gap: 3rem !important;
  column-gap: 3rem !important;
}
.font-monospace {
  font-family: var(--bs-font-monospace) !important;
}
.fs-1 {
  font-size: calc(1.375rem + 1.5vw) !important;
}
.fs-2 {
  font-size: calc(1.325rem + 0.9vw) !important;
}
.fs-3 {
  font-size: calc(1.3rem + 0.6vw) !important;
}
.fs-4 {
  font-size: calc(1.275rem + 0.3vw) !important;
}
.fs-5 {
  font-size: 1.25rem !important;
}
.fs-6 {
  font-size: 1rem !important;
}
.fst-italic {
  font-style: italic !important;
}
.fst-normal {
  font-style: normal !important;
}
.fw-lighter {
  font-weight: lighter !important;
}
.fw-light {
  font-weight: 300 !important;
}
.fw-normal {
  font-weight: 400 !important;
}
.fw-medium {
  font-weight: 500 !important;
}
.fw-semibold {
  font-weight: 600 !important;
}
.fw-bold {
  font-weight: 700 !important;
}
.fw-bolder {
  font-weight: bolder !important;
}
.lh-1 {
  line-height: 1 !important;
}
.lh-sm {
  line-height: 1.25 !important;
}
.lh-base {
  line-height: 1.5 !important;
}
.lh-lg {
  line-height: 2 !important;
}
.text-start {
  text-align: left !important;
}
.text-end {
  text-align: right !important;
}
.text-center {
  text-align: center !important;
}
.text-decoration-none {
  text-decoration: none !important;
}
.text-decoration-underline {
  text-decoration: underline !important;
}
.text-decoration-line-through {
  text-decoration: line-through !important;
}
.text-lowercase {
  text-transform: lowercase !important;
}
.text-uppercase {
  text-transform: uppercase !important;
}
.text-capitalize {
  text-transform: capitalize !important;
}
.text-wrap {
  white-space: normal !important;
}
.text-nowrap {
  white-space: nowrap !important;
}
/* rtl:begin:remove */
.text-break {
  word-wrap: break-word !important;
  word-break: break-word !important;
}
/* rtl:end:remove */
.text-primary {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-primary-rgb), var(--bs-text-opacity)) !important;
}
.text-secondary {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-secondary-rgb), var(--bs-text-opacity)) !important;
}
.text-success {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-success-rgb), var(--bs-text-opacity)) !important;
}
.text-info {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-info-rgb), var(--bs-text-opacity)) !important;
}
.text-warning {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-warning-rgb), var(--bs-text-opacity)) !important;
}
.text-danger {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-danger-rgb), var(--bs-text-opacity)) !important;
}
.text-light {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-light-rgb), var(--bs-text-opacity)) !important;
}
.text-dark {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-dark-rgb), var(--bs-text-opacity)) !important;
}
.text-black {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-black-rgb), var(--bs-text-opacity)) !important;
}
.text-white {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-white-rgb), var(--bs-text-opacity)) !important;
}
.text-body {
  --bs-text-opacity: 1;
  color: rgba(var(--bs-body-color-rgb), var(--bs-text-opacity)) !important;
}
.text-muted {
  --bs-text-opacity: 1;
  color: var(--bs-secondary-color) !important;
}
.text-black-50 {
  --bs-text-opacity: 1;
  color: rgba(0, 0, 0, 0.5) !important;
}
.text-white-50 {
  --bs-text-opacity: 1;
  color: rgba(255, 255, 255, 0.5) !important;
}
.text-body-secondary {
  --bs-text-opacity: 1;
  color: var(--bs-secondary-color) !important;
}
.text-body-tertiary {
  --bs-text-opacity: 1;
  color: var(--bs-tertiary-color) !important;
}
.text-body-emphasis {
  --bs-text-opacity: 1;
  color: var(--bs-emphasis-color) !important;
}
.text-reset {
  --bs-text-opacity: 1;
  color: inherit !important;
}
.text-opacity-25 {
  --bs-text-opacity: 0.25;
}
.text-opacity-50 {
  --bs-text-opacity: 0.5;
}
.text-opacity-75 {
  --bs-text-opacity: 0.75;
}
.text-opacity-100 {
  --bs-text-opacity: 1;
}
.text-primary-emphasis {
  color: var(--bs-primary-text-emphasis) !important;
}
.text-secondary-emphasis {
  color: var(--bs-secondary-text-emphasis) !important;
}
.text-success-emphasis {
  color: var(--bs-success-text-emphasis) !important;
}
.text-info-emphasis {
  color: var(--bs-info-text-emphasis) !important;
}
.text-warning-emphasis {
  color: var(--bs-warning-text-emphasis) !important;
}
.text-danger-emphasis {
  color: var(--bs-danger-text-emphasis) !important;
}
.text-light-emphasis {
  color: var(--bs-light-text-emphasis) !important;
}
.text-dark-emphasis {
  color: var(--bs-dark-text-emphasis) !important;
}
.link-opacity-10 {
  --bs-link-opacity: 0.1;
}
.link-opacity-10-hover:hover {
  --bs-link-opacity: 0.1;
}
.link-opacity-25 {
  --bs-link-opacity: 0.25;
}
.link-opacity-25-hover:hover {
  --bs-link-opacity: 0.25;
}
.link-opacity-50 {
  --bs-link-opacity: 0.5;
}
.link-opacity-50-hover:hover {
  --bs-link-opacity: 0.5;
}
.link-opacity-75 {
  --bs-link-opacity: 0.75;
}
.link-opacity-75-hover:hover {
  --bs-link-opacity: 0.75;
}
.link-opacity-100 {
  --bs-link-opacity: 1;
}
.link-opacity-100-hover:hover {
  --bs-link-opacity: 1;
}
.link-offset-1 {
  text-underline-offset: 0.125em !important;
}
.link-offset-1-hover:hover {
  text-underline-offset: 0.125em !important;
}
.link-offset-2 {
  text-underline-offset: 0.25em !important;
}
.link-offset-2-hover:hover {
  text-underline-offset: 0.25em !important;
}
.link-offset-3 {
  text-underline-offset: 0.375em !important;
}
.link-offset-3-hover:hover {
  text-underline-offset: 0.375em !important;
}
.link-underline-primary {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-primary-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-secondary {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-secondary-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-success {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-success-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-info {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-info-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-warning {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-warning-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-danger {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-danger-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-light {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-light-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline-dark {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-dark-rgb), var(--bs-link-underline-opacity)) !important;
}
.link-underline {
  --bs-link-underline-opacity: 1;
  text-decoration-color: rgba(var(--bs-link-color-rgb), var(--bs-link-underline-opacity, 1)) !important;
}
.link-underline-opacity-0 {
  --bs-link-underline-opacity: 0;
}
.link-underline-opacity-0-hover:hover {
  --bs-link-underline-opacity: 0;
}
.link-underline-opacity-10 {
  --bs-link-underline-opacity: 0.1;
}
.link-underline-opacity-10-hover:hover {
  --bs-link-underline-opacity: 0.1;
}
.link-underline-opacity-25 {
  --bs-link-underline-opacity: 0.25;
}
.link-underline-opacity-25-hover:hover {
  --bs-link-underline-opacity: 0.25;
}
.link-underline-opacity-50 {
  --bs-link-underline-opacity: 0.5;
}
.link-underline-opacity-50-hover:hover {
  --bs-link-underline-opacity: 0.5;
}
.link-underline-opacity-75 {
  --bs-link-underline-opacity: 0.75;
}
.link-underline-opacity-75-hover:hover {
  --bs-link-underline-opacity: 0.75;
}
.link-underline-opacity-100 {
  --bs-link-underline-opacity: 1;
}
.link-underline-opacity-100-hover:hover {
  --bs-link-underline-opacity: 1;
}
.bg-primary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-primary-rgb), var(--bs-bg-opacity)) !important;
}
.bg-secondary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-secondary-rgb), var(--bs-bg-opacity)) !important;
}
.bg-success {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-success-rgb), var(--bs-bg-opacity)) !important;
}
.bg-info {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-info-rgb), var(--bs-bg-opacity)) !important;
}
.bg-warning {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-warning-rgb), var(--bs-bg-opacity)) !important;
}
.bg-danger {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-danger-rgb), var(--bs-bg-opacity)) !important;
}
.bg-light {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-light-rgb), var(--bs-bg-opacity)) !important;
}
.bg-dark {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-dark-rgb), var(--bs-bg-opacity)) !important;
}
.bg-black {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-black-rgb), var(--bs-bg-opacity)) !important;
}
.bg-white {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-white-rgb), var(--bs-bg-opacity)) !important;
}
.bg-body {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-body-bg-rgb), var(--bs-bg-opacity)) !important;
}
.bg-transparent {
  --bs-bg-opacity: 1;
  background-color: transparent !important;
}
.bg-body-secondary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-secondary-bg-rgb), var(--bs-bg-opacity)) !important;
}
.bg-body-tertiary {
  --bs-bg-opacity: 1;
  background-color: rgba(var(--bs-tertiary-bg-rgb), var(--bs-bg-opacity)) !important;
}
.bg-opacity-10 {
  --bs-bg-opacity: 0.1;
}
.bg-opacity-25 {
  --bs-bg-opacity: 0.25;
}
.bg-opacity-50 {
  --bs-bg-opacity: 0.5;
}
.bg-opacity-75 {
  --bs-bg-opacity: 0.75;
}
.bg-opacity-100 {
  --bs-bg-opacity: 1;
}
.bg-primary-subtle {
  background-color: var(--bs-primary-bg-subtle) !important;
}
.bg-secondary-subtle {
  background-color: var(--bs-secondary-bg-subtle) !important;
}
.bg-success-subtle {
  background-color: var(--bs-success-bg-subtle) !important;
}
.bg-info-subtle {
  background-color: var(--bs-info-bg-subtle) !important;
}
.bg-warning-subtle {
  background-color: var(--bs-warning-bg-subtle) !important;
}
.bg-danger-subtle {
  background-color: var(--bs-danger-bg-subtle) !important;
}
.bg-light-subtle {
  background-color: var(--bs-light-bg-subtle) !important;
}
.bg-dark-subtle {
  background-color: var(--bs-dark-bg-subtle) !important;
}
.bg-gradient {
  background-image: var(--bs-gradient) !important;
}
.user-select-all {
  -webkit-user-select: all !important;
  -moz-user-select: all !important;
  user-select: all !important;
}
.user-select-auto {
  -webkit-user-select: auto !important;
  -moz-user-select: auto !important;
  user-select: auto !important;
}
.user-select-none {
  -webkit-user-select: none !important;
  -moz-user-select: none !important;
  user-select: none !important;
}
.pe-none {
  pointer-events: none !important;
}
.pe-auto {
  pointer-events: auto !important;
}
.rounded {
  border-radius: var(--bs-border-radius) !important;
}
.rounded-0 {
  border-radius: 0 !important;
}
.rounded-1 {
  border-radius: var(--bs-border-radius-sm) !important;
}
.rounded-2 {
  border-radius: var(--bs-border-radius) !important;
}
.rounded-3 {
  border-radius: var(--bs-border-radius-lg) !important;
}
.rounded-4 {
  border-radius: var(--bs-border-radius-xl) !important;
}
.rounded-5 {
  border-radius: var(--bs-border-radius-xxl) !important;
}
.rounded-circle {
  border-radius: 50% !important;
}
.rounded-pill {
  border-radius: var(--bs-border-radius-pill) !important;
}
.rounded-top {
  border-top-left-radius: var(--bs-border-radius) !important;
  border-top-right-radius: var(--bs-border-radius) !important;
}
.rounded-top-0 {
  border-top-left-radius: 0 !important;
  border-top-right-radius: 0 !important;
}
.rounded-top-1 {
  border-top-left-radius: var(--bs-border-radius-sm) !important;
  border-top-right-radius: var(--bs-border-radius-sm) !important;
}
.rounded-top-2 {
  border-top-left-radius: var(--bs-border-radius) !important;
  border-top-right-radius: var(--bs-border-radius) !important;
}
.rounded-top-3 {
  border-top-left-radius: var(--bs-border-radius-lg) !important;
  border-top-right-radius: var(--bs-border-radius-lg) !important;
}
.rounded-top-4 {
  border-top-left-radius: var(--bs-border-radius-xl) !important;
  border-top-right-radius: var(--bs-border-radius-xl) !important;
}
.rounded-top-5 {
  border-top-left-radius: var(--bs-border-radius-xxl) !important;
  border-top-right-radius: var(--bs-border-radius-xxl) !important;
}
.rounded-top-circle {
  border-top-left-radius: 50% !important;
  border-top-right-radius: 50% !important;
}
.rounded-top-pill {
  border-top-left-radius: var(--bs-border-radius-pill) !important;
  border-top-right-radius: var(--bs-border-radius-pill) !important;
}
.rounded-end {
  border-top-right-radius: var(--bs-border-radius) !important;
  border-bottom-right-radius: var(--bs-border-radius) !important;
}
.rounded-end-0 {
  border-top-right-radius: 0 !important;
  border-bottom-right-radius: 0 !important;
}
.rounded-end-1 {
  border-top-right-radius: var(--bs-border-radius-sm) !important;
  border-bottom-right-radius: var(--bs-border-radius-sm) !important;
}
.rounded-end-2 {
  border-top-right-radius: var(--bs-border-radius) !important;
  border-bottom-right-radius: var(--bs-border-radius) !important;
}
.rounded-end-3 {
  border-top-right-radius: var(--bs-border-radius-lg) !important;
  border-bottom-right-radius: var(--bs-border-radius-lg) !important;
}
.rounded-end-4 {
  border-top-right-radius: var(--bs-border-radius-xl) !important;
  border-bottom-right-radius: var(--bs-border-radius-xl) !important;
}
.rounded-end-5 {
  border-top-right-radius: var(--bs-border-radius-xxl) !important;
  border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
}
.rounded-end-circle {
  border-top-right-radius: 50% !important;
  border-bottom-right-radius: 50% !important;
}
.rounded-end-pill {
  border-top-right-radius: var(--bs-border-radius-pill) !important;
  border-bottom-right-radius: var(--bs-border-radius-pill) !important;
}
.rounded-bottom {
  border-bottom-right-radius: var(--bs-border-radius) !important;
  border-bottom-left-radius: var(--bs-border-radius) !important;
}
.rounded-bottom-0 {
  border-bottom-right-radius: 0 !important;
  border-bottom-left-radius: 0 !important;
}
.rounded-bottom-1 {
  border-bottom-right-radius: var(--bs-border-radius-sm) !important;
  border-bottom-left-radius: var(--bs-border-radius-sm) !important;
}
.rounded-bottom-2 {
  border-bottom-right-radius: var(--bs-border-radius) !important;
  border-bottom-left-radius: var(--bs-border-radius) !important;
}
.rounded-bottom-3 {
  border-bottom-right-radius: var(--bs-border-radius-lg) !important;
  border-bottom-left-radius: var(--bs-border-radius-lg) !important;
}
.rounded-bottom-4 {
  border-bottom-right-radius: var(--bs-border-radius-xl) !important;
  border-bottom-left-radius: var(--bs-border-radius-xl) !important;
}
.rounded-bottom-5 {
  border-bottom-right-radius: var(--bs-border-radius-xxl) !important;
  border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
}
.rounded-bottom-circle {
  border-bottom-right-radius: 50% !important;
  border-bottom-left-radius: 50% !important;
}
.rounded-bottom-pill {
  border-bottom-right-radius: var(--bs-border-radius-pill) !important;
  border-bottom-left-radius: var(--bs-border-radius-pill) !important;
}
.rounded-start {
  border-bottom-left-radius: var(--bs-border-radius) !important;
  border-top-left-radius: var(--bs-border-radius) !important;
}
.rounded-start-0 {
  border-bottom-left-radius: 0 !important;
  border-top-left-radius: 0 !important;
}
.rounded-start-1 {
  border-bottom-left-radius: var(--bs-border-radius-sm) !important;
  border-top-left-radius: var(--bs-border-radius-sm) !important;
}
.rounded-start-2 {
  border-bottom-left-radius: var(--bs-border-radius) !important;
  border-top-left-radius: var(--bs-border-radius) !important;
}
.rounded-start-3 {
  border-bottom-left-radius: var(--bs-border-radius-lg) !important;
  border-top-left-radius: var(--bs-border-radius-lg) !important;
}
.rounded-start-4 {
  border-bottom-left-radius: var(--bs-border-radius-xl) !important;
  border-top-left-radius: var(--bs-border-radius-xl) !important;
}
.rounded-start-5 {
  border-bottom-left-radius: var(--bs-border-radius-xxl) !important;
  border-top-left-radius: var(--bs-border-radius-xxl) !important;
}
.rounded-start-circle {
  border-bottom-left-radius: 50% !important;
  border-top-left-radius: 50% !important;
}
.rounded-start-pill {
  border-bottom-left-radius: var(--bs-border-radius-pill) !important;
  border-top-left-radius: var(--bs-border-radius-pill) !important;
}
.visible {
  visibility: visible !important;
}
.invisible {
  visibility: hidden !important;
}
.z-n1 {
  z-index: -1 !important;
}
.z-0 {
  z-index: 0 !important;
}
.z-1 {
  z-index: 1 !important;
}
.z-2 {
  z-index: 2 !important;
}
.z-3 {
  z-index: 3 !important;
}
@media (min-width: 576px) {
  .float-sm-start {
    float: left !important;
  }
  .float-sm-end {
    float: right !important;
  }
  .float-sm-none {
    float: none !important;
  }
  .object-fit-sm-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important;
  }
  .object-fit-sm-cover {
    -o-object-fit: cover !important;
    object-fit: cover !important;
  }
  .object-fit-sm-fill {
    -o-object-fit: fill !important;
    object-fit: fill !important;
  }
  .object-fit-sm-scale {
    -o-object-fit: scale-down !important;
    object-fit: scale-down !important;
  }
  .object-fit-sm-none {
    -o-object-fit: none !important;
    object-fit: none !important;
  }
  .d-sm-inline {
    display: inline !important;
  }
  .d-sm-inline-block {
    display: inline-block !important;
  }
  .d-sm-block {
    display: block !important;
  }
  .d-sm-grid {
    display: grid !important;
  }
  .d-sm-inline-grid {
    display: inline-grid !important;
  }
  .d-sm-table {
    display: table !important;
  }
  .d-sm-table-row {
    display: table-row !important;
  }
  .d-sm-table-cell {
    display: table-cell !important;
  }
  .d-sm-flex {
    display: flex !important;
  }
  .d-sm-inline-flex {
    display: inline-flex !important;
  }
  .d-sm-none {
    display: none !important;
  }
  .flex-sm-fill {
    flex: 1 1 auto !important;
  }
  .flex-sm-row {
    flex-direction: row !important;
  }
  .flex-sm-column {
    flex-direction: column !important;
  }
  .flex-sm-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-sm-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-sm-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-sm-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-sm-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-sm-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-sm-wrap {
    flex-wrap: wrap !important;
  }
  .flex-sm-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-sm-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-sm-start {
    justify-content: flex-start !important;
  }
  .justify-content-sm-end {
    justify-content: flex-end !important;
  }
  .justify-content-sm-center {
    justify-content: center !important;
  }
  .justify-content-sm-between {
    justify-content: space-between !important;
  }
  .justify-content-sm-around {
    justify-content: space-around !important;
  }
  .justify-content-sm-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-sm-start {
    align-items: flex-start !important;
  }
  .align-items-sm-end {
    align-items: flex-end !important;
  }
  .align-items-sm-center {
    align-items: center !important;
  }
  .align-items-sm-baseline {
    align-items: baseline !important;
  }
  .align-items-sm-stretch {
    align-items: stretch !important;
  }
  .align-content-sm-start {
    align-content: flex-start !important;
  }
  .align-content-sm-end {
    align-content: flex-end !important;
  }
  .align-content-sm-center {
    align-content: center !important;
  }
  .align-content-sm-between {
    align-content: space-between !important;
  }
  .align-content-sm-around {
    align-content: space-around !important;
  }
  .align-content-sm-stretch {
    align-content: stretch !important;
  }
  .align-self-sm-auto {
    align-self: auto !important;
  }
  .align-self-sm-start {
    align-self: flex-start !important;
  }
  .align-self-sm-end {
    align-self: flex-end !important;
  }
  .align-self-sm-center {
    align-self: center !important;
  }
  .align-self-sm-baseline {
    align-self: baseline !important;
  }
  .align-self-sm-stretch {
    align-self: stretch !important;
  }
  .order-sm-first {
    order: -1 !important;
  }
  .order-sm-0 {
    order: 0 !important;
  }
  .order-sm-1 {
    order: 1 !important;
  }
  .order-sm-2 {
    order: 2 !important;
  }
  .order-sm-3 {
    order: 3 !important;
  }
  .order-sm-4 {
    order: 4 !important;
  }
  .order-sm-5 {
    order: 5 !important;
  }
  .order-sm-last {
    order: 6 !important;
  }
  .m-sm-0 {
    margin: 0 !important;
  }
  .m-sm-1 {
    margin: 0.25rem !important;
  }
  .m-sm-2 {
    margin: 0.5rem !important;
  }
  .m-sm-3 {
    margin: 1rem !important;
  }
  .m-sm-4 {
    margin: 1.5rem !important;
  }
  .m-sm-5 {
    margin: 3rem !important;
  }
  .m-sm-auto {
    margin: auto !important;
  }
  .mx-sm-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-sm-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-sm-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-sm-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-sm-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-sm-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-sm-auto {
    margin-right: auto !important;
    margin-left: auto !important;
  }
  .my-sm-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-sm-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-sm-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-sm-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-sm-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-sm-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-sm-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .mt-sm-0 {
    margin-top: 0 !important;
  }
  .mt-sm-1 {
    margin-top: 0.25rem !important;
  }
  .mt-sm-2 {
    margin-top: 0.5rem !important;
  }
  .mt-sm-3 {
    margin-top: 1rem !important;
  }
  .mt-sm-4 {
    margin-top: 1.5rem !important;
  }
  .mt-sm-5 {
    margin-top: 3rem !important;
  }
  .mt-sm-auto {
    margin-top: auto !important;
  }
  .me-sm-0 {
    margin-right: 0 !important;
  }
  .me-sm-1 {
    margin-right: 0.25rem !important;
  }
  .me-sm-2 {
    margin-right: 0.5rem !important;
  }
  .me-sm-3 {
    margin-right: 1rem !important;
  }
  .me-sm-4 {
    margin-right: 1.5rem !important;
  }
  .me-sm-5 {
    margin-right: 3rem !important;
  }
  .me-sm-auto {
    margin-right: auto !important;
  }
  .mb-sm-0 {
    margin-bottom: 0 !important;
  }
  .mb-sm-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-sm-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-sm-3 {
    margin-bottom: 1rem !important;
  }
  .mb-sm-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-sm-5 {
    margin-bottom: 3rem !important;
  }
  .mb-sm-auto {
    margin-bottom: auto !important;
  }
  .ms-sm-0 {
    margin-left: 0 !important;
  }
  .ms-sm-1 {
    margin-left: 0.25rem !important;
  }
  .ms-sm-2 {
    margin-left: 0.5rem !important;
  }
  .ms-sm-3 {
    margin-left: 1rem !important;
  }
  .ms-sm-4 {
    margin-left: 1.5rem !important;
  }
  .ms-sm-5 {
    margin-left: 3rem !important;
  }
  .ms-sm-auto {
    margin-left: auto !important;
  }
  .p-sm-0 {
    padding: 0 !important;
  }
  .p-sm-1 {
    padding: 0.25rem !important;
  }
  .p-sm-2 {
    padding: 0.5rem !important;
  }
  .p-sm-3 {
    padding: 1rem !important;
  }
  .p-sm-4 {
    padding: 1.5rem !important;
  }
  .p-sm-5 {
    padding: 3rem !important;
  }
  .px-sm-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-sm-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-sm-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-sm-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-sm-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-sm-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
  }
  .py-sm-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-sm-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-sm-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-sm-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-sm-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-sm-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .pt-sm-0 {
    padding-top: 0 !important;
  }
  .pt-sm-1 {
    padding-top: 0.25rem !important;
  }
  .pt-sm-2 {
    padding-top: 0.5rem !important;
  }
  .pt-sm-3 {
    padding-top: 1rem !important;
  }
  .pt-sm-4 {
    padding-top: 1.5rem !important;
  }
  .pt-sm-5 {
    padding-top: 3rem !important;
  }
  .pe-sm-0 {
    padding-right: 0 !important;
  }
  .pe-sm-1 {
    padding-right: 0.25rem !important;
  }
  .pe-sm-2 {
    padding-right: 0.5rem !important;
  }
  .pe-sm-3 {
    padding-right: 1rem !important;
  }
  .pe-sm-4 {
    padding-right: 1.5rem !important;
  }
  .pe-sm-5 {
    padding-right: 3rem !important;
  }
  .pb-sm-0 {
    padding-bottom: 0 !important;
  }
  .pb-sm-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-sm-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-sm-3 {
    padding-bottom: 1rem !important;
  }
  .pb-sm-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-sm-5 {
    padding-bottom: 3rem !important;
  }
  .ps-sm-0 {
    padding-left: 0 !important;
  }
  .ps-sm-1 {
    padding-left: 0.25rem !important;
  }
  .ps-sm-2 {
    padding-left: 0.5rem !important;
  }
  .ps-sm-3 {
    padding-left: 1rem !important;
  }
  .ps-sm-4 {
    padding-left: 1.5rem !important;
  }
  .ps-sm-5 {
    padding-left: 3rem !important;
  }
  .gap-sm-0 {
    gap: 0 !important;
  }
  .gap-sm-1 {
    gap: 0.25rem !important;
  }
  .gap-sm-2 {
    gap: 0.5rem !important;
  }
  .gap-sm-3 {
    gap: 1rem !important;
  }
  .gap-sm-4 {
    gap: 1.5rem !important;
  }
  .gap-sm-5 {
    gap: 3rem !important;
  }
  .row-gap-sm-0 {
    row-gap: 0 !important;
  }
  .row-gap-sm-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-sm-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-sm-3 {
    row-gap: 1rem !important;
  }
  .row-gap-sm-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-sm-5 {
    row-gap: 3rem !important;
  }
  .column-gap-sm-0 {
    -moz-column-gap: 0 !important;
    column-gap: 0 !important;
  }
  .column-gap-sm-1 {
    -moz-column-gap: 0.25rem !important;
    column-gap: 0.25rem !important;
  }
  .column-gap-sm-2 {
    -moz-column-gap: 0.5rem !important;
    column-gap: 0.5rem !important;
  }
  .column-gap-sm-3 {
    -moz-column-gap: 1rem !important;
    column-gap: 1rem !important;
  }
  .column-gap-sm-4 {
    -moz-column-gap: 1.5rem !important;
    column-gap: 1.5rem !important;
  }
  .column-gap-sm-5 {
    -moz-column-gap: 3rem !important;
    column-gap: 3rem !important;
  }
  .text-sm-start {
    text-align: left !important;
  }
  .text-sm-end {
    text-align: right !important;
  }
  .text-sm-center {
    text-align: center !important;
  }
}
@media (min-width: 768px) {
  .float-md-start {
    float: left !important;
  }
  .float-md-end {
    float: right !important;
  }
  .float-md-none {
    float: none !important;
  }
  .object-fit-md-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important;
  }
  .object-fit-md-cover {
    -o-object-fit: cover !important;
    object-fit: cover !important;
  }
  .object-fit-md-fill {
    -o-object-fit: fill !important;
    object-fit: fill !important;
  }
  .object-fit-md-scale {
    -o-object-fit: scale-down !important;
    object-fit: scale-down !important;
  }
  .object-fit-md-none {
    -o-object-fit: none !important;
    object-fit: none !important;
  }
  .d-md-inline {
    display: inline !important;
  }
  .d-md-inline-block {
    display: inline-block !important;
  }
  .d-md-block {
    display: block !important;
  }
  .d-md-grid {
    display: grid !important;
  }
  .d-md-inline-grid {
    display: inline-grid !important;
  }
  .d-md-table {
    display: table !important;
  }
  .d-md-table-row {
    display: table-row !important;
  }
  .d-md-table-cell {
    display: table-cell !important;
  }
  .d-md-flex {
    display: flex !important;
  }
  .d-md-inline-flex {
    display: inline-flex !important;
  }
  .d-md-none {
    display: none !important;
  }
  .flex-md-fill {
    flex: 1 1 auto !important;
  }
  .flex-md-row {
    flex-direction: row !important;
  }
  .flex-md-column {
    flex-direction: column !important;
  }
  .flex-md-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-md-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-md-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-md-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-md-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-md-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-md-wrap {
    flex-wrap: wrap !important;
  }
  .flex-md-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-md-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-md-start {
    justify-content: flex-start !important;
  }
  .justify-content-md-end {
    justify-content: flex-end !important;
  }
  .justify-content-md-center {
    justify-content: center !important;
  }
  .justify-content-md-between {
    justify-content: space-between !important;
  }
  .justify-content-md-around {
    justify-content: space-around !important;
  }
  .justify-content-md-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-md-start {
    align-items: flex-start !important;
  }
  .align-items-md-end {
    align-items: flex-end !important;
  }
  .align-items-md-center {
    align-items: center !important;
  }
  .align-items-md-baseline {
    align-items: baseline !important;
  }
  .align-items-md-stretch {
    align-items: stretch !important;
  }
  .align-content-md-start {
    align-content: flex-start !important;
  }
  .align-content-md-end {
    align-content: flex-end !important;
  }
  .align-content-md-center {
    align-content: center !important;
  }
  .align-content-md-between {
    align-content: space-between !important;
  }
  .align-content-md-around {
    align-content: space-around !important;
  }
  .align-content-md-stretch {
    align-content: stretch !important;
  }
  .align-self-md-auto {
    align-self: auto !important;
  }
  .align-self-md-start {
    align-self: flex-start !important;
  }
  .align-self-md-end {
    align-self: flex-end !important;
  }
  .align-self-md-center {
    align-self: center !important;
  }
  .align-self-md-baseline {
    align-self: baseline !important;
  }
  .align-self-md-stretch {
    align-self: stretch !important;
  }
  .order-md-first {
    order: -1 !important;
  }
  .order-md-0 {
    order: 0 !important;
  }
  .order-md-1 {
    order: 1 !important;
  }
  .order-md-2 {
    order: 2 !important;
  }
  .order-md-3 {
    order: 3 !important;
  }
  .order-md-4 {
    order: 4 !important;
  }
  .order-md-5 {
    order: 5 !important;
  }
  .order-md-last {
    order: 6 !important;
  }
  .m-md-0 {
    margin: 0 !important;
  }
  .m-md-1 {
    margin: 0.25rem !important;
  }
  .m-md-2 {
    margin: 0.5rem !important;
  }
  .m-md-3 {
    margin: 1rem !important;
  }
  .m-md-4 {
    margin: 1.5rem !important;
  }
  .m-md-5 {
    margin: 3rem !important;
  }
  .m-md-auto {
    margin: auto !important;
  }
  .mx-md-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-md-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-md-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-md-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-md-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-md-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-md-auto {
    margin-right: auto !important;
    margin-left: auto !important;
  }
  .my-md-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-md-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-md-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-md-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-md-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-md-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-md-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .mt-md-0 {
    margin-top: 0 !important;
  }
  .mt-md-1 {
    margin-top: 0.25rem !important;
  }
  .mt-md-2 {
    margin-top: 0.5rem !important;
  }
  .mt-md-3 {
    margin-top: 1rem !important;
  }
  .mt-md-4 {
    margin-top: 1.5rem !important;
  }
  .mt-md-5 {
    margin-top: 3rem !important;
  }
  .mt-md-auto {
    margin-top: auto !important;
  }
  .me-md-0 {
    margin-right: 0 !important;
  }
  .me-md-1 {
    margin-right: 0.25rem !important;
  }
  .me-md-2 {
    margin-right: 0.5rem !important;
  }
  .me-md-3 {
    margin-right: 1rem !important;
  }
  .me-md-4 {
    margin-right: 1.5rem !important;
  }
  .me-md-5 {
    margin-right: 3rem !important;
  }
  .me-md-auto {
    margin-right: auto !important;
  }
  .mb-md-0 {
    margin-bottom: 0 !important;
  }
  .mb-md-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-md-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-md-3 {
    margin-bottom: 1rem !important;
  }
  .mb-md-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-md-5 {
    margin-bottom: 3rem !important;
  }
  .mb-md-auto {
    margin-bottom: auto !important;
  }
  .ms-md-0 {
    margin-left: 0 !important;
  }
  .ms-md-1 {
    margin-left: 0.25rem !important;
  }
  .ms-md-2 {
    margin-left: 0.5rem !important;
  }
  .ms-md-3 {
    margin-left: 1rem !important;
  }
  .ms-md-4 {
    margin-left: 1.5rem !important;
  }
  .ms-md-5 {
    margin-left: 3rem !important;
  }
  .ms-md-auto {
    margin-left: auto !important;
  }
  .p-md-0 {
    padding: 0 !important;
  }
  .p-md-1 {
    padding: 0.25rem !important;
  }
  .p-md-2 {
    padding: 0.5rem !important;
  }
  .p-md-3 {
    padding: 1rem !important;
  }
  .p-md-4 {
    padding: 1.5rem !important;
  }
  .p-md-5 {
    padding: 3rem !important;
  }
  .px-md-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-md-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-md-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-md-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-md-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-md-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
  }
  .py-md-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-md-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-md-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-md-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-md-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-md-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .pt-md-0 {
    padding-top: 0 !important;
  }
  .pt-md-1 {
    padding-top: 0.25rem !important;
  }
  .pt-md-2 {
    padding-top: 0.5rem !important;
  }
  .pt-md-3 {
    padding-top: 1rem !important;
  }
  .pt-md-4 {
    padding-top: 1.5rem !important;
  }
  .pt-md-5 {
    padding-top: 3rem !important;
  }
  .pe-md-0 {
    padding-right: 0 !important;
  }
  .pe-md-1 {
    padding-right: 0.25rem !important;
  }
  .pe-md-2 {
    padding-right: 0.5rem !important;
  }
  .pe-md-3 {
    padding-right: 1rem !important;
  }
  .pe-md-4 {
    padding-right: 1.5rem !important;
  }
  .pe-md-5 {
    padding-right: 3rem !important;
  }
  .pb-md-0 {
    padding-bottom: 0 !important;
  }
  .pb-md-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-md-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-md-3 {
    padding-bottom: 1rem !important;
  }
  .pb-md-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-md-5 {
    padding-bottom: 3rem !important;
  }
  .ps-md-0 {
    padding-left: 0 !important;
  }
  .ps-md-1 {
    padding-left: 0.25rem !important;
  }
  .ps-md-2 {
    padding-left: 0.5rem !important;
  }
  .ps-md-3 {
    padding-left: 1rem !important;
  }
  .ps-md-4 {
    padding-left: 1.5rem !important;
  }
  .ps-md-5 {
    padding-left: 3rem !important;
  }
  .gap-md-0 {
    gap: 0 !important;
  }
  .gap-md-1 {
    gap: 0.25rem !important;
  }
  .gap-md-2 {
    gap: 0.5rem !important;
  }
  .gap-md-3 {
    gap: 1rem !important;
  }
  .gap-md-4 {
    gap: 1.5rem !important;
  }
  .gap-md-5 {
    gap: 3rem !important;
  }
  .row-gap-md-0 {
    row-gap: 0 !important;
  }
  .row-gap-md-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-md-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-md-3 {
    row-gap: 1rem !important;
  }
  .row-gap-md-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-md-5 {
    row-gap: 3rem !important;
  }
  .column-gap-md-0 {
    -moz-column-gap: 0 !important;
    column-gap: 0 !important;
  }
  .column-gap-md-1 {
    -moz-column-gap: 0.25rem !important;
    column-gap: 0.25rem !important;
  }
  .column-gap-md-2 {
    -moz-column-gap: 0.5rem !important;
    column-gap: 0.5rem !important;
  }
  .column-gap-md-3 {
    -moz-column-gap: 1rem !important;
    column-gap: 1rem !important;
  }
  .column-gap-md-4 {
    -moz-column-gap: 1.5rem !important;
    column-gap: 1.5rem !important;
  }
  .column-gap-md-5 {
    -moz-column-gap: 3rem !important;
    column-gap: 3rem !important;
  }
  .text-md-start {
    text-align: left !important;
  }
  .text-md-end {
    text-align: right !important;
  }
  .text-md-center {
    text-align: center !important;
  }
}
@media (min-width: 992px) {
  .float-lg-start {
    float: left !important;
  }
  .float-lg-end {
    float: right !important;
  }
  .float-lg-none {
    float: none !important;
  }
  .object-fit-lg-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important;
  }
  .object-fit-lg-cover {
    -o-object-fit: cover !important;
    object-fit: cover !important;
  }
  .object-fit-lg-fill {
    -o-object-fit: fill !important;
    object-fit: fill !important;
  }
  .object-fit-lg-scale {
    -o-object-fit: scale-down !important;
    object-fit: scale-down !important;
  }
  .object-fit-lg-none {
    -o-object-fit: none !important;
    object-fit: none !important;
  }
  .d-lg-inline {
    display: inline !important;
  }
  .d-lg-inline-block {
    display: inline-block !important;
  }
  .d-lg-block {
    display: block !important;
  }
  .d-lg-grid {
    display: grid !important;
  }
  .d-lg-inline-grid {
    display: inline-grid !important;
  }
  .d-lg-table {
    display: table !important;
  }
  .d-lg-table-row {
    display: table-row !important;
  }
  .d-lg-table-cell {
    display: table-cell !important;
  }
  .d-lg-flex {
    display: flex !important;
  }
  .d-lg-inline-flex {
    display: inline-flex !important;
  }
  .d-lg-none {
    display: none !important;
  }
  .flex-lg-fill {
    flex: 1 1 auto !important;
  }
  .flex-lg-row {
    flex-direction: row !important;
  }
  .flex-lg-column {
    flex-direction: column !important;
  }
  .flex-lg-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-lg-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-lg-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-lg-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-lg-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-lg-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-lg-wrap {
    flex-wrap: wrap !important;
  }
  .flex-lg-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-lg-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-lg-start {
    justify-content: flex-start !important;
  }
  .justify-content-lg-end {
    justify-content: flex-end !important;
  }
  .justify-content-lg-center {
    justify-content: center !important;
  }
  .justify-content-lg-between {
    justify-content: space-between !important;
  }
  .justify-content-lg-around {
    justify-content: space-around !important;
  }
  .justify-content-lg-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-lg-start {
    align-items: flex-start !important;
  }
  .align-items-lg-end {
    align-items: flex-end !important;
  }
  .align-items-lg-center {
    align-items: center !important;
  }
  .align-items-lg-baseline {
    align-items: baseline !important;
  }
  .align-items-lg-stretch {
    align-items: stretch !important;
  }
  .align-content-lg-start {
    align-content: flex-start !important;
  }
  .align-content-lg-end {
    align-content: flex-end !important;
  }
  .align-content-lg-center {
    align-content: center !important;
  }
  .align-content-lg-between {
    align-content: space-between !important;
  }
  .align-content-lg-around {
    align-content: space-around !important;
  }
  .align-content-lg-stretch {
    align-content: stretch !important;
  }
  .align-self-lg-auto {
    align-self: auto !important;
  }
  .align-self-lg-start {
    align-self: flex-start !important;
  }
  .align-self-lg-end {
    align-self: flex-end !important;
  }
  .align-self-lg-center {
    align-self: center !important;
  }
  .align-self-lg-baseline {
    align-self: baseline !important;
  }
  .align-self-lg-stretch {
    align-self: stretch !important;
  }
  .order-lg-first {
    order: -1 !important;
  }
  .order-lg-0 {
    order: 0 !important;
  }
  .order-lg-1 {
    order: 1 !important;
  }
  .order-lg-2 {
    order: 2 !important;
  }
  .order-lg-3 {
    order: 3 !important;
  }
  .order-lg-4 {
    order: 4 !important;
  }
  .order-lg-5 {
    order: 5 !important;
  }
  .order-lg-last {
    order: 6 !important;
  }
  .m-lg-0 {
    margin: 0 !important;
  }
  .m-lg-1 {
    margin: 0.25rem !important;
  }
  .m-lg-2 {
    margin: 0.5rem !important;
  }
  .m-lg-3 {
    margin: 1rem !important;
  }
  .m-lg-4 {
    margin: 1.5rem !important;
  }
  .m-lg-5 {
    margin: 3rem !important;
  }
  .m-lg-auto {
    margin: auto !important;
  }
  .mx-lg-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-lg-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-lg-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-lg-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-lg-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-lg-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-lg-auto {
    margin-right: auto !important;
    margin-left: auto !important;
  }
  .my-lg-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-lg-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-lg-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-lg-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-lg-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-lg-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-lg-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .mt-lg-0 {
    margin-top: 0 !important;
  }
  .mt-lg-1 {
    margin-top: 0.25rem !important;
  }
  .mt-lg-2 {
    margin-top: 0.5rem !important;
  }
  .mt-lg-3 {
    margin-top: 1rem !important;
  }
  .mt-lg-4 {
    margin-top: 1.5rem !important;
  }
  .mt-lg-5 {
    margin-top: 3rem !important;
  }
  .mt-lg-auto {
    margin-top: auto !important;
  }
  .me-lg-0 {
    margin-right: 0 !important;
  }
  .me-lg-1 {
    margin-right: 0.25rem !important;
  }
  .me-lg-2 {
    margin-right: 0.5rem !important;
  }
  .me-lg-3 {
    margin-right: 1rem !important;
  }
  .me-lg-4 {
    margin-right: 1.5rem !important;
  }
  .me-lg-5 {
    margin-right: 3rem !important;
  }
  .me-lg-auto {
    margin-right: auto !important;
  }
  .mb-lg-0 {
    margin-bottom: 0 !important;
  }
  .mb-lg-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-lg-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-lg-3 {
    margin-bottom: 1rem !important;
  }
  .mb-lg-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-lg-5 {
    margin-bottom: 3rem !important;
  }
  .mb-lg-auto {
    margin-bottom: auto !important;
  }
  .ms-lg-0 {
    margin-left: 0 !important;
  }
  .ms-lg-1 {
    margin-left: 0.25rem !important;
  }
  .ms-lg-2 {
    margin-left: 0.5rem !important;
  }
  .ms-lg-3 {
    margin-left: 1rem !important;
  }
  .ms-lg-4 {
    margin-left: 1.5rem !important;
  }
  .ms-lg-5 {
    margin-left: 3rem !important;
  }
  .ms-lg-auto {
    margin-left: auto !important;
  }
  .p-lg-0 {
    padding: 0 !important;
  }
  .p-lg-1 {
    padding: 0.25rem !important;
  }
  .p-lg-2 {
    padding: 0.5rem !important;
  }
  .p-lg-3 {
    padding: 1rem !important;
  }
  .p-lg-4 {
    padding: 1.5rem !important;
  }
  .p-lg-5 {
    padding: 3rem !important;
  }
  .px-lg-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-lg-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-lg-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-lg-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-lg-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-lg-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
  }
  .py-lg-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-lg-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-lg-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-lg-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-lg-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-lg-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .pt-lg-0 {
    padding-top: 0 !important;
  }
  .pt-lg-1 {
    padding-top: 0.25rem !important;
  }
  .pt-lg-2 {
    padding-top: 0.5rem !important;
  }
  .pt-lg-3 {
    padding-top: 1rem !important;
  }
  .pt-lg-4 {
    padding-top: 1.5rem !important;
  }
  .pt-lg-5 {
    padding-top: 3rem !important;
  }
  .pe-lg-0 {
    padding-right: 0 !important;
  }
  .pe-lg-1 {
    padding-right: 0.25rem !important;
  }
  .pe-lg-2 {
    padding-right: 0.5rem !important;
  }
  .pe-lg-3 {
    padding-right: 1rem !important;
  }
  .pe-lg-4 {
    padding-right: 1.5rem !important;
  }
  .pe-lg-5 {
    padding-right: 3rem !important;
  }
  .pb-lg-0 {
    padding-bottom: 0 !important;
  }
  .pb-lg-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-lg-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-lg-3 {
    padding-bottom: 1rem !important;
  }
  .pb-lg-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-lg-5 {
    padding-bottom: 3rem !important;
  }
  .ps-lg-0 {
    padding-left: 0 !important;
  }
  .ps-lg-1 {
    padding-left: 0.25rem !important;
  }
  .ps-lg-2 {
    padding-left: 0.5rem !important;
  }
  .ps-lg-3 {
    padding-left: 1rem !important;
  }
  .ps-lg-4 {
    padding-left: 1.5rem !important;
  }
  .ps-lg-5 {
    padding-left: 3rem !important;
  }
  .gap-lg-0 {
    gap: 0 !important;
  }
  .gap-lg-1 {
    gap: 0.25rem !important;
  }
  .gap-lg-2 {
    gap: 0.5rem !important;
  }
  .gap-lg-3 {
    gap: 1rem !important;
  }
  .gap-lg-4 {
    gap: 1.5rem !important;
  }
  .gap-lg-5 {
    gap: 3rem !important;
  }
  .row-gap-lg-0 {
    row-gap: 0 !important;
  }
  .row-gap-lg-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-lg-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-lg-3 {
    row-gap: 1rem !important;
  }
  .row-gap-lg-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-lg-5 {
    row-gap: 3rem !important;
  }
  .column-gap-lg-0 {
    -moz-column-gap: 0 !important;
    column-gap: 0 !important;
  }
  .column-gap-lg-1 {
    -moz-column-gap: 0.25rem !important;
    column-gap: 0.25rem !important;
  }
  .column-gap-lg-2 {
    -moz-column-gap: 0.5rem !important;
    column-gap: 0.5rem !important;
  }
  .column-gap-lg-3 {
    -moz-column-gap: 1rem !important;
    column-gap: 1rem !important;
  }
  .column-gap-lg-4 {
    -moz-column-gap: 1.5rem !important;
    column-gap: 1.5rem !important;
  }
  .column-gap-lg-5 {
    -moz-column-gap: 3rem !important;
    column-gap: 3rem !important;
  }
  .text-lg-start {
    text-align: left !important;
  }
  .text-lg-end {
    text-align: right !important;
  }
  .text-lg-center {
    text-align: center !important;
  }
}
@media (min-width: 1200px) {
  .float-xl-start {
    float: left !important;
  }
  .float-xl-end {
    float: right !important;
  }
  .float-xl-none {
    float: none !important;
  }
  .object-fit-xl-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important;
  }
  .object-fit-xl-cover {
    -o-object-fit: cover !important;
    object-fit: cover !important;
  }
  .object-fit-xl-fill {
    -o-object-fit: fill !important;
    object-fit: fill !important;
  }
  .object-fit-xl-scale {
    -o-object-fit: scale-down !important;
    object-fit: scale-down !important;
  }
  .object-fit-xl-none {
    -o-object-fit: none !important;
    object-fit: none !important;
  }
  .d-xl-inline {
    display: inline !important;
  }
  .d-xl-inline-block {
    display: inline-block !important;
  }
  .d-xl-block {
    display: block !important;
  }
  .d-xl-grid {
    display: grid !important;
  }
  .d-xl-inline-grid {
    display: inline-grid !important;
  }
  .d-xl-table {
    display: table !important;
  }
  .d-xl-table-row {
    display: table-row !important;
  }
  .d-xl-table-cell {
    display: table-cell !important;
  }
  .d-xl-flex {
    display: flex !important;
  }
  .d-xl-inline-flex {
    display: inline-flex !important;
  }
  .d-xl-none {
    display: none !important;
  }
  .flex-xl-fill {
    flex: 1 1 auto !important;
  }
  .flex-xl-row {
    flex-direction: row !important;
  }
  .flex-xl-column {
    flex-direction: column !important;
  }
  .flex-xl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xl-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-xl-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-xl-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-xl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-xl-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-xl-wrap {
    flex-wrap: wrap !important;
  }
  .flex-xl-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-xl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-xl-start {
    justify-content: flex-start !important;
  }
  .justify-content-xl-end {
    justify-content: flex-end !important;
  }
  .justify-content-xl-center {
    justify-content: center !important;
  }
  .justify-content-xl-between {
    justify-content: space-between !important;
  }
  .justify-content-xl-around {
    justify-content: space-around !important;
  }
  .justify-content-xl-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-xl-start {
    align-items: flex-start !important;
  }
  .align-items-xl-end {
    align-items: flex-end !important;
  }
  .align-items-xl-center {
    align-items: center !important;
  }
  .align-items-xl-baseline {
    align-items: baseline !important;
  }
  .align-items-xl-stretch {
    align-items: stretch !important;
  }
  .align-content-xl-start {
    align-content: flex-start !important;
  }
  .align-content-xl-end {
    align-content: flex-end !important;
  }
  .align-content-xl-center {
    align-content: center !important;
  }
  .align-content-xl-between {
    align-content: space-between !important;
  }
  .align-content-xl-around {
    align-content: space-around !important;
  }
  .align-content-xl-stretch {
    align-content: stretch !important;
  }
  .align-self-xl-auto {
    align-self: auto !important;
  }
  .align-self-xl-start {
    align-self: flex-start !important;
  }
  .align-self-xl-end {
    align-self: flex-end !important;
  }
  .align-self-xl-center {
    align-self: center !important;
  }
  .align-self-xl-baseline {
    align-self: baseline !important;
  }
  .align-self-xl-stretch {
    align-self: stretch !important;
  }
  .order-xl-first {
    order: -1 !important;
  }
  .order-xl-0 {
    order: 0 !important;
  }
  .order-xl-1 {
    order: 1 !important;
  }
  .order-xl-2 {
    order: 2 !important;
  }
  .order-xl-3 {
    order: 3 !important;
  }
  .order-xl-4 {
    order: 4 !important;
  }
  .order-xl-5 {
    order: 5 !important;
  }
  .order-xl-last {
    order: 6 !important;
  }
  .m-xl-0 {
    margin: 0 !important;
  }
  .m-xl-1 {
    margin: 0.25rem !important;
  }
  .m-xl-2 {
    margin: 0.5rem !important;
  }
  .m-xl-3 {
    margin: 1rem !important;
  }
  .m-xl-4 {
    margin: 1.5rem !important;
  }
  .m-xl-5 {
    margin: 3rem !important;
  }
  .m-xl-auto {
    margin: auto !important;
  }
  .mx-xl-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-xl-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-xl-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-xl-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-xl-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-xl-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-xl-auto {
    margin-right: auto !important;
    margin-left: auto !important;
  }
  .my-xl-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-xl-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-xl-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-xl-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-xl-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-xl-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xl-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .mt-xl-0 {
    margin-top: 0 !important;
  }
  .mt-xl-1 {
    margin-top: 0.25rem !important;
  }
  .mt-xl-2 {
    margin-top: 0.5rem !important;
  }
  .mt-xl-3 {
    margin-top: 1rem !important;
  }
  .mt-xl-4 {
    margin-top: 1.5rem !important;
  }
  .mt-xl-5 {
    margin-top: 3rem !important;
  }
  .mt-xl-auto {
    margin-top: auto !important;
  }
  .me-xl-0 {
    margin-right: 0 !important;
  }
  .me-xl-1 {
    margin-right: 0.25rem !important;
  }
  .me-xl-2 {
    margin-right: 0.5rem !important;
  }
  .me-xl-3 {
    margin-right: 1rem !important;
  }
  .me-xl-4 {
    margin-right: 1.5rem !important;
  }
  .me-xl-5 {
    margin-right: 3rem !important;
  }
  .me-xl-auto {
    margin-right: auto !important;
  }
  .mb-xl-0 {
    margin-bottom: 0 !important;
  }
  .mb-xl-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-xl-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-xl-3 {
    margin-bottom: 1rem !important;
  }
  .mb-xl-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-xl-5 {
    margin-bottom: 3rem !important;
  }
  .mb-xl-auto {
    margin-bottom: auto !important;
  }
  .ms-xl-0 {
    margin-left: 0 !important;
  }
  .ms-xl-1 {
    margin-left: 0.25rem !important;
  }
  .ms-xl-2 {
    margin-left: 0.5rem !important;
  }
  .ms-xl-3 {
    margin-left: 1rem !important;
  }
  .ms-xl-4 {
    margin-left: 1.5rem !important;
  }
  .ms-xl-5 {
    margin-left: 3rem !important;
  }
  .ms-xl-auto {
    margin-left: auto !important;
  }
  .p-xl-0 {
    padding: 0 !important;
  }
  .p-xl-1 {
    padding: 0.25rem !important;
  }
  .p-xl-2 {
    padding: 0.5rem !important;
  }
  .p-xl-3 {
    padding: 1rem !important;
  }
  .p-xl-4 {
    padding: 1.5rem !important;
  }
  .p-xl-5 {
    padding: 3rem !important;
  }
  .px-xl-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-xl-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-xl-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-xl-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-xl-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-xl-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
  }
  .py-xl-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-xl-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-xl-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-xl-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-xl-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-xl-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .pt-xl-0 {
    padding-top: 0 !important;
  }
  .pt-xl-1 {
    padding-top: 0.25rem !important;
  }
  .pt-xl-2 {
    padding-top: 0.5rem !important;
  }
  .pt-xl-3 {
    padding-top: 1rem !important;
  }
  .pt-xl-4 {
    padding-top: 1.5rem !important;
  }
  .pt-xl-5 {
    padding-top: 3rem !important;
  }
  .pe-xl-0 {
    padding-right: 0 !important;
  }
  .pe-xl-1 {
    padding-right: 0.25rem !important;
  }
  .pe-xl-2 {
    padding-right: 0.5rem !important;
  }
  .pe-xl-3 {
    padding-right: 1rem !important;
  }
  .pe-xl-4 {
    padding-right: 1.5rem !important;
  }
  .pe-xl-5 {
    padding-right: 3rem !important;
  }
  .pb-xl-0 {
    padding-bottom: 0 !important;
  }
  .pb-xl-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-xl-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-xl-3 {
    padding-bottom: 1rem !important;
  }
  .pb-xl-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-xl-5 {
    padding-bottom: 3rem !important;
  }
  .ps-xl-0 {
    padding-left: 0 !important;
  }
  .ps-xl-1 {
    padding-left: 0.25rem !important;
  }
  .ps-xl-2 {
    padding-left: 0.5rem !important;
  }
  .ps-xl-3 {
    padding-left: 1rem !important;
  }
  .ps-xl-4 {
    padding-left: 1.5rem !important;
  }
  .ps-xl-5 {
    padding-left: 3rem !important;
  }
  .gap-xl-0 {
    gap: 0 !important;
  }
  .gap-xl-1 {
    gap: 0.25rem !important;
  }
  .gap-xl-2 {
    gap: 0.5rem !important;
  }
  .gap-xl-3 {
    gap: 1rem !important;
  }
  .gap-xl-4 {
    gap: 1.5rem !important;
  }
  .gap-xl-5 {
    gap: 3rem !important;
  }
  .row-gap-xl-0 {
    row-gap: 0 !important;
  }
  .row-gap-xl-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-xl-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-xl-3 {
    row-gap: 1rem !important;
  }
  .row-gap-xl-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-xl-5 {
    row-gap: 3rem !important;
  }
  .column-gap-xl-0 {
    -moz-column-gap: 0 !important;
    column-gap: 0 !important;
  }
  .column-gap-xl-1 {
    -moz-column-gap: 0.25rem !important;
    column-gap: 0.25rem !important;
  }
  .column-gap-xl-2 {
    -moz-column-gap: 0.5rem !important;
    column-gap: 0.5rem !important;
  }
  .column-gap-xl-3 {
    -moz-column-gap: 1rem !important;
    column-gap: 1rem !important;
  }
  .column-gap-xl-4 {
    -moz-column-gap: 1.5rem !important;
    column-gap: 1.5rem !important;
  }
  .column-gap-xl-5 {
    -moz-column-gap: 3rem !important;
    column-gap: 3rem !important;
  }
  .text-xl-start {
    text-align: left !important;
  }
  .text-xl-end {
    text-align: right !important;
  }
  .text-xl-center {
    text-align: center !important;
  }
}
@media (min-width: 1400px) {
  .float-xxl-start {
    float: left !important;
  }
  .float-xxl-end {
    float: right !important;
  }
  .float-xxl-none {
    float: none !important;
  }
  .object-fit-xxl-contain {
    -o-object-fit: contain !important;
    object-fit: contain !important;
  }
  .object-fit-xxl-cover {
    -o-object-fit: cover !important;
    object-fit: cover !important;
  }
  .object-fit-xxl-fill {
    -o-object-fit: fill !important;
    object-fit: fill !important;
  }
  .object-fit-xxl-scale {
    -o-object-fit: scale-down !important;
    object-fit: scale-down !important;
  }
  .object-fit-xxl-none {
    -o-object-fit: none !important;
    object-fit: none !important;
  }
  .d-xxl-inline {
    display: inline !important;
  }
  .d-xxl-inline-block {
    display: inline-block !important;
  }
  .d-xxl-block {
    display: block !important;
  }
  .d-xxl-grid {
    display: grid !important;
  }
  .d-xxl-inline-grid {
    display: inline-grid !important;
  }
  .d-xxl-table {
    display: table !important;
  }
  .d-xxl-table-row {
    display: table-row !important;
  }
  .d-xxl-table-cell {
    display: table-cell !important;
  }
  .d-xxl-flex {
    display: flex !important;
  }
  .d-xxl-inline-flex {
    display: inline-flex !important;
  }
  .d-xxl-none {
    display: none !important;
  }
  .flex-xxl-fill {
    flex: 1 1 auto !important;
  }
  .flex-xxl-row {
    flex-direction: row !important;
  }
  .flex-xxl-column {
    flex-direction: column !important;
  }
  .flex-xxl-row-reverse {
    flex-direction: row-reverse !important;
  }
  .flex-xxl-column-reverse {
    flex-direction: column-reverse !important;
  }
  .flex-xxl-grow-0 {
    flex-grow: 0 !important;
  }
  .flex-xxl-grow-1 {
    flex-grow: 1 !important;
  }
  .flex-xxl-shrink-0 {
    flex-shrink: 0 !important;
  }
  .flex-xxl-shrink-1 {
    flex-shrink: 1 !important;
  }
  .flex-xxl-wrap {
    flex-wrap: wrap !important;
  }
  .flex-xxl-nowrap {
    flex-wrap: nowrap !important;
  }
  .flex-xxl-wrap-reverse {
    flex-wrap: wrap-reverse !important;
  }
  .justify-content-xxl-start {
    justify-content: flex-start !important;
  }
  .justify-content-xxl-end {
    justify-content: flex-end !important;
  }
  .justify-content-xxl-center {
    justify-content: center !important;
  }
  .justify-content-xxl-between {
    justify-content: space-between !important;
  }
  .justify-content-xxl-around {
    justify-content: space-around !important;
  }
  .justify-content-xxl-evenly {
    justify-content: space-evenly !important;
  }
  .align-items-xxl-start {
    align-items: flex-start !important;
  }
  .align-items-xxl-end {
    align-items: flex-end !important;
  }
  .align-items-xxl-center {
    align-items: center !important;
  }
  .align-items-xxl-baseline {
    align-items: baseline !important;
  }
  .align-items-xxl-stretch {
    align-items: stretch !important;
  }
  .align-content-xxl-start {
    align-content: flex-start !important;
  }
  .align-content-xxl-end {
    align-content: flex-end !important;
  }
  .align-content-xxl-center {
    align-content: center !important;
  }
  .align-content-xxl-between {
    align-content: space-between !important;
  }
  .align-content-xxl-around {
    align-content: space-around !important;
  }
  .align-content-xxl-stretch {
    align-content: stretch !important;
  }
  .align-self-xxl-auto {
    align-self: auto !important;
  }
  .align-self-xxl-start {
    align-self: flex-start !important;
  }
  .align-self-xxl-end {
    align-self: flex-end !important;
  }
  .align-self-xxl-center {
    align-self: center !important;
  }
  .align-self-xxl-baseline {
    align-self: baseline !important;
  }
  .align-self-xxl-stretch {
    align-self: stretch !important;
  }
  .order-xxl-first {
    order: -1 !important;
  }
  .order-xxl-0 {
    order: 0 !important;
  }
  .order-xxl-1 {
    order: 1 !important;
  }
  .order-xxl-2 {
    order: 2 !important;
  }
  .order-xxl-3 {
    order: 3 !important;
  }
  .order-xxl-4 {
    order: 4 !important;
  }
  .order-xxl-5 {
    order: 5 !important;
  }
  .order-xxl-last {
    order: 6 !important;
  }
  .m-xxl-0 {
    margin: 0 !important;
  }
  .m-xxl-1 {
    margin: 0.25rem !important;
  }
  .m-xxl-2 {
    margin: 0.5rem !important;
  }
  .m-xxl-3 {
    margin: 1rem !important;
  }
  .m-xxl-4 {
    margin: 1.5rem !important;
  }
  .m-xxl-5 {
    margin: 3rem !important;
  }
  .m-xxl-auto {
    margin: auto !important;
  }
  .mx-xxl-0 {
    margin-right: 0 !important;
    margin-left: 0 !important;
  }
  .mx-xxl-1 {
    margin-right: 0.25rem !important;
    margin-left: 0.25rem !important;
  }
  .mx-xxl-2 {
    margin-right: 0.5rem !important;
    margin-left: 0.5rem !important;
  }
  .mx-xxl-3 {
    margin-right: 1rem !important;
    margin-left: 1rem !important;
  }
  .mx-xxl-4 {
    margin-right: 1.5rem !important;
    margin-left: 1.5rem !important;
  }
  .mx-xxl-5 {
    margin-right: 3rem !important;
    margin-left: 3rem !important;
  }
  .mx-xxl-auto {
    margin-right: auto !important;
    margin-left: auto !important;
  }
  .my-xxl-0 {
    margin-top: 0 !important;
    margin-bottom: 0 !important;
  }
  .my-xxl-1 {
    margin-top: 0.25rem !important;
    margin-bottom: 0.25rem !important;
  }
  .my-xxl-2 {
    margin-top: 0.5rem !important;
    margin-bottom: 0.5rem !important;
  }
  .my-xxl-3 {
    margin-top: 1rem !important;
    margin-bottom: 1rem !important;
  }
  .my-xxl-4 {
    margin-top: 1.5rem !important;
    margin-bottom: 1.5rem !important;
  }
  .my-xxl-5 {
    margin-top: 3rem !important;
    margin-bottom: 3rem !important;
  }
  .my-xxl-auto {
    margin-top: auto !important;
    margin-bottom: auto !important;
  }
  .mt-xxl-0 {
    margin-top: 0 !important;
  }
  .mt-xxl-1 {
    margin-top: 0.25rem !important;
  }
  .mt-xxl-2 {
    margin-top: 0.5rem !important;
  }
  .mt-xxl-3 {
    margin-top: 1rem !important;
  }
  .mt-xxl-4 {
    margin-top: 1.5rem !important;
  }
  .mt-xxl-5 {
    margin-top: 3rem !important;
  }
  .mt-xxl-auto {
    margin-top: auto !important;
  }
  .me-xxl-0 {
    margin-right: 0 !important;
  }
  .me-xxl-1 {
    margin-right: 0.25rem !important;
  }
  .me-xxl-2 {
    margin-right: 0.5rem !important;
  }
  .me-xxl-3 {
    margin-right: 1rem !important;
  }
  .me-xxl-4 {
    margin-right: 1.5rem !important;
  }
  .me-xxl-5 {
    margin-right: 3rem !important;
  }
  .me-xxl-auto {
    margin-right: auto !important;
  }
  .mb-xxl-0 {
    margin-bottom: 0 !important;
  }
  .mb-xxl-1 {
    margin-bottom: 0.25rem !important;
  }
  .mb-xxl-2 {
    margin-bottom: 0.5rem !important;
  }
  .mb-xxl-3 {
    margin-bottom: 1rem !important;
  }
  .mb-xxl-4 {
    margin-bottom: 1.5rem !important;
  }
  .mb-xxl-5 {
    margin-bottom: 3rem !important;
  }
  .mb-xxl-auto {
    margin-bottom: auto !important;
  }
  .ms-xxl-0 {
    margin-left: 0 !important;
  }
  .ms-xxl-1 {
    margin-left: 0.25rem !important;
  }
  .ms-xxl-2 {
    margin-left: 0.5rem !important;
  }
  .ms-xxl-3 {
    margin-left: 1rem !important;
  }
  .ms-xxl-4 {
    margin-left: 1.5rem !important;
  }
  .ms-xxl-5 {
    margin-left: 3rem !important;
  }
  .ms-xxl-auto {
    margin-left: auto !important;
  }
  .p-xxl-0 {
    padding: 0 !important;
  }
  .p-xxl-1 {
    padding: 0.25rem !important;
  }
  .p-xxl-2 {
    padding: 0.5rem !important;
  }
  .p-xxl-3 {
    padding: 1rem !important;
  }
  .p-xxl-4 {
    padding: 1.5rem !important;
  }
  .p-xxl-5 {
    padding: 3rem !important;
  }
  .px-xxl-0 {
    padding-right: 0 !important;
    padding-left: 0 !important;
  }
  .px-xxl-1 {
    padding-right: 0.25rem !important;
    padding-left: 0.25rem !important;
  }
  .px-xxl-2 {
    padding-right: 0.5rem !important;
    padding-left: 0.5rem !important;
  }
  .px-xxl-3 {
    padding-right: 1rem !important;
    padding-left: 1rem !important;
  }
  .px-xxl-4 {
    padding-right: 1.5rem !important;
    padding-left: 1.5rem !important;
  }
  .px-xxl-5 {
    padding-right: 3rem !important;
    padding-left: 3rem !important;
  }
  .py-xxl-0 {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
  }
  .py-xxl-1 {
    padding-top: 0.25rem !important;
    padding-bottom: 0.25rem !important;
  }
  .py-xxl-2 {
    padding-top: 0.5rem !important;
    padding-bottom: 0.5rem !important;
  }
  .py-xxl-3 {
    padding-top: 1rem !important;
    padding-bottom: 1rem !important;
  }
  .py-xxl-4 {
    padding-top: 1.5rem !important;
    padding-bottom: 1.5rem !important;
  }
  .py-xxl-5 {
    padding-top: 3rem !important;
    padding-bottom: 3rem !important;
  }
  .pt-xxl-0 {
    padding-top: 0 !important;
  }
  .pt-xxl-1 {
    padding-top: 0.25rem !important;
  }
  .pt-xxl-2 {
    padding-top: 0.5rem !important;
  }
  .pt-xxl-3 {
    padding-top: 1rem !important;
  }
  .pt-xxl-4 {
    padding-top: 1.5rem !important;
  }
  .pt-xxl-5 {
    padding-top: 3rem !important;
  }
  .pe-xxl-0 {
    padding-right: 0 !important;
  }
  .pe-xxl-1 {
    padding-right: 0.25rem !important;
  }
  .pe-xxl-2 {
    padding-right: 0.5rem !important;
  }
  .pe-xxl-3 {
    padding-right: 1rem !important;
  }
  .pe-xxl-4 {
    padding-right: 1.5rem !important;
  }
  .pe-xxl-5 {
    padding-right: 3rem !important;
  }
  .pb-xxl-0 {
    padding-bottom: 0 !important;
  }
  .pb-xxl-1 {
    padding-bottom: 0.25rem !important;
  }
  .pb-xxl-2 {
    padding-bottom: 0.5rem !important;
  }
  .pb-xxl-3 {
    padding-bottom: 1rem !important;
  }
  .pb-xxl-4 {
    padding-bottom: 1.5rem !important;
  }
  .pb-xxl-5 {
    padding-bottom: 3rem !important;
  }
  .ps-xxl-0 {
    padding-left: 0 !important;
  }
  .ps-xxl-1 {
    padding-left: 0.25rem !important;
  }
  .ps-xxl-2 {
    padding-left: 0.5rem !important;
  }
  .ps-xxl-3 {
    padding-left: 1rem !important;
  }
  .ps-xxl-4 {
    padding-left: 1.5rem !important;
  }
  .ps-xxl-5 {
    padding-left: 3rem !important;
  }
  .gap-xxl-0 {
    gap: 0 !important;
  }
  .gap-xxl-1 {
    gap: 0.25rem !important;
  }
  .gap-xxl-2 {
    gap: 0.5rem !important;
  }
  .gap-xxl-3 {
    gap: 1rem !important;
  }
  .gap-xxl-4 {
    gap: 1.5rem !important;
  }
  .gap-xxl-5 {
    gap: 3rem !important;
  }
  .row-gap-xxl-0 {
    row-gap: 0 !important;
  }
  .row-gap-xxl-1 {
    row-gap: 0.25rem !important;
  }
  .row-gap-xxl-2 {
    row-gap: 0.5rem !important;
  }
  .row-gap-xxl-3 {
    row-gap: 1rem !important;
  }
  .row-gap-xxl-4 {
    row-gap: 1.5rem !important;
  }
  .row-gap-xxl-5 {
    row-gap: 3rem !important;
  }
  .column-gap-xxl-0 {
    -moz-column-gap: 0 !important;
    column-gap: 0 !important;
  }
  .column-gap-xxl-1 {
    -moz-column-gap: 0.25rem !important;
    column-gap: 0.25rem !important;
  }
  .column-gap-xxl-2 {
    -moz-column-gap: 0.5rem !important;
    column-gap: 0.5rem !important;
  }
  .column-gap-xxl-3 {
    -moz-column-gap: 1rem !important;
    column-gap: 1rem !important;
  }
  .column-gap-xxl-4 {
    -moz-column-gap: 1.5rem !important;
    column-gap: 1.5rem !important;
  }
  .column-gap-xxl-5 {
    -moz-column-gap: 3rem !important;
    column-gap: 3rem !important;
  }
  .text-xxl-start {
    text-align: left !important;
  }
  .text-xxl-end {
    text-align: right !important;
  }
  .text-xxl-center {
    text-align: center !important;
  }
}
@media (min-width: 1200px) {
  .fs-1 {
    font-size: 2.5rem !important;
  }
  .fs-2 {
    font-size: 2rem !important;
  }
  .fs-3 {
    font-size: 1.75rem !important;
  }
  .fs-4 {
    font-size: 1.5rem !important;
  }
}
@media print {
  .d-print-inline {
    display: inline !important;
  }
  .d-print-inline-block {
    display: inline-block !important;
  }
  .d-print-block {
    display: block !important;
  }
  .d-print-grid {
    display: grid !important;
  }
  .d-print-inline-grid {
    display: inline-grid !important;
  }
  .d-print-table {
    display: table !important;
  }
  .d-print-table-row {
    display: table-row !important;
  }
  .d-print-table-cell {
    display: table-cell !important;
  }
  .d-print-flex {
    display: flex !important;
  }
  .d-print-inline-flex {
    display: inline-flex !important;
  }
  .d-print-none {
    display: none !important;
  }
}
/**
 * selectize.css (v0.12.6)
 * Copyright (c) 2013–2015 Brian Reavis & contributors
 *
 * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this
 * file except in compliance with the License. You may obtain a copy of the License at:
 * http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software distributed under
 * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF
 * ANY KIND, either express or implied. See the License for the specific language
 * governing permissions and limitations under the License.
 *
 * @author Brian Reavis <brian@thirdroute.com>
 */
.selectize-control.plugin-drag_drop.multi > .selectize-input > div.ui-sortable-placeholder {
  visibility: visible !important;
  background: #f2f2f2 !important;
  background: rgba(0, 0, 0, 0.06) !important;
  border: 0 none !important;
  box-shadow: inset 0 0 12px 4px #fff;
}
.selectize-control.plugin-drag_drop .ui-sortable-placeholder::after {
  content: '!';
  visibility: hidden;
}
.selectize-control.plugin-drag_drop .ui-sortable-helper {
  box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}
.selectize-dropdown-header {
  position: relative;
  padding: 5px 8px;
  border-bottom: 1px solid #d0d0d0;
  background: #f8f8f8;
  border-radius: 3px 3px 0 0;
}
.selectize-dropdown-header-close {
  position: absolute;
  right: 8px;
  top: 50%;
  color: #303030;
  opacity: 0.4;
  margin-top: -12px;
  line-height: 20px;
  font-size: 20px !important;
}
.selectize-dropdown-header-close:hover {
  color: #000000;
}
.selectize-dropdown.plugin-optgroup_columns .optgroup {
  border-right: 1px solid #f2f2f2;
  border-top: 0 none;
  float: left;
  box-sizing: border-box;
}
.selectize-dropdown.plugin-optgroup_columns .optgroup:last-child {
  border-right: 0 none;
}
.selectize-dropdown.plugin-optgroup_columns .optgroup:before {
  display: none;
}
.selectize-dropdown.plugin-optgroup_columns .optgroup-header {
  border-top: 0 none;
}
.selectize-control.plugin-remove_button [data-value] {
  position: relative;
  padding-right: 24px !important;
}
.selectize-control.plugin-remove_button [data-value] .remove {
  z-index: 1;
  /* fixes ie bug (see #392) */
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: 17px;
  text-align: center;
  font-weight: bold;
  font-size: 12px;
  color: inherit;
  text-decoration: none;
  vertical-align: middle;
  display: inline-block;
  padding: 2px 0 0 0;
  border-left: 1px solid #d0d0d0;
  border-radius: 0 2px 2px 0;
  box-sizing: border-box;
}
.selectize-control.plugin-remove_button [data-value] .remove:hover {
  background: rgba(0, 0, 0, 0.05);
}
.selectize-control.plugin-remove_button [data-value].active .remove {
  border-left-color: #cacaca;
}
.selectize-control.plugin-remove_button .disabled [data-value] .remove:hover {
  background: none;
}
.selectize-control.plugin-remove_button .disabled [data-value] .remove {
  border-left-color: #ffffff;
}
.selectize-control.plugin-remove_button .remove-single {
  position: absolute;
  right: 0;
  top: 0;
  font-size: 23px;
}
.selectize-control {
  position: relative;
}
.selectize-dropdown,
.selectize-input,
.selectize-input input {
  color: #303030;
  font-family: inherit;
  font-size: 13px;
  line-height: 18px;
  -webkit-font-smoothing: inherit;
}
.selectize-input,
.selectize-control.single .selectize-input.input-active {
  background: #fff;
  cursor: text;
  display: inline-block;
}
.selectize-input {
  border: 1px solid #d0d0d0;
  padding: 8px 8px;
  display: inline-block;
  width: 100%;
  overflow: hidden;
  position: relative;
  z-index: 1;
  box-sizing: border-box;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.1);
  border-radius: 3px;
}
.selectize-control.multi .selectize-input.has-items {
  padding: 6px 8px 3px;
}
.selectize-input.full {
  background-color: #fff;
}
.selectize-input.disabled,
.selectize-input.disabled * {
  cursor: default !important;
}
.selectize-input.focus {
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.15);
}
.selectize-input.dropdown-active {
  border-radius: 3px 3px 0 0;
}
.selectize-input > * {
  vertical-align: baseline;
  display: -moz-inline-stack;
  display: inline-block;
  zoom: 1;
  *display: inline;
}
.selectize-control.multi .selectize-input > div {
  cursor: pointer;
  margin: 0 3px 3px 0;
  padding: 2px 6px;
  background: #f2f2f2;
  color: #303030;
  border: 0 solid #d0d0d0;
}
.selectize-control.multi .selectize-input > div.active {
  background: #e8e8e8;
  color: #303030;
  border: 0 solid #cacaca;
}
.selectize-control.multi .selectize-input.disabled > div,
.selectize-control.multi .selectize-input.disabled > div.active {
  color: #7d7d7d;
  background: #ffffff;
  border: 0 solid #ffffff;
}
.selectize-input > input {
  display: inline-block !important;
  padding: 0 !important;
  min-height: 0 !important;
  max-height: none !important;
  max-width: 100% !important;
  margin: 0 2px 0 0 !important;
  text-indent: 0 !important;
  border: 0 none !important;
  background: none !important;
  line-height: inherit !important;
  -webkit-user-select: auto !important;
  box-shadow: none !important;
}
.selectize-input > input::-ms-clear {
  display: none;
}
.selectize-input > input:focus {
  outline: none !important;
}
.selectize-input::after {
  content: ' ';
  display: block;
  clear: left;
}
.selectize-input.dropdown-active::before {
  content: ' ';
  display: block;
  position: absolute;
  background: #f0f0f0;
  height: 1px;
  bottom: 0;
  left: 0;
  right: 0;
}
.selectize-dropdown {
  position: absolute;
  z-index: 10;
  border: 1px solid #d0d0d0;
  background: #fff;
  margin: -1px 0 0 0;
  border-top: 0 none;
  box-sizing: border-box;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  border-radius: 0 0 3px 3px;
}
.selectize-dropdown [data-selectable] {
  cursor: pointer;
  overflow: hidden;
}
.selectize-dropdown [data-selectable] .highlight {
  background: rgba(125, 168, 208, 0.2);
  border-radius: 1px;
}
.selectize-dropdown .option,
.selectize-dropdown .optgroup-header {
  padding: 5px 8px;
}
.selectize-dropdown .option,
.selectize-dropdown [data-disabled],
.selectize-dropdown [data-disabled] [data-selectable].option {
  cursor: inherit;
  opacity: 0.5;
}
.selectize-dropdown [data-selectable].option {
  opacity: 1;
}
.selectize-dropdown .optgroup:first-child .optgroup-header {
  border-top: 0 none;
}
.selectize-dropdown .optgroup-header {
  color: #303030;
  background: #fff;
  cursor: default;
}
.selectize-dropdown .active {
  background-color: #f5fafd;
  color: #495c68;
}
.selectize-dropdown .active.create {
  color: #495c68;
}
.selectize-dropdown .create {
  color: rgba(48, 48, 48, 0.5);
}
.selectize-dropdown-content {
  overflow-y: auto;
  overflow-x: hidden;
  max-height: 200px;
  -webkit-overflow-scrolling: touch;
}
.selectize-control.single .selectize-input,
.selectize-control.single .selectize-input input {
  cursor: pointer;
}
.selectize-control.single .selectize-input.input-active,
.selectize-control.single .selectize-input.input-active input {
  cursor: text;
}
.selectize-control.single .selectize-input:after {
  content: ' ';
  display: block;
  position: absolute;
  top: 50%;
  right: 15px;
  margin-top: -3px;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 5px 5px 0 5px;
  border-color: #808080 transparent transparent transparent;
}
.selectize-control.single .selectize-input.dropdown-active:after {
  margin-top: -4px;
  border-width: 0 5px 5px 5px;
  border-color: transparent transparent #808080 transparent;
}
.selectize-control.rtl.single .selectize-input:after {
  left: 15px;
  right: auto;
}
.selectize-control.rtl .selectize-input > input {
  margin: 0 4px 0 -2px !important;
}
.selectize-control .selectize-input.disabled {
  opacity: 0.5;
  background-color: #fafafa;
}
.toast-title{font-weight:700}
.toast-message{-ms-word-wrap:break-word;word-wrap:break-word}
.toast-message a,.toast-message label{color:#FFF}
.toast-message a:hover{color:#CCC;text-decoration:none}
.toast-close-button{position:relative;right:-.3em;top:-.3em;float:right;font-size:20px;font-weight:700;color:#FFF;-webkit-text-shadow:0 1px 0 #fff;text-shadow:0 1px 0 #fff;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80);line-height:1}
.toast-close-button:focus,.toast-close-button:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}
.rtl .toast-close-button{left:-.3em;float:left;right:.3em}
button.toast-close-button{padding:0;cursor:pointer;background:0 0;border:0;-webkit-appearance:none}
.toast-top-center{top:0;right:0;width:100%}
.toast-bottom-center{bottom:0;right:0;width:100%}
.toast-top-full-width{top:0;right:0;width:100%}
.toast-bottom-full-width{bottom:0;right:0;width:100%}
.toast-top-left{top:12px;left:12px}
.toast-top-right{top:12px;right:12px}
.toast-bottom-right{right:12px;bottom:12px}
.toast-bottom-left{bottom:12px;left:12px}
#toast-container{position:fixed;z-index:999999;pointer-events:none}
#toast-container *{box-sizing:border-box}
#toast-container>div{position:relative;pointer-events:auto;overflow:hidden;margin:0 0 6px;padding:15px 15px 15px 50px;width:300px;border-radius:3px;background-position:15px center;background-repeat:no-repeat;box-shadow:0 0 12px #999;color:#FFF;opacity:.8;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=80);filter:alpha(opacity=80)}
#toast-container>div.rtl{direction:rtl;padding:15px 50px 15px 15px;background-position:right 15px center}
#toast-container>div:hover{box-shadow:0 0 12px #000;opacity:1;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=100);filter:alpha(opacity=100);cursor:pointer}
#toast-container>.toast-info{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGwSURBVEhLtZa9SgNBEMc9sUxxRcoUKSzSWIhXpFMhhYWFhaBg4yPYiWCXZxBLERsLRS3EQkEfwCKdjWJAwSKCgoKCcudv4O5YLrt7EzgXhiU3/4+b2ckmwVjJSpKkQ6wAi4gwhT+z3wRBcEz0yjSseUTrcRyfsHsXmD0AmbHOC9Ii8VImnuXBPglHpQ5wwSVM7sNnTG7Za4JwDdCjxyAiH3nyA2mtaTJufiDZ5dCaqlItILh1NHatfN5skvjx9Z38m69CgzuXmZgVrPIGE763Jx9qKsRozWYw6xOHdER+nn2KkO+Bb+UV5CBN6WC6QtBgbRVozrahAbmm6HtUsgtPC19tFdxXZYBOfkbmFJ1VaHA1VAHjd0pp70oTZzvR+EVrx2Ygfdsq6eu55BHYR8hlcki+n+kERUFG8BrA0BwjeAv2M8WLQBtcy+SD6fNsmnB3AlBLrgTtVW1c2QN4bVWLATaIS60J2Du5y1TiJgjSBvFVZgTmwCU+dAZFoPxGEEs8nyHC9Bwe2GvEJv2WXZb0vjdyFT4Cxk3e/kIqlOGoVLwwPevpYHT+00T+hWwXDf4AJAOUqWcDhbwAAAAASUVORK5CYII=)!important}
#toast-container>.toast-error{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAHOSURBVEhLrZa/SgNBEMZzh0WKCClSCKaIYOED+AAKeQQLG8HWztLCImBrYadgIdY+gIKNYkBFSwu7CAoqCgkkoGBI/E28PdbLZmeDLgzZzcx83/zZ2SSXC1j9fr+I1Hq93g2yxH4iwM1vkoBWAdxCmpzTxfkN2RcyZNaHFIkSo10+8kgxkXIURV5HGxTmFuc75B2RfQkpxHG8aAgaAFa0tAHqYFfQ7Iwe2yhODk8+J4C7yAoRTWI3w/4klGRgR4lO7Rpn9+gvMyWp+uxFh8+H+ARlgN1nJuJuQAYvNkEnwGFck18Er4q3egEc/oO+mhLdKgRyhdNFiacC0rlOCbhNVz4H9FnAYgDBvU3QIioZlJFLJtsoHYRDfiZoUyIxqCtRpVlANq0EU4dApjrtgezPFad5S19Wgjkc0hNVnuF4HjVA6C7QrSIbylB+oZe3aHgBsqlNqKYH48jXyJKMuAbiyVJ8KzaB3eRc0pg9VwQ4niFryI68qiOi3AbjwdsfnAtk0bCjTLJKr6mrD9g8iq/S/B81hguOMlQTnVyG40wAcjnmgsCNESDrjme7wfftP4P7SP4N3CJZdvzoNyGq2c/HWOXJGsvVg+RA/k2MC/wN6I2YA2Pt8GkAAAAASUVORK5CYII=)!important}
#toast-container>.toast-success{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAADsSURBVEhLY2AYBfQMgf///3P8+/evAIgvA/FsIF+BavYDDWMBGroaSMMBiE8VC7AZDrIFaMFnii3AZTjUgsUUWUDA8OdAH6iQbQEhw4HyGsPEcKBXBIC4ARhex4G4BsjmweU1soIFaGg/WtoFZRIZdEvIMhxkCCjXIVsATV6gFGACs4Rsw0EGgIIH3QJYJgHSARQZDrWAB+jawzgs+Q2UO49D7jnRSRGoEFRILcdmEMWGI0cm0JJ2QpYA1RDvcmzJEWhABhD/pqrL0S0CWuABKgnRki9lLseS7g2AlqwHWQSKH4oKLrILpRGhEQCw2LiRUIa4lwAAAABJRU5ErkJggg==)!important}
#toast-container>.toast-warning{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABgAAAAYCAYAAADgdz34AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAGYSURBVEhL5ZSvTsNQFMbXZGICMYGYmJhAQIJAICYQPAACiSDB8AiICQQJT4CqQEwgJvYASAQCiZiYmJhAIBATCARJy+9rTsldd8sKu1M0+dLb057v6/lbq/2rK0mS/TRNj9cWNAKPYIJII7gIxCcQ51cvqID+GIEX8ASG4B1bK5gIZFeQfoJdEXOfgX4QAQg7kH2A65yQ87lyxb27sggkAzAuFhbbg1K2kgCkB1bVwyIR9m2L7PRPIhDUIXgGtyKw575yz3lTNs6X4JXnjV+LKM/m3MydnTbtOKIjtz6VhCBq4vSm3ncdrD2lk0VgUXSVKjVDJXJzijW1RQdsU7F77He8u68koNZTz8Oz5yGa6J3H3lZ0xYgXBK2QymlWWA+RWnYhskLBv2vmE+hBMCtbA7KX5drWyRT/2JsqZ2IvfB9Y4bWDNMFbJRFmC9E74SoS0CqulwjkC0+5bpcV1CZ8NMej4pjy0U+doDQsGyo1hzVJttIjhQ7GnBtRFN1UarUlH8F3xict+HY07rEzoUGPlWcjRFRr4/gChZgc3ZL2d8oAAAAASUVORK5CYII=)!important}
#toast-container.toast-bottom-center>div,#toast-container.toast-top-center>div{width:300px;margin-left:auto;margin-right:auto}
#toast-container.toast-bottom-full-width>div,#toast-container.toast-top-full-width>div{width:96%;margin-left:auto;margin-right:auto}
.toast{background-color:#030303}
.toast-success{background-color:#51A351}
.toast-error{background-color:#BD362F}
.toast-info{background-color:#2F96B4}
.toast-warning{background-color:#F89406}
.toast-progress{position:absolute;left:0;bottom:0;height:4px;background-color:#000;opacity:.4;-ms-filter:progid:DXImageTransform.Microsoft.Alpha(Opacity=40);filter:alpha(opacity=40)}
@media all and (max-width:240px){#toast-container>div{padding:8px 8px 8px 50px;width:11em}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{right:-.2em;top:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}
@media all and (min-width:241px) and (max-width:480px){#toast-container>div{padding:8px 8px 8px 50px;width:18em}#toast-container>div.rtl{padding:8px 50px 8px 8px}#toast-container .toast-close-button{right:-.2em;top:-.2em}#toast-container .rtl .toast-close-button{left:-.2em;right:.2em}}
@media all and (min-width:481px) and (max-width:768px){#toast-container>div{padding:15px 15px 15px 50px;width:25em}#toast-container>div.rtl{padding:15px 50px 15px 15px}}
/*!
 * FilePond 4.32.7
 * Licensed under MIT, https://opensource.org/licenses/MIT/
 * Please visit https://pqina.nl/filepond/ for details.
 */
/* eslint-disable */
.filepond--assistant{position:absolute;overflow:hidden;height:1px;width:1px;padding:0;border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}
.filepond--browser.filepond--browser{position:absolute;margin:0;padding:0;left:1em;top:1.75em;width:calc(100% - 2em);opacity:0;font-size:0}
.filepond--data{position:absolute;width:0;height:0;padding:0;margin:0;border:none;visibility:hidden;pointer-events:none;contain:strict}
.filepond--drip{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;opacity:.1;pointer-events:none;border-radius:.5em;background:rgba(0,0,0,.01)}
.filepond--drip-blob{transform-origin:center center;width:8em;height:8em;margin-left:-4em;margin-top:-4em;background:#292625;border-radius:50%}
.filepond--drip-blob,.filepond--drop-label{position:absolute;top:0;left:0;will-change:transform,opacity}
.filepond--drop-label{right:0;margin:0;color:#4f4f4f;display:flex;justify-content:center;align-items:center;height:0;-webkit-user-select:none;-moz-user-select:none;user-select:none}
.filepond--drop-label.filepond--drop-label label{display:block;margin:0;padding:.5em}
.filepond--drop-label label{cursor:default;font-size:.875em;font-weight:400;text-align:center;line-height:1.5}
.filepond--label-action{text-decoration:underline;-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto;text-decoration-color:#a7a4a4;cursor:pointer}
.filepond--root[data-disabled] .filepond--drop-label label{opacity:.5}
.filepond--file-action-button.filepond--file-action-button{font-size:1em;width:1.625em;height:1.625em;font-family:inherit;line-height:inherit;margin:0;padding:0;border:none;outline:none;will-change:transform,opacity}
.filepond--file-action-button.filepond--file-action-button span{position:absolute;overflow:hidden;height:1px;width:1px;padding:0;border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}
.filepond--file-action-button.filepond--file-action-button svg{width:100%;height:100%}
.filepond--file-action-button.filepond--file-action-button:after{position:absolute;left:-.75em;right:-.75em;top:-.75em;bottom:-.75em;content:""}
.filepond--file-action-button{cursor:auto;color:#fff;border-radius:50%;background-color:rgba(0,0,0,.5);background-image:none;box-shadow:0 0 0 0 hsla(0,0%,100%,0);transition:box-shadow .25s ease-in}
.filepond--file-action-button:focus,.filepond--file-action-button:hover{box-shadow:0 0 0 .125em hsla(0,0%,100%,.9)}
.filepond--file-action-button[disabled]{color:hsla(0,0%,100%,.5);background-color:rgba(0,0,0,.25)}
.filepond--file-action-button[hidden]{display:none}
.filepond--action-edit-item.filepond--action-edit-item{width:2em;height:2em;padding:.1875em}
.filepond--action-edit-item.filepond--action-edit-item[data-align*=center]{margin-left:-.1875em}
.filepond--action-edit-item.filepond--action-edit-item[data-align*=bottom]{margin-bottom:-.1875em}
.filepond--action-edit-item-alt{border:none;line-height:inherit;background:transparent;font-family:inherit;color:inherit;outline:none;padding:0;margin:0 0 0 .25em;pointer-events:all;position:absolute}
.filepond--action-edit-item-alt svg{width:1.3125em;height:1.3125em}
.filepond--action-edit-item-alt span{font-size:0;opacity:0}
.filepond--file-info{position:static;display:flex;flex-direction:column;align-items:flex-start;flex:1;margin:0 .5em 0 0;min-width:0;will-change:transform,opacity;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}
.filepond--file-info *{margin:0}
.filepond--file-info .filepond--file-info-main{font-size:.75em;line-height:1.2;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;width:100%}
.filepond--file-info .filepond--file-info-sub{font-size:.625em;opacity:.5;transition:opacity .25s ease-in-out;white-space:nowrap}
.filepond--file-info .filepond--file-info-sub:empty{display:none}
.filepond--file-status{position:static;display:flex;flex-direction:column;align-items:flex-end;flex-grow:0;flex-shrink:0;margin:0;min-width:2.25em;text-align:right;will-change:transform,opacity;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}
.filepond--file-status *{margin:0;white-space:nowrap}
.filepond--file-status .filepond--file-status-main{font-size:.75em;line-height:1.2}
.filepond--file-status .filepond--file-status-sub{font-size:.625em;opacity:.5;transition:opacity .25s ease-in-out}
.filepond--file-wrapper.filepond--file-wrapper{border:none;margin:0;padding:0;min-width:0;height:100%}
.filepond--file-wrapper.filepond--file-wrapper>legend{position:absolute;overflow:hidden;height:1px;width:1px;padding:0;border:0;clip:rect(1px,1px,1px,1px);clip-path:inset(50%);white-space:nowrap}
.filepond--file{position:static;display:flex;height:100%;align-items:flex-start;padding:.5625em;color:#fff;border-radius:.5em}
.filepond--file .filepond--file-status{margin-left:auto;margin-right:2.25em}
.filepond--file .filepond--processing-complete-indicator{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none;z-index:3}
.filepond--file .filepond--file-action-button,.filepond--file .filepond--processing-complete-indicator,.filepond--file .filepond--progress-indicator{position:absolute}
.filepond--file [data-align*=left]{left:.5625em}
.filepond--file [data-align*=right]{right:.5625em}
.filepond--file [data-align*=center]{left:calc(50% - .8125em)}
.filepond--file [data-align*=bottom]{bottom:1.125em}
.filepond--file [data-align=center]{top:calc(50% - .8125em)}
.filepond--file .filepond--progress-indicator{margin-top:.1875em}
.filepond--file .filepond--progress-indicator[data-align*=right]{margin-right:.1875em}
.filepond--file .filepond--progress-indicator[data-align*=left]{margin-left:.1875em}
[data-filepond-item-state*=error] .filepond--file-info,[data-filepond-item-state*=invalid] .filepond--file-info,[data-filepond-item-state=cancelled] .filepond--file-info{margin-right:2.25em}
[data-filepond-item-state~=processing] .filepond--file-status-sub{opacity:0}
[data-filepond-item-state~=processing] .filepond--action-abort-item-processing~.filepond--file-status .filepond--file-status-sub{opacity:.5}
[data-filepond-item-state=processing-error] .filepond--file-status-sub{opacity:0}
[data-filepond-item-state=processing-error] .filepond--action-retry-item-processing~.filepond--file-status .filepond--file-status-sub{opacity:.5}
[data-filepond-item-state=processing-complete] .filepond--action-revert-item-processing svg{animation:fall .5s linear .125s both}
[data-filepond-item-state=processing-complete] .filepond--file-status-sub{opacity:.5}
[data-filepond-item-state=processing-complete] .filepond--file-info-sub,[data-filepond-item-state=processing-complete] .filepond--processing-complete-indicator:not([style*=hidden])~.filepond--file-status .filepond--file-status-sub{opacity:0}
[data-filepond-item-state=processing-complete] .filepond--action-revert-item-processing~.filepond--file-info .filepond--file-info-sub{opacity:.5}
[data-filepond-item-state*=error] .filepond--file-wrapper,[data-filepond-item-state*=error] .filepond--panel,[data-filepond-item-state*=invalid] .filepond--file-wrapper,[data-filepond-item-state*=invalid] .filepond--panel{animation:shake .65s linear both}
[data-filepond-item-state*=busy] .filepond--progress-indicator svg{animation:spin 1s linear infinite}
@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}
@keyframes shake{10%,90%{transform:translateX(-.0625em)}20%,80%{transform:translateX(.125em)}30%,50%,70%{transform:translateX(-.25em)}40%,60%{transform:translateX(.25em)}}
@keyframes fall{0%{opacity:0;transform:scale(.5);animation-timing-function:ease-out}70%{opacity:1;transform:scale(1.1);animation-timing-function:ease-in-out}to{transform:scale(1);animation-timing-function:ease-out}}
.filepond--hopper[data-hopper-state=drag-over]>*{pointer-events:none}
.filepond--hopper[data-hopper-state=drag-over]:after{content:"";position:absolute;left:0;top:0;right:0;bottom:0;z-index:100}
.filepond--progress-indicator{z-index:103}
.filepond--file-action-button{z-index:102}
.filepond--file-status{z-index:101}
.filepond--file-info{z-index:100}
.filepond--item{position:absolute;top:0;left:0;right:0;z-index:1;padding:0;margin:.25em;will-change:transform,opacity;touch-action:auto}
.filepond--item>.filepond--panel{z-index:-1}
.filepond--item>.filepond--panel .filepond--panel-bottom{box-shadow:0 .0625em .125em -.0625em rgba(0,0,0,.25)}
.filepond--item>.filepond--file-wrapper,.filepond--item>.filepond--panel{transition:opacity .15s ease-out}
.filepond--item[data-drag-state]{cursor:grab}
.filepond--item[data-drag-state]>.filepond--panel{transition:box-shadow .125s ease-in-out;box-shadow:0 0 0 transparent}
.filepond--item[data-drag-state=drag]{cursor:grabbing}
.filepond--item[data-drag-state=drag]>.filepond--panel{box-shadow:0 .125em .3125em rgba(0,0,0,.325)}
.filepond--item[data-drag-state]:not([data-drag-state=idle]){z-index:2}
.filepond--item-panel{background-color:#64605e}
[data-filepond-item-state=processing-complete] .filepond--item-panel{background-color:#369763}
[data-filepond-item-state*=error] .filepond--item-panel,[data-filepond-item-state*=invalid] .filepond--item-panel{background-color:#c44e47}
.filepond--item-panel{border-radius:.5em;transition:background-color .25s}
.filepond--list-scroller{position:absolute;top:0;left:0;right:0;margin:0;will-change:transform}
.filepond--list-scroller[data-state=overflow] .filepond--list{bottom:0;right:0}
.filepond--list-scroller[data-state=overflow]{overflow-y:scroll;overflow-x:hidden;-webkit-overflow-scrolling:touch;-webkit-mask:linear-gradient(180deg,#000 calc(100% - .5em),transparent);mask:linear-gradient(180deg,#000 calc(100% - .5em),transparent)}
.filepond--list-scroller::-webkit-scrollbar{background:transparent}
.filepond--list-scroller::-webkit-scrollbar:vertical{width:1em}
.filepond--list-scroller::-webkit-scrollbar:horizontal{height:0}
.filepond--list-scroller::-webkit-scrollbar-thumb{background-color:rgba(0,0,0,.3);border-radius:99999px;border:.3125em solid transparent;background-clip:content-box}
.filepond--list.filepond--list{position:absolute;top:0;margin:0;padding:0;list-style-type:none;will-change:transform}
.filepond--list{left:.75em;right:.75em}
.filepond--root[data-style-panel-layout~=integrated]{width:100%;height:100%;max-width:none;margin:0}
.filepond--root[data-style-panel-layout~=circle] .filepond--panel-root,.filepond--root[data-style-panel-layout~=integrated] .filepond--panel-root{border-radius:0}
.filepond--root[data-style-panel-layout~=circle] .filepond--panel-root>*,.filepond--root[data-style-panel-layout~=integrated] .filepond--panel-root>*{display:none}
.filepond--root[data-style-panel-layout~=circle] .filepond--drop-label,.filepond--root[data-style-panel-layout~=integrated] .filepond--drop-label{bottom:0;height:auto;display:flex;justify-content:center;align-items:center;z-index:7}
.filepond--root[data-style-panel-layout~=circle] .filepond--item-panel,.filepond--root[data-style-panel-layout~=integrated] .filepond--item-panel{display:none}
.filepond--root[data-style-panel-layout~=compact] .filepond--list-scroller,.filepond--root[data-style-panel-layout~=integrated] .filepond--list-scroller{overflow:hidden;height:100%;margin-top:0;margin-bottom:0}
.filepond--root[data-style-panel-layout~=compact] .filepond--list,.filepond--root[data-style-panel-layout~=integrated] .filepond--list{left:0;right:0;height:100%}
.filepond--root[data-style-panel-layout~=compact] .filepond--item,.filepond--root[data-style-panel-layout~=integrated] .filepond--item{margin:0}
.filepond--root[data-style-panel-layout~=compact] .filepond--file-wrapper,.filepond--root[data-style-panel-layout~=integrated] .filepond--file-wrapper{height:100%}
.filepond--root[data-style-panel-layout~=compact] .filepond--drop-label,.filepond--root[data-style-panel-layout~=integrated] .filepond--drop-label{z-index:7}
.filepond--root[data-style-panel-layout~=circle]{border-radius:99999rem;overflow:hidden}
.filepond--root[data-style-panel-layout~=circle]>.filepond--panel{border-radius:inherit}
.filepond--root[data-style-panel-layout~=circle]>.filepond--panel>*{display:none}
.filepond--root[data-style-panel-layout~=circle] .filepond--file-info,.filepond--root[data-style-panel-layout~=circle] .filepond--file-status{display:none}
.filepond--root[data-style-panel-layout~=circle] .filepond--action-edit-item{opacity:1!important;visibility:visible!important}
@media not all and (min-resolution:0.001dpcm){@supports (-webkit-appearance:none) and (stroke-color:transparent){.filepond--root[data-style-panel-layout~=circle]{will-change:transform}}}
.filepond--panel-root{border-radius:.5em;background-color:#f1f0ef}
.filepond--panel{position:absolute;left:0;top:0;right:0;margin:0;height:100%!important;pointer-events:none}
.filepond-panel:not([data-scalable=false]){height:auto!important}
.filepond--panel[data-scalable=false]>div{display:none}
.filepond--panel[data-scalable=true]{transform-style:preserve-3d;background-color:transparent!important;border:none!important}
.filepond--panel-bottom,.filepond--panel-center,.filepond--panel-top{position:absolute;left:0;top:0;right:0;margin:0;padding:0}
.filepond--panel-bottom,.filepond--panel-top{height:.5em}
.filepond--panel-top{border-bottom-left-radius:0!important;border-bottom-right-radius:0!important;border-bottom:none!important}
.filepond--panel-top:after{content:"";position:absolute;height:2px;left:0;right:0;bottom:-1px;background-color:inherit}
.filepond--panel-bottom,.filepond--panel-center{will-change:transform;backface-visibility:hidden;transform-origin:left top;transform:translate3d(0,.5em,0)}
.filepond--panel-bottom{border-top-left-radius:0!important;border-top-right-radius:0!important;border-top:none!important}
.filepond--panel-bottom:before{content:"";position:absolute;height:2px;left:0;right:0;top:-1px;background-color:inherit}
.filepond--panel-center{height:100px!important;border-top:none!important;border-bottom:none!important;border-radius:0!important}
.filepond--panel-center:not([style]){visibility:hidden}
.filepond--progress-indicator{position:static;width:1.25em;height:1.25em;color:#fff;margin:0;pointer-events:none;will-change:transform,opacity}
.filepond--progress-indicator svg{width:100%;height:100%;vertical-align:top;transform-box:fill-box}
.filepond--progress-indicator path{fill:none;stroke:currentColor}
.filepond--list-scroller{z-index:6}
.filepond--drop-label{z-index:5}
.filepond--drip{z-index:3}
.filepond--root>.filepond--panel{z-index:2}
.filepond--browser{z-index:1}
.filepond--root{box-sizing:border-box;position:relative;margin-bottom:1em;font-size:1rem;line-height:normal;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol;font-weight:450;text-align:left;text-rendering:optimizeLegibility;direction:ltr;contain:layout style size}
.filepond--root *{box-sizing:inherit;line-height:inherit}
.filepond--root :not(text){font-size:inherit}
.filepond--root[data-disabled]{pointer-events:none}
.filepond--root[data-disabled] .filepond--list-scroller{pointer-events:all}
.filepond--root[data-disabled] .filepond--list{pointer-events:none}
.filepond--root .filepond--drop-label{min-height:4.75em}
.filepond--root .filepond--list-scroller{margin-top:1em;margin-bottom:1em}
.filepond--root .filepond--credits{position:absolute;right:0;opacity:.4;line-height:.85;font-size:11px;color:inherit;text-decoration:none;z-index:3;bottom:-14px}
.filepond--root .filepond--credits[style]{top:0;bottom:auto;margin-top:14px}
/*!
 * FilePondPluginImagePreview 4.6.12
 * Licensed under MIT, https://opensource.org/licenses/MIT/
 * Please visit https://pqina.nl/filepond/ for details.
 */
/* eslint-disable */
.filepond--image-preview-markup{position:absolute;left:0;top:0}
.filepond--image-preview-wrapper{z-index:2}
.filepond--image-preview-overlay{display:block;position:absolute;left:0;top:0;width:100%;min-height:5rem;max-height:7rem;margin:0;opacity:0;z-index:2;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}
.filepond--image-preview-overlay svg{width:100%;height:auto;color:inherit;max-height:inherit}
.filepond--image-preview-overlay-idle{mix-blend-mode:multiply;color:rgba(40,40,40,.85)}
.filepond--image-preview-overlay-success{mix-blend-mode:normal;color:#369763}
.filepond--image-preview-overlay-failure{mix-blend-mode:normal;color:#c44e47}
@supports (-webkit-marquee-repetition:infinite) and ((-o-object-fit: fill) or (object-fit: fill)){.filepond--image-preview-overlay-idle{mix-blend-mode:normal}}
.filepond--image-preview-wrapper{-webkit-user-select:none;-moz-user-select:none;user-select:none;position:absolute;left:0;top:0;right:0;height:100%;margin:0;border-radius:.45em;overflow:hidden;background:rgba(0,0,0,.01)}
.filepond--image-preview{position:absolute;left:0;top:0;z-index:1;display:flex;align-items:center;height:100%;width:100%;pointer-events:none;background:#222;will-change:transform,opacity}
.filepond--image-clip{position:relative;overflow:hidden;margin:0 auto}
.filepond--image-clip[data-transparency-indicator=grid] canvas,.filepond--image-clip[data-transparency-indicator=grid] img{background-color:#fff;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg' fill='%23eee'%3E%3Cpath d='M0 0h50v50H0M50 50h50v50H50'/%3E%3C/svg%3E");background-size:1.25em 1.25em}
.filepond--image-bitmap,.filepond--image-vector{position:absolute;left:0;top:0;will-change:transform}
.filepond--root[data-style-panel-layout~=integrated] .filepond--image-preview-wrapper{border-radius:0}
.filepond--root[data-style-panel-layout~=integrated] .filepond--image-preview{height:100%;display:flex;justify-content:center;align-items:center}
.filepond--root[data-style-panel-layout~=circle] .filepond--image-preview-wrapper{border-radius:99999rem}
.filepond--root[data-style-panel-layout~=circle] .filepond--image-preview-overlay{top:auto;bottom:0;transform:scaleY(-1)}
.filepond--root[data-style-panel-layout~=circle] .filepond--file .filepond--file-action-button[data-align*=bottom]:not([data-align*=center]){margin-bottom:.325em}
.filepond--root[data-style-panel-layout~=circle] .filepond--file [data-align*=left]{left:calc(50% - 3em)}
.filepond--root[data-style-panel-layout~=circle] .filepond--file [data-align*=right]{right:calc(50% - 3em)}
.filepond--root[data-style-panel-layout~=circle] .filepond--progress-indicator[data-align*=bottom][data-align*=left],.filepond--root[data-style-panel-layout~=circle] .filepond--progress-indicator[data-align*=bottom][data-align*=right]{margin-bottom:.5125em}
.filepond--root[data-style-panel-layout~=circle] .filepond--progress-indicator[data-align*=bottom][data-align*=center]{margin-top:0;margin-bottom:.1875em;margin-left:.1875em}
/* Font Awesome - loaded via CDN in application.html.erb for better caching */
trix-editor {
  border: 1px solid #bbb;
  border-radius: 3px;
  margin: 0;
  padding: 0.4em 0.6em;
  min-height: 5em;
  outline: none;
}
trix-toolbar * {
  box-sizing: border-box;
}
trix-toolbar .trix-button-row {
  display: flex;
  flex-wrap: nowrap;
  justify-content: space-between;
  overflow-x: auto;
}
trix-toolbar .trix-button-group {
  display: flex;
  margin-bottom: 10px;
  border: 1px solid #bbb;
  border-top-color: #ccc;
  border-bottom-color: #888;
  border-radius: 3px;
}
trix-toolbar .trix-button-group:not(:first-child) {
  margin-left: 1.5vw;
}
@media (max-width: 768px) {
  trix-toolbar .trix-button-group:not(:first-child) {
    margin-left: 0;
  }
}
trix-toolbar .trix-button-group-spacer {
  flex-grow: 1;
}
@media (max-width: 768px) {
  trix-toolbar .trix-button-group-spacer {
    display: none;
  }
}
trix-toolbar .trix-button {
  position: relative;
  float: left;
  color: rgba(0, 0, 0, 0.6);
  font-size: 0.75em;
  font-weight: 600;
  white-space: nowrap;
  padding: 0 0.5em;
  margin: 0;
  outline: none;
  border: none;
  border-bottom: 1px solid #ddd;
  border-radius: 0;
  background: transparent;
}
trix-toolbar .trix-button:not(:first-child) {
  border-left: 1px solid #ccc;
}
trix-toolbar .trix-button.trix-active {
  background: #cbeefa;
  color: rgb(0, 0, 0);
}
trix-toolbar .trix-button:not(:disabled) {
  cursor: pointer;
}
trix-toolbar .trix-button:disabled {
  color: rgba(0, 0, 0, 0.125);
}
@media (max-width: 768px) {
  trix-toolbar .trix-button {
    letter-spacing: -0.01em;
    padding: 0 0.3em;
  }
}
trix-toolbar .trix-button--icon {
  font-size: inherit;
  width: 2.6em;
  height: 1.6em;
  max-width: calc(0.8em + 4vw);
  text-indent: -9999px;
}
@media (max-width: 768px) {
  trix-toolbar .trix-button--icon {
    height: 2em;
    max-width: calc(0.8em + 3.5vw);
  }
}
trix-toolbar .trix-button--icon::before {
  display: inline-block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0.6;
  content: "";
  background-position: center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media (max-width: 768px) {
  trix-toolbar .trix-button--icon::before {
    right: 6%;
    left: 6%;
  }
}
trix-toolbar .trix-button--icon.trix-active::before {
  opacity: 1;
}
trix-toolbar .trix-button--icon:disabled::before {
  opacity: 0.125;
}
trix-toolbar .trix-button--icon-attach::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M10.5%2018V7.5c0-2.25%203-2.25%203%200V18c0%204.125-6%204.125-6%200V7.5c0-6.375%209-6.375%209%200V18%22%20stroke%3D%22%23000%22%20stroke-width%3D%222%22%20stroke-miterlimit%3D%2210%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%2F%3E%3C%2Fsvg%3E");
  top: 8%;
  bottom: 4%;
}
trix-toolbar .trix-button--icon-bold::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M6.522%2019.242a.5.5%200%200%201-.5-.5V5.35a.5.5%200%200%201%20.5-.5h5.783c1.347%200%202.46.345%203.24.982.783.64%201.216%201.562%201.216%202.683%200%201.13-.587%202.129-1.476%202.71a.35.35%200%200%200%20.049.613c1.259.56%202.101%201.742%202.101%203.22%200%201.282-.483%202.334-1.363%203.063-.876.726-2.132%201.12-3.66%201.12h-5.89ZM9.27%207.347v3.362h1.97c.766%200%201.347-.17%201.733-.464.38-.291.587-.716.587-1.27%200-.53-.183-.928-.513-1.198-.334-.273-.838-.43-1.505-.43H9.27Zm0%205.606v3.791h2.389c.832%200%201.448-.177%201.853-.497.399-.315.614-.786.614-1.423%200-.62-.22-1.077-.63-1.385-.418-.313-1.053-.486-1.905-.486H9.27Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-italic::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M9%205h6.5v2h-2.23l-2.31%2010H13v2H6v-2h2.461l2.306-10H9V5Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-link::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M18.948%205.258a4.337%204.337%200%200%200-6.108%200L11.217%206.87a.993.993%200%200%200%200%201.41c.392.39%201.027.39%201.418%200l1.623-1.613a2.323%202.323%200%200%201%203.271%200%202.29%202.29%200%200%201%200%203.251l-2.393%202.38a3.021%203.021%200%200%201-4.255%200l-.05-.049a1.007%201.007%200%200%200-1.418%200%20.993.993%200%200%200%200%201.41l.05.049a5.036%205.036%200%200%200%207.091%200l2.394-2.38a4.275%204.275%200%200%200%200-6.072Zm-13.683%2013.6a4.337%204.337%200%200%200%206.108%200l1.262-1.255a.993.993%200%200%200%200-1.41%201.007%201.007%200%200%200-1.418%200L9.954%2017.45a2.323%202.323%200%200%201-3.27%200%202.29%202.29%200%200%201%200-3.251l2.344-2.331a2.579%202.579%200%200%201%203.631%200c.392.39%201.027.39%201.419%200a.993.993%200%200%200%200-1.41%204.593%204.593%200%200%200-6.468%200l-2.345%202.33a4.275%204.275%200%200%200%200%206.072Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-strike::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M6%2014.986c.088%202.647%202.246%204.258%205.635%204.258%203.496%200%205.713-1.728%205.713-4.463%200-.275-.02-.536-.062-.781h-3.461c.398.293.573.654.573%201.123%200%201.035-1.074%201.787-2.646%201.787-1.563%200-2.773-.762-2.91-1.924H6ZM6.432%2010h3.763c-.632-.314-.914-.715-.914-1.273%200-1.045.977-1.739%202.432-1.739%201.475%200%202.52.723%202.617%201.914h2.764c-.05-2.548-2.11-4.238-5.39-4.238-3.145%200-5.392%201.719-5.392%204.316%200%20.363.04.703.12%201.02ZM4%2011a1%201%200%201%200%200%202h15a1%201%200%201%200%200-2H4Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-quote::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M4.581%208.471c.44-.5%201.056-.834%201.758-.995C8.074%207.17%209.201%207.822%2010%208.752c1.354%201.578%201.33%203.555.394%205.277-.941%201.731-2.788%203.163-4.988%203.56a.622.622%200%200%201-.653-.317c-.113-.205-.121-.49.16-.764.294-.286.567-.566.791-.835.222-.266.413-.54.524-.815.113-.28.156-.597.026-.908-.128-.303-.39-.524-.72-.69a3.02%203.02%200%200%201-1.674-2.7c0-.905.283-1.59.72-2.088Zm9.419%200c.44-.5%201.055-.834%201.758-.995%201.734-.306%202.862.346%203.66%201.276%201.355%201.578%201.33%203.555.395%205.277-.941%201.731-2.789%203.163-4.988%203.56a.622.622%200%200%201-.653-.317c-.113-.205-.122-.49.16-.764.294-.286.567-.566.791-.835.222-.266.412-.54.523-.815.114-.28.157-.597.026-.908-.127-.303-.39-.524-.72-.69a3.02%203.02%200%200%201-1.672-2.701c0-.905.283-1.59.72-2.088Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-heading-1::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M21.5%207.5v-3h-12v3H14v13h3v-13h4.5ZM9%2013.5h3.5v-3h-10v3H6v7h3v-7Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-code::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3.293%2011.293a1%201%200%200%200%200%201.414l4%204a1%201%200%201%200%201.414-1.414L5.414%2012l3.293-3.293a1%201%200%200%200-1.414-1.414l-4%204Zm13.414%205.414%204-4a1%201%200%200%200%200-1.414l-4-4a1%201%200%201%200-1.414%201.414L18.586%2012l-3.293%203.293a1%201%200%200%200%201.414%201.414Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-bullet-list::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%207.5a1.5%201.5%200%201%200%200-3%201.5%201.5%200%200%200%200%203ZM8%206a1%201%200%200%201%201-1h11a1%201%200%201%201%200%202H9a1%201%200%200%201-1-1Zm1%205a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm0%206a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm-2.5-5a1.5%201.5%200%201%201-3%200%201.5%201.5%200%200%201%203%200ZM5%2019.5a1.5%201.5%200%201%200%200-3%201.5%201.5%200%200%200%200%203Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-number-list::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3%204h2v4H4V5H3V4Zm5%202a1%201%200%200%201%201-1h11a1%201%200%201%201%200%202H9a1%201%200%200%201-1-1Zm1%205a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm0%206a1%201%200%201%200%200%202h11a1%201%200%201%200%200-2H9Zm-3.5-7H6v1l-1.5%202H6v1H3v-1l1.667-2H3v-1h2.5ZM3%2017v-1h3v4H3v-1h2v-.5H4v-1h1V17H3Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-undo::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M3%2014a1%201%200%200%200%201%201h6a1%201%200%201%200%200-2H6.257c2.247-2.764%205.151-3.668%207.579-3.264%202.589.432%204.739%202.356%205.174%205.405a1%201%200%200%200%201.98-.283c-.564-3.95-3.415-6.526-6.825-7.095C11.084%207.25%207.63%208.377%205%2011.39V8a1%201%200%200%200-2%200v6Zm2-1Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-redo::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M21%2014a1%201%200%200%201-1%201h-6a1%201%200%201%201%200-2h3.743c-2.247-2.764-5.151-3.668-7.579-3.264-2.589.432-4.739%202.356-5.174%205.405a1%201%200%200%201-1.98-.283c.564-3.95%203.415-6.526%206.826-7.095%203.08-.513%206.534.614%209.164%203.626V8a1%201%200%201%201%202%200v6Zm-2-1Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-decrease-nesting-level::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%206a1%201%200%200%201%201-1h12a1%201%200%201%201%200%202H6a1%201%200%200%201-1-1Zm4%205a1%201%200%201%200%200%202h9a1%201%200%201%200%200-2H9Zm-3%206a1%201%200%201%200%200%202h12a1%201%200%201%200%200-2H6Zm-3.707-5.707a1%201%200%200%200%200%201.414l2%202a1%201%200%201%200%201.414-1.414L4.414%2012l1.293-1.293a1%201%200%200%200-1.414-1.414l-2%202Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-button--icon-increase-nesting-level::before {
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M5%206a1%201%200%200%201%201-1h12a1%201%200%201%201%200%202H6a1%201%200%200%201-1-1Zm4%205a1%201%200%201%200%200%202h9a1%201%200%201%200%200-2H9Zm-3%206a1%201%200%201%200%200%202h12a1%201%200%201%200%200-2H6Zm-2.293-2.293%202-2a1%201%200%200%200%200-1.414l-2-2a1%201%200%201%200-1.414%201.414L3.586%2012l-1.293%201.293a1%201%200%201%200%201.414%201.414Z%22%20fill%3D%22%23000%22%2F%3E%3C%2Fsvg%3E");
}
trix-toolbar .trix-dialogs {
  position: relative;
}
trix-toolbar .trix-dialog {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  font-size: 0.75em;
  padding: 15px 10px;
  background: #fff;
  box-shadow: 0 0.3em 1em #ccc;
  border-top: 2px solid #888;
  border-radius: 5px;
  z-index: 5;
}
trix-toolbar .trix-input--dialog {
  font-size: inherit;
  font-weight: normal;
  padding: 0.5em 0.8em;
  margin: 0 10px 0 0;
  border-radius: 3px;
  border: 1px solid #bbb;
  background-color: #fff;
  box-shadow: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
trix-toolbar .trix-input--dialog.validate:invalid {
  box-shadow: #F00 0px 0px 1.5px 1px;
}
trix-toolbar .trix-button--dialog {
  font-size: inherit;
  padding: 0.5em;
  border-bottom: none;
}
trix-toolbar .trix-dialog--link {
  max-width: 600px;
}
trix-toolbar .trix-dialog__link-fields {
  display: flex;
  align-items: baseline;
}
trix-toolbar .trix-dialog__link-fields .trix-input {
  flex: 1;
}
trix-toolbar .trix-dialog__link-fields .trix-button-group {
  flex: 0 0 content;
  margin: 0;
}
trix-editor [data-trix-mutable]:not(.attachment__caption-editor) {
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
trix-editor [data-trix-mutable] ::-moz-selection, trix-editor [data-trix-mutable]::-moz-selection,
trix-editor [data-trix-cursor-target]::-moz-selection {
  background: none;
}
trix-editor [data-trix-mutable] ::-moz-selection, trix-editor [data-trix-mutable]::-moz-selection, trix-editor [data-trix-cursor-target]::-moz-selection {
  background: none;
}
trix-editor [data-trix-mutable] ::selection, trix-editor [data-trix-mutable]::selection,
trix-editor [data-trix-cursor-target]::selection {
  background: none;
}
trix-editor [data-trix-mutable].attachment__caption-editor:focus::-moz-selection {
  background: highlight;
}
trix-editor [data-trix-mutable].attachment__caption-editor:focus::selection {
  background: highlight;
}
trix-editor [data-trix-mutable].attachment.attachment--file {
  box-shadow: 0 0 0 2px highlight;
  border-color: transparent;
}
trix-editor [data-trix-mutable].attachment img {
  box-shadow: 0 0 0 2px highlight;
}
trix-editor .attachment {
  position: relative;
}
trix-editor .attachment:hover {
  cursor: default;
}
trix-editor .attachment--preview .attachment__caption:hover {
  cursor: text;
}
trix-editor .attachment__progress {
  position: absolute;
  z-index: 1;
  height: 20px;
  top: calc(50% - 10px);
  left: 5%;
  width: 90%;
  opacity: 0.9;
  transition: opacity 200ms ease-in;
}
trix-editor .attachment__progress[value="100"] {
  opacity: 0;
}
trix-editor .attachment__caption-editor {
  display: inline-block;
  width: 100%;
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-family: inherit;
  line-height: inherit;
  color: inherit;
  text-align: center;
  vertical-align: top;
  border: none;
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}
trix-editor .attachment__toolbar {
  position: absolute;
  z-index: 1;
  top: -0.9em;
  left: 0;
  width: 100%;
  text-align: center;
}
trix-editor .trix-button-group {
  display: inline-flex;
}
trix-editor .trix-button {
  position: relative;
  float: left;
  color: #666;
  white-space: nowrap;
  font-size: 80%;
  padding: 0 0.8em;
  margin: 0;
  outline: none;
  border: none;
  border-radius: 0;
  background: transparent;
}
trix-editor .trix-button:not(:first-child) {
  border-left: 1px solid #ccc;
}
trix-editor .trix-button.trix-active {
  background: #cbeefa;
}
trix-editor .trix-button:not(:disabled) {
  cursor: pointer;
}
trix-editor .trix-button--remove {
  text-indent: -9999px;
  display: inline-block;
  padding: 0;
  outline: none;
  width: 1.8em;
  height: 1.8em;
  line-height: 1.8em;
  border-radius: 50%;
  background-color: #fff;
  border: 2px solid highlight;
  box-shadow: 1px 1px 6px rgba(0, 0, 0, 0.25);
}
trix-editor .trix-button--remove::before {
  display: inline-block;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  opacity: 0.7;
  content: "";
  background-image: url("data:image/svg+xml,%3Csvg%20height%3D%2224%22%20width%3D%2224%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M19%206.41%2017.59%205%2012%2010.59%206.41%205%205%206.41%2010.59%2012%205%2017.59%206.41%2019%2012%2013.41%2017.59%2019%2019%2017.59%2013.41%2012z%22%2F%3E%3Cpath%20d%3D%22M0%200h24v24H0z%22%20fill%3D%22none%22%2F%3E%3C%2Fsvg%3E");
  background-position: center;
  background-repeat: no-repeat;
  background-size: 90%;
}
trix-editor .trix-button--remove:hover {
  border-color: #333;
}
trix-editor .trix-button--remove:hover::before {
  opacity: 1;
}
trix-editor .attachment__metadata-container {
  position: relative;
}
trix-editor .attachment__metadata {
  position: absolute;
  left: 50%;
  top: 2em;
  transform: translate(-50%, 0);
  max-width: 90%;
  padding: 0.1em 0.6em;
  font-size: 0.8em;
  color: #fff;
  background-color: rgba(0, 0, 0, 0.7);
  border-radius: 3px;
}
trix-editor .attachment__metadata .attachment__name {
  display: inline-block;
  max-width: 100%;
  vertical-align: bottom;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
trix-editor .attachment__metadata .attachment__size {
  margin-left: 0.2em;
  white-space: nowrap;
}
.trix-content {
  line-height: 1.5;
  overflow-wrap: break-word;
  word-break: break-word;
}
.trix-content * {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
.trix-content h1 {
  font-size: 1.2em;
  line-height: 1.2;
}
.trix-content blockquote {
  border: 0 solid #ccc;
  border-left-width: 0.3em;
  margin-left: 0.3em;
  padding-left: 0.6em;
}
.trix-content [dir=rtl] blockquote,
.trix-content blockquote[dir=rtl] {
  border-width: 0;
  border-right-width: 0.3em;
  margin-right: 0.3em;
  padding-right: 0.6em;
}
.trix-content li {
  margin-left: 1em;
}
.trix-content [dir=rtl] li {
  margin-right: 1em;
}
.trix-content pre {
  display: inline-block;
  width: 100%;
  vertical-align: top;
  font-family: monospace;
  font-size: 0.9em;
  padding: 0.5em;
  white-space: pre;
  background-color: #eee;
  overflow-x: auto;
}
.trix-content img {
  max-width: 100%;
  height: auto;
}
.trix-content .attachment {
  display: inline-block;
  position: relative;
  max-width: 100%;
}
.trix-content .attachment a {
  color: inherit;
  text-decoration: none;
}
.trix-content .attachment a:hover, .trix-content .attachment a:visited:hover {
  color: inherit;
}
.trix-content .attachment__caption {
  text-align: center;
}
.trix-content .attachment__caption .attachment__name + .attachment__size::before {
  content: " •";
}
.trix-content .attachment--preview {
  width: 100%;
  text-align: center;
}
.trix-content .attachment--preview .attachment__caption {
  color: #666;
  font-size: 0.9em;
  line-height: 1.2;
}
.trix-content .attachment--file {
  color: #333;
  line-height: 1;
  margin: 0 2px 2px 2px;
  padding: 0.4em 1em;
  border: 1px solid #bbb;
  border-radius: 5px;
}
.trix-content .attachment-gallery {
  display: flex;
  flex-wrap: wrap;
  position: relative;
}
.trix-content .attachment-gallery .attachment {
  flex: 1 0 33%;
  padding: 0 0.5em;
  max-width: 33%;
}
.trix-content .attachment-gallery.attachment-gallery--2 .attachment, .trix-content .attachment-gallery.attachment-gallery--4 .attachment {
  flex-basis: 50%;
  max-width: 50%;
}
/* ==========================================================================
   3. Base (overrides vendors)
   ========================================================================== */
/* ========================================================================== */
/* Variables - Design Tokens */
/* ========================================================================== */
/* NOTA: Bootstrap 5 ya provee breakpoints ($grid-breakpoints) */
/* Usamos Bootstrap para responsive: sm, md, lg, xl, xxl */
:root {
  /* ======================================== */
  /* Colores Primarios (Brand) */
  /* ======================================== */
  --primary-color: #32b768;
  --secondary-color: #007aff;
  --danger-color: #ff3b30;
  --warning-color: #ff9500;
  --success-color: #34c759;

  /* ======================================== */
  /* Escala de Grises */
  /* ======================================== */
  --gray-50: #f9fafb;
  --gray-100: #f3f4f6;
  --gray-200: #e5e7eb;
  --gray-300: #d1d5db;
  --gray-400: #9ca3af;
  --gray-500: #6b7280;
  --gray-600: #4b5563;
  --gray-700: #374151;
  --gray-800: #1f2937;
  --gray-900: #111827;

  /* ======================================== */
  /* Shadows */
  /* ======================================== */
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  --shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
  --shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
  --shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);

  /* ======================================== */
  /* Border Radius */
  /* ======================================== */
  --border-radius-sm: 8px;
  --border-radius-md: 12px;
  --border-radius-lg: 16px;
  --border-radius-xl: 20px;

  /* ======================================== */
  /* Transiciones */
  /* ======================================== */
  --transition: all 0.3s ease;

  /* ======================================== */
  /* Dark Theme (Chat) */
  /* ======================================== */
  --dark-bg: #1a1a1a;
  --dark-surface: #2a2a2a;
  --dark-border: #3a3a3a;
  --dark-text: #f2f2f7;
  --dark-muted: #888888;
  --dark-accent: #32b768;
  --dark-accent-hover: #2a9d5a;

  /* ======================================== */
  /* Store Theme - Defaults (verde) */
  /* Para futura personalización por tienda */
  /* ======================================== */
  --store-primary: var(--primary-color);
  --store-accent: var(--success-color);
  --store-price: var(--primary-color);
  --store-title: var(--gray-800);
  --store-badge-bg: linear-gradient(135deg, var(--primary-color), var(--success-color));
  --store-badge-text: white;
}
/* ======================================== */
/* Store Themes - Color Variants */
/* ======================================== */
/* Theme Azul */
[data-store-theme="blue"] {
  --store-primary: #3b82f6;
  --store-accent: #60a5fa;
  --store-price: #2563eb;
  --store-badge-bg: linear-gradient(135deg, #3b82f6, #60a5fa);
}
/* Theme Rojo */
[data-store-theme="red"] {
  --store-primary: #ef4444;
  --store-accent: #f87171;
  --store-price: #dc2626;
  --store-badge-bg: linear-gradient(135deg, #ef4444, #f87171);
}
/* Theme Morado */
[data-store-theme="purple"] {
  --store-primary: #8b5cf6;
  --store-accent: #a78bfa;
  --store-price: #7c3aed;
  --store-badge-bg: linear-gradient(135deg, #8b5cf6, #a78bfa);
}
/* Theme Naranja */
[data-store-theme="orange"] {
  --store-primary: #f97316;
  --store-accent: #fb923c;
  --store-price: #ea580c;
  --store-badge-bg: linear-gradient(135deg, #f97316, #fb923c);
}
/* ========================================================================== */
/* Reset - Estilos base de elementos HTML */
/* ========================================================================== */
a {
  background-color: transparent;
  text-decoration: none !important;
  outline: none !important;
}
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
img {
  max-width: 100%;
}
/* ======================================== */
/* Placeholder global */
/* ======================================== */
input::-moz-placeholder, textarea::-moz-placeholder, .form-control::-moz-placeholder {
  color: #adb5bd;
  font-style: italic;
  font-size: 0.875rem;
}
input::placeholder,
textarea::placeholder,
.form-control::placeholder {
  color: #adb5bd;
  font-style: italic;
  font-size: 0.875rem;
}
/* ========================================================================== */
/* Typography - Estilos de tipografía global */
/* ========================================================================== */
/* ======================================== */
/* Clases de título personalizadas */
/* ======================================== */
.h1-title {
  font-size: 90px;
  line-height: 108px;
  text-transform: capitalize;
  margin-bottom: 25px;
  font-weight: 900;
}
.h1-title span {
    color: var(--primary-color);
    background-image: linear-gradient(0deg, rgb(13 13 37 / 8%), rgb(13 13 37 / 8%));
    background-size: 100% 15px;
    background-position: 0 90%;
    background-repeat: no-repeat;
    display: inline;
    transition: var(--transition);
    font-family: Poppins, sans-serif !important;
    font-weight: 700;
  }
.h2-title {
  font-size: 46px;
  line-height: 56px;
  margin-bottom: 15px;
  text-transform: capitalize;
  position: relative;
}
.h2-title span {
    display: block;
  }
.h4-title {
  font-size: 26px;
  line-height: 36px;
}
.h5-title {
  font-size: 18px;
  line-height: 28px;
  font-weight: 600;
}
/* ======================================== */
/* Responsive Typography */
/* ======================================== */
@media (max-width: 1399px) {
  .h1-title {
    font-size: 80px;
    line-height: 90px;
  }

  .h4-title {
    font-size: 24px;
    line-height: 34px;
  }

  .h2-title {
    font-size: 38px;
    line-height: 48px;
  }
}
@media (max-width: 991px) {
  .h1-title {
    font-size: 60px;
    line-height: 80px;
  }
}
@media (max-width: 575px) {
  .h1-title {
    font-size: 40px;
    line-height: 60px;
    margin-bottom: 20px;
  }

    .h1-title span {
      background-size: 100% 8px;
    }
}
/* ========================================================================== */
/* Utilities - Clases de utilidad compartidas */
/* ========================================================================== */
/* ======================================== */
/* Colores */
/* ======================================== */
.color-green {
  color: var(--primary-color) !important;
}
.bg-color-green {
  background-color: var(--primary-color) !important;
}
/* ======================================== */
/* Contenedores y secciones */
/* ======================================== */
.sec-wp {
  position: relative;
  z-index: 4;
}
.section {
  padding-top: 100px;
  padding-bottom: 100px;
  position: relative;
}
.sec-sub-title {
  text-transform: uppercase;
  display: inline-block;
  background: var(--gray-50);
  box-shadow: 9px 9px 12px #e4e4e4, -9px -9px 12px #ffffff;
  padding: 3px 20px;
  border-radius: 60px;
  color: var(--primary-color);
  font-size: 14px;
}
/* ======================================== */
/* Imágenes de fondo */
/* ======================================== */
.back-img {
  background-position: center;
  background-size: cover;
}
.repeat-img {
  background-size: contain;
  background-repeat: repeat;
}
/* ======================================== */
/* Logo */
/* ======================================== */
.gf-logo {
  color: #4dbe3b;
}
/* ======================================== */
/* Responsive Utilities */
/* ======================================== */
@media (max-width: 400px) {
  .section {
    padding-top: 60px;
    padding-bottom: 60px;
  }
}
/* ======================================== */
/* Empty states */
/* ======================================== */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 3rem 1.5rem;
}
.empty-state-icon {
  font-size: 3rem;
  margin-bottom: 1rem;
  opacity: 0.6;
}
.empty-state-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 0.5rem;
}
.empty-state-description {
  color: var(--gray-500);
  font-size: 0.875rem;
  max-width: 280px;
}
/* ==========================================================================
   4. Components
   ========================================================================== */
/* ========================================================================== */
/* Buttons - Estilos de botones compartidos */
/* ========================================================================== */
/* ======================================== */
/* Botón principal (sec-btn) */
/* ======================================== */
.sec-btn {
  background-color: var(--primary-color);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 30px;
  color: #fff;
  text-transform: capitalize;
  text-align: center;
  border: none;
  cursor: pointer;
  outline: none !important;
  transition: var(--transition);
  overflow: hidden;
  position: relative;
  z-index: 2;
  padding: 6px 15px;
  margin-right: 10px;
}
.sec-btn:hover {
    border-color: var(--gray-900);
    box-shadow: var(--shadow-md);
  }
/* ======================================== */
/* Botones de acción (dashboard) */
/* ======================================== */
.btn-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 12px;
  border-radius: var(--border-radius-sm);
  font-size: 13px;
  font-weight: 500;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
}
.btn-action:hover {
    transform: translateY(-1px);
  }
.btn-edit {
  background-color: #e3f2fd;
  color: #1976d2;
}
.btn-edit:hover {
    background-color: #bbdefb;
    color: #1565c0;
  }
.btn-delete {
  background-color: #ffebee;
  color: #d32f2f;
}
.btn-delete:hover {
    background-color: #ffcdd2;
    color: #c62828;
  }
.btn-create {
  background-color: #e8f5e9;
  color: #388e3c;
}
.btn-create:hover {
    background-color: #c8e6c9;
    color: #2e7d32;
  }
.btn-view {
  background-color: var(--gray-100);
  color: var(--gray-700);
}
.btn-view:hover {
    background-color: var(--gray-200);
    color: var(--gray-800);
  }
/* ======================================== */
/* Botones dashboard (primario/secundario) */
/* ======================================== */
.btn-dashboard {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25rem;
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 500;
  border-radius: 6px;
  border: none;
  cursor: pointer;
  transition: all 0.2s ease;
  white-space: nowrap;
}
.btn-primary-dashboard {
  background: var(--primary-color);
  color: #fff;
  font-weight: 400;
}
.btn-primary-dashboard:hover {
    background: #2a9d5a;
    transform: translateY(-1px);
    box-shadow: 0 4px 12px rgba(50, 183, 104, 0.3);
    color: #fff;
  }
.btn-primary-dashboard:active {
    transform: translateY(0);
  }
.btn-secondary-dashboard {
  background: var(--gray-100);
  color: var(--gray-700);
  border: 1px solid var(--gray-300);
}
.btn-secondary-dashboard:hover {
    background: var(--gray-200);
    border-color: var(--gray-400);
  }
/* ======================================== */
/* Botón header action (secundario) */
/* ======================================== */
.btn-header-action {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
  font-weight: 400;
  border-radius: 6px;
  text-decoration: none;
  transition: all 0.2s ease;
  white-space: nowrap;
  background: #fff;
  color: #374151;
  border: 1px solid #d1d5db;
}
.btn-header-action:hover {
    background: #f9fafb;
    border-color: #9ca3af;
    color: #1f2937;
  }
.btn-header-action i {
    font-size: 0.75rem;
    color: #6b7280;
  }
/* ======================================== */
/* Botones de acción en tablas */
/* ======================================== */
.table-action-btn {
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-weight: 500;
  font-size: 0.7rem;
  font-family: 'Poppins', sans-serif;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s ease;
  min-width: auto;
  border: 1px solid transparent;
}
.table-action-btn.btn-edit {
    background: #e3f2fd;
    color: #1976d2;
    border-color: #bbdefb;
  }
.table-action-btn.btn-edit:hover {
      background: #bbdefb;
      color: #0d47a1;
      transform: translateY(-1px);
      box-shadow: 0 2px 4px rgba(25, 118, 210, 0.2);
    }
.table-action-btn.btn-archive,.table-action-btn.btn-delete {
    background: #ffebee;
    color: #d32f2f;
    border-color: #ffcdd2;
  }
:is(.table-action-btn.btn-archive,.table-action-btn.btn-delete):hover {
      background: #ffcdd2;
      color: #b71c1c;
      transform: translateY(-1px);
      box-shadow: 0 2px 4px rgba(211, 47, 47, 0.2);
    }
.table-action-btn.btn-create {
    background: #e8f5e9;
    color: #388e3c;
    border-color: #c8e6c9;
  }
.table-action-btn.btn-create:hover {
      background: #c8e6c9;
      color: #2e7d32;
      transform: translateY(-1px);
      box-shadow: 0 2px 4px rgba(56, 142, 60, 0.2);
    }
/* ======================================== */
/* Mini action button (iconos pequeños) */
/* ======================================== */
.mini-action-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 4px;
  text-decoration: none;
  transition: all 0.15s ease;
  font-size: 0.875rem;
}
.mini-action-btn.btn-edit {
    background: #e3f2fd;
    color: #1976d2;
  }
.mini-action-btn.btn-edit:hover {
      background: #bbdefb;
    }
.mini-action-btn.btn-delete {
    background: #ffebee;
    color: #d32f2f;
  }
.mini-action-btn.btn-delete:hover {
      background: #ffcdd2;
    }
.mini-action-btn.btn-view {
    background: var(--gray-100);
    color: var(--gray-600);
  }
.mini-action-btn.btn-view:hover {
      background: var(--gray-200);
    }
/* ======================================== */
/* Botón de éxito/enviado (deshabilitado) */
/* ======================================== */
.btn-success-sent {
  background: var(--gray-100) !important;
  color: var(--gray-500) !important;
  border: 1px solid var(--gray-200) !important;
  cursor: not-allowed;
}
.btn-success-sent:disabled {
    opacity: 0.8;
  }
/* ======================================== */
/* Botón mostrar más (show more) */
/* ======================================== */
.load-more-store {
  display: flex;
  justify-content: center;
  padding: 1.5rem 0 2rem;
}
.load-more-store a {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1.25rem;
    font-size: 0.8125rem;
    font-weight: 400;
    color: #374151;
    background: #fff;
    border: 1px solid #d1d5db;
    border-radius: 25px;
    text-decoration: none;
    transition: all 0.2s ease;
  }
:is(.load-more-store a):hover {
      background: #f9fafb;
      border-color: #9ca3af;
      color: #1f2937;
    }
/* ======================================== */
/* Responsive */
/* ======================================== */
@media (max-width: 576px) {
  .btn-dashboard {
    width: 100%;
    justify-content: center;
  }

  .load-more-store {
    padding: 1rem 1rem 1.5rem;
  }

  .load-more-store a {
    width: 100%;
    justify-content: center;
  }
}
/* ======================================== */
/* Store Action Buttons (Enlaces sociales) */
/* ======================================== */
.store-action-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 500;
  font-family: 'Poppins', sans-serif;
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s ease;
  border: none;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.store-action-btn i {
    font-size: 18px;
  }
.store-action-btn:hover {
    transform: translateY(-2px);
    text-decoration: none;
  }
.store-action-btn:active {
    transform: translateY(0);
  }
/* Variante: Primary (Cómo llegar - Maps) - Solo este botón es de color sólido */
.store-action-btn--primary {
  background: var(--primary-color);
  color: white;
  box-shadow: 0 2px 8px rgba(50, 183, 104, 0.2);
}
.store-action-btn--primary:hover {
    background: #2a9d5a;
    color: white;
    box-shadow: 0 4px 12px rgba(50, 183, 104, 0.3);
  }
.store-action-btn--primary i {
    color: white;
  }
/* Variante: WhatsApp - Outline con icono verde */
.store-action-btn--whatsapp {
  background: white;
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
}
.store-action-btn--whatsapp:hover {
    background: #f0fdf4;
    border-color: #25D366;
    color: var(--gray-800);
  }
.store-action-btn--whatsapp i {
    color: #25D366;
  }
/* Variante: Instagram - Outline con icono rosa/gradiente */
.store-action-btn--instagram {
  background: white;
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
}
.store-action-btn--instagram:hover {
    background: #fdf2f8;
    border-color: #E1306C;
    color: var(--gray-800);
  }
.store-action-btn--instagram i {
    background: linear-gradient(45deg, #f09433, #e6683c, #dc2743, #cc2366, #bc1888);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
  }
/* Variante: Website - Outline con icono gris */
.store-action-btn--website {
  background: white;
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
}
.store-action-btn--website:hover {
    background: var(--gray-50);
    border-color: var(--gray-400);
    color: var(--gray-800);
  }
.store-action-btn--website i {
    color: var(--gray-500);
  }
/* Variante: Call/Phone - Outline con icono azul */
.store-action-btn--phone {
  background: white;
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
}
.store-action-btn--phone:hover {
    background: #eff6ff;
    border-color: #007AFF;
    color: var(--gray-800);
  }
.store-action-btn--phone i {
    color: #007AFF;
  }
/* Container para los botones */
.store-actions-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
/* ========================================================================== */
/* Tables - Estilos de tablas compartidos (dashboard) */
/* ========================================================================== */
/* ======================================== */
/* Tabla base del dashboard */
/* ======================================== */
.table-dashboard {
  font-family: 'Poppins', sans-serif;
  table-layout: fixed;
  width: 100%;
}
.table-dashboard thead th {
    font-weight: 500;
    color: var(--gray-700);
    font-size: 0.75rem;
    background-color: var(--gray-50);
    border-bottom: 2px solid var(--gray-200);
    border-top: none;
    padding: 0.75rem 1rem;
    white-space: nowrap;
  }
/* Tabla de productos - min-width para scroll horizontal en móvil */
.table-dashboard.table-products {
    min-width: 700px;
  }
/* Tabla de secciones - min-width para scroll horizontal en móvil */
.table-dashboard.table-sections {
    min-width: 600px;
  }
.table-dashboard tbody td {
    font-size: 0.8rem;
    color: var(--gray-700);
    padding: 0.75rem 1rem;
    vertical-align: middle;
    border-bottom: 1px solid #f1f3f4;
    border-top: none;
  }
.table-dashboard tbody tr {
    transition: background-color 0.15s ease;
    background-color: #fff;
  }
:is(.table-dashboard tbody tr):hover {
      background-color: var(--gray-50);
    }
:is(.table-dashboard tbody tr):last-child td {
      border-bottom: none;
    }
/* ======================================== */
/* Card header para secciones de tabla */
/* ======================================== */
.card .card-header h3 {
  font-family: 'Poppins', sans-serif;
  font-weight: 400;
  font-size: 1.125rem;
  color: var(--gray-700);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin: 0;
}
/* ======================================== */
/* Thumbnail en tablas */
/* ======================================== */
.table-thumbnail {
  width: 48px;
  height: 48px;
  min-width: 48px;
  max-width: 48px;
  min-height: 48px;
  max-height: 48px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
  transition: transform 0.2s ease;
  flex-shrink: 0;
}
/* ======================================== */
/* Tabla dentro de dashboard-card */
/* ======================================== */
.dashboard-card .table-dashboard {
  margin: 0;
}
.dashboard-card .table-dashboard thead th:first-child {
  padding-left: 1.25rem;
}
.dashboard-card .table-dashboard tbody td:first-child {
  padding-left: 1.25rem;
}
.dashboard-card .table-dashboard thead th:last-child {
  padding-right: 1.25rem;
}
.dashboard-card .table-dashboard tbody td:last-child {
  padding-right: 1.25rem;
}
/* ======================================== */
/* Error de toggle inline */
/* ======================================== */
.toggle-error {
  display: block;
  font-size: 0.7rem;
  color: #dc3545;
  margin-top: 0.25rem;
  animation: fadeIn 0.2s ease;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-4px); }
  to { opacity: 1; transform: translateY(0); }
}
/* ======================================== */
/* Precio con descuento en tablas */
/* ======================================== */
.price-with-discount {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}
.price-original {
  font-size: 0.7rem;
  color: var(--gray-500);
  text-decoration: line-through;
}
.price-discounted {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--primary-color);
}
.price-regular {
  font-size: 0.875rem;
  font-weight: 300;
  color: var(--gray-800);
}
.discount-badge-product{
  display: inline-block;
  padding: 0.125rem 0.375rem;
  font-size: 0.65rem;
  font-weight: 500;
  color: #d97706;
  background-color: #fef3c7;
  border-radius: 4px;
}
.discount-days {
  font-size: 0.65rem;
  color: var(--gray-500);
  margin-top: 0.125rem;
}
/* ========================================================================== */
/* Badges - Etiquetas y badges compartidos */
/* ========================================================================== */
/* ======================================== */
/* Badge base */
/* ======================================== */
.badge-custom {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.5rem;
  border-radius: 4px;
  font-size: 0.7rem;
  font-weight: 500;
  font-family: 'Poppins', sans-serif;
}
/* ======================================== */
/* Badges de estado */
/* ======================================== */
.badge-active {
  background-color: #e8f5e9;
  color: #388e3c;
}
.badge-inactive {
  background-color: #f5f5f5;
  color: #757575;
}
.badge-pending {
  background-color: #fff3e0;
  color: #f57c00;
}
.badge-success {
  background-color: #e8f5e9;
  color: #388e3c;
}
.badge-warning {
  background-color: #fff3e0;
  color: #f57c00;
}
.badge-danger {
  background-color: #ffebee;
  color: #d32f2f;
}
.badge-info {
  background-color: #e3f2fd;
  color: #1976d2;
}
/* ======================================== */
/* Badges de roles */
/* ======================================== */
.badge-staff {
  background-color: #e3f2fd;
  color: #1976d2;
}
.badge-admin {
  background-color: #fce4ec;
  color: #c2185b;
}
.badge-role {
  background-color: #f3e5f5;
  color: #7b1fa2;
}
.badge-permission {
  background-color: #e8f5e9;
  color: #388e3c;
  font-size: 0.65rem;
  padding: 0.15rem 0.4rem;
}
/* ======================================== */
/* Badge de stock */
/* ======================================== */
.badge-stock {
  font-size: 0.65rem;
  padding: 0.2rem 0.4rem;
  border-radius: 3px;
}
.badge-stock.in-stock {
    background-color: #e8f5e9;
    color: #388e3c;
  }
.badge-stock.low-stock {
    background-color: #fff3e0;
    color: #f57c00;
  }
.badge-stock.out-of-stock {
    background-color: #ffebee;
    color: #d32f2f;
  }
/* ======================================== */
/* Badge de precio (inline) */
/* ======================================== */
.badge-price {
  display: inline-block;
  vertical-align: middle;
  padding: 0.125rem 0.5rem;
  font-size: 0.7rem;
  font-weight: 500;
  color: var(--primary-color);
  background-color: rgba(50, 183, 104, 0.1);
  border-radius: 12px;
}
/* ======================================== */
/* Dietary Badges (Vegan, Vegetarian, etc.) */
/* ======================================== */
.dietary-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 3px 8px 3px 6px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--badge-color, #22c55e) 12%, white);
  font-size: 10px;
  font-weight: 600;
  transition: transform 0.2s ease;
}
.dietary-badge i {
    font-size: 10px;
  }
.dietary-badge:hover {
    transform: scale(1.05);
  }
.dietary-badge__text {
  white-space: nowrap;
}
/* Tamaño grande para product show */
.product-show__categories .dietary-badge,
.dietary-badge--large {
  padding: 4px 10px 4px 8px;
  font-size: 12px;
}
:is(.product-show__categories .dietary-badge,.dietary-badge--large) .dietary-badge__text {
    font-size: 11px;
  }
/* ======================================== */
/* Category Badges (non-dietary categories) */
/* ======================================== */
.category-badge {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 12px;
  background: var(--gray-100);
  color: var(--gray-600);
  font-size: 10px;
  font-weight: 500;
  white-space: nowrap;
  transition: transform 0.2s ease;
}
.category-badge:hover {
    transform: scale(1.05);
    background: var(--gray-200);
  }
/* Tamaño grande para product show */
.product-show__categories .category-badge,
.category-badge--large {
  padding: 4px 10px;
  font-size: 11px;
}
/* ======================================== */
/* Product Card Discount Badge */
/* ======================================== */
.product-card__badge {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 700;
  color: white;
  background: var(--store-badge-bg, linear-gradient(135deg, var(--primary-color), var(--success-color)));
  border-radius: 6px;
  z-index: 2;
  box-shadow: var(--shadow-sm);
}
.product-card__badge--hot {
  background: linear-gradient(135deg, #ef4444, #f97316);
  animation: pulse-badge 2s ease-in-out infinite;
}
@keyframes pulse-badge {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}
/* ======================================== */
/* Cart Item Discount Badge */
/* ======================================== */
.cart-item-badge {
  position: absolute;
  top: -6px;
  right: -6px;
  background: var(--primary-color);
  color: white;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 6px;
  border-radius: 8px;
  z-index: 2;
}
/* ======================================== */
/* Categories Container */
/* ======================================== */
.product-card__dietary,
.product-show__categories {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.product-show__categories {
  gap: 8px;
  margin: 8px 0 12px;
}
/* ======================================== */
/* Legacy category badges (backwards compat) */
/* ======================================== */
.product-card__categories {
  display: flex;
  gap: 4px;
  flex-wrap: wrap;
}
.product-card__category {
  font-size: 10px;
  font-weight: 600;
  color: var(--store-badge-text, white);
  background: var(--store-badge-bg, linear-gradient(135deg, var(--primary-color), var(--success-color)));
  padding: 2px 6px;
  border-radius: 4px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
/* ========================================================================== */
/* Cards - Estructura base de cards compartida */
/* ========================================================================== */
/* ======================================== */
/* Card base con hover effect */
/* ======================================== */
.card-hover {
  transition: all 0.2s ease;
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-md);
}
.card-hover:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-2px);
  }
/* ======================================== */
/* Card header estándar */
/* ======================================== */
.card-header-custom {
  padding: 0.75rem 1.25rem;
  background-color: #fff;
  border-bottom: 1px solid var(--gray-200);
}
.card-header-custom h3,.card-header-custom h4,.card-header-custom h5 {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    margin: 0;
  }
/* ======================================== */
/* Card body sin padding (para tablas) */
/* ======================================== */
.card-body-flush {
  padding: 0;
}
/* ======================================== */
/* Card con imagen */
/* ======================================== */
.card-image-container {
  position: relative;
  overflow: hidden;
  border-radius: var(--border-radius-md) var(--border-radius-md) 0 0;
}
.card-image-container img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    transition: transform 0.3s ease;
  }
.card-image-container:hover img {
    transform: scale(1.05);
  }
/* ======================================== */
/* Card spacing utilities */
/* ======================================== */
.card-spacing {
  margin-bottom: 1.5rem;
}
.card-spacing-sm {
  margin-bottom: 1rem;
}
.card-spacing-lg {
  margin-bottom: 2rem;
}
/* ======================================== */
/* Store card (listado público) */
/* ======================================== */
.store-card-public {
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  transition: all 0.3s ease;
  background: #fff;
  border: 1px solid var(--gray-200);
}
.store-card-public:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
  }
.store-card-public .store-image {
    height: 140px;
    overflow: hidden;
  }
:is(.store-card-public .store-image) img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
         object-fit: cover;
    }
.store-card-public .store-info {
    padding: 1rem;
  }
:is(.store-card-public .store-info) .store-name {
      font-size: 1rem;
      font-weight: 600;
      margin-bottom: 0.25rem;
    }
:is(.store-card-public .store-info) .store-category {
      font-size: 0.8rem;
      color: var(--gray-500);
    }
:is(.store-card-public .store-info) .store-discount {
      margin-top: 0.5rem;
      display: inline-block;
      background: var(--primary-color);
      color: #fff;
      padding: 0.2rem 0.5rem;
      border-radius: 4px;
      font-size: 0.75rem;
      font-weight: 600;
    }
/* ======================================== */
/* Product Card - Mobile First (BEM) */
/* ======================================== */
.product-card {
  position: relative;
  display: flex;
  gap: 14px;
  padding: 14px;
  background: white;
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--gray-100);
  margin-bottom: 12px;
  transition: all 0.2s ease;
}
.product-card:active {
    transform: scale(0.99);
  }
@media (min-width: 768px) {
.product-card {
    padding: 16px;
    gap: 16px;
}

    .product-card:hover {
      box-shadow: var(--shadow-md);
      transform: translateY(-2px);
    }
  }
/* Badge de descuento */
.product-card__badge {
  position: absolute;
  top: 10px;
  right: 10px;
  padding: 2px 8px;
  font-size: 11px;
  font-weight: 600;
  color: white;
  background: var(--store-badge-bg, linear-gradient(135deg, var(--primary-color), var(--success-color)));
  border-radius: 8px;
  z-index: 2;
  box-shadow: var(--shadow-sm);
}
.product-card__badge--hot {
  background: linear-gradient(135deg, #ef4444, #f97316);
  animation: pulse-badge 2s ease-in-out infinite;
}
@keyframes pulse-badge {
  0%, 100% { transform: scale(1); }
  50% { transform: scale(1.05); }
}
/* Imagen */
.product-card__figure {
  flex-shrink: 0;
  width: 100px;
  height: 100px;
  margin: 0;
  border-radius: var(--border-radius-md);
  overflow: hidden;
  background: var(--gray-100);
}
.product-card__figure a {
    display: block;
    width: 100%;
    height: 100%;
  }
@media (min-width: 768px) {
.product-card__figure {
    width: 110px;
    height: 110px;
}
  }
.product-card__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.3s ease;
}
.product-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-400);
  font-size: 24px;
}
/* Contenido */
.product-card__content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
}
/* Precio */
.product-card__price {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 4px;
}
.product-card__price-current {
  font-size: 17px;
  font-weight: 700;
  color: var(--store-price, var(--primary-color));
}
@media (min-width: 768px) {
.product-card__price-current {
    font-size: 18px;
}
  }
.product-card__price-original {
  font-size: 13px;
  color: var(--gray-400);
  text-decoration: line-through;
}
/* Nombre y descripción */
.product-card__link {
  text-decoration: none;
}
.product-card__link:hover .product-card__name {
    color: var(--store-primary, var(--primary-color));
  }
.product-card__name {
  font-size: 15px;
  font-weight: 600;
  color: var(--store-title, var(--gray-800));
  margin: 0 0 4px 0;
  line-height: 1.3;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  transition: color 0.2s ease;
}
.product-card__desc {
  font-size: 13px;
  color: var(--gray-500);
  margin: 0;
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* Footer */
.product-card__footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: auto;
  padding-top: 8px;
  gap: 8px;
}
/* Badges moved to components/_badges.css */
.product-card__stock {
  font-size: 11px;
  font-weight: 500;
  color: var(--gray-500);
  display: flex;
  align-items: center;
  gap: 4px;
}
.product-card__stock i {
    font-size: 10px;
  }
.product-card__stock--low {
  color: var(--danger-color);
}
.product-card__edit {
  position: absolute;
  top: 10px;
  left: 10px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 50%;
  color: var(--success-color);
  font-size: 14px;
  box-shadow: var(--shadow-sm);
  z-index: 2;
  text-decoration: none;
}
.product-card__edit:hover {
    background: white;
    transform: scale(1.05);
  }
/* ======================================== */
/* Favorite Store Card (Account Following) */
/* ======================================== */
.favorite-stores {
  padding: 16px;
  padding-top: 80px;
  max-width: 600px;
  margin: 0 auto;
}
@media (min-width: 768px) {
.favorite-stores {
    padding: 32px 24px;
    padding-top: 100px;
}
  }
.favorite-stores__header {
  margin-bottom: 20px;
}
.favorite-stores__title {
  font-size: 24px;
  font-weight: 700;
  color: var(--gray-800);
  margin: 0 0 6px;
}
.favorite-stores__subtitle {
  font-size: 14px;
  color: var(--gray-500);
  margin: 0;
}
.favorite-stores__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
/* Individual store card */
.favorite-store-card {
  display: flex;
  gap: 12px;
  padding: 12px;
  background: white;
  border-radius: 16px;
  border: none;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  text-decoration: none;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.favorite-store-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.1);
    transform: translateY(-2px);
    text-decoration: none;
  }
.favorite-store-card:active {
    transform: scale(0.99);
  }
@media (min-width: 768px) {
.favorite-store-card {
    padding: 16px;
    gap: 16px;
}
  }
.favorite-store-card__image {
  position: relative;
  flex-shrink: 0;
  width: 72px;
  height: 72px;
  border-radius: 12px;
  overflow: hidden;
  background: var(--gray-100);
}
@media (min-width: 768px) {
.favorite-store-card__image {
    width: 90px;
    height: 90px;
}
  }
.favorite-store-card__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.favorite-store-card__avatar {
  position: absolute;
  bottom: -4px;
  right: -4px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 2px solid white;
  -o-object-fit: cover;
     object-fit: cover;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) {
.favorite-store-card__avatar {
    width: 32px;
    height: 32px;
}
  }
.favorite-store-card__placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-400);
  font-size: 22px;
}
.favorite-store-card__content {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.favorite-store-card__name {
  font-size: 15px;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 2px;
  line-height: 1.3;
}
.favorite-store-card__description {
  font-size: 13px;
  color: var(--gray-500);
  margin: 0 0 10px;
  line-height: 1.3;
}
.favorite-store-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: auto;
}
.favorite-store-card__tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 500;
  color: var(--gray-600);
  background: var(--gray-100);
  border-radius: 20px;
}
.favorite-store-card__tag i {
    font-size: 6px;
  }
.favorite-store-card__tag--distance {
  color: var(--primary-color);
  background: rgba(50, 183, 104, 0.1);
}
.favorite-store-card__tag--distance i {
    font-size: 10px;
  }
.favorite-store-card__tag--status i {
    font-size: 6px;
  }
.favorite-store-card__tag--status.open {
    color: #22c55e;
    background: rgba(34, 197, 94, 0.1);
  }
.favorite-store-card__tag--status.closed {
    color: #ef4444;
    background: rgba(239, 68, 68, 0.1);
  }
.favorite-store-card__action {
  flex-shrink: 0;
  align-self: center;
  color: var(--gray-300);
  font-size: 14px;
}
/* Empty State */
.favorite-stores__empty {
  text-align: center;
  padding: 60px 20px;
  background: white;
  border-radius: var(--border-radius-lg);
  border: 1px solid var(--gray-100);
}
.favorite-stores__empty-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 20px;
  border-radius: 50%;
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--gray-400);
}
.favorite-stores__empty-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--gray-700);
  margin: 0 0 8px;
}
.favorite-stores__empty-text {
  font-size: 14px;
  color: var(--gray-500);
  margin: 0 0 24px;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}
.favorite-stores__empty-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  color: white;
  background: var(--primary-color);
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s ease;
}
.favorite-stores__empty-btn:hover {
    background: #2a9d5a;
    transform: translateY(-2px);
    text-decoration: none;
    color: white;
  }
.favorite-stores__empty-btn i {
    font-size: 12px;
  }
/* ========================================================================== */
/* Cards Dashboard - Cards para vista partner/staff */
/* ========================================================================== */
/* Cards de gestión en dashboard, productos, órdenes, etc. */
/* ======================================== */
/* Dashboard Card - Panel genérico reutilizable */
/* ======================================== */
.dashboard-card {
  background: #fff;
  border-radius: var(--border-radius-md);
  border: 1px solid var(--gray-200);
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04), 0 4px 12px rgba(0, 0, 0, 0.04);
  overflow: hidden;
}
.dashboard-card-header {
  padding: 1rem 1.25rem;
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.dashboard-card-header h3 {
  font-size: 1rem;
  font-weight: 500;
  color: var(--gray-800);
  margin: 0;
}
.dashboard-card-body {
  padding: 1.25rem;
}
.dashboard-card-body.no-padding {
  padding: 0;
}
/* ======================================== */
/* Product card (dashboard - gestión) */
/* ======================================== */
.product-card-dashboard {
  display: flex;
  align-items: center;
  padding: 0.75rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-sm);
  transition: all 0.2s ease;
  gap: 0.75rem;
}
.product-card-dashboard:hover {
    background-color: var(--gray-50);
    box-shadow: var(--shadow-sm);
  }
.product-card-dashboard .product-thumb {
    width: 48px;
    height: 48px;
    min-width: 48px;
    border-radius: 6px;
    -o-object-fit: cover;
       object-fit: cover;
    border: 1px solid var(--gray-200);
  }
.product-card-dashboard .product-details {
    flex: 1;
    min-width: 0;
  }
:is(.product-card-dashboard .product-details) .product-name {
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--gray-800);
      margin-bottom: 0.15rem;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }
:is(.product-card-dashboard .product-details) .product-meta {
      font-size: 0.75rem;
      color: var(--gray-500);
    }
:is(:is(.product-card-dashboard .product-details) .product-meta) span {
        margin-right: 0.75rem;
      }
.product-card-dashboard .product-price {
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--primary-color);
    white-space: nowrap;
  }
.product-card-dashboard .product-actions {
    display: flex;
    gap: 0.35rem;
  }
/* ======================================== */
/* Order card (dashboard) */
/* ======================================== */
.order-card-dashboard {
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-md);
  background: #fff;
  overflow: hidden;
}
.order-card-dashboard .order-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0.75rem 1rem;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
  }
:is(.order-card-dashboard .order-header) .order-number {
      font-weight: 600;
      font-size: 0.9rem;
    }
:is(.order-card-dashboard .order-header) .order-status {
      font-size: 0.75rem;
      padding: 0.2rem 0.5rem;
      border-radius: 4px;
    }
.order-card-dashboard .order-body {
    padding: 1rem;
  }
:is(.order-card-dashboard .order-body) .order-customer {
      font-size: 0.85rem;
      margin-bottom: 0.5rem;
    }
:is(.order-card-dashboard .order-body) .order-items {
      font-size: 0.8rem;
      color: var(--gray-600);
    }
:is(.order-card-dashboard .order-body) .order-total {
      font-weight: 600;
      color: var(--primary-color);
      margin-top: 0.5rem;
    }
.order-card-dashboard .order-footer {
    display: flex;
    justify-content: flex-end;
    gap: 0.5rem;
    padding: 0.75rem 1rem;
    border-top: 1px solid var(--gray-200);
    background: #fafafa;
  }
/* ======================================== */
/* Stats card (dashboard) */
/* ======================================== */
.stats-card-dashboard {
  padding: 1.25rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-md);
  transition: all 0.2s ease;
}
.stats-card-dashboard:hover {
    box-shadow: var(--shadow-md);
  }
.stats-card-dashboard .stats-icon {
    width: 48px;
    height: 48px;
    border-radius: var(--border-radius-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    margin-bottom: 1rem;
  }
.primary:is(.stats-card-dashboard .stats-icon) {
      background: rgba(50, 183, 104, 0.1);
      color: var(--primary-color);
    }
.info:is(.stats-card-dashboard .stats-icon) {
      background: rgba(0, 122, 255, 0.1);
      color: var(--secondary-color);
    }
.warning:is(.stats-card-dashboard .stats-icon) {
      background: rgba(255, 149, 0, 0.1);
      color: var(--warning-color);
    }
.danger:is(.stats-card-dashboard .stats-icon) {
      background: rgba(255, 59, 48, 0.1);
      color: var(--danger-color);
    }
.stats-card-dashboard .stats-value {
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--gray-800);
    margin-bottom: 0.25rem;
  }
.stats-card-dashboard .stats-label {
    font-size: 0.8rem;
    color: var(--gray-500);
  }
.stats-card-dashboard .stats-change {
    font-size: 0.75rem;
    margin-top: 0.5rem;
  }
.positive:is(.stats-card-dashboard .stats-change) {
      color: var(--success-color);
    }
.negative:is(.stats-card-dashboard .stats-change) {
      color: var(--danger-color);
    }
/* ========================================================================== */
/* Forms - Estilos de formularios compartidos */
/* ========================================================================== */
/* ======================================== */
/* Input base mejorado */
/* ======================================== */
.form-control-custom {
  border-radius: 6px;
  border: 1px solid #ced4da;
  padding: 0.5rem 0.75rem;
  font-size: 0.875rem;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.form-control-custom:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(50, 183, 104, 0.15);
    outline: none;
  }
.form-control-custom::-moz-placeholder {
    color: #adb5bd;
  }
.form-control-custom::placeholder {
    color: #adb5bd;
  }
/* ======================================== */
/* Label mejorado */
/* ======================================== */
.form-label-custom {
  font-size: 0.8rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: 0.35rem;
}
/* Labels en dashboard cards */
.dashboard-card label,
.dashboard-card .form-label {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: 0.375rem;
}
/* ======================================== */
/* Form group con spacing */
/* ======================================== */
.form-group-custom {
  margin-bottom: 1rem;
}
.form-group-custom:last-child {
    margin-bottom: 0;
  }
/* ======================================== */
/* Select custom */
/* ======================================== */
.form-select-custom {
  border-radius: 6px;
  border: 1px solid #ced4da;
  padding: 0.5rem 2rem 0.5rem 0.75rem;
  font-size: 0.875rem;
  background-position: right 0.75rem center;
}
.form-select-custom:focus {
    border-color: var(--primary-color);
    box-shadow: 0 0 0 0.2rem rgba(50, 183, 104, 0.15);
  }
/* ======================================== */
/* Textarea custom */
/* ======================================== */
.form-textarea-custom {
  min-height: 100px;
  resize: vertical;
}
/* ======================================== */
/* Input con icono */
/* ======================================== */
.input-icon-wrapper {
  position: relative;
}
.input-icon-wrapper .input-icon {
    position: absolute;
    left: 0.75rem;
    top: 50%;
    transform: translateY(-50%);
    color: #adb5bd;
    font-size: 0.875rem;
  }
.input-icon-wrapper input {
    padding-left: 2.25rem;
  }
/* ======================================== */
/* Validation states */
/* ======================================== */
.is-valid-custom {
  border-color: #28a745 !important;
}
.is-valid-custom:focus {
    box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15) !important;
  }
.is-invalid-custom {
  border-color: #dc3545 !important;
}
.is-invalid-custom:focus {
    box-shadow: 0 0 0 0.2rem rgba(220, 53, 69, 0.15) !important;
  }
.validation-message {
  font-size: 0.75rem;
  margin-top: 0.25rem;
}
.validation-message.valid {
    color: #28a745;
  }
.validation-message.invalid {
    color: #dc3545;
  }
/* ======================================== */
/* Input de posición/número pequeño */
/* ======================================== */
.input-position {
  width: 50px;
  text-align: center;
  border: 1px solid var(--gray-300);
  border-radius: 6px;
  padding: 0.375rem;
  font-size: 0.875rem;
}
.input-position:focus {
    border-color: var(--primary-color);
    outline: none;
    box-shadow: 0 0 0 2px rgba(50, 183, 104, 0.2);
  }
/* ======================================== */
/* Grupo de input con botón */
/* ======================================== */
.input-group-compact {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}
.input-group-compact .btn-icon-sm {
  padding: 0.375rem 0.5rem;
  background: var(--gray-100);
  border: 1px solid var(--gray-300);
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s;
}
:is(.input-group-compact .btn-icon-sm):hover {
    background: var(--gray-200);
  }
/* ======================================== */
/* Formulario inline para dashboard */
/* ======================================== */
.form-inline-dashboard {
  width: 100%;
}
.form-inline-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.form-inline-field {
  flex: 1;

  /* Override simple_form wrapper margins */
}
.form-inline-field .form-group {
    margin-bottom: 0;
  }
.form-inline-field .string {
    margin-bottom: 0;
  }
.form-inline-action {
  flex-shrink: 0;
}
.form-control-dashboard {
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  padding: 0.625rem 1rem;
  font-size: 0.875rem;
  width: 100%;
  transition: all 0.2s ease;
  background: #fff;
}
.form-control-dashboard::-moz-placeholder {
    color: var(--gray-400);
  }
.form-control-dashboard::placeholder {
    color: var(--gray-400);
  }
.form-control-dashboard:focus {
    border-color: var(--primary-color);
    outline: none;
    box-shadow: 0 0 0 3px rgba(50, 183, 104, 0.15);
  }
/* Responsive */
@media (max-width: 576px) {
  .form-inline-row {
    flex-direction: column;
    align-items: stretch;
  }

  .form-inline-action {
    width: 100%;
  }
}
/* ======================================== */
/* Formulario de validador QR */
/* ======================================== */
.validator-form {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}
.validator-form .string {
    flex: 1;
    margin-bottom: 0;
    min-width: 0;
  }
.validator-form .form-control-dashboard {
    width: 100%;
  }
.validator-form .btn-dashboard {
    flex-shrink: 0;
    height: 42px;
  }
@media (max-width: 576px) {
  .validator-form {
    flex-direction: column;
  }

    .validator-form .string {
      width: 100%;
    }

    .validator-form .btn-dashboard {
      width: 100%;
    }
}
/* ========================================================================== */
/* Modals - Estilos de modales compartidos */
/* ========================================================================== */
/* ======================================== */
/* Modal header custom */
/* ======================================== */
.modal-header-custom {
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--gray-200);
  background-color: #fff;
}
.modal-header-custom .modal-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    font-size: 1.1rem;
    color: var(--gray-800);
  }
.modal-header-custom .btn-close {
    opacity: 0.5;
    transition: opacity 0.2s ease;
  }
:is(.modal-header-custom .btn-close):hover {
      opacity: 1;
    }
/* ======================================== */
/* Modal body custom */
/* ======================================== */
.modal-body-custom {
  padding: 1.25rem;
}
/* ======================================== */
/* Modal footer custom */
/* ======================================== */
.modal-footer-custom {
  padding: 1rem 1.25rem;
  border-top: 1px solid var(--gray-200);
  gap: 0.5rem;
}
/* ======================================== */
/* Modal sizes */
/* ======================================== */
.modal-sm-custom {
  max-width: 350px;
}
.modal-md-custom {
  max-width: 500px;
}
.modal-lg-custom {
  max-width: 800px;
}
/* ======================================== */
/* Modal de confirmación */
/* ======================================== */
.modal-confirm .modal-body {
    text-align: center;
    padding: 2rem;
  }
:is(.modal-confirm .modal-body) .confirm-icon {
      font-size: 3rem;
      margin-bottom: 1rem;
    }
.warning:is(:is(.modal-confirm .modal-body) .confirm-icon) {
        color: #f57c00;
      }
.danger:is(:is(.modal-confirm .modal-body) .confirm-icon) {
        color: #d32f2f;
      }
.success:is(:is(.modal-confirm .modal-body) .confirm-icon) {
        color: #388e3c;
      }
:is(.modal-confirm .modal-body) .confirm-title {
      font-size: 1.25rem;
      font-weight: 600;
      margin-bottom: 0.5rem;
    }
:is(.modal-confirm .modal-body) .confirm-message {
      color: var(--gray-500);
      margin-bottom: 0;
    }
.modal-confirm .modal-footer {
    justify-content: center;
    border-top: none;
    padding-top: 0;
  }
/* ======================================== */
/* Login Required Modal */
/* ======================================== */
.login-modal .modal-content {
  border: none;
  border-radius: 20px;
  overflow: hidden;
}
.login-modal__body {
  padding: 32px 24px;
  text-align: center;
}
.login-modal__icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 16px;
  border-radius: 50%;
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  color: var(--gray-400);
}
.login-modal__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 8px;
}
.login-modal__text {
  font-size: 14px;
  color: var(--gray-500);
  margin: 0 0 24px;
  line-height: 1.5;
}
.login-modal__buttons {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.login-modal__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  font-size: 14px;
  font-weight: 600;
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.login-modal__btn:hover {
    text-decoration: none;
    transform: translateY(-1px);
  }
.login-modal__btn:active {
    transform: translateY(0);
  }
.login-modal__btn--primary {
  background: var(--primary-color);
  color: white;
}
.login-modal__btn--primary:hover {
    background: #2a9d5a;
    color: white;
  }
.login-modal__btn--secondary {
  background: var(--gray-100);
  color: var(--gray-700);
}
.login-modal__btn--secondary:hover {
    background: var(--gray-200);
    color: var(--gray-800);
  }
/* ========================================================================== */
/* Dropdowns - Menús desplegables compartidos */
/* ========================================================================== */
/* ======================================== */
/* Dropdown menu custom */
/* ======================================== */
.dropdown-menu-custom {
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-sm);
  box-shadow: var(--shadow-lg);
  padding: 0.5rem 0;
  min-width: 180px;
}
.dropdown-menu-custom .dropdown-item {
    padding: 0.5rem 1rem;
    font-size: 0.875rem;
    color: var(--gray-700);
    transition: all 0.15s ease;
  }
:is(.dropdown-menu-custom .dropdown-item):hover {
      background-color: var(--gray-50);
      color: var(--gray-900);
    }
:is(.dropdown-menu-custom .dropdown-item):active {
      background-color: var(--primary-color);
      color: #fff;
    }
:is(.dropdown-menu-custom .dropdown-item) i,:is(.dropdown-menu-custom .dropdown-item) .icon {
      margin-right: 0.5rem;
      width: 1rem;
      text-align: center;
    }
.dropdown-menu-custom .dropdown-divider {
    margin: 0.5rem 0;
    border-top-color: var(--gray-200);
  }
.dropdown-menu-custom .dropdown-header {
    padding: 0.5rem 1rem;
    font-size: 0.7rem;
    font-weight: 600;
    color: var(--gray-500);
    text-transform: uppercase;
    letter-spacing: 0.5px;
  }
/* ======================================== */
/* Dropdown de acciones (tablas) */
/* ======================================== */
.dropdown-actions .dropdown-toggle {
    padding: 0.25rem 0.5rem;
    background: transparent;
    border: 1px solid var(--gray-200);
    border-radius: 4px;
    font-size: 0.8rem;
    color: var(--gray-600);
  }
:is(.dropdown-actions .dropdown-toggle):hover {
      background-color: var(--gray-50);
      border-color: var(--gray-300);
    }
:is(.dropdown-actions .dropdown-toggle)::after {
      display: none;
    }
.dropdown-actions .dropdown-menu {
    min-width: 140px;
  }
/* ======================================== */
/* Dropdown de usuario (header) */
/* ======================================== */
.dropdown-user .dropdown-toggle {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
:is(.dropdown-user .dropdown-toggle) .user-avatar {
      width: 32px;
      height: 32px;
      border-radius: 50%;
      -o-object-fit: cover;
         object-fit: cover;
    }
:is(.dropdown-user .dropdown-toggle) .user-name {
      font-weight: 500;
      font-size: 0.875rem;
    }
.dropdown-user .dropdown-menu {
    right: 0;
    left: auto;
    min-width: 200px;
  }
/* ======================================== */
/* Dropdown toggle genérico para dashboard */
/* ======================================== */
.dropdown-toggle-dashboard {
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  padding: 0.375rem 0.75rem;
  font-size: 0.8125rem;
  color: var(--gray-700);
  cursor: pointer;
  transition: all 0.2s;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}
.dropdown-toggle-dashboard:hover {
    background: var(--gray-200);
    border-color: var(--gray-300);
  }
.dropdown-toggle-dashboard .dropdown-arrow {
    transition: transform 0.2s;
    font-size: 0.625rem;
  }
.dropdown-toggle-dashboard[aria-expanded="true"] .dropdown-arrow {
    transform: rotate(180deg);
  }
/* ======================================== */
/* Contenido colapsable */
/* ======================================== */
.dropdown-content-dashboard {
  margin-top: 0.75rem;
  background: var(--gray-50);
  border-radius: var(--border-radius-sm);
  padding: 0.75rem;
}
/* ======================================== */
/* Dropdown de productos (secciones) */
/* ======================================== */
.products-dropdown {
  position: relative;
}
.products-collapse {
  margin-top: 0.5rem;
}
.products-list-content {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-sm);
  padding: 0.5rem;
  max-height: 300px;
  overflow-y: auto;
  overflow-x: auto;
}
.product-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem;
  background: #fff;
  border-radius: 6px;
  margin-bottom: 0.375rem;
  border: 1px solid var(--gray-100);
  transition: all 0.15s ease;
  min-width: 220px;
}
.product-item:last-child {
    margin-bottom: 0;
  }
.product-item:hover {
    border-color: var(--gray-200);
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.05);
  }
.product-mini-thumb {
  width: 36px;
  height: 36px;
  min-width: 36px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 4px;
  border: 1px solid var(--gray-200);
}
.product-mini-thumb-placeholder {
  width: 36px;
  height: 36px;
  min-width: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-100);
  border-radius: 4px;
  font-size: 1rem;
}
.product-item .product-info {
  flex: 1;
  min-width: 0;
}
.product-item .product-name {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--gray-800);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 0.125rem;
}
.product-item .product-price {
  font-size: 0.7rem;
  color: var(--primary-color);
  font-weight: 600;
}
.product-item .product-actions {
  flex-shrink: 0;
}
/* .mini-action-btn movido a _buttons.css */
/* ========================================================================== */
/* Alerts - Alertas y notificaciones para dashboard */
/* ========================================================================== */
/* ======================================== */
/* Base alert para dashboard */
/* ======================================== */
.dashboard-alert {
  display: flex;
  align-items: flex-start;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-radius: var(--border-radius-sm);
  font-size: 0.875rem;
}
.dashboard-alert-icon {
  font-size: 1.25rem;
  flex-shrink: 0;
}
/* ======================================== */
/* Alert variants */
/* ======================================== */
.dashboard-alert.alert-info {
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  color: #1e40af;
}
.dashboard-alert.alert-warning {
  background: #fef9c3;
  border: 1px solid #fde047;
  color: #854d0e;
}
.dashboard-alert.alert-success {
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  color: #15803d;
}
.dashboard-alert.alert-danger {
  background: #fee2e2;
  border: 1px solid #fca5a5;
  color: #991b1b;
}
/* ======================================== */
/* Alert content */
/* ======================================== */
.dashboard-alert strong {
  font-weight: 600;
}
.dashboard-alert a {
  color: inherit;
  text-decoration: underline;
}
:is(.dashboard-alert a):hover {
    opacity: 0.8;
  }
/* ======================================== */
/* Alert con contenido y acción */
/* ======================================== */
.dashboard-alert-content {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}
/* btn-alert-action movido a _buttons.css como .btn-header-action */
/* ========================================================================== */
/* Toggles - Switches y checkboxes custom */
/* ========================================================================== */
/* ======================================== */
/* Switch verde para dashboard */
/* ======================================== */
/* Switches en tablas del dashboard - color verde */
.form-switch .form-check-input:checked {
  background-color: #32b768 !important;
  border-color: #32b768 !important;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='-4 -4 8 8'%3e%3ccircle r='3' fill='%23fff'/%3e%3c/svg%3e") !important;
}
.form-switch .form-check-input:focus {
  border-color: #80bdab;
  box-shadow: 0 0 0 0.2rem rgba(50, 183, 104, 0.25);
}
/* ======================================== */
/* Switch compacto para tablas */
/* ======================================== */
.switch-compact {
  display: flex;
  align-items: center;
  margin: 0;
  padding-left: 2.25em;
  min-height: auto;
}
.switch-compact .form-check-input {
    width: 2em;
    height: 1em;
    margin-top: 0;
    margin-left: -2.25em;
  }
:is(.switch-compact .form-check-input):checked {
      background-color: var(--primary-color);
      border-color: var(--primary-color);
    }
:is(.switch-compact .form-check-input):focus {
      border-color: #80bdab;
      box-shadow: none;
    }
.switch-compact .form-check-label {
    font-size: 0.7rem;
    font-weight: 500;
    color: var(--gray-500);
    margin-left: 0.25rem;
  }
/* ======================================== */
/* Toggle de disponibilidad */
/* ======================================== */
:is(.toggle-availability .form-check-input):checked {
      background-color: #28a745;
      border-color: #28a745;
    }
.available:is(.toggle-availability .form-check-label) {
      color: #28a745;
    }
.unavailable:is(.toggle-availability .form-check-label) {
      color: #dc3545;
    }
/* ======================================== */
/* Category Checkbox (ingredientes) */
/* ======================================== */
.category-checkbox:checked {
  background-color: #28a745;
  border-color: #28a745;
}
.category-checkbox:focus {
  border-color: #28a745;
  box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
}
/* ======================================== */
/* Checkbox verde para formularios */
/* ======================================== */
/* Checkboxes regulares en formularios - color verde */
.form-check-input:checked {
  background-color: #32b768 !important;
  border-color: #32b768 !important;
}
.form-check-input:focus {
  border-color: #80bdab;
  box-shadow: 0 0 0 0.2rem rgba(50, 183, 104, 0.25);
}
/* ======================================== */
/* Toggle group (múltiples toggles) */
/* ======================================== */
.toggle-group {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.toggle-group .toggle-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.5rem;
    border-radius: var(--border-radius-sm);
    background-color: var(--gray-50);
  }
:is(.toggle-group .toggle-item):hover {
      background-color: var(--gray-100);
    }
/* ========================================================================== */
/* Spinner - Componente de carga */
/* ========================================================================== */
#spinner {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1050;
  justify-content: center;
  align-items: center;
  background: rgba(255, 255, 255, 0.8);
}
.loader {
  border: 16px solid #657069;
  border-top: 16px solid var(--primary-color, #3ac035);
  border-radius: 50%;
  width: 120px;
  height: 120px;
  animation: spin 2s linear infinite;
}
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
/* ========================================================================== */
/* Skeleton - Componentes de carga placeholder */
/* ========================================================================== */
.ph-item {
  padding: 4px 2px !important;
}
.ph-picture {
  height: 100px !important;
}
@media (min-width: 992px) {
.ph-picture {
    height: 300px !important;
}
  }
.placeholder-card .ph-item {
  margin: 0;
  height: 100%;
  border: 0 !important;
}
.store-skeleton-wrapper {
  position: relative;
  height: 120px;
}
@media (min-width: 992px) {
.store-skeleton-wrapper {
    height: 200px;
}
  }
@keyframes fadeIn {
  from { opacity: 0; visibility: hidden; }
  to   { opacity: 1; visibility: visible; }
}
/* ======================================== */
/* Pagination */
/* ======================================== */
.pagination {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
:is(.pagination .page-item) .page-link {
      display: flex;
      align-items: center;
      justify-content: center;
      min-width: 36px;
      height: 36px;
      padding: 0 0.625rem;
      font-size: 0.875rem;
      font-weight: 500;
      color: var(--gray-600);
      background: #fff;
      border: 1px solid var(--gray-200);
      border-radius: 8px;
      text-decoration: none;
      transition: all 0.15s ease;
    }
:is(:is(.pagination .page-item) .page-link):hover {
        background: var(--gray-100);
        border-color: var(--gray-300);
        color: var(--gray-800);
      }
.active:is(.pagination .page-item) .page-link {
      background: var(--gray-500);
      border-color: var(--gray-500);
      color: #fff;
    }
.disabled:is(.pagination .page-item) .page-link {
      background: var(--gray-50);
      color: var(--gray-300);
      cursor: not-allowed;
      pointer-events: none;
      border-color: var(--gray-100);
    }
:is(.prev:is(.pagination .page-item),.next:is(.pagination .page-item),.first:is(.pagination .page-item),.last:is(.pagination .page-item)) .page-link {
        font-size: 0.75rem;
        padding: 0 0.75rem;
        color: var(--gray-500);
      }
:is(.pagination .gap) .page-link {
      background: transparent;
      border: none;
      color: var(--gray-400);
      cursor: default;
    }
:is(:is(.pagination .gap) .page-link):hover {
        background: transparent;
        border: none;
      }
/* Card Footer for pagination container */
.card-footer-custom {
  padding: 1rem 1.5rem;
  border-top: 1px solid var(--gray-100);
  background: var(--gray-50);
  display: flex;
  justify-content: center;
}
/* ==========================================================================
   5. Layout
   ========================================================================== */
/* ========================================================================== */
/* Header - Navegación y header del sitio */
/* ========================================================================== */
/* Header para vista pública (home, stores, etc.) */
/* ======================================== */
/* Site Header (público - home) */
/* ======================================== */
.site-header {
  position: fixed;
  height: 60px;
  display: flex;
  align-items: center;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 99;
  transition: 0.5s;
  border-bottom: 1px solid transparent;
}
.main-navigation {
  display: flex;
  width: 100%;
  height: 100%;
  justify-content: flex-end;
  align-items: center;
}
.main-navigation .menu li {
  display: inline-block;
  position: relative;
  padding-top: 10px;
}
.main-navigation .menu li:first-child {
  margin-left: 0;
}
.main-navigation .menu li:last-child {
  margin-right: 0;
}
.main-navigation .menu li:hover > ul {
  opacity: 1;
  margin-top: 6px;
  visibility: visible;
}
.main-navigation .menu li a {
  display: flex;
  transition: 0.3s;
  position: relative;
  justify-content: center;
  align-items: center;
  color: var(--gray-50) !important;
  text-transform: capitalize;
  font-weight: 500;
  padding: 5px 18px;
  border-radius: 30px;
  font-size: 1rem;
}
.main-navigation .menu li a:hover {
  color: var(--primary-color);
}
.fa-user {
  color: #fff;
  opacity: 0.7;
  margin-left: 10px;
}
.fa-user:hover {
  color: #fff;
  opacity: 1;
}
/* ======================================== */
/* Dashboard Header (partner/staff) */
/* ======================================== */
.headera {
  background-color: #212529;
  z-index: 997;
  height: 60px;
  box-shadow: 0px 2px 20px rgba(1, 41, 112, 0.1);
  padding-left: 20px;
}
.headera .toggle-sidebar-btn {
  font-size: 32px;
  padding-left: 10px;
  cursor: pointer;
}
.headera .search-bar {
  min-width: 360px;
  padding: 0 20px;
}
.headera .search-form {
  width: 100%;
}
.headera .search-form input {
  border: 1px solid rgba(1, 41, 112, 0.2);
  border-radius: 3px;
  padding: 7px 38px 7px 8px;
  font-size: 14px;
  color: #012970;
  transition: 0.3s;
  width: 100%;
  outline: none;
}
.headera .search-form input:focus,
.headera .search-form input:hover {
  box-shadow: 0 0 10px 0 rgba(1, 41, 112, 0.15);
  border: 1px solid rgba(1, 41, 112, 0.3);
}
/* ======================================== */
/* Header Icons */
/* ======================================== */
.bi-list {
  color: var(--primary-color) !important;
}
.bi-bell,
.bi-chat-left-text,
.name {
  color: var(--gray-50);
}
/* ======================================== */
/* Logo */
/* ======================================== */
.logo-text {
  font-family: poppins;
  font-size: 25px;
  font-weight: 700;
  color: whitesmoke;
}
.store-name-logo {
  max-width: 180px;
  overflow: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
  display: inline-block;
  font-weight: 600;
  font-size: 1.2rem;
  color: whitesmoke;
}
@media (min-width: 1200px) {
  .logo {
    width: 280px;
  }
}
/* ======================================== */
/* Header Nav (Dashboard) */
/* ======================================== */
.headera-nav ul {
  list-style: none;
}
.headera-nav > ul {
  margin: 0;
  padding: 0;
}
.headera-nav .nav-icon {
  font-size: 20px;
  color: #012970;
}
.headera-nav .nav-profile {
  color: #012970;
}
.headera-nav .nav-profile img {
  max-height: 36px;
}
.headera-nav .nav-profile span {
  font-size: 14px;
  font-weight: 600;
}
.headera-nav .badge-number {
  position: absolute;
  inset: -6px -8px auto auto;
  font-weight: normal;
  font-size: 10px;
  padding: 3px 6px;
}
/* ======================================== */
/* Badge Cart (Header) */
/* ======================================== */
.badge-cart {
  display: inline-block;
  line-height: 1;
  color: #fff;
  text-align: center;
  white-space: nowrap;
  vertical-align: baseline;
  border-radius: 0.25rem;
  background-color: var(--primary-color);
}
.badge-cart:empty {
  display: none;
}
/* ======================================== */
/* Menu Toggle (Mobile) */
/* ======================================== */
@media screen and (min-width: 992px) {
  .menu-toggle {
    display: none;
  }
}
@media (max-width: 991px) {
  .menu-toggle {
    position: absolute;
    top: 50%;
    right: 30px;
    border: none;
    outline: none !important;
    background: transparent;
    width: 40px;
    height: 40px;
    transform: translate(0, -50%);
    z-index: 100;
    border-radius: 10px;
    padding: 0 8px;
  }

  .menu-toggle span {
    display: block;
    width: 100%;
    height: 4px;
    background: var(--primary-color);
    margin-bottom: 5px;
    transition: 0.3s;
    border-radius: 5px;
    position: relative;
  }

  .menu-toggle span:last-child {
    margin: 0;
  }

  .toggled .menu-toggle span:nth-child(1) {
    transform: rotate(45deg);
    top: 5px;
  }

  .toggled .menu-toggle span:nth-child(2) {
    transform: rotate(-45deg);
    top: -4px;
  }

  .toggled .menu-toggle span:nth-child(3) {
    opacity: 0;
    height: 0;
  }

  .main-navigation.toggled .header-menu {
    transform: translatey(0);
  }

  .header-menu {
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 2;
    padding-top: 50px;
    padding-left: 30px;
    transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1);
    overflow-y: auto;
    transform: translatey(-100%);
    background-color: #212529;
    background-position: center;
  }

  .hidden {
    display: none;
  }

  .main-navigation .menu li {
    display: block;
    float: none;
    margin: 0;
    margin-bottom: 20px;
  }

  .main-navigation .menu li a {
    display: inline-block;
    font-size: 14px;
  }

  .main-navigation .menu li:last-child {
    margin: 0;
  }

  .site-header {
    padding: 20px 0;
    background: rgb(255 255 255 / 90%);
  }
}
/* ======================================== */
/* Search Bar Responsive */
/* ======================================== */
@media (max-width: 1199px) {
  .headera .search-bar {
    position: fixed;
    top: 50px;
    left: 0;
    right: 0;
    padding: 20px;
    box-shadow: 0px 0px 15px 0px rgba(1, 41, 112, 0.1);
    background: white;
    z-index: 9999;
    transition: 0.3s;
    visibility: hidden;
    opacity: 0;
  }

  .headera .search-bar-show {
    top: 60px;
    visibility: visible;
    opacity: 1;
  }
}
/* ======================================== */
/* Navigation Responsive */
/* ======================================== */
@media (max-width: 1399px) {
  .main-navigation .menu li {
    margin: 0 3px;
  }
}
@media (max-width: 1199px) {
  .main-navigation .menu li {
    margin: 0;
  }

  .main-navigation .menu li a {
    padding: 4px 15px;
    font-size: 15px;
  }
}
/* ========================================================================== */
/* Footer - Estilos del pie de página */
/* ========================================================================== */
footer {
  background-color: #121921;
  padding: 60px 0 35px;
}
@media (max-width: 767px) {
  footer {
    padding: 0 0 15px;
  }
}
footer hr {
  background-color: hsla(0, 0%, 100%, 0.15);
  margin-top: 5px;
}
@media (max-width: 767px) {
  footer hr {
    opacity: 0;
  }
}
/* ======================================== */
/* Footer Contacts */
/* ======================================== */
footer .contacts ul {
  margin: 0 0 25px;
  padding: 0;
  list-style: none;
}
@media (max-width: 767px) {
  footer .contacts ul {
    margin-top: 15px;
  }
}
footer .contacts ul li {
  padding-left: 35px;
  position: relative;
  margin-bottom: 15px;
  color: #fff;
  opacity: 0.6;
}
footer .contacts ul li a {
  color: #fff;
  opacity: 1;
}
footer .contacts ul li a:hover {
  opacity: 1;
}
footer .contacts ul li i {
  font-size: 18px;
  font-size: 1.125rem;
  position: absolute;
  top: 0;
  left: 0;
  color: #fff;
  line-height: 1;
}
/* ======================================== */
/* Footer Headings */
/* ======================================== */
footer h3 {
  font-size: 14px;
  font-size: 0.875rem;
  margin-bottom: 15px;
  transition: all 0.3s ease-in-out;
  color: #fff;
  text-transform: uppercase;
}
@media (max-width: 767px) {
  footer h3 {
    font-size: 13px;
    font-size: 0.8125rem;
    cursor: pointer;
    border-bottom: 1px solid hsla(0, 0%, 100%, 0.15);
    margin: 0 -10px;
    padding: 15px;
    display: block;
  }

  footer h3:after {
    font-family: ElegantIcons;
    content: "L";
    width: 20px;
    display: block;
    float: right;
  }

  .size-header {
    width: 100%;
    height: 200px;
  }
}
/* ======================================== */
/* Footer Links */
/* ======================================== */
footer .links ul {
  margin: 0 0 25px;
  padding: 0;
  list-style: none;
}
@media (max-width: 767px) {
  footer .links ul {
    margin-top: 15px;
  }
}
/* ======================================== */
/* Bottom Footer */
/* ======================================== */
.bottom-footer {
  border-top: 1px solid rgb(204 204 204 / 40%);
  position: relative;
}
.copyright-text p {
  margin: 0;
}
.copyright-text {
  padding: 20px 0;
}
/* ======================================== */
/* Scroll to Top (Footer) */
/* ======================================== */
.scrolltop-home {
  position: absolute;
  bottom: 10px;
  right: 30px;
  width: 50px;
  height: 50px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  background: var(--gray-50);
  color: var(--primary-color);
  font-size: 16px;
  transition: var(--transition);
  border: none;
}
.scrolltop-home:hover {
  box-shadow: var(--shadow-lg);
  color: var(--gray-900);
}
/* ======================================== */
/* Newsletter (Footer) */
/* ======================================== */
@media (max-width: 767px) {
  #newsletter {
    margin-top: 20px;
  }
}
/* ========================================================================== */
/* Sidebar - Navegación lateral del dashboard */
/* ========================================================================== */
.sidebar {
  position: fixed;
  top: 60px;
  left: -280px; /* Oculto por defecto */
  bottom: 85px; /* Espacio para nav bottom en mobile */
  width: 280px;
  z-index: 999;
  transition: all 0.3s;
  padding: 20px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: #aab7cf transparent;
  box-shadow: 0px 0px 20px rgba(1, 41, 112, 0.1);
  background-color: #fff;

  /* En desktop no hay nav bottom, sidebar va hasta abajo */
}
@media (min-width: 992px) {
.sidebar {
    bottom: 0;
}
  }
/* ======================================== */
/* Scrollbar Styles */
/* ======================================== */
.sidebar::-webkit-scrollbar {
  width: 5px;
  height: 8px;
  background-color: #fff;
}
.sidebar::-webkit-scrollbar-thumb {
  background-color: #aab7cf;
}
/* ======================================== */
/* Sidebar Toggle Behavior */
/* ======================================== */
/* Por defecto, en pantallas grandes NO hay margen */
@media (min-width: 1729px) {
  #main,
  #footer {
    margin-left: 0;
  }
}
/* Cuando se activa toggle-sidebar -> ABRIR sidebar y mover el main */
.toggle-sidebar .sidebar {
  left: 0;
}
@media (min-width: 1729px) {
  .toggle-sidebar #main,
  .toggle-sidebar #footer {
    margin-left: 300px;
  }
}
/* ======================================== */
/* Sidebar Navigation */
/* ======================================== */
.sidebar-nav {
  padding: 0;
  margin: 0;
  list-style: none;
}
.sidebar-nav li {
  padding: 0;
  margin: 0;
  list-style: none;
}
.sidebar-nav .nav-item {
  margin-bottom: 5px;
}
.sidebar-nav .nav-heading {
  font-size: 11px;
  text-transform: uppercase;
  color: #899bbd;
  font-weight: 600;
  margin: 10px 0 5px 15px;
}
.sidebar-nav .nav-link {
  display: flex;
  align-items: center;
  font-size: 15px;
  font-weight: 600;
  color: #4154f1;
  transition: 0.3s;
  background: #f6f9ff;
  padding: 10px 15px;
  border-radius: 4px;
}
.sidebar-nav .nav-link i {
  font-size: 16px;
  margin-right: 10px;
  color: #4154f1;
}
.sidebar-nav .nav-link.collapsed {
  color: #012970;
  background: #fff;
}
.sidebar-nav .nav-link.collapsed i {
  color: #899bbd;
}
.sidebar-nav .nav-link:hover {
  color: #4154f1;
  background: #f6f9ff;
}
.sidebar-nav .nav-link:hover i {
  color: #4154f1;
}
.sidebar-nav .nav-link .bi-chevron-down {
  margin-right: 0;
  transition: transform 0.2s ease-in-out;
}
.sidebar-nav .nav-link:not(.collapsed) .bi-chevron-down {
  transform: rotate(180deg);
}
/* ======================================== */
/* Sidebar Nav Content (Submenu) */
/* ======================================== */
.sidebar-nav .nav-content {
  padding: 5px 0 0 0;
  margin: 0;
  list-style: none;
}
.sidebar-nav .nav-content a {
  display: flex;
  align-items: center;
  font-size: 14px;
  font-weight: 600;
  color: #012970;
  padding: 10px 0 10px 40px;
  transition: 0.3s;
}
.sidebar-nav .nav-content a i {
  font-size: 6px;
  margin-right: 8px;
  line-height: 0;
  border-radius: 50%;
}
.sidebar-nav .nav-content a:hover,
.sidebar-nav .nav-content a.active {
  color: #4154f1;
}
.sidebar-nav .nav-content a.active i {
  background-color: #4154f1;
}
/* ======================================== */
/* Breadcrumbs (relacionado con sidebar) */
/* ======================================== */
.breadcrumb {
  padding: 0 0;
  margin-top: 60px;
  margin-bottom: 1rem;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  font-size: 14px;
  font-family: "Nunito", sans-serif;
  font-weight: 600;
  align-self: start;
}
.breadcrumb a:hover {
  color: #51678f;
}
.breadcrumb .breadcrumb-item::before {
  color: #899bbd;
}
.breadcrumb .active {
  color: #51678f;
  font-weight: 600;
}
.breadcrumb-item a {
  color: var(--primary-color);
  text-decoration: underline !important;
  font-family: var(--bs-body-font-family);
}
/* ======================================== */
/* Error 404 (legacy - dentro de sidebar) */
/* ======================================== */
@media (min-width: 992px) {
  .error-404 img {
    max-width: 50%;
  }
}
/* ======================================== */
/* Section Dashboard */
/* ======================================== */
.section-dash {
  padding-top: 30px;
  padding-bottom: 30px;
  position: relative;
}
.card-icon h6 {
  font-family: "nunito, sans-serif";
}
/* ======================================== */
/* Logout - Fixed at Bottom */
/* ======================================== */
.sidebar-nav {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 185px); /* 60px header + 85px nav bottom + 40px padding */
}
.sidebar-nav > .nav-item:last-child {
  margin-top: auto;
  padding-top: 1rem;
  border-top: 1px solid #e5e7eb;
}
.sidebar-nav .nav-link[data-method="delete"]:hover {
  color: #dc2626;
  background: #fef2f2;
}
.sidebar-nav .nav-link[data-method="delete"]:hover i {
  color: #dc2626;
}
/* ========================================================================== */
/* Nav - Navegación principal */
/* ========================================================================== */
.main-nav {
  transition: margin-left 0.5s;
  margin-top: 65px;
}
/* ======================================== */
/* Profile Dropdown Menu */
/* ======================================== */
.dropdown-menu.profile {
  font-family: 'Poppins', sans-serif;
  border: none;
  border-radius: 8px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
  padding: 0.5rem 0;
  min-width: 220px;
  overflow: hidden;

  /* Dropdown arrow */
}
.dropdown-menu.profile.dropdown-menu-arrow::before {
    content: "";
    position: absolute;
    top: -8px;
    right: 16px;
    width: 16px;
    height: 16px;
    background: #fff;
    transform: rotate(45deg);
    border-top: 1px solid rgba(0, 0, 0, 0.05);
    border-left: 1px solid rgba(0, 0, 0, 0.05);
  }
/* Dropdown items */
.dropdown-menu.profile .dropdown-item {
    padding: 0.65rem 1.25rem;
    font-size: 0.875rem;
    color: var(--gray-700);
    transition: all 0.2s ease;
    gap: 0.75rem;
  }
:is(.dropdown-menu.profile .dropdown-item) i {
      font-size: 1.1rem;
      color: var(--gray-500);
      width: 20px;
      text-align: center;
      transition: color 0.2s ease;
    }
:is(.dropdown-menu.profile .dropdown-item) span {
      font-weight: 500;
    }
:is(.dropdown-menu.profile .dropdown-item):hover {
      background-color: var(--gray-50);
      color: #2c3e50;
      padding-left: 1.5rem;
    }
:is(.dropdown-menu.profile .dropdown-item):hover i {
        color: var(--primary-color);
      }
:is(.dropdown-menu.profile .dropdown-item):active {
      background-color: var(--gray-200);
      color: #2c3e50;
    }
/* Dividers */
.dropdown-menu.profile .dropdown-divider {
    margin: 0.35rem 0;
    border-top: 1px solid #f1f3f4;
  }
/* Dropdown header (Mis tiendas) */
:is(.dropdown-menu.profile .dropdown-headera) .dropdown-item {
      background: linear-gradient(135deg, var(--gray-50) 0%, #ffffff 100%);
      border-bottom: 1px solid #f1f3f4;
    }
:is(:is(.dropdown-menu.profile .dropdown-headera) .dropdown-item) i {
        color: var(--primary-color);
      }
:is(:is(.dropdown-menu.profile .dropdown-headera) .dropdown-item) span {
        font-weight: 600;
        color: #2c3e50;
      }
:is(:is(.dropdown-menu.profile .dropdown-headera) .dropdown-item):hover {
        background: linear-gradient(135deg, #e8f5e9 0%, var(--gray-50) 100%);
      }
/* Cerrar sesión - special styling */
.dropdown-menu.profile .dropdown-item[href*="sign_out"],.dropdown-menu.profile .dropdown-item[data-method="delete"] {
    color: var(--danger-color);
  }
:is(.dropdown-menu.profile .dropdown-item[href*="sign_out"],.dropdown-menu.profile .dropdown-item[data-method="delete"]) i {
      color: var(--danger-color);
    }
:is(.dropdown-menu.profile .dropdown-item[href*="sign_out"],.dropdown-menu.profile .dropdown-item[data-method="delete"]):hover {
      background-color: #ffebee;
      color: #b71c1c;
    }
:is(.dropdown-menu.profile .dropdown-item[href*="sign_out"],.dropdown-menu.profile .dropdown-item[data-method="delete"]):hover i {
        color: #b71c1c;
      }
/* ========================================================================== */
/* Nav Bottom - Navegación inferior móvil */
/* ========================================================================== */
.badge-notify {
  font-size: 10px !important;
  position: absolute;
  padding: 1px 6px;
  transform: translate(25%, -25%);
  border-radius: 50%;
  color: #ffffff;
  background-color: var(--danger-color);
  inset: 10px 35px auto auto;
}
.navbar {
  transition: transform 0.35s ease-in-out;
}
/* ========================================================================== */
/* Dashboard Layout - Estructura base del área de gestión */
/* ========================================================================== */
/* Layout para partner/staff: sidebar + content area */
/* ======================================== */
/* Main Content Area */
/* ======================================== */
#main {
  transition: margin-left 0.3s;
}
/* ======================================== */
/* Dashboard Container */
/* ======================================== */
.dashboard-container {
  min-height: calc(100vh - 60px);
  background-color: var(--gray-50);
}
/* ======================================== */
/* Dashboard Content */
/* ======================================== */
.dashboard-content {
  padding: 1.5rem;
}
@media (min-width: 768px) {
.dashboard-content {
    padding: 2rem;
}
  }
/* ======================================== */
/* Dashboard Header */
/* ======================================== */
.dashboard-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1.5rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.dashboard-header .dashboard-title {
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--gray-800);
    margin: 0;
  }
.dashboard-header .dashboard-actions {
    display: flex;
    gap: 0.5rem;
  }
/* ======================================== */
/* Dashboard Grid */
/* ======================================== */
.dashboard-grid {
  display: grid;
  gap: 1.5rem;
  grid-template-columns: 1fr;
}
@media (min-width: 768px) {
.dashboard-grid {
    grid-template-columns: repeat(2, 1fr);
}
  }
@media (min-width: 1200px) {
.dashboard-grid {
    grid-template-columns: repeat(3, 1fr);
}
  }
/* ======================================== */
/* Dashboard Panel */
/* ======================================== */
.dashboard-panel {
  background: #fff;
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}
.dashboard-panel .panel-header {
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--gray-200);
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
:is(.dashboard-panel .panel-header) .panel-title {
      font-size: 1rem;
      font-weight: 600;
      color: var(--gray-800);
      margin: 0;
    }
.dashboard-panel .panel-body {
    padding: 1.25rem;
  }
.dashboard-panel .panel-footer {
    padding: 1rem 1.25rem;
    border-top: 1px solid var(--gray-200);
    background: var(--gray-50);
  }
/* ======================================== */
/* Dashboard Stats Row */
/* ======================================== */
.dashboard-stats {
  display: grid;
  gap: 1rem;
  grid-template-columns: repeat(2, 1fr);
  margin-bottom: 1.5rem;
}
@media (min-width: 768px) {
.dashboard-stats {
    grid-template-columns: repeat(4, 1fr);
}
  }
/* ======================================== */
/* Empty State */
/* ======================================== */
.dashboard-empty {
  text-align: center;
  padding: 3rem 1.5rem;
  color: var(--gray-500);
}
.dashboard-empty .empty-icon {
    font-size: 3rem;
    margin-bottom: 1rem;
    opacity: 0.5;
  }
.dashboard-empty .empty-title {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--gray-700);
    margin-bottom: 0.5rem;
  }
.dashboard-empty .empty-description {
    font-size: 0.875rem;
    margin-bottom: 1.5rem;
  }
/* ========================================================================== */
/* Dashboard Stores Page */
/* ========================================================================== */
.dashboard-stores-page {
  padding: 1.5rem;
  max-width: 1200px;
  margin: 0 auto;
  margin-top: 60px;
}
@media (min-width: 768px) {
.dashboard-stores-page {
    padding: 2rem;
}
  }
/* Header */
.stores-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 2rem;
  flex-wrap: wrap;
  gap: 1rem;
}
.stores-header .header-content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.stores-header .page-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
}
.stores-header .staff-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.25rem 0.625rem;
  background: #dbeafe;
  color: #1d4ed8;
  font-size: 0.75rem;
  font-weight: 500;
  border-radius: 100px;
}
.stores-header .staff-badge i {
  font-size: 0.75rem;
}
/* Stores List - Horizontal Cards */
.stores-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
/* Store Row - Horizontal Card */
.store-row {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.25rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  transition: all 0.2s ease;
}
.store-row:hover {
  border-color: var(--gray-300);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
/* Store Deactivated State */
.store-row-deactivated {
  opacity: 0.6;
  background: var(--gray-50);
  border-style: dashed;
}
.store-row-deactivated:hover {
  opacity: 0.8;
}
/* Store Avatar */
.store-row-avatar {
  width: 56px;
  height: 56px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--gray-100);
}
.store-row-avatar img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.store-row-avatar .avatar-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--gray-100) 0%, var(--gray-200) 100%);
}
.store-row-avatar .avatar-placeholder i {
  font-size: 1.5rem;
  color: var(--gray-400);
}
/* Store Info */
.store-row-info {
  flex: 1;
  min-width: 0;
}
.store-row-name {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 0.25rem 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.store-row-address {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin: 0;
}
.store-row-address i {
  font-size: 0.75rem;
  color: var(--gray-400);
  flex-shrink: 0;
}
/* Store Stats - Inline */
.store-row-stats {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  flex-shrink: 0;
}
.store-row-stats .stat-item {
  display: flex;
  align-items: baseline;
  gap: 0.25rem;
}
.store-row-stats .stat-value {
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--gray-800);
}
.store-row-stats .stat-label {
  font-size: 0.75rem;
  color: var(--gray-500);
}
.store-row-stats .stats-separator {
  width: 4px;
  height: 4px;
  background: var(--gray-300);
  border-radius: 50%;
  margin: 0 0.5rem;
}
/* Store Actions */
.store-row-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}
.btn-row-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  padding: 0.5rem 0.875rem;
  font-size: 0.8125rem;
  font-weight: 500;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.15s ease;
  border: none;
}
.btn-row-action.btn-row-primary {
  background: var(--gray-800);
  color: #fff;
}
.btn-row-action.btn-row-primary:hover {
  background: var(--gray-900);
  color: #fff;
}
.btn-row-action.btn-row-icon {
  width: 36px;
  height: 36px;
  padding: 0;
  background: var(--gray-50);
  color: var(--gray-500);
  border: 1px solid var(--gray-200);
}
.btn-row-action.btn-row-icon:hover {
  background: var(--gray-100);
  color: var(--gray-700);
  border-color: var(--gray-300);
}
.btn-row-action.btn-row-danger:hover {
  background: #fef2f2;
  color: #dc2626;
  border-color: #fecaca;
}
.btn-row-action.btn-row-success {
  background: #dcfce7;
  color: #16a34a;
  border-color: #bbf7d0;
}
.btn-row-action.btn-row-success:hover {
  background: #bbf7d0;
  color: #15803d;
  border-color: #86efac;
}
/* Responsive - Tablet */
@media (max-width: 991px) {
  .store-row-stats {
    display: none;
  }
}
/* Responsive - Mobile */
@media (max-width: 640px) {
  .store-row {
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  .store-row-avatar {
    width: 48px;
    height: 48px;
  }

  .store-row-info {
    flex: 1;
    min-width: calc(100% - 60px);
  }

  .store-row-actions {
    width: 100%;
    justify-content: flex-end;
    padding-top: 0.5rem;
    border-top: 1px solid var(--gray-100);
    margin-top: 0.25rem;
  }

  .btn-row-action.btn-row-primary span {
    display: none;
  }

  .btn-row-action.btn-row-primary {
    width: 36px;
    height: 36px;
    padding: 0;
  }
}
/* Empty State */
.stores-empty {
  text-align: center;
  padding: 4rem 2rem;
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--gray-200);
}
.stores-empty .empty-illustration {
  width: 80px;
  height: 80px;
  margin: 0 auto 1.5rem;
  background: var(--gray-100);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.stores-empty .empty-illustration i {
  font-size: 2rem;
  color: var(--gray-400);
}
.stores-empty .empty-title {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 0.5rem 0;
}
.stores-empty .empty-description {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin: 0 0 1.5rem 0;
}
/* ==========================================================================
   6. Pages
   ========================================================================== */
/* ========================================================================== */
/* Home - Landing page styles */
/* ========================================================================== */
/* ======================================== */
/* Main Banner */
/* ======================================== */
.main-banner {
  padding: 200px 0 300px;
  min-height: 100vh;
  position: relative;
}
.js-parallax-scene {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.banner-img-wp {
  width: 100%;
  height: 100%;
  padding-left: 30px;
}
.banner-img {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: center;
  animation: border-radius-ani 4.5s linear infinite alternate;
  box-shadow: var(--shadow-sm);
}
/* ======================================== */
/* Banner Animation */
/* ======================================== */
@keyframes border-radius-ani {
  0% {
    border-radius: 48% 52% 57% 43% / 34% 44% 56% 66%;
  }
  25% {
    border-radius: 62% 38% 64% 36% / 34% 55% 45% 66%;
  }
  50% {
    border-radius: 43% 57% 51% 49% / 33% 42% 58% 67%;
  }
  100% {
    border-radius: 40% 60% 43% 57% / 52% 32% 68% 48%;
  }
}
/* ======================================== */
/* Banner Text & Shapes */
/* ======================================== */
.banner-img-text .h5-title {
  text-transform: capitalize;
  letter-spacing: 0.5px;
}
.banner-img-text {
  max-width: 400px;
}
.banner-shape-1 img {
  position: absolute;
  left: 85%;
  top: -50px;
  max-width: 330px;
  pointer-events: none;
}
.banner-shape-2 {
  top: auto !important;
  bottom: 0;
}
.banner-shape-2 img {
  position: absolute;
  bottom: 0;
  right: 82% !important;
  max-width: 410px;
  pointer-events: none;
}
.our-menu-shape img {
  position: absolute;
  left: 70%;
  top: -200px;
  pointer-events: none;
}
/* ======================================== */
/* FAQ Section */
/* ======================================== */
.faq-row {
  -moz-column-count: 3;
       column-count: 3;
  margin: 0 -5px;
}
.faq-box {
  border: 1px solid var(--gray-200);
  border-radius: 30px;
  background: linear-gradient(145deg, #e4e4e4, #ffffff);
  -moz-column-break-inside: avoid;
       break-inside: avoid;
  margin: 0px 5px 30px;
  box-shadow: 10px 10px 30px rgb(207 207 208 / 20%), -10px -10px 30px rgb(255 255 255 / 90%);
}
.faq-box .h4-title {
  padding: 16px 30px;
  border-bottom: 1px solid var(--gray-200);
  text-transform: capitalize;
  font-weight: 600;
}
.faq-box p {
  padding: 8px 30px 20px;
  margin: 0;
}
.faq-shape img {
  position: absolute;
  top: -100px;
  left: 82%;
  pointer-events: none;
}
/* ======================================== */
/* Background Pattern */
/* ======================================== */
.bg-pattern {
  background-image: url("/assets/blog-pattern-bg.png");
}
/* ======================================== */
/* Responsive - Home */
/* ======================================== */
@media (min-width: 1500px) {
  .container {
    max-width: 1368px;
  }
}
@media (min-width: 2100px) {
  .container {
    max-width: 1400px;
  }

  p,
  button,
  input {
    font-size: 18px;
    line-height: 32px;
  }
}
@media (max-width: 1199px) {
  .main-banner {
    padding: 200px 0;
  }

  .banner-img-wp {
    height: 360px;
  }

  .faq-box .h4-title {
    padding: 16px 20px;
  }

  .faq-box p {
    padding: 8px 20px 20px;
  }
}
@media (max-width: 991px) {
  .js-parallax-scene {
    display: none;
  }

  .main-banner {
    padding: 80px 0 10px;
  }

  .banner-img-wp {
    padding: 0;
    height: 75vw;
    padding-top: 50px;
  }

  .faq-row {
    -moz-column-count: 1;
         column-count: 1;
    margin: 0;
  }

  .faq-box {
    margin: 0;
    margin-bottom: 30px;
  }
}
@media (max-width: 767px) {
  .banner-img-wp {
    height: 75vw;
    min-height: 60vw;
    width: auto;
  }
}
@media (max-width: 575px) {

  .banner-img-wp {
    height: 90vw;
  }

  .faq-shape {
    display: none;
  }
}
@media (max-width: 400px) {
  .container {
    padding: 0 15px;
  }

  .our-menu-shape {
    display: none;
  }
}
/* ========================================================================== */
/* Login - Estilos de autenticación */
/* ========================================================================== */
/* ======================================== */
/* Form Style */
/* ======================================== */
.form-style {
  padding: 1rem;
  background-color: #fff;
  border-radius: 1.5rem;
  width: 100%;
  box-shadow: rgba(0, 0, 0, 0.35) 0px 5px 15px;
  transform: scale(0);
  transition: 0.5s ease-in-out;
  transition-delay: 1s;
}
.form-style button {
  cursor: pointer;
  width: 100%;
  padding: 0.6rem 0;
  border-radius: 0.5rem;
  border: none;
  background-color: var(--primary-color);
  color: #fff !important;
  font-size: 1.2rem;
  outline: none;
}
.form-style p {
  margin: 1rem 0;
  font-size: 0.7rem;
  text-align: center;
}
/* ======================================== */
/* Input Group Login */
/* ======================================== */
.input-group-login {
  position: relative;
  width: 100%;
  margin: 1rem 0;
}
/* Contenedor del input con icono */
.input-group-login .input-wrapper {
  position: relative;
  display: flex;
  align-items: center;
}
/* Icono del input - nueva estructura */
.input-group-login .input-icon {
  position: absolute;
  left: 1rem;
  font-size: 1.4rem;
  color: var(--gray-500);
  z-index: 1;
  pointer-events: none;
}
/* Icono legacy (i directamente en input-group-login) */
.input-group-login > i:first-child {
  position: absolute;
  top: 0.875rem;
  left: 1rem;
  font-size: 1.4rem;
  color: var(--gray-500);
  z-index: 1;
  pointer-events: none;
}
/* Wrapper de Simple Form */
.input-group-login > div {
  position: relative;
  width: 100%;
}
/* Input base */
.input-group-login input {
  width: 100%;
  padding: 1rem 1rem 1rem 3rem;
  font-size: 1rem;
  background-color: var(--gray-100);
  border: 1px solid transparent;
  border-radius: 0.375rem;
  outline: none;
  transition: border-color 0.2s ease, background-color 0.2s ease;
}
.input-group-login input:focus {
  border-color: var(--primary-color);
  background-color: #fff;
}
/* Padding específico para el input de contraseña */
.input-group-login input[type="password"] {
  padding-right: 3.5rem;
}
/* ======================================== */
/* Form Error States */
/* ======================================== */
/* Ocultar wrapper de field_with_errors de Rails (display: contents) */
.input-group-login .field_with_errors,
.phone-input-wrapper .field_with_errors,
.terms-wrapper .field_with_errors {
  display: contents;
}
/* Input con error */
.input-group-login .field_with_errors input,
.input-group-login input.is-invalid,
.phone-input-wrapper .field_with_errors input {
  border-color: #dc3545 !important;
  background-color: #fff !important;
}
/* Mensajes de error de Simple Form */
.input-group-login .error,
.input-group-login span.error,
.phone-input-wrapper .error,
.terms-wrapper .error {
  display: block;
  margin-top: 0.375rem;
  font-size: 0.75rem;
  color: #dc3545;
  line-height: 1.3;
}
/* ======================================== */
/* Phone Input Group */
/* ======================================== */
.phone-input-wrapper {
  margin: 1rem 0;
}
.phone-input-group {
  display: flex;
  align-items: stretch;
  gap: 0.5rem;
}
.phone-input-group .phone-prefix {
  display: flex;
  align-items: center;
  padding: 0 1rem;
  background-color: var(--gray-100);
  border: 1px solid transparent;
  border-radius: 0.375rem;
  font-size: 1rem;
  color: var(--gray-600);
  font-weight: 500;
  min-width: 60px;
  justify-content: center;
}
.phone-input-group .phone-field {
  flex: 1;
  position: relative;
}
.phone-input-group .phone-field .input-icon {
  position: absolute;
  left: 1rem;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.4rem;
  color: var(--gray-500);
  z-index: 1;
  pointer-events: none;
}
.phone-input-group input {
  width: 100%;
  padding: 1rem 1rem 1rem 3rem;
  font-size: 1rem;
  background-color: var(--gray-100);
  border: 1px solid transparent;
  border-radius: 0.375rem;
  outline: none;
  transition: border-color 0.2s ease;
}
.phone-input-group input:focus {
  border-color: var(--primary-color);
  background-color: #fff;
}
/* Phone con error */
.phone-input-wrapper.has-error .phone-prefix,
.phone-input-wrapper.has-error input,
.phone-input-wrapper .field_with_errors + .phone-input-group .phone-prefix,
.phone-input-wrapper .field_with_errors input {
  border-color: #dc3545 !important;
  background-color: #fff !important;
}
/* ======================================== */
/* Terms Checkbox Wrapper */
/* ======================================== */
.terms-wrapper {
  margin: 1rem 0;
}
.terms-wrapper .boolean {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 0;
}
.terms-wrapper label {
  font-size: 0.875rem;
  color: var(--gray-600);
  font-weight: normal;
  cursor: pointer;
  margin: 0;
}
/* ======================================== */
/* Google Button */
/* ======================================== */
.google-button {
  color: inherit;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 350px;
  margin: 0 auto;
  padding: 10px;
  border: 1px solid #dadce0;
  border-radius: 8px;
  background-color: #fff !important;
  color: #5f6368;
  font-weight: 500;
  text-decoration: none;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
  transition: background-color 0.3s ease, box-shadow 0.3s ease;
}
.google-button:hover {
  background-color: #f7f8f9;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
}
.google-icon img {
  width: 20px;
  height: 20px;
  margin-right: 5px;
}
.google-text {
  color: #202124;
  font-size: 12px;
}
/* ======================================== */
/* Icons */
/* ======================================== */
.icon-i {
  font-family: 'Font Awesome 5 Free' !important;
  font-weight: 900 !important;
  margin: 2px !important;
  padding: 0 !important;
}
.info-i {
  margin: -15px 0;
}
/* ======================================== */
/* Form (alternative) */
/* ======================================== */
.form {
  padding: 1rem;
  background-color: #fff;
  border-radius: 1.5rem;
  width: 100%;
}
.form .button {
  cursor: pointer;
  width: 100%;
  border-radius: 0.5rem;
  border: none;
  background-color: var(--primary-color);
  color: #fff;
  font-size: 1.2rem;
  outline: none;
}
.form p {
  margin: 1rem 0;
  font-size: 0.7rem;
  text-align: center;
}
/* ======================================== */
/* Password Toggle */
/* ======================================== */
.btn-toggle-password {
  position: absolute;
  right: 0.2rem;
  top: 50%;
  transform: translateY(-50%);
  background: none;
  border: none;
  cursor: pointer;
  font-size: 1.2rem;
  color: #555;
  padding: 0px 40px;
  z-index: 2;
  width: 2rem;
  height: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
.btn-toggle-password:focus {
  outline: none;
}
#bi-eye {
  position: absolute;
  right: 0.5rem;
  top: 50%;
  transform: translateY(-50%);
  cursor: pointer;
  color: #555;
  z-index: 3;
  font-size: 1.2rem;
}
/* ======================================== */
/* Green Checkbox */
/* ======================================== */
.green-checkbox {
  accent-color: var(--primary-color) !important;
}
.green-checkbox:checked {
  background-color: var(--primary-color) !important;
  border-color: var(--primary-color) !important;
}
.green-checkbox:focus {
  box-shadow: 0 0 0 0.2rem rgba(50, 183, 104, 0.25) !important;
  border-color: var(--primary-color) !important;
}
input[type="checkbox"].green-checkbox:checked::before {
  background-color: var(--primary-color) !important;
}
/* ======================================== */
/* Links primarios */
/* ======================================== */
.link-primary-color {
  color: var(--primary-color);
  text-decoration: none;
}
.link-primary-color:hover {
  color: #2a9d5a;
  text-decoration: underline;
}
/* ========================================================================== */
/* Cart - Carrito de compras */
/* ========================================================================== */
/* ======================================== */
/* Cart Buttons (Original) */
/* ======================================== */
.dis-btn,
.au-btn {
  width: 30px;
  height: 30px;
  padding: 0 !important;
}
.trash {
  padding-top: 5px;
  font-size: 18px;
}
.fixed-width {
  width: 50px !important;
  min-width: 50px !important;
  max-width: 50px !important;
  padding: 0;
  font-size: 12px;
}
.input-group input {
  height: 30px;
  background-color: whitesmoke;
}
.badge-align {
  margin-left: -10px;
  padding: 2px;
  opacity: 0.95;
}
/* ======================================== */
/* Ingredient Details (Original) */
/* ======================================== */
.ingredient-details .ingredient-list {
  display: block;
  max-height: 1.4em;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.ingredient-category-line {
  display: block;
}
/* Cuando expanded, el max-height se controla via JS inline style */
/* No usar max-height: none aquí porque rompe la transición */
.ingredient-details strong {
  font-weight: 600;
}
.show-more-btn {
  display: block;
  margin-top: 4px;
  font-size: 12px;
  color: var(--primary-color) !important;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-weight: 500;
  text-decoration: none !important;
  -webkit-tap-highlight-color: transparent;
}
.show-more-btn:hover,.show-more-btn:focus,.show-more-btn:active,.show-more-btn:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    color: var(--primary-color) !important;
    text-decoration: none !important;
  }
/* ======================================== */
/* Cart Page */
/* ======================================== */
.cart-page {
  color: var(--gray-800);
}
.cart-page .card.shadow-sm {
    border-radius: 16px;
    overflow: hidden;
    box-shadow: var(--shadow-md) !important;
  }
.cart-page .card-title {
    font-weight: 700;
    margin-bottom: 8px;
  }
.cart-page .list-group-item {
    border: 0;
    padding: 12px 0;
    display: flex;
    align-items: center;
  }
.cart-page .btn.btn-outline-secondary.dis-btn,.cart-page .btn.dis-btn {
    border: 0;
    background: var(--gray-100);
    color: var(--gray-700);
    border-radius: 999px;
    width: 28px;
    height: 28px;
    line-height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
.cart-page .btn.btn-outline-secondary.dis-btn:disabled {
    opacity: 0.5;
  }
.cart-page .quantity-input.fixed-width {
    background: var(--gray-100);
    border: 0;
    height: 28px;
    font-weight: 400;
  }
.cart-page .remove-item .trash {
    color: var(--gray-600);
  }
.cart-page .btn-group-vertical .btn {
    border-radius: 12px;
  }
/* ======================================== */
/* Cart Item Card */
/* ======================================== */
.cart-item {
  background: #fff;
  border-radius: 16px;
  padding: 14px;
  margin-bottom: 12px;
}
.cart-item-row {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
/* Imagen */
.cart-item-image {
  position: relative;
  flex-shrink: 0;
}
.cart-item-img {
  width: 70px;
  height: 70px;
  -o-object-fit: cover;
     object-fit: cover;
  border-radius: 12px;
}
/* Contenido */
.cart-item-content {
  flex: 1;
  min-width: 0;
}
.cart-item-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--gray-800);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.3;
  margin-bottom: 4px;
}
/* Precio */
.cart-item-price {
  text-align: right;
  flex-shrink: 0;
}
.cart-item-price .discounted-price {
  display: block;
  font-size: 16px;
  font-weight: 700;
  color: var(--primary-color);
}
.cart-item-price .original-price {
  display: block;
  font-size: 12px;
  color: var(--gray-400);
  text-decoration: line-through;
}
/* Footer: cantidad y botón otro */
.cart-item-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--gray-100);
}
.cart-item-quantity {
  width: auto;
  gap: 0;
}
/* Botón "Otro +" */
.add-another-btn {
  color: var(--primary-color);
  background: rgba(50, 183, 104, 0.1);
  border: none;
  border-radius: 8px;
  padding: 6px 10px;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.add-another-btn:hover {
    background: rgba(50, 183, 104, 0.15);
    text-decoration: none;
    color: var(--primary-color);
  }
/* ======================================== */
/* Add More Products Button */
/* ======================================== */
.cart-add-products-btn {
  display: inline-flex;
  align-items: center;
  text-align: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--gray-600);
  background: var(--gray-100);
  border: 1px solid var(--gray-200);
  border-radius: 20px;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.cart-add-products-btn i {
    font-size: 11px;
  }
.cart-add-products-btn:hover {
    background: var(--gray-200);
    color: var(--gray-700);
  }
.cart-add-products-btn:active {
    transform: scale(0.98);
  }
/* ======================================== */
/* Cart Sections (Summary, Chef, Payment) */
/* ======================================== */
.cart-section {
  background: white;
  border-radius: 16px;
  padding: 16px;
  margin-bottom: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.cart-section__title {
  font-size: 15px;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}
/* ======================================== */
/* Chef Recommendation */
/* ======================================== */
.cart-chef__content {
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.cart-chef__message {
  flex: 1;
  font-size: 13px;
  line-height: 1.5;
  color: var(--gray-600);
}
.cart-chef__product {
  flex-shrink: 0;
  text-align: center;
  min-width: 90px;
}
.cart-chef__product-figure {
  position: relative;
  margin: 0 0 8px;
}
.cart-chef__product-badge {
  position: absolute;
  top: -4px;
  right: -4px;
  background: var(--primary-color);
  color: white;
  font-size: 9px;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 6px;
  z-index: 2;
}
.cart-chef__product-img {
  width: 70px;
  height: 70px;
  border-radius: 12px;
  -o-object-fit: cover;
     object-fit: cover;
}
.cart-chef__product-price {
  font-size: 14px;
  font-weight: 700;
  color: var(--primary-color);
  margin-bottom: 6px;
}
.cart-chef__product-btn {
  font-size: 11px;
  font-weight: 600;
  color: var(--primary-color);
  background: rgba(50, 183, 104, 0.1);
  padding: 6px 10px;
  border-radius: 8px;
  text-decoration: none;
  border: none;
  cursor: pointer;
  display: inline-block;
}
.cart-chef__product-btn:hover {
    background: rgba(50, 183, 104, 0.15);
    text-decoration: none;
    color: var(--primary-color);
  }
/* Chef Placeholder / Loading */
.cart-chef__placeholder {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: var(--gray-50);
  border-radius: 12px;
}
.cart-chef__placeholder-spinner {
  width: 20px;
  height: 20px;
  border: 2px solid var(--gray-200);
  border-top-color: var(--primary-color);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}
.cart-chef__placeholder-text {
  font-size: 13px;
  color: var(--gray-500);
}
/* ======================================== */
/* Cart Summary */
/* ======================================== */
.cart-summary__row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  font-size: 14px;
  color: var(--gray-600);
  border-bottom: 1px solid var(--gray-50);
}
.cart-summary__row:last-child {
    border-bottom: none;
  }
.cart-summary__row--savings {
  color: var(--primary-color);
  font-weight: 500;
}
.cart-summary__row--fee .cart-summary__strikethrough {
  text-decoration: line-through;
  color: var(--gray-400);
}
.cart-summary__row--total {
  font-size: 16px;
  font-weight: 600;
  color: var(--gray-800);
  padding-top: 12px;
  margin-top: 4px;
  border-top: 1px solid var(--gray-200);
}
/* ======================================== */
/* Payment Buttons */
/* ======================================== */
.cart-payment__buttons {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.cart-payment__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 14px 20px;
  font-size: 15px;
  font-weight: 600;
  font-family: 'Poppins', sans-serif;
  border-radius: 12px;
  border: none;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.cart-payment__btn:hover {
    transform: translateY(-2px);
    text-decoration: none;
  }
.cart-payment__btn:active {
    transform: translateY(0);
  }
.cart-payment__btn i {
    font-size: 18px;
  }
.cart-payment__btn--presential {
  background: white;
  color: var(--gray-700);
  border: 1px solid var(--gray-200);
}
.cart-payment__btn--presential:hover {
    background: var(--gray-50);
    border-color: var(--gray-300);
    color: var(--gray-700);
  }
.cart-payment__btn-mp {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 52px;
  background: #FBE701;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.cart-payment__btn-mp:hover {
    transform: translateY(-2px);
    background: var(--gray-50);
    border-color: var(--gray-300);
  }
.cart-payment__btn-mp:active {
    transform: translateY(0);
  }
.cart-payment__mp-img {
  height: 70px;
  width: auto;
}
/* ======================================== */
/* QR Modal */
/* ======================================== */
.cart-qr-modal .modal-content {
  border-radius: 20px;
  border: none;
  box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
}
.cart-qr-modal .modal-header {
  border-bottom: none;
  padding: 20px 20px 10px;
}
.cart-qr-modal .modal-body {
  padding: 10px 20px 30px;
  text-align: center;
}
.cart-qr-modal__title {
  font-size: 16px;
  font-weight: 600;
  color: var(--gray-700);
  text-align: center;
  flex: 1;
}
.cart-qr-modal__savings {
  color: var(--primary-color);
  font-weight: 700;
}
.cart-qr-modal__image {
  max-width: 200px;
  margin: 0 auto 16px;
}
.cart-qr-modal__order {
  font-size: 14px;
  color: var(--gray-600);
  margin-bottom: 8px;
}
.cart-qr-modal__total {
  font-size: 18px;
  font-weight: 600;
  color: var(--primary-color);
}
/* ======================================== */
/* Floating Cart Bar (Keep existing) */
/* ======================================== */
.floating-cart-bar {
  position: fixed;
  bottom: 95px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1000;
  width: calc(100% - 32px);
  max-width: 420px;
}
.floating-cart-bar .floating-cart-link {
    display: block;
    text-decoration: none;
    background: rgba(0.5, 0.4, 0.1, 0.1);
    border-radius: 14px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.25), 0 2px 8px rgba(0, 0, 0, 0.1);
    transition: all 0.2s ease;
    margin: 0 20px;
    backdrop-filter: blur(10px);
  }
:is(.floating-cart-bar .floating-cart-link):hover {
      transform: translateY(-2px);
      box-shadow: 0 6px 24px rgba(0, 0, 0, 0.3), 0 4px 12px rgba(0, 0, 0, 0.1);
      background: rgba(0, 0, 0, 0.45);
    }
:is(.floating-cart-bar .floating-cart-link):active {
      transform: translateY(0);
    }
.floating-cart-bar .floating-cart-content {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 16px;
  }
.floating-cart-bar .floating-cart-info {
    display: flex;
    align-items: center;
    gap: 10px;
  }
.floating-cart-bar .floating-cart-badge {
    background: rgba(255, 255, 255, 0.95);
    color: var(--gray-800);
    font-size: 12px;
    font-weight: 700;
    min-width: 24px;
    height: 24px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0 6px;
  }
.floating-cart-bar .floating-cart-text {
    color: rgba(255, 255, 255, 0.9);
    font-size: 12px;
    font-weight: 500;
  }
.floating-cart-bar .floating-cart-action {
    display: flex;
    align-items: center;
    gap: 8px;
  }
.floating-cart-bar .floating-cart-total {
    color: #fff;
    font-size: 15px;
    font-weight: 700;
  }
.floating-cart-bar .floating-cart-button {
    background: rgba(255, 255, 255, 0.95);
    color: var(--gray-800);
    padding: 6px 12px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 600;
    display: flex;
    align-items: center;
  }
:is(.floating-cart-bar .floating-cart-button) i {
      font-size: 10px;
    }
/* ======================================== */
/* Legacy Styles (Keep for compatibility) */
/* ======================================== */
.disable-dbl-tap-zoom {
  touch-action: manipulation;
}
/* Keep old class mappings for JS that references them */
.discounted-price {
  color: var(--primary-color);
  font-weight: bold;
}
.original-price {
  text-decoration: line-through;
  color: var(--gray-400);
}
.title-product {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}
/* ========================================================================== */
/* Chat - Interfaz de chat */
/* ========================================================================== */
*,
*::before,
*::after {
  box-sizing: border-box;
}
/* ======================================== */
/* Chat Container */
/* ======================================== */
.chat-container {
  height: 100dvh;
  display: flex;
  justify-content: center;
  background: var(--dark-bg);
}
.chat-inner {
  width: 100%;
  max-width: 900px;
  display: flex;
  flex-direction: column;
}
/* ======================================== */
/* Messages Container */
/* ======================================== */
.messages-container {
  flex: 1;
  overflow-y: auto;
  margin-top: 65px;
  padding: 0 1rem 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  scroll-behavior: smooth;
}
.messages-container .empty-state {
    margin: auto;
    font-size: 0.9375rem;
    text-align: center;
  }
#messagesList {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
#messagesList  > turbo-frame {
    order: unset;
  }
/* ======================================== */
/* Message Bubbles */
/* ======================================== */
.message {
  max-width: 70%;
  padding: 0.75rem 1rem;
  border-radius: 18px;
  font-size: 0.9375rem;
  line-height: 1.5;
  animation: fadeIn 0.25s ease-out;
}
.message.user {
    margin-left: auto;
    background: var(--dark-accent);
    color: #fff;
    border-bottom-right-radius: 4px;
  }
.message.assistant {
    background: var(--dark-surface);
    color: var(--dark-text);
    border: 1px solid var(--dark-border);
    border-bottom-left-radius: 4px;
    width: 100%;
    max-width: 100%;
  }
.message.tool {
    align-self: center;
    max-width: 60%;
    font-size: 0.8125rem;
    color: var(--dark-muted);
    background: transparent;
    border: none;
  }
.message .message-meta {
    margin-top: 0.25rem;
    font-size: 0.6875rem;
    color: var(--dark-muted);
    text-align: right;
  }
/* ======================================== */
/* Message Form */
/* ======================================== */
.message-form {
  position: sticky;
  bottom: 0;
  background: var(--dark-bg);
  border-top: 1px solid rgba(224, 224, 224, 0.1);
  padding: 0.75rem 1rem calc(0.75rem + env(safe-area-inset-bottom)) 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  z-index: 10;
}
.preview-list {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  max-height: 120px;
  overflow-y: auto;
}
.preview-list .preview-item {
    position: relative;
    width: 60px;
    height: 60px;
    border: 1px solid var(--dark-border);
    border-radius: 6px;
    background: var(--dark-surface) center/cover;
    font-size: 12px;
    color: var(--dark-text);
    display: flex;
    align-items: center;
    justify-content: center;
  }
.inputs-row {
  display: flex;
  align-items: flex-end;
  gap: 0.5rem;
}
/* ======================================== */
/* File Button */
/* ======================================== */
.file-btn {
  position: relative;
  flex: 0 0 44px;
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: var(--dark-surface);
  cursor: pointer;
}
.file-btn::before {
    content: "📎";
    font-size: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    inset: 0;
    color: var(--dark-text);
  }
.file-btn input.attachment-input {
    position: absolute;
    inset: 0;
    opacity: 0;
    cursor: pointer;
  }
/* ======================================== */
/* Textarea */
/* ======================================== */
.chat-container textarea {
  flex: 1;
  background: var(--dark-surface);
  color: var(--dark-text);
  border: 1px solid var(--dark-border);
  border-radius: 20px;
  padding: 0.625rem 1rem;
  font-size: 0.9375rem;
  line-height: 1.4;
  resize: none;
  max-height: 120px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
:is(.chat-container textarea):focus {
    outline: none;
    border-color: var(--dark-accent);
    box-shadow: 0 0 0 2px rgba(50, 183, 104, 0.25);
  }
/* ======================================== */
/* Send Button */
/* ======================================== */
.send-button {
  flex: 0 0 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--dark-accent);
  color: #fff;
  border: none;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}
.send-button:hover:not(:disabled) {
    background: var(--dark-accent-hover);
  }
.send-button:disabled {
    opacity: 0.4;
    cursor: not-allowed;
  }
.send-button .send-icon {
    width: 20px;
    height: 20px;
  }
/* ======================================== */
/* Markdown Content */
/* ======================================== */
.markdown-content table {
    width: 100%;
    border-collapse: collapse;
    margin: 1rem 0;
    font-size: 0.9rem;
    color: #fff;
  }
.markdown-content th {
    padding: 0.5rem 0.75rem;
    background: #333;
    font-weight: 600;
    color: #ddd;
    border-bottom: 1px solid #444;
    text-align: left;
  }
.markdown-content td {
    padding: 0.5rem 0.75rem;
    border-bottom: 1px solid #444;
  }
.markdown-content tr:last-child td {
    border-bottom: none;
  }
.markdown-content a {
    color: var(--dark-text) !important;
    text-decoration: underline;
  }
:is(.markdown-content a):hover {
      text-decoration: none;
    }
/* ======================================== */
/* Animations */
/* ======================================== */
@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(6px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.thinking {
  display: inline-block;
  color: var(--dark-muted);
}
.thinking::after {
    content: "●●●";
    animation: typing 1.2s steps(4, end) infinite;
  }
@keyframes typing {
  0% {
    opacity: 0.1;
  }
  25% {
    opacity: 0.5;
  }
  50% {
    opacity: 1;
  }
  75% {
    opacity: 0.5;
  }
  100% {
    opacity: 0.1;
  }
}
/* ======================================== */
/* Scrollbar (Chat) */
/* ======================================== */
:is(.chat-container,.chat-messages)::-webkit-scrollbar {
    width: 8px;
  }
:is(.chat-container,.chat-messages)::-webkit-scrollbar-track {
    background: var(--dark-bg);
  }
:is(.chat-container,.chat-messages)::-webkit-scrollbar-thumb {
    background: var(--dark-border);
    border-radius: 4px;
  }
:is(:is(.chat-container,.chat-messages)::-webkit-scrollbar-thumb):hover {
      background: #2a2a2a;
    }
/* ======================================== */
/* Preview Remove Button */
/* ======================================== */
.preview-remove {
  position: absolute;
  top: -6px;
  right: -6px;
  width: 18px;
  height: 18px;
  border: none;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  font-size: 12px;
  line-height: 18px;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.preview-remove:hover {
  background: rgba(0, 0, 0, 0.8);
}
/* ======================================== */
/* Upload Placeholder */
/* ======================================== */
.upload-placeholder {
  position: sticky;
  bottom: 0;
  align-self: flex-end;
  max-width: 85%;
  margin-left: auto;
  background: rgba(50, 183, 104, 0.4);
  color: #fff;
  padding: 0.75rem 1rem;
  border-radius: 8px;
  font-size: 14px;
  opacity: 0.8;
}
.upload-placeholder::after {
    content: "";
    display: inline-block;
    width: 16px;
    height: 16px;
    margin-left: 8px;
    border: 2px solid #fff;
    border-top-color: transparent;
    border-radius: 50%;
    animation: ph-spin 0.8s linear infinite;
    vertical-align: -3px;
  }
@keyframes ph-spin {
  to {
    transform: rotate(360deg);
  }
}
/* ======================================== */
/* Mobile Responsive */
/* ======================================== */
@media (max-width: 600px) {
  .chat-inner {
    max-width: 100%;
  }

  .message-form {
    padding: 0.5rem 0.75rem calc(0.5rem + env(safe-area-inset-bottom)) 0.75rem;
  }

  .chat-container textarea {
    font-size: 14px;
  }

  .file-btn::before {
    font-size: 18px;
  }
}
/* ========================================================================== */
/* PWA - Progressive Web App styles */
/* ========================================================================== */
/* ======================================== */
/* Placeholder PWA */
/* ======================================== */
.placeholder-pwa {
  position: absolute;
  margin-top: 78px;
  width: 100%;
}
@media (min-width: 992px) {
  .placeholder-pwa {
    top: 74px;
    left: 300px;
    max-width: 960px;
    margin: 0 auto;
  }
}
/* ======================================== */
/* Install Button */
/* ======================================== */
.install-button {
  font-size: 0.9rem;
  background-color: #F5F2F0;
  color: #000;
  border: none;
  padding: 10px 20px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  cursor: pointer;
}
.install-button:hover {
  background: linear-gradient(90deg, #a9a9a9, #808080);
  box-shadow: 0px 6px 10px rgba(0, 0, 0, 0.10);
}
.install-button:active {
  transform: scale(0.98);
}
/* ======================================== */
/* Instruction Icon */
/* ======================================== */
.instruction-icon {
  font-size: 20px;
  vertical-align: middle;
  margin-left: 0px;
}
/* ======================================== */
/* Install Modal */
/* ======================================== */
.install-modal {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: #212529 !important;
  padding: 20px;
  border-top: 1px solid #ccc;
  border-radius: 20px 20px 0 0;
  box-shadow: 0 -2px 6px rgba(0, 0, 0, 0.1);
  z-index: 300;
  animation: slideUp 0.5s ease-out;
}
@keyframes slideUp {
  from {
    transform: translateY(100%);
  }
  to {
    transform: translateY(0);
  }
}
/* ======================================== */
/* Close Modal Button */
/* ======================================== */
.close-modal {
  position: absolute;
  top: 10px;
  right: 10px;
  background: none;
  border: none;
  font-size: 24px;
  color: #999;
  cursor: pointer;
  font-weight: bold;
}
.close-modal:hover {
  color: #000;
}
/* ======================================== */
/* Modal Header */
/* ======================================== */
.modal-header {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}
.modal-icon {
  width: 40px;
  height: 40px;
  margin-right: 10px;
}
.modal-title {
  margin: 0;
  font-size: 18px;
  padding-left: 4px;
  color: #F5F2F0;
}
.modal-subtitle {
  margin: 0;
  font-size: 14px;
  color: #F5F2F0;
}
/* ======================================== */
/* Instructions List */
/* ======================================== */
.instructions-list {
  list-style: none;
  padding: 0;
  margin: 0 0 15px 0;
  font-size: 14px;
  color: #F5F2F0;
}
/* ======================================== */
/* Modal Buttons */
/* ======================================== */
.modal-button {
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 16px;
}
.install-now {
  background-color: #28a745;
  color: white;
  font-weight: bold;
}
.install-now:hover {
  background-color: #218838;
}
/* ========================================================================== */
/* Stores Public - Vista pública de tiendas */
/* ========================================================================== */
/* ======================================== */
/* Icon Fonts */
/* ======================================== */
@font-face {
  font-family: Glyphter;
  src: url("/assets/icon_fonts/font/Glyphter-8810300d.eot");
  src: url("/assets/icon_fonts/font/Glyphter-8810300d.eot?#iefix") format("embedded-opentype"),
       url("/assets/icon_fonts/font/Glyphter-539c8da3.woff") format("woff"),
       url("/assets/icon_fonts/font/Glyphter-b0d01c81.ttf") format("truetype"),
       url("/assets/icon_fonts/font/Glyphter-1ca5029e.svg#Glyphter") format("svg");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'food';
  src: url("/assets/icon_fonts/font/food-569472ef.eot");
  src: url("/assets/icon_fonts/font/food-569472ef.eot?#iefix") format("embedded-opentype"),
       url("/assets/icon_fonts/font/food-b0c0c0e1.woff") format("woff"),
       url("/assets/icon_fonts/font/food-a438460c.ttf") format("truetype"),
       url("/assets/icon_fonts/font/food-2ae16ff9.svg#food") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: 'ElegantIcons';
  src: url("/assets/icon_fonts/font/ElegantIcons-55d6114a.eot");
  src: url("/assets/icon_fonts/font/ElegantIcons-55d6114a.eot?#iefix") format("embedded-opentype"),
       url("/assets/icon_fonts/font/ElegantIcons-316612b5.woff") format("woff"),
       url("/assets/icon_fonts/font/ElegantIcons-8c6bc50e.ttf") format("truetype"),
       url("/assets/icon_fonts/font/ElegantIcons-c5a02456.svg#ElegantIcons") format("svg");
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
/* ======================================== */
/* Icon Classes */
/* ======================================== */
.arrow_carrot-right,
.icon_close,
.icon_adjust-vert,
.icon_lock_alt,
.icon_house_alt,
.icon_mobile,
.icon_mail_alt,
.icon_pin_alt {
  font-family: 'ElegantIcons';
  font-style: normal;
  font-weight: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;
  -webkit-font-smoothing: antialiased;
}
.arrow_carrot-right:before { content: "\35"; }
.icon_close:before { content: "\4d"; }
.icon_adjust-vert:before { content: "\67"; }
.icon_lock_alt:before { content: "\7e"; }
.icon_house_alt:before { content: "\e009"; }
.icon_mobile:before { content: "\e00b"; }
.icon_mail_alt:before { content: "\e010"; }
.icon_pin_alt:before { content: "\e01d"; }
.icon-food_icon_delivery:before { content: '\0074'; }
/* ======================================== */
/* Page Header */
/* ======================================== */
.page_header {
  padding: 20px 0 20px 0;
  background-color: #f4f4f4;
}
@media (max-width: 767px) {
  .page_header {
    padding: 15px 0;
  }
}
.page_header h1 {
  font-size: 18px;
  font-size: 1.125rem;
  margin: 0;
}
@media (max-width: 767px) {
  .page_header h1 {
    font-size: 16px;
    font-size: 1rem;
  }
}
/* ======================================== */
/* Breadcrumbs */
/* ======================================== */
.breadcrumbs {
  line-height: 1;
  color: #555;
}
.breadcrumbs ul {
  margin: 5px 0 5px 0;
  padding: 0;
  font-size: 12px;
  font-size: 0.75rem;
}
.breadcrumbs ul li {
  display: inline-block;
  margin-right: 5px;
  padding-right: 10px;
  position: relative;
}
.breadcrumbs ul li a {
  color: #777;
}
.breadcrumbs ul li a:hover {
  color: var(--primary-color);
}
.breadcrumbs ul li:after {
  font-family: 'ElegantIcons';
  content: "\35";
  font-size: 16px;
  font-size: 1rem;
  position: absolute;
  top: -3px;
}
.breadcrumbs ul li:last-child {
  font-weight: 500;
}
.breadcrumbs ul li:last-child:after {
  content: '';
  margin-right: 0;
}
/* ======================================== */
/* Search Bar */
/* ======================================== */
.search_bar_list {
  position: relative;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
  color: var(--primary-color);
}
.search_bar_list input[type='text'] {
  border: 0;
  height: 40px;
  border-radius: 3px;
  padding-left: 15px;
}
.search_bar_list input[type='submit'] {
  position: absolute;
  right: -1px;
  color: #fff;
  font-weight: 600;
  top: 0;
  border: 0;
  padding: 0 15px;
  height: 40px;
  cursor: pointer;
  border-radius: 0 3px 3px 0;
  background-color: #35a765;
  transition: all 0.3s ease-in-out;
}
.search_bar_list input[type='submit']:hover {
  background-color: #3db760;
}
.search_bar_list input[type='submit']:focus {
  box-shadow: none;
}
/* ======================================== */
/* Empty State */
/* ======================================== */
.empty-state {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 400px;
  padding: 40px 20px;
}
.empty-state-content {
  text-align: center;
  max-width: 400px;
}
.empty-state-icon {
  font-size: 4rem;
  color: #e0e0e0;
  margin-bottom: 20px;
}
.empty-state-content h3 {
  font-size: 1.5rem;
  font-weight: 600;
  color: #333;
  margin-bottom: 10px;
}
.empty-state-content p {
  color: #666;
  line-height: 1.6;
  margin-bottom: 8px;
}
.empty-state-suggestion {
  font-weight: 500;
  color: var(--primary-color);
}
/* ======================================== */
/* Store Cards */
/* ======================================== */
.store-card {
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  margin-bottom: 24px;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
  position: relative;
}
.store-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 8px 25px rgba(0, 0, 0, 0.12);
  }
.store-card.modern {
    border: 1px solid rgba(0, 0, 0, 0.05);
  }
.store-card-header {
  height: 160px;
  overflow: hidden;
  background: linear-gradient(135deg, #f5f5f5 0%, #e0e0e0 100%);
}
.store-card-header-link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.store-card-header-link:hover {
    text-decoration: none;
    color: inherit;
  }
.store-header-img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.store-header-img.fade-in {
    opacity: 1;
    transition: opacity 0.4s ease-in-out;
  }
.store-header-img.invisible {
    opacity: 0;
  }
/* ======================================== */
/* Store Badges */
/* ======================================== */
.store-badges {
  position: absolute;
  top: 10px;
  left: 8px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.status-badge {
  background: rgba(0, 0, 0, 0.7);
  color: white;
  padding: 3px 10px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 500;
  backdrop-filter: blur(10px);
}
.status-badge.closed {
    background: rgba(220, 53, 69, 0.9);
  }
.discount-badge {
  background: linear-gradient(135deg, #d34343, #ee5a52);
  color: white;
  padding: 2px 12px;
  border-radius: 20px;
  font-size: 0.70rem;
  font-weight: 400;
  box-shadow: 0 2px 8px rgba(238, 90, 82, 0.3);
  margin-left: auto;
}
/* ======================================== */
/* Store Avatar */
/* ======================================== */
.store-avatar-logo {
  position: absolute;
  bottom: 60px;
  right: 16px;
  width: 85px;
  height: 85px;
  border-radius: 50%;
  background: white;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  z-index: 3;
  border: 3px solid white;
  opacity: 0;
  transition: opacity 0.4s ease-in-out;
}
.store-avatar-logo img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    border-radius: 50%;
  }
.avatar-placeholder {
  color: #999;
  font-size: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
}
/* ======================================== */
/* Store Card Body */
/* ======================================== */
.store-card-body {
  padding: 12px;
  padding-top: 10px;
}
.store-info {
  margin-bottom: 10px;
}
.store-name {
  font-size: 14px;
  font-weight: 500;
  margin-bottom: 2px;
  margin-right: 70px;
  line-height: 1.3;
  color: #1a1a1a;
}
.store-link {
  color: inherit;
  text-decoration: none;
  transition: color 0.2s ease;
}
.store-link:hover {
    color: var(--primary-color);
    text-decoration: none;
  }
.store-description {
  color: #666;
  font-size: 12px;
  line-height: 1.4;
  margin: 0;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
/* ======================================== */
/* Store Meta */
/* ======================================== */
.store-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
}
.meta-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 0.8rem;
  color: #666;
}
.meta-item i {
    font-size: 0.9rem;
  }
.meta-item.distance i {
    color: var(--primary-color);
  }
.meta-item.delivery .delivery-active {
      color: var(--primary-color);
    }
.meta-item.delivery .delivery-inactive {
      color: #ccc;
    }
.active:is(.meta-item.delivery .delivery-text) {
        color: var(--primary-color);
        font-weight: 500;
      }
.inactive:is(.meta-item.delivery .delivery-text) {
        color: #999;
        text-decoration: line-through;
      }
.meta-item.rating {
    margin-left: auto;
  }
.rating-stars {
  display: flex;
  gap: 2px;
}
.rating-stars i {
    color: #ffc107;
    font-size: 0.75rem;
  }
.rating-text {
  font-weight: 600;
  color: #333;
  margin-left: 4px;
}
/* ======================================== */
/* Skeleton Loader */
/* ======================================== */
.store-skeleton {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, #f0f0f0 25%, #e0e0e0 50%, #f0f0f0 75%);
  background-size: 200% 100%;
  animation: loading 1.5s infinite;
}
.skeleton-shimmer {
  width: 100%;
  height: 100%;
  background: inherit;
}
@keyframes loading {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}
/* ======================================== */
/* Filter Column */
/* ======================================== */
.filter_col {
  border: 1px solid #ededed;
  padding: 12px;
  margin-bottom: 20px;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
}
@media (max-width: 991px) {
  .filter_col {
    overflow: auto;
    transform: translateX(-200%);
    top: 0;
    left: -100%;
    bottom: 0;
    width: 45%;
    height: 100%;
    position: fixed !important;
    background-color: #fff;
    z-index: 99999999 !important;
    margin: 0;
    transition: all 0.5s cubic-bezier(0.77, 0, 0.175, 1);
  }

    .filter_col.show {
      transform: translateX(0);
      left: 0;
      border: 0;
    }
}
@media (max-width: 767px) {
  .filter_col {
    width: 100%;
  }
}
.filter_col .inner_bt {
  border-bottom: 1px solid #ededed;
  text-align: right;
  margin: -10px -15px 15px -15px;
  padding: 0 8px;
  display: none;
}
@media (max-width: 991px) {
  .filter_col .inner_bt {
    display: block;
  }
}
.filter_col .inner_bt i {
  font-size: 36px;
  font-size: 2.25rem;
  color: #999;
}
.filter_col .inner_bt i:hover {
  color: #111;
}
/* ======================================== */
/* Filter Type */
/* ======================================== */
.filter_type {
  border-bottom: 1px solid #ededed;
  margin: 0 -15px 10px -15px;
  padding: 0 15px;
}
.filter_type label {
  font-weight: 400;
  font-size: 13px;
}
.filter_type label small {
  float: right;
  color: #777;
  padding-top: 2px;
  font-size: 10px;
}
.filter_type ul {
  list-style: none;
  padding: 6px 8px 4px 8px;
  margin: 0;
}
.filter_type ul li {
  margin-bottom: 4px;
}
.filter_type h4 {
  margin: 0;
}
.filter_type h4 a {
  display: block;
  font-size: 13px;
  color: #444;
  font-weight: 500;
  padding: 8px 10px;
  margin: -5px -5px 0 -5px;
  line-height: 1;
  position: relative;
}
:is(.filter_type h4 a):after {
    transition: all 0.3s ease-in-out;
    font-family: 'ElegantIcons';
    font-size: 20px;
    position: absolute;
    right: 3px;
    top: 0;
  }
.opened:is(.filter_type h4 a) {
    background-color: #f8f8f8;
  }
.opened:is(.filter_type h4 a):after {
      content: "\33";
      transform: rotate(180deg);
    }
.closed:is(.filter_type h4 a):after {
    content: "\33";
    transform: rotate(0);
  }
/* ======================================== */
/* Map */
/* ======================================== */
.map {
  width: 100%;
  height: 500px;
}
/* ======================================== */
/* Map Marker Popup */
/* ======================================== */
.map-popup {
  position: relative;
  width: 150px;
  font-family: 'Poppins', sans-serif;
}
.map-popup-close {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 23px;
  height: 23px;
  padding: 3px;
  border: none;
  background: rgba(0, 0, 0, 0.5);
  color: white;
  font-size: 12px;
  border-radius: 50%;
  cursor: pointer;
  z-index: 10;
  transition: background 0.2s;
}
.map-popup-close:hover {
  background: rgba(0, 0, 0, 0.7);
}
.map-popup-image {
  display: block;
  position: relative;
  width: 100%;
  height: 80px;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 6px;
}
.map-popup-image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  transition: transform 0.2s ease;
}
.map-popup-image:hover img {
  transform: scale(1.05);
}
.map-popup-discount {
  position: absolute;
  bottom: 6px;
  left: 6px;
  background: linear-gradient(135deg, #ff3b30, #ff6b6b);
  color: white;
  font-size: 9px;
  font-weight: 600;
  padding: 3px 6px;
  border-radius: 4px;
  text-transform: uppercase;
}
.map-popup-name {
  font-size: 12px;
  font-weight: 600;
  color: #1f2937;
  margin: 0;
  line-height: 1.2;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Override Google Maps InfoWindow styles */
.gm-style-iw-c {
  padding: 8px !important;
  border-radius: 10px !important;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1) !important;
}
.gm-style-iw-d {
  overflow: hidden !important;
}
.gm-style-iw-tc::after {
  background: white !important;
}
/* Hide default close button */
.gm-style-iw-c > button,
.gm-style-iw-chr {
  display: none !important;
}
/* ======================================== */
/* Buttons */
/* ======================================== */
a.btn_map {
  display: block;
  background-color: #ccc;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin-bottom: 15px;
  height: 100px;
  border-radius: 3px;
  overflow: hidden;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
}
@media (max-width: 991px) {
  a.btn_map {
    display: none !important;
  }
}
a.btn_map span {
  background-color: #121921;
  color: #fff;
  padding: 5px 10px;
  font-weight: 500;
  font-size: 13px;
  font-size: 0.8125rem;
  border-radius: 3px;
}
a.btn_filters {
  border: 1px solid #ededed;
  display: none;
  padding: 10px;
  border-radius: 3px;
  height: 42px;
}
a.btn_filters span {
  display: none;
}
a.btn_filters i {
  font-size: 21px;
  font-size: 1.3125rem;
  color: #444;
}
@media (max-width: 991px) {
  a.btn_filters {
    float: right;
    display: block !important;
    margin: 0 0 0 5px;
    background: none;
  }
}
/* ======================================== */
/* Form Checkbox */
/* ======================================== */
.container_check {
  display: block;
  position: relative;
  padding-left: 26px;
  line-height: 1.4;
  margin-bottom: 8px;
  cursor: pointer;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  font-size: 13px;
  color: #555;
}
.container_check input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}
.container_check input:checked ~ .checkmark {
  background-color: var(--primary-color);
  border: 1px solid transparent;
}
.container_check .checkmark {
  position: absolute;
  top: 0;
  left: 0;
  height: 18px;
  width: 18px;
  border: 1px solid #d2d8dd;
  background-color: #fff;
  border-radius: 3px;
  transition: all 0.2s ease;
}
.container_check .checkmark:after {
  content: "";
  position: absolute;
  display: none;
  left: 6px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid white;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.container_check input:checked ~ .checkmark:after {
  display: block;
}
/* ======================================== */
/* Spacing Utilities */
/* ======================================== */
.margin_30_40 {
  padding-top: 30px;
}
.add_bottom_15 {
  padding-bottom: 15px;
}
.add_bottom_25 {
  padding-bottom: 25px;
}
.mb_5 {
  margin-bottom: 5px;
}
/* ========================================================================== */
/* Orders Manage - Gestión de órdenes (Dashboard) */
/* ========================================================================== */
/* ======================================== */
/* Fixed Scanner Header */
/* ======================================== */
.paid-order-index .fixed-scanner-header {
    background: linear-gradient(135deg, #ffffff 0%, var(--gray-50) 100%);
    border-bottom: 1px solid var(--gray-300);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
  }
:is(.paid-order-index .fixed-scanner-header) .scanner-card {
      border: none;
      border-radius: 12px;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
      margin: 1rem;
      overflow: hidden;
      background-color: #fff;
    }
:is(:is(.paid-order-index .fixed-scanner-header) .scanner-card) .card-body {
        padding: 1.5rem;
      }
:is(.paid-order-index .fixed-scanner-header) .validation-form {
      background-color: var(--gray-50);
      border-radius: 8px;
      margin: 1rem;
    }
:is(:is(.paid-order-index .fixed-scanner-header) .validation-form) .form-control {
        border-radius: 6px;
        border: 1px solid var(--gray-300);
      }
:is(:is(:is(.paid-order-index .fixed-scanner-header) .validation-form) .form-control):focus {
          border-color: #0d6efd;
          box-shadow: 0 0 0 0.2rem rgba(13, 110, 253, 0.25);
        }
/* Kitchen controls - nuevo layout */
:is(.paid-order-index .fixed-scanner-header) .kitchen-controls {
      display: flex;
      align-items: center;
      gap: 1rem;
      flex-wrap: wrap;
    }
:is(.paid-order-index .fixed-scanner-header) .kitchen-buttons {
      display: flex;
      gap: 0.5rem;
      flex-shrink: 0;
    }
/* El form element necesita flex: 1 para expandirse */
:is(.paid-order-index .fixed-scanner-header) form:has(.kitchen-form) {
      flex: 1;
      min-width: 300px;
    }
:is(.paid-order-index .fixed-scanner-header) .kitchen-form {
      display: flex;
      gap: 0.75rem;
      align-items: flex-start;
    }
:is(:is(.paid-order-index .fixed-scanner-header) .kitchen-form) .string {
        flex: 1;
        margin-bottom: 0;
        min-width: 0;
      }
:is(:is(.paid-order-index .fixed-scanner-header) .kitchen-form) .form-control-dashboard {
        width: 100%;
      }
:is(:is(.paid-order-index .fixed-scanner-header) .kitchen-form) .btn-dashboard {
        flex-shrink: 0;
        height: 42px;
      }
@media (max-width: 768px) {
      :is(.paid-order-index .fixed-scanner-header) .kitchen-controls {
        flex-direction: column;
        align-items: stretch;
      }

      :is(.paid-order-index .fixed-scanner-header) .kitchen-buttons {
        justify-content: flex-start;
      }

      :is(.paid-order-index .fixed-scanner-header) .kitchen-form {
        width: 100%;
      }

        :is(:is(.paid-order-index .fixed-scanner-header) .kitchen-form) .btn-dashboard {
          width: auto;
        }
    }
/* ======================================== */
/* Orders List */
/* ======================================== */
:is(.paid-order-index .orders-list) .order-card {
      border: 2px solid var(--primary-color);
      border-radius: 12px;
      box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
      overflow: hidden;
      transition: all 0.3s ease;
      background-color: #fff;
    }
:is(:is(.paid-order-index .orders-list) .order-card):hover {
        box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
        transform: translateY(-2px);
      }
.order-presencial:is(:is(.paid-order-index .orders-list) .order-card) {
        border: 2px solid #64748b;
      }
.order-notified:is(:is(.paid-order-index .orders-list) .order-card) {
        border-left: 4px solid #198754;
        opacity: 0.6;
        background-color: rgb(244, 244, 244);
      }
.order-notified:is(:is(.paid-order-index .orders-list) .order-card) .order-header {
          background: linear-gradient(135deg, #d4edda 0%, #c3e6cb 100%);
        }
.order-presencial.order-notified:is(:is(.paid-order-index .orders-list) .order-card) {
        border-left: 4px solid #64748b;
      }
.order-presencial.order-notified:is(:is(.paid-order-index .orders-list) .order-card) .order-header {
          background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
        }
/* ======================================== */
/* Order Header */
/* ======================================== */
:is(:is(.paid-order-index .orders-list) .order-card) .order-header {
        background: linear-gradient(135deg, var(--gray-50) 0%, var(--gray-200) 100%);
        border-bottom: 1px solid var(--gray-300);
        padding: 0.35rem 1rem;
      }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .order-number {
          font-family: 'Poppins', sans-serif;
          font-weight: 500;
          color: var(--gray-700);
          font-size: 13px;
          margin-bottom: 0.25rem;
        }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .store-name {
          font-weight: 500;
          color: var(--gray-700);
          font-size: 0.8rem;
          margin-bottom: 0.25rem;
        }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .order-time {
          font-size: 0.75rem;
          color: var(--gray-500);
          margin-bottom: 0.25rem;
        }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .order-status) .badge {
            font-size: 10px;
            padding: 4px 8px;
            border-radius: 6px;
            font-weight: 300;
          }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .customer-info {
          font-size: 0.8rem;
          font-weight: 500;
          color: var(--gray-700);
          margin-bottom: 0.25rem;
        }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-header) .order-total {
          font-family: 'Poppins', sans-serif;
          font-weight: 600;
          font-size: 0.95rem;
          color: #198754;
        }
/* ======================================== */
/* Order Items */
/* ======================================== */
:is(:is(.paid-order-index .orders-list) .order-card) .order-items {
        padding: 0.75rem 1rem;
        background-color: #fafafa;
      }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item {
          border: none;
          padding: 0.5rem 0;
          background-color: transparent;
        }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item):not(:last-child) {
            border-bottom: 1px solid var(--gray-200);
            padding-bottom: 0.75rem;
            margin-bottom: 0.75rem;
          }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .item-header {
            font-weight: 500;
            color: var(--gray-700);
            margin-bottom: 0.25rem;
            font-size: 0.85rem;
          }
:is(:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .item-header) .quantity-badge {
              background-color: var(--gray-200);
              color: var(--gray-700);
              padding: 0.15rem 0.4rem;
              border-radius: 4px;
              font-size: 0.7rem;
              font-weight: 600;
              margin-right: 0.35rem;
            }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .item-description {
            font-size: 0.75rem;
            color: var(--gray-500);
            margin-bottom: 0.25rem;
          }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .ingredients-compact {
            display: flex;
            flex-wrap: wrap;
            gap: 0.25rem;
            margin-top: 0.25rem;
          }
:is(:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .ingredients-compact) .ingredient-tag {
              background-color: #e7f5ec;
              color: #198754;
              padding: 0.1rem 0.4rem;
              border-radius: 4px;
              font-size: 0.7rem;
              display: inline-flex;
              align-items: center;
            }
:is(:is(:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .ingredients-compact) .ingredient-tag) i {
                font-size: 0.65rem;
              }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-items) .list-group-item) .small {
            font-size: 0.75rem;
            line-height: 1.3;
          }
/* ======================================== */
/* Order Actions */
/* ======================================== */
:is(:is(.paid-order-index .orders-list) .order-card) .order-actions {
        padding: 0.75rem 1rem;
        background-color: var(--gray-50);
        border-top: 1px solid var(--gray-300);
      }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn {
          font-size: 0.8rem;
          font-weight: 500;
          border-radius: 6px;
          transition: all 0.2s ease;
          padding: 0.4rem 0.8rem;
        }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn):hover:not(:disabled) {
            transform: translateY(-1px);
          }
.btn-outline-success:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn):hover {
              box-shadow: 0 2px 8px rgba(25, 135, 84, 0.25);
            }
.btn-notify-presencial:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn) {
            background-color: transparent;
            border: 1px solid #64748b;
            color: #475569;
          }
.btn-notify-presencial:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn):hover:not(:disabled) {
              background-color: #64748b;
              color: white;
              box-shadow: 0 2px 8px rgba(100, 116, 139, 0.25);
            }
.btn-notify-online:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn) {
            background-color: transparent;
            border: 1px solid var(--primary-color);
            color: var(--primary-color);
          }
.btn-notify-online:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn):hover:not(:disabled) {
              background-color: var(--primary-color);
              color: white;
              box-shadow: 0 2px 8px rgba(50, 183, 104, 0.25);
            }
:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-actions) .btn):disabled {
            opacity: 0.7;
            cursor: not-allowed;
          }
:is(:is(.paid-order-index .orders-list) .order-card) .badge-presencial {
        background-color: #64748b;
        color: white;
      }
/* ======================================== */
/* Prepare Button */
/* ======================================== */
:is(:is(.paid-order-index .orders-list) .order-card) .order-claim {
        background-color: #fafafa;
      }
:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn {
          font-weight: 500;
          font-size: 0.8rem;
          border-radius: 6px;
          transition: all 0.2s ease;
        }
.btn-prepare:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn) {
            background-color: var(--primary-color);
            border: none;
            color: white;
          }
.btn-prepare:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn):hover:not(:disabled) {
              background-color: #2a9d5a;
              transform: translateY(-1px);
              box-shadow: 0 2px 8px rgba(50, 183, 104, 0.3);
            }
.btn-prepare:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn):active {
              transform: translateY(0);
              background-color: #24864d;
            }
.btn-cooking:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn) {
            background-color: #f1f5f9;
            border: 1px solid #cbd5e1;
            color: #475569;
            cursor: default;
          }
.btn-cooking:is(:is(:is(:is(.paid-order-index .orders-list) .order-card) .order-claim) .claim-order-btn) .cooking-icon {
              display: inline-block;
              animation: cooking-shake 0.6s ease-in-out infinite;
            }
:is(.paid-order-index .orders-list) .order-card .order-header .order-status .badge {
      font-size: 10px;
      padding: 4px 8px;
      border-radius: 6px;
      font-weight: 300;
    }
:is(.paid-order-index .orders-list) .order-card span.badge {
      font-size: 10px;
      padding: 4px 8px;
      border-radius: 6px;
      font-weight: 300;
    }
/* ======================================== */
/* Empty State */
/* ======================================== */
.paid-order-index .empty-state-orders {
    text-align: center;
    padding: 3rem 2rem;
    margin-top: 2rem;
  }
:is(.paid-order-index .empty-state-orders) .empty-message {
      font-size: 1.125rem;
      font-weight: 600;
      color: var(--gray-500);
      margin-bottom: 0.5rem;
    }
:is(.paid-order-index .empty-state-orders) .empty-description {
      color: #adb5bd;
      font-size: 0.875rem;
    }
/* ======================================== */
/* Animations (global) */
/* ======================================== */
.new-order-alert {
  animation: orderBlink 1s linear 5;
  box-shadow: 0 0 20px rgba(50, 183, 104, 0.5);
}
@keyframes orderBlink {
  0%, 100% {
    opacity: 1;
    box-shadow: 0 0 20px rgba(50, 183, 104, 0.5);
  }
  50% {
    opacity: 0.7;
    box-shadow: 0 0 30px rgba(50, 183, 104, 0.8);
  }
}
@keyframes cooking-shake {
  0%, 100% {
    transform: rotate(-3deg);
  }
  50% {
    transform: rotate(3deg);
  }
}
/* ========================================================================== */
/* Reports - Reportes y analytics (Dashboard) */
/* ========================================================================== */
/* ======================================== */
/* Dashboard Info Cards */
/* ======================================== */
.dashboard .info-card {
  padding-bottom: 10px;
}
.dashboard .info-card h6 {
  font-size: 28px;
  color: #012970;
  font-weight: 700;
  margin: 10px;
  padding: 0;
  font-family: "nunito, sans-serif";
}
.dashboard .card-icon {
  font-size: 32px;
  line-height: 0;
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  flex-grow: 0;
}
.dashboard .sales-card .card-icon {
  color: #4154f1;
  background: #f6f6fe;
}
.dashboard .revenue-card .card-icon {
  color: #2eca6a;
  background: #e0f8e9;
}
.dashboard .customers-card .card-icon {
  color: #ff771d;
  background: #ffecdf;
}
.dashboard .cancelled-card .card-icon {
  color: #dc3545;
  background: #fdeaea;
}
.dashboard .refund-card .card-icon {
  color: #dc3545;
  background: #fdeaea;
}
@media (min-width: 1200px) {
  .dashboard .stats-col {
    flex: 0 0 20%;
    max-width: 20%;
  }
}
.dashboard .filtera {
  position: absolute;
  right: 0px;
  top: 15px;
}
/* ======================================== */
/* Card Title */
/* ======================================== */
.card-title {
  padding: 20px 0 15px 0;
  font-size: 18px;
  font-weight: 500;
  color: midnightblue;
  font-family: 'Poppins', sans-serif;
}
.card-title span {
  color: #899bbd;
  font-size: 14px;
  font-weight: 400;
}
.card-body {
  padding: 0 20px 20px 20px;
}
.card-img-overlay {
  background-color: rgba(255, 255, 255, 0.6);
}
/* ======================================== */
/* Report Buttons */
/* ======================================== */
.sec-btn-2 {
  background-color: white;
  border: 1px solid var(--primary-color);
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 25px;
  cursor: pointer;
  outline: none !important;
  transition: all 0.3s ease-in-out;
  overflow: hidden;
  z-index: 2;
  padding: 8px 16px;
  min-width: -moz-max-content;
  min-width: max-content;
  flex-shrink: 0;
  white-space: nowrap;
  box-shadow: var(--shadow-sm);
  color: var(--primary-color);
  font-weight: 500;
}
.sec-btn-2 i {
    color: inherit;
    transition: all 0.3s ease-in-out;
  }
.sec-btn-2.color-green:hover,.sec-btn-2:hover {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: white !important;
    transform: translateY(-1px);
    box-shadow: var(--shadow-md);
  }
:is(.sec-btn-2.color-green:hover,.sec-btn-2:hover) i {
      color: white !important;
    }
.sec-btn-2.color-green:active,.sec-btn-2:active {
    background-color: var(--primary-color) !important;
    border-color: var(--primary-color) !important;
    color: white !important;
    transform: translateY(0);
  }
:is(.sec-btn-2.color-green:active,.sec-btn-2:active) i {
      color: white !important;
    }
.sec-btn-2 a {
  color: inherit;
  font-weight: inherit;
  text-decoration: none;
  transition: all 0.3s ease-in-out;
}
.btn-selected,
.sec-btn-2.btn-selected {
  background-color: var(--primary-color);
  color: white !important;
  border-color: var(--primary-color);
  transform: translateY(-1px);
}
:is(.btn-selected,.sec-btn-2.btn-selected) a,:is(.btn-selected,.sec-btn-2.btn-selected) i {
    color: white !important;
  }
/* ======================================== */
/* Reports Section */
/* ======================================== */
.reports-section .reports-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    color: #2c3e50;
    font-size: 1.5rem;
    letter-spacing: 0.3px;
  }
:is(.reports-section .reports-title) i {
      color: var(--primary-color);
      margin-right: 0.5rem;
    }
.reports-section .card {
    border: none;
    border-radius: 12px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.08);
  }
:is(.reports-section .card) .card-body {
      padding: 1.5rem;
    }
.reports-section .sec-btn-2 {
    font-family: 'Poppins', sans-serif;
    font-size: 0.875rem;
    font-weight: 500;
    border-radius: 8px !important;
    letter-spacing: 0.2px;
  }
:is(.reports-section .sec-btn-2) i {
      font-size: 0.9rem;
    }
.reports-section .form-label {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    color: #2c3e50;
    margin-bottom: 0.75rem;
    font-size: 0.9rem;
    letter-spacing: 0.3px;
  }
.reports-section .form-label.text-muted {
    color: #2c3e50 !important;
    font-weight: 500 !important;
  }
:is(.reports-section .form-select):focus {
      border-color: #198754;
      box-shadow: 0 0 0 0.2rem rgba(25, 135, 84, 0.25);
    }
/* ======================================== */
/* Sales Report Page */
/* ======================================== */
/* Export Actions - Inside Turbo Frame */
.sales-report-page .export-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
  }
/* Header Actions - Export Buttons */
.sales-report-page .header-actions {
    display: flex;
    gap: 0.5rem;
  }
.sales-report-page .btn-export {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.5rem;
    border-radius: 6px;
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
  }
@media (min-width: 576px) {
.sales-report-page .btn-export {
      padding: 0.5rem 0.875rem;
  }
    }
:is(.sales-report-page .btn-export) i {
      font-size: 1rem;
    }
:is(.sales-report-page .btn-export) i.bi-download {
      font-size: 0.75rem;
      opacity: 0.7;
    }
:is(.sales-report-page .btn-export) span {
      display: none;
    }
@media (min-width: 576px) {
:is(.sales-report-page .btn-export) span {
        display: inline;
    }
      }
.sales-report-page .btn-export-pdf {
    background: #fee2e2;
    color: #dc2626;
  }
:is(.sales-report-page .btn-export-pdf):hover {
      background: #fecaca;
      color: #b91c1c;
    }
.sales-report-page .btn-export-excel {
    background: #dcfce7;
    color: #16a34a;
  }
:is(.sales-report-page .btn-export-excel):hover {
      background: #bbf7d0;
      color: #15803d;
    }
/* Quick Filters */
.sales-report-page .quick-filters {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
.sales-report-page .quick-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    cursor: pointer;
    transition: all 0.2s ease;
  }
:is(.sales-report-page .quick-filter-btn) i {
      font-size: 0.875rem;
      color: var(--gray-400);
    }
:is(.sales-report-page .quick-filter-btn):hover {
      border-color: var(--primary-color);
      color: var(--primary-color);
      background: #f0fdf4;
    }
:is(.sales-report-page .quick-filter-btn):hover i {
        color: var(--primary-color);
      }
.active:is(.sales-report-page .quick-filter-btn) {
      border-color: var(--primary-color);
      color: var(--primary-color);
      background: #f0fdf4;
    }
.active:is(.sales-report-page .quick-filter-btn) i {
        color: var(--primary-color);
      }
/* Filter Row */
.sales-report-page .filter-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: flex-end;
  }
.sales-report-page .filter-field {
    flex: 1;
    min-width: 200px;
  }
.sales-report-page .filter-submit {
    flex: 0 0 auto;
    min-width: 120px;
  }
:is(.sales-report-page .filter-submit) .btn-header-action {
      width: 100%;
      height: 42px;
    }
.sales-report-page .filter-label {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    margin-bottom: 0.5rem;
  }
:is(.sales-report-page .filter-label) i {
      font-size: 0.875rem;
      color: var(--gray-400);
    }
/* Stats Grid */
.sales-report-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1rem;
  }
.sales-report-page .stat-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  }
.sales-report-page .stat-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 12px;
    font-size: 1.5rem;
    flex-shrink: 0;
  }
.sales-report-page .stat-card-primary .stat-icon {
    background: #eff6ff;
    color: #3b82f6;
  }
.sales-report-page .stat-card-success .stat-icon {
    background: #f0fdf4;
    color: #22c55e;
  }
.sales-report-page .stat-content {
    display: flex;
    flex-direction: column;
  }
.sales-report-page .stat-value {
    font-size: 1.5rem;
    font-weight: 500;
    color: var(--gray-800);
    line-height: 1.2;
  }
.sales-report-page .stat-label {
    font-size: 0.8125rem;
    color: var(--gray-500);
    font-weight: 400;
  }
/* Charts Grid */
.sales-report-page .charts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(400px, 1fr));
    gap: 1.5rem;
  }
:is(.sales-report-page .chart-card) .dashboard-card-body {
      padding: 1rem 1.5rem 1.5rem;
    }
.sales-report-page .chart-container {
    min-height: 280px;
  }
/* Responsive */
@media (max-width: 768px) {
    .sales-report-page .filter-row {
      flex-direction: column;
    }

    .sales-report-page .filter-field {
      width: 100%;
    }

    .sales-report-page .filter-submit {
      width: 100%;
    }

    .sales-report-page .charts-grid {
      grid-template-columns: 1fr;
    }
  }
/* ======================================== */
/* Product Report Page - Extends Sales Report */
/* ======================================== */
/* Export Actions - Inside Turbo Frame */
.product-report-page .export-actions {
    display: flex;
    gap: 0.5rem;
    justify-content: flex-end;
  }
/* Inherit all styles from sales-report-page */
.product-report-page .header-actions {
    display: flex;
    gap: 0.5rem;
  }
.product-report-page .btn-export {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.375rem 0.5rem;
    border-radius: 6px;
    font-size: 0.8125rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s ease;
  }
@media (min-width: 576px) {
.product-report-page .btn-export {
      padding: 0.5rem 0.875rem;
  }
    }
:is(.product-report-page .btn-export) i { font-size: 1rem; }
:is(.product-report-page .btn-export) i.bi-download { font-size: 0.75rem; opacity: 0.7; }
:is(.product-report-page .btn-export) span {
      display: none;
    }
@media (min-width: 576px) {
:is(.product-report-page .btn-export) span { display: inline;
    } }
.product-report-page .btn-export-pdf {
    background: #fee2e2;
    color: #dc2626;
  }
:is(.product-report-page .btn-export-pdf):hover { background: #fecaca; color: #b91c1c; }
.product-report-page .quick-filters {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
.product-report-page .quick-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    cursor: pointer;
    transition: all 0.2s ease;
  }
:is(.product-report-page .quick-filter-btn) i { font-size: 0.875rem; color: var(--gray-400); }
:is(.product-report-page .quick-filter-btn):hover {
      border-color: var(--primary-color);
      color: var(--primary-color);
      background: #f0fdf4;
    }
:is(.product-report-page .quick-filter-btn):hover i { color: var(--primary-color); }
.active:is(.product-report-page .quick-filter-btn) {
      border-color: var(--primary-color);
      color: var(--primary-color);
      background: #f0fdf4;
    }
.active:is(.product-report-page .quick-filter-btn) i { color: var(--primary-color); }
.product-report-page .filter-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: flex-end;
  }
.product-report-page .filter-field {
    flex: 1;
    min-width: 200px;
  }
.product-report-page .filter-submit {
    flex: 0 0 auto;
    min-width: 120px;
  }
:is(.product-report-page .filter-submit) .btn-header-action { width: 100%; height: 42px; }
.product-report-page .filter-label {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    margin-bottom: 0.5rem;
  }
:is(.product-report-page .filter-label) i { font-size: 0.875rem; color: var(--gray-400); }
.product-report-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1rem;
  }
.product-report-page .stat-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  }
.product-report-page .stat-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 12px;
    font-size: 1.5rem;
    flex-shrink: 0;
  }
.product-report-page .stat-card-primary .stat-icon { background: #eff6ff; color: #3b82f6; }
.product-report-page .stat-card-success .stat-icon { background: #f0fdf4; color: #22c55e; }
.product-report-page .stat-card-warning .stat-icon { background: #fef9e7; color: #eab308; }
.product-report-page .stat-content { display: flex; flex-direction: column; }
.product-report-page .stat-value { font-size: 1.5rem; font-weight: 500; color: var(--gray-800); line-height: 1.2; }
.product-report-page .stat-value-sm { font-size: 1rem; }
.product-report-page .stat-label { font-size: 0.8125rem; color: var(--gray-500); font-weight: 400; }
.product-report-page .charts-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
.product-report-page .chart-card .dashboard-card-body { padding: 1rem 1.5rem 1.5rem; }
.product-report-page .chart-container { min-height: 280px; }
.product-report-page .chart-container-large { min-height: 400px; }
@media (max-width: 768px) {
    .product-report-page .filter-row { flex-direction: column; }
    .product-report-page .filter-field,.product-report-page .filter-submit { width: 100%; }
  }
/* ======================================== */
/* Payments Admin Page */
/* ======================================== */
/* Inherits styles from sales-report-page */
/* Quick Filters */
.payments-admin-page .quick-filters {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
.payments-admin-page .quick-filter-btn {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    cursor: pointer;
    transition: all 0.2s ease;
  }
:is(.payments-admin-page .quick-filter-btn) i { font-size: 0.875rem; color: var(--gray-400); }
:is(.payments-admin-page .quick-filter-btn):hover,.active:is(.payments-admin-page .quick-filter-btn) {
      border-color: var(--primary-color);
      color: var(--primary-color);
      background: #f0fdf4;
    }
:is(:is(.payments-admin-page .quick-filter-btn):hover,.active:is(.payments-admin-page .quick-filter-btn)) i { color: var(--primary-color); }
/* Filter Row */
.payments-admin-page .filter-row {
    display: flex;
    gap: 1rem;
    flex-wrap: wrap;
    align-items: flex-end;
  }
.payments-admin-page .filter-field {
    flex: 1;
    min-width: 200px;
  }
.payments-admin-page .filter-submit {
    flex: 0 0 auto;
    min-width: 120px;
  }
:is(.payments-admin-page .filter-submit) .btn-header-action { width: 100%; height: 42px; }
.payments-admin-page .filter-label {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    margin-bottom: 0.5rem;
  }
:is(.payments-admin-page .filter-label) i { font-size: 0.875rem; color: var(--gray-400); }
/* Stats Grid */
.payments-admin-page .stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 1rem;
  }
.payments-admin-page .stat-card {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.25rem 1.5rem;
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
  }
.payments-admin-page .stat-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    border-radius: 12px;
    font-size: 1.5rem;
    flex-shrink: 0;
  }
.payments-admin-page .stat-card-success .stat-icon { background: #f0fdf4; color: #22c55e; }
.payments-admin-page .stat-card-danger .stat-icon { background: #fee2e2; color: #dc2626; }
.payments-admin-page .stat-card-warning .stat-icon { background: #fef3c7; color: #d97706; }
.payments-admin-page .stat-card-secondary .stat-icon { background: #f3f4f6; color: #6b7280; }
.payments-admin-page .stat-content { display: flex; flex-direction: column; }
.payments-admin-page .stat-value { font-size: 1.5rem; font-weight: 500; color: var(--gray-800); line-height: 1.2; }
.payments-admin-page .stat-label {
    font-size: 0.8125rem;
    color: var(--gray-500);
    font-weight: 400;
    display: flex;
    align-items: center;
    gap: 0.375rem;
  }
:is(.payments-admin-page .stat-label) i.bi-info-circle {
      font-size: 0.75rem;
      opacity: 0.6;
      cursor: help;
    }
/* Filter Pills */
.payments-admin-page .filter-pills {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
  }
.payments-admin-page .filter-pill {
    display: inline-flex;
    align-items: center;
    padding: 0.5rem 1rem;
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 20px;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    text-decoration: none;
    transition: all 0.2s ease;
  }
:is(.payments-admin-page .filter-pill):hover {
      border-color: var(--gray-300);
      color: var(--gray-700);
    }
.active:is(.payments-admin-page .filter-pill) {
      border-color: var(--primary-color);
      background: #f0fdf4;
      color: var(--primary-color);
    }
/* Table Styles */
.payments-admin-page .table {
    margin-bottom: 0;
  }
:is(.payments-admin-page .table) thead th {
      background: var(--gray-50);
      border-bottom: 1px solid var(--gray-200);
      font-size: 0.875rem;
      font-weight: 600;
      padding: 0.75rem 0.75rem;
      white-space: nowrap;
    }
:is(.payments-admin-page .table) tbody td {
      padding: 0.75rem 0.75rem;
      vertical-align: middle;
      border-bottom: 1px solid var(--gray-100);
      font-size: 0.8125rem;
    }
:is(.payments-admin-page .table) tbody tr:last-child td {
      border-bottom: none;
    }
:is(.payments-admin-page .table) tbody tr:hover {
      background: var(--gray-50);
    }
/* Cell: Fecha */
:is(.payments-admin-page .cell-date) .date-primary {
      display: block;
      font-weight: 500;
      color: var(--gray-700);
      font-size: 0.8125rem;
    }
:is(.payments-admin-page .cell-date) .date-secondary {
      display: block;
      font-size: 0.6875rem;
      color: var(--gray-400);
      margin-top: 2px;
    }
/* Cell: Orden */
:is(.payments-admin-page .cell-order) .order-number {
      font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
      font-size: 0.75rem;
      color: var(--gray-600);
      background: var(--gray-100);
      padding: 0.25rem 0.5rem;
      border-radius: 4px;
    }
/* Cell: Cliente */
:is(.payments-admin-page .cell-client) .client-name {
      font-weight: 500;
      color: var(--gray-700);
    }
:is(.payments-admin-page .cell-client) .client-presencial {
      display: inline-flex;
      align-items: center;
      gap: 0.375rem;
      font-size: 0.75rem;
      color: var(--gray-500);
    }
:is(:is(.payments-admin-page .cell-client) .client-presencial) i { font-size: 0.875rem; }
/* Cell: Montos */
.payments-admin-page .cell-amount,.payments-admin-page .cell-available {
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
  }
.payments-admin-page .amount-value {
    font-weight: 500;
    color: var(--gray-700);
  }
.payments-admin-page .amount-available {
    font-weight: 600;
    color: #16a34a;
  }
.payments-admin-page .amount-zero {
    color: var(--gray-400);
  }
/* Status Badges */
.payments-admin-page .status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.625rem;
    border-radius: 100px;
    font-size: 0.6875rem;
    font-weight: 500;
    white-space: nowrap;
  }
:is(.payments-admin-page .status-badge) i { font-size: 0.625rem; }
.payments-admin-page .status-full {
    background: #f3f4f6;
    color: #4b5563;
  }
.payments-admin-page .status-partial {
    background: #fef3c7;
    color: #b45309;
  }
.payments-admin-page .status-approved {
    background: #dcfce7;
    color: #16a34a;
  }
.payments-admin-page .status-pending {
    background: #fef3c7;
    color: #d97706;
  }
.payments-admin-page .status-rejected {
    background: #fee2e2;
    color: #dc2626;
  }
.payments-admin-page .status-default {
    background: var(--gray-100);
    color: var(--gray-600);
  }
/* Method Badges */
.payments-admin-page .method-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.25rem 0.5rem;
    border-radius: 6px;
    font-size: 0.6875rem;
    font-weight: 500;
  }
:is(.payments-admin-page .method-badge) i { font-size: 0.75rem; }
.payments-admin-page .method-online {
    background: #e0f2fe;
    color: #0284c7;
  }
.payments-admin-page .method-cash {
    background: #f0fdf4;
    color: #16a34a;
  }
.payments-admin-page .method-other {
    background: var(--gray-100);
    color: var(--gray-600);
  }
/* Action Buttons */
.payments-admin-page .cell-actions {
    white-space: nowrap;
    text-align: right;
  }
.payments-admin-page .action-buttons {
    display: inline-flex;
    gap: 0.375rem;
    align-items: center;
  }
.payments-admin-page .action-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    padding: 0.375rem 0.625rem;
    border-radius: 6px;
    font-size: 0.6875rem;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.15s ease;
    border: 1px solid;
    white-space: nowrap;
  }
:is(.payments-admin-page .action-btn) i { font-size: 0.75rem; }
/* Empty State */
.payments-admin-page .empty-state {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 3rem 1.5rem;
    text-align: center;
    color: var(--gray-400);
  }
:is(.payments-admin-page .empty-state) i {
      font-size: 3rem;
      margin-bottom: 1rem;
    }
:is(.payments-admin-page .empty-state) p {
      margin: 0;
      font-size: 0.9375rem;
      color: var(--gray-500);
    }
/* Responsive */
@media (max-width: 768px) {
    .payments-admin-page .stats-grid {
      grid-template-columns: repeat(2, 1fr);
    }

    .payments-admin-page .filter-row {
      flex-direction: column;
    }

    .payments-admin-page .filter-field,.payments-admin-page .filter-submit {
      width: 100%;
    }

    .payments-admin-page .table-responsive {
      border-radius: 0;
    }
  }
@media (max-width: 480px) {
    .payments-admin-page .stats-grid {
      grid-template-columns: 1fr;
    }
  }
/* ======================================== */
/* Refund Modal */
/* ======================================== */
.refund-modal .modal-content {
    border: none;
    border-radius: 16px;
    box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
    overflow: hidden;
  }
.refund-modal .modal-header {
    background: #fff;
    padding: 1rem 1.25rem;
    border-bottom: 1px solid var(--gray-200);
  }
:is(.refund-modal .modal-header) .modal-title {
      font-size: 1rem;
      font-weight: 600;
      color: var(--gray-800);
    }
:is(.refund-modal .modal-header) .btn-close {
      opacity: 0.6;
    }
:is(:is(.refund-modal .modal-header) .btn-close):hover { opacity: 1; }
.refund-modal .modal-body {
    padding: 1.25rem 1.5rem;
    background: #fff;
  }
/* Warning Alert */
.refund-modal .refund-warning {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 0.75rem;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 6px;
    margin-bottom: 0.875rem;
  }
:is(.refund-modal .refund-warning) .warning-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      flex-shrink: 0;
    }
:is(:is(.refund-modal .refund-warning) .warning-icon) i {
        font-size: 1.125rem;
        color: #d97706;
      }
:is(.refund-modal .refund-warning) .warning-text {
      font-size: 0.8125rem;
      color: #92400e;
      line-height: 1.4;
    }
:is(:is(.refund-modal .refund-warning) .warning-text) strong {
        color: #b45309;
      }
/* Payment Info Card */
.refund-modal .payment-info-card {
    padding: 0.875rem 1rem;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    margin-bottom: 0.875rem;
  }
:is(.refund-modal .payment-info-card) .info-item {
      display: flex;
      flex-direction: column;
      gap: 0.125rem;
    }
:is(:is(.refund-modal .payment-info-card) .info-item) .info-label {
        font-size: 0.625rem;
        font-weight: 500;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        color: var(--gray-500);
      }
:is(:is(.refund-modal .payment-info-card) .info-item) span:not(.info-label) {
        font-size: 0.9375rem;
        font-weight: 600;
        color: var(--gray-800);
      }
.refund-modal .info-note {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    padding: 0.5rem 1rem;
    background: #fffbeb;
    border: 1px solid #fde68a;
    border-radius: 6px;
    margin-bottom: 0.875rem;
  }
:is(.refund-modal .info-note) i {
      font-size: 0.75rem;
      color: #d97706;
    }
:is(.refund-modal .info-note) span {
      font-size: 0.6875rem;
      color: #b45309;
      font-weight: 500;
    }
/* Products Section */
.refund-modal .products-section {
    margin-bottom: 0.875rem;
  }
.refund-modal .products-section .section-header {
    display: flex !important;
    flex-direction: row !important;
    justify-content: space-between !important;
    align-items: center !important;
    width: 100% !important;
    margin-bottom: 0.375rem;
    gap: 1rem;
  }
.refund-modal .products-section .section-header .section-title {
    display: inline-block !important;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray-700);
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1;
    flex-shrink: 0;
  }
.refund-modal .products-section .section-header .select-all-link {
    display: inline-flex !important;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.6875rem;
    font-weight: 500;
    color: var(--primary-color);
    text-decoration: none;
    transition: all 0.15s ease;
    white-space: nowrap;
    margin-left: auto;
  }
.refund-modal .products-section .section-header .select-all-link i {
    font-size: 0.75rem;
  }
.refund-modal .products-section .section-header .select-all-link:hover {
    color: var(--primary-color-dark);
  }
.refund-modal .products-section .exceeds-alert {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.625rem 0.875rem;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 8px;
    margin-bottom: 0.75rem;
    font-size: 0.75rem;
    color: #dc2626;
  }
.refund-modal .products-section .exceeds-alert i {
    font-size: 0.875rem;
  }
.refund-modal .products-section .exceeds-alert.d-none {
    display: none !important;
  }
.refund-modal .products-section .products-list {
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
    max-height: 220px;
    overflow-y: auto;
  }
.refund-modal .products-section .products-list::-webkit-scrollbar {
    width: 6px;
  }
.refund-modal .products-section .products-list::-webkit-scrollbar-track {
    background: var(--gray-100);
  }
.refund-modal .products-section .products-list::-webkit-scrollbar-thumb {
    background: var(--gray-300);
    border-radius: 3px;
  }
.refund-modal .products-section .product-item {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.625rem 0.875rem;
    background: #fff;
    border-bottom: 1px solid var(--gray-100);
    transition: background 0.15s ease;
  }
.refund-modal .products-section .product-item:last-child {
    border-bottom: none;
  }
.refund-modal .products-section .product-item:hover {
    background: var(--gray-50);
  }
.refund-modal .products-section .product-item.disabled {
    opacity: 0.5;
    pointer-events: none;
  }
.refund-modal .products-section .product-check {
    display: flex;
    align-items: flex-start;
    gap: 0.75rem;
    flex: 1;
  }
.refund-modal .products-section .product-check .form-check-input {
    width: 18px;
    height: 18px;
    margin-top: 0.125rem;
    cursor: pointer;
    border-color: var(--gray-300);
  }
.refund-modal .products-section .product-check .form-check-input:checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
  }
.refund-modal .products-section .product-check .form-check-input:focus {
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.2);
  }
.refund-modal .products-section .product-info {
    display: flex;
    flex-direction: column;
    gap: 0.125rem;
  }
.refund-modal .products-section .product-name {
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-800);
    line-height: 1.3;
  }
.refund-modal .products-section .product-price {
    font-size: 0.6875rem;
    color: var(--gray-500);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
  }
.refund-modal .products-section .product-exceeds-badge {
    display: inline-flex;
    align-items: center;
    padding: 0.125rem 0.375rem;
    background: #fef3c7;
    color: #b45309;
    font-size: 0.5625rem;
    font-weight: 500;
    border-radius: 4px;
    margin-top: 0.25rem;
  }
.refund-modal .products-section .product-quantity {
    display: flex;
    align-items: center;
    gap: 0.625rem;
  }
.refund-modal .products-section .qty-label {
    font-size: 0.6875rem;
    color: var(--gray-500);
  }
.refund-modal .products-section .qty-input {
    width: 56px;
    height: 32px;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--gray-200);
    border-radius: 6px;
    font-size: 0.8125rem;
    text-align: center;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
  }
.refund-modal .products-section .qty-input:focus {
    border-color: var(--primary-color);
    outline: none;
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
  }
.refund-modal .products-section .qty-input:disabled {
    background: var(--gray-100);
    color: var(--gray-400);
  }
.refund-modal .products-section .qty-subtotal {
    min-width: 70px;
    padding: 0.375rem 0.625rem;
    background: var(--gray-100);
    border-radius: 6px;
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--gray-700);
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
    text-align: center;
  }
.refund-modal .products-section .empty-products {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 2rem 1rem;
    background: var(--gray-50);
    color: var(--gray-400);
  }
.refund-modal .products-section .empty-products i {
    font-size: 2rem;
    margin-bottom: 0.5rem;
  }
.refund-modal .products-section .empty-products span {
    font-size: 0.8125rem;
    color: var(--gray-500);
  }
.refund-modal .products-section .total-row {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
    padding-top: 0.5rem;
    border-top: 1px dashed var(--gray-200);
  }
.refund-modal .products-section .total-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--gray-600);
  }
.refund-modal .products-section .total-value {
    font-size: 1rem;
    font-weight: 700;
    color: #16a34a;
    font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
  }
/* Reason Section */
.refund-modal .reason-section {
    margin-bottom: 0.875rem;
  }
:is(.refund-modal .reason-section) .reason-label {
      display: block;
      font-size: 0.75rem;
      font-weight: 600;
      color: var(--gray-700);
      margin-bottom: 0.375rem;
    }
:is(.refund-modal .reason-section) .reason-textarea {
      width: 100%;
      min-height: 70px;
      padding: 0.625rem 0.875rem;
      border: 1px solid var(--gray-200);
      border-radius: 8px;
      font-size: 0.8125rem;
      color: var(--gray-800);
      resize: vertical;
      transition: all 0.15s ease;
    }
:is(:is(.refund-modal .reason-section) .reason-textarea)::-moz-placeholder {
        color: var(--gray-400);
      }
:is(:is(.refund-modal .reason-section) .reason-textarea)::placeholder {
        color: var(--gray-400);
      }
:is(:is(.refund-modal .reason-section) .reason-textarea):focus {
        border-color: var(--primary-color);
        outline: none;
        box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
      }
:is(.refund-modal .reason-section) .char-count {
      font-size: 0.625rem;
      color: var(--gray-400);
      margin-top: 0.25rem;
    }
/* Payment Method Card */
.refund-modal .payment-method-card {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.75rem;
    background: linear-gradient(135deg, #f0f9ff 0%, #e0f2fe 100%);
    border: 1px solid #bae6fd;
    border-radius: 8px;
  }
:is(.refund-modal .payment-method-card) .method-icon {
      display: flex;
      align-items: center;
      justify-content: center;
      width: 36px;
      height: 36px;
      background: #fff;
      border-radius: 8px;
    }
:is(:is(.refund-modal .payment-method-card) .method-icon) i {
        font-size: 1rem;
        color: #0284c7;
      }
:is(.refund-modal .payment-method-card) .method-info {
      display: flex;
      flex-direction: column;
      gap: 0;
    }
:is(:is(.refund-modal .payment-method-card) .method-info) .method-label {
        font-size: 0.5625rem;
        font-weight: 500;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        color: #0369a1;
      }
:is(:is(.refund-modal .payment-method-card) .method-info) .method-name {
        font-size: 0.8125rem;
        font-weight: 600;
        color: #0c4a6e;
      }
:is(:is(.refund-modal .payment-method-card) .method-info) .method-note {
        font-size: 0.625rem;
        color: #0284c7;
        margin-top: 0;
      }
.method-cash:is(.refund-modal .payment-method-card) {
      background: linear-gradient(135deg, #f0fdf4 0%, #dcfce7 100%);
      border-color: #bbf7d0;
    }
:is(.method-cash:is(.refund-modal .payment-method-card) .method-icon) i { color: #16a34a; }
:is(.method-cash:is(.refund-modal .payment-method-card) .method-info) .method-label { color: #15803d; }
:is(.method-cash:is(.refund-modal .payment-method-card) .method-info) .method-name { color: #14532d; }
:is(.method-cash:is(.refund-modal .payment-method-card) .method-info) .method-note { color: #16a34a; }
/* Modal Footer */
.refund-modal .modal-footer {
    padding: 0.875rem 1.25rem;
    background: var(--gray-50);
    border-top: 1px solid var(--gray-200);
    gap: 0.5rem;
  }
:is(.refund-modal .modal-footer) .btn-cancel {
      padding: 0.5rem 1rem;
      background: #fff;
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      font-size: 0.75rem;
      font-weight: 500;
      color: var(--gray-600);
      text-decoration: none;
      transition: all 0.15s ease;
    }
:is(:is(.refund-modal .modal-footer) .btn-cancel):hover {
        background: var(--gray-100);
        border-color: var(--gray-400);
        color: var(--gray-700);
      }
:is(.refund-modal .modal-footer) .btn-confirm {
      display: inline-flex;
      align-items: center;
      gap: 0.375rem;
      padding: 0.5rem 1.25rem;
      background: var(--primary-color);
      border: none;
      border-radius: 6px;
      font-size: 0.75rem;
      font-weight: 600;
      color: #fff;
      cursor: pointer;
      transition: all 0.15s ease;
    }
:is(:is(.refund-modal .modal-footer) .btn-confirm):hover:not(:disabled) {
        background: var(--primary-color-dark);
      }
:is(:is(.refund-modal .modal-footer) .btn-confirm):disabled {
        opacity: 0.5;
        cursor: not-allowed;
      }
/* Flash Alert */
.refund-modal .flash-alert {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    padding: 0.875rem 1rem;
    margin: 0 1.5rem 1rem;
    background: #fef2f2;
    border: 1px solid #fecaca;
    border-radius: 10px;
  }
:is(.refund-modal .flash-alert) i {
      font-size: 1.125rem;
      color: #dc2626;
    }
:is(.refund-modal .flash-alert) span {
      font-size: 0.8125rem;
      color: #991b1b;
    }
/* Responsive */
@media (max-width: 576px) {
    .refund-modal .modal-dialog {
      margin: 0.5rem;
    }

    .refund-modal .product-item {
      flex-direction: column;
      align-items: flex-start;
      gap: 0.75rem;
    }

    .refund-modal .product-quantity {
      width: 100%;
      justify-content: flex-end;
    }
  }
/* ======================================== */
/* Refund Show Page */
/* ======================================== */
/* Header */
.refund-show-page .refund-show-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 1.5rem;
    gap: 1rem;
    flex-wrap: wrap;
  }
/* Info Summary (similar to payment-info-card in modal) */
.refund-show-page .refund-info-summary {
    padding: 1rem 1.25rem;
    background: var(--gray-50);
    border: 1px solid var(--gray-200);
    border-radius: 10px;
  }
:is(.refund-show-page .refund-info-summary) .info-item {
      display: flex;
      flex-direction: column;
      gap: 0.25rem;
    }
:is(:is(.refund-show-page .refund-info-summary) .info-item) .info-label {
        font-size: 0.6875rem;
        font-weight: 500;
        text-transform: uppercase;
        letter-spacing: 0.05em;
        color: var(--gray-500);
      }
:is(:is(.refund-show-page .refund-info-summary) .info-item) .info-value {
        font-size: 1.125rem;
        font-weight: 500;
        color: var(--gray-800);
      }
/* Details List */
.refund-show-page .refund-details-list {
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    overflow: hidden;
  }
.refund-show-page .detail-row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 0.875rem 1rem;
    border-bottom: 1px solid var(--gray-100);
    gap: 1rem;
  }
:is(.refund-show-page .detail-row):last-child {
      border-bottom: none;
    }
.detail-row-danger:is(.refund-show-page .detail-row) {
      background: #fef2f2;
    }
.refund-show-page .detail-label {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--gray-600);
    flex-shrink: 0;
  }
:is(.refund-show-page .detail-label) i {
      font-size: 0.875rem;
      color: var(--gray-400);
    }
.refund-show-page .detail-value {
    font-size: 0.8125rem;
    color: var(--gray-800);
    text-align: right;
  }
:is(.refund-show-page .detail-value) code {
      font-size: 0.75rem;
      background: var(--gray-100);
      padding: 0.25rem 0.5rem;
      border-radius: 4px;
      color: var(--gray-700);
    }
/* Refund Items List */
:is(.refund-show-page .refund-items-list) .refund-item-row {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 0.875rem 1.25rem;
      border-bottom: 1px solid var(--gray-100);
    }
:is(:is(.refund-show-page .refund-items-list) .refund-item-row):last-child {
        border-bottom: none;
      }
:is(:is(.refund-show-page .refund-items-list) .refund-item-row):hover {
        background: var(--gray-50);
      }
:is(.refund-show-page .refund-items-list) .refund-item-info {
      display: flex;
      align-items: center;
      gap: 0.75rem;
    }
:is(:is(.refund-show-page .refund-items-list) .refund-item-info) .item-name {
        font-size: 0.875rem;
        font-weight: 500;
        color: var(--gray-800);
      }
:is(:is(.refund-show-page .refund-items-list) .refund-item-info) .item-qty {
        font-size: 0.75rem;
        font-weight: 500;
        color: var(--gray-500);
        background: var(--gray-100);
        padding: 0.125rem 0.5rem;
        border-radius: 4px;
      }
:is(.refund-show-page .refund-items-list) .refund-item-price {
      font-family: 'SF Mono', 'Monaco', 'Inconsolata', monospace;
      font-size: 0.875rem;
      font-weight: 600;
      color: var(--gray-700);
    }
/* Sidebar Info List */
.refund-show-page .sidebar-info-list {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
  }
.refund-show-page .sidebar-info-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--gray-100);
  }
:is(.refund-show-page .sidebar-info-item):last-child {
      padding-bottom: 0;
      border-bottom: none;
    }
.refund-show-page .sidebar-label {
    font-size: 0.75rem;
    font-weight: 500;
    color: var(--gray-500);
  }
.refund-show-page .sidebar-value {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--gray-800);
  }
:is(.refund-show-page .sidebar-value) i {
      margin-right: 0.25rem;
      color: var(--gray-500);
    }
:is(.refund-show-page .sidebar-value) code {
      font-size: 0.6875rem;
      background: var(--gray-100);
      padding: 0.125rem 0.375rem;
      border-radius: 3px;
    }
/* Status Badges (extending from payments-admin-page) */
.refund-show-page .status-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.625rem;
    border-radius: 100px;
    font-size: 0.6875rem;
    font-weight: 500;
    white-space: nowrap;
  }
:is(.refund-show-page .status-badge) i { font-size: 0.625rem; }
.refund-show-page .status-full {
    background: #f3f4f6;
    color: #4b5563;
  }
.refund-show-page .status-partial {
    background: #fef3c7;
    color: #b45309;
  }
.refund-show-page .status-approved {
    background: #dcfce7;
    color: #16a34a;
  }
.refund-show-page .status-pending {
    background: #fef3c7;
    color: #d97706;
  }
.refund-show-page .status-rejected {
    background: #fee2e2;
    color: #dc2626;
  }
/* Responsive */
@media (max-width: 768px) {
    .refund-show-page .refund-show-header {
      flex-direction: column;
    }

    .refund-show-page .refund-info-summary {
      flex-direction: column;
      gap: 1rem;
    }

      :is(.refund-show-page .refund-info-summary) .info-item {
        flex-direction: row;
        justify-content: space-between;
        align-items: center;
      }

    .refund-show-page .detail-row {
      flex-direction: column;
      gap: 0.25rem;
    }

    .refund-show-page .detail-value {
      text-align: left;
    }
  }
/* ========================================================================== */
/* Product Show - Vista de producto individual (cliente) */
/* ========================================================================== */
/* ======================================== */
/* Table Secondary (archived products) */
/* ======================================== */
tr.table-secondary {
  background-color: var(--gray-50) !important;
  opacity: 0.4;
}
.timer-fields {
  display: none;
}
/* ======================================== */
/* Product Image Container */
/* ======================================== */
.show-product-image-container {
  width: 100%;
  height: 200px;
  overflow: hidden;
  border-radius: var(--border-radius-lg);
  background: var(--gray-100);
  box-shadow: var(--shadow-md);
}
.show-product-image {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
@media (min-width: 1024px) {
  .show-product-image-container {
    height: 350px;
  }

  .show-product-image {
    height: 100%;
  }
}
/* ======================================== */
/* Quantity Controls */
/* ======================================== */
.disable-dbl-tap-zoom {
  touch-action: manipulation;
}
.quantity-wrapper {
  --stepper-h: 32px;
  --stepper-btn: 30px;
  --stepper-fs: 16px;
  background: var(--gray-100);
  border: none;
  border-radius: 25px;
  padding: 2px 4px;
  gap: 14px;
  box-shadow: var(--shadow-sm);
  max-width: 120px;
}
.quantity-input {
  width: 40px;
  height: var(--stepper-h);
  text-align: center;
  border: none;
  box-shadow: none;
  background: transparent;
  font-weight: 400;
  font-size: var(--stepper-fs);
  color: var(--gray-800);
  padding: 0 6px;
}
/* Hide number input spinners */
.quantity-wrapper input[type="number"]::-webkit-outer-spin-button,
.quantity-wrapper input[type="number"]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}
.quantity-wrapper input[type="number"] {
  -webkit-appearance: textfield;
          appearance: textfield;
  -moz-appearance: textfield;
}
.quantity-btn {
  width: var(--stepper-btn);
  height: var(--stepper-btn);
  border-radius: 25px;
  border: none !important;
  background: transparent !important;
  color: var(--gray-700) !important;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 !important;
  line-height: 1;
  font-size: 14px;
}
/* Neutralize Bootstrap button bulk inside the stepper */
.quantity-wrapper .btn {
  box-shadow: none !important;
  border: none !important;
  padding: 0 !important;
}
.quantity-wrapper .btn-outline-secondary {
  background: transparent !important;
}
@media (max-width: 480px) {
  .quantity-wrapper {
    --stepper-h: 32px;
    --stepper-btn: 30px;
    --stepper-fs: 16px;
  }

  .quantity-input {
    width: 36px;
  }
}
/* ======================================== */
/* Product Show - Modern (iOS/Web) */
/* ======================================== */
.product-show {
  --pad-x: 16px;
  --pad-y: 16px;
  --radius-lg: var(--border-radius-lg);
  --radius-md: var(--border-radius-md);
}
.product-title {
  font-size: 1.4rem;
  font-weight: 600;
  color: var(--gray-900);
  margin: 12px 0 4px;
}
.discount-badge-products {
  background: linear-gradient(135deg, var(--danger-color), #ff5a5f) !important;
  box-shadow: var(--shadow-sm);
  font-weight: 300 !important;
}
.product-pricing h4,
.product-pricing .discounted-price-top,
.product-pricing .discounted-price-bottom {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.product-pricing .original-price span {
  text-decoration: line-through;
  color: var(--gray-500);
}
.stock-indicator {
  font-size: 0.9rem;
  color: var(--gray-600);
}
/* Badges moved to components/_badges.css */
/* ======================================== */
/* Product Description - ActionText Content */
/* ======================================== */
.product-description {
  font-size: 0.98rem;
  line-height: 1.55;
  color: var(--gray-700);
  background: white;
  border: 1px solid var(--gray-100);
  border-radius: var(--border-radius-lg);
  padding: 12px 14px;
  box-shadow: var(--shadow-sm);

  /* Lists */
}
.product-description ul,.product-description ol {
    margin: 0;
    padding-left: 20px;
  }
.product-description ul {
    list-style-type: disc;
  }
.product-description li {
    margin-bottom: 4px;
    padding-left: 4px;
  }
/* Tables inside description */
.product-description table {
    width: 100%;
    border-collapse: collapse;
    margin: 12px 0;
    font-size: 0.9rem;
  }
.product-description th,.product-description td {
    padding: 8px 10px;
    text-align: left;
    border-bottom: 1px solid var(--gray-100);
  }
.product-description th {
    font-weight: 600;
    background: var(--gray-50);
    color: var(--gray-700);
  }
.product-description tr:last-child td {
    border-bottom: none;
  }
/* Strong/Bold text */
.product-description strong,.product-description b {
    font-weight: 600;
    color: var(--gray-800);
  }
/* Links */
.product-description a {
    color: var(--primary-color);
    text-decoration: underline;
  }
/* Headings inside description */
.product-description h1,.product-description h2,.product-description h3,.product-description h4 {
    font-size: 1rem;
    font-weight: 600;
    color: var(--gray-800);
    margin: 12px 0 8px;
  }
/* ======================================== */
/* Ingredients Card - Improved */
/* ======================================== */
.ingredients-card {
  border: 1px solid var(--gray-100);
  border-radius: var(--border-radius-lg);
  overflow: hidden;
}
.ingredients-card .card-header {
  background: var(--gray-50);
  font-weight: 600;
  font-size: 14px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--gray-100);
}
.ingredients-card .card-body {
  padding: 0;
}
.ingredients-card .card-body > div {
  padding: 10px 14px;
  border-bottom: 1px solid var(--gray-50);
  transition: background 0.15s ease;
}
:is(.ingredients-card .card-body > div):last-child {
    border-bottom: none;
  }
:is(.ingredients-card .card-body > div):hover {
    background: var(--gray-50);
  }
.ingredients-card .form-check {
  margin: 0;
  padding: 0;
}
.ingredients-card .form-check-label {
  font-weight: 400;
  color: var(--gray-700);
  font-size: 14px;
  cursor: pointer;
}
.ingredients-card .form-check-input {
  width: 20px;
  height: 20px;
  border-radius: 4px;
  border: 2px solid var(--gray-300);
  cursor: pointer;
}
:is(.ingredients-card .form-check-input):checked {
    background-color: var(--primary-color);
    border-color: var(--primary-color);
  }
:is(.ingredients-card .form-check-input):focus {
    box-shadow: 0 0 0 3px rgba(34, 197, 94, 0.15);
  }
.choice-ingredient-title {
  font-size: 16px;
  margin-bottom: 12px;
  font-weight: 600;
}
.required-ingredients {
  font-size: 12px;
  color: var(--danger-color);
  font-weight: 500;
}
.max-ingredients {
  font-size: 12px;
  color: var(--gray-500);
}
/* ======================================== */
/* Responsive */
/* ======================================== */
@media (max-width: 768px) {
  .product-title {
    font-size: 1.2rem;
  }
}
/* ========================================================================== */
/* Notifications - Notificaciones del usuario/account */
/* ========================================================================== */
.notifications-container {
  max-width: 100%;
}
/* ======================================== */
/* Notification Card */
/* ======================================== */
.notification-card {
  background: white;
  border-radius: 12px;
  margin-bottom: 12px;
  padding: 16px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
  border: 1px solid #f0f0f0;
  transition: all 0.2s ease;
  position: relative;
  overflow: hidden;
  animation: slideInUp 0.3s ease forwards;
}
.notification-card:hover {
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.12);
    transform: translateY(-1px);
  }
.notification-card.unread {
    border-left: 4px solid var(--secondary-color);
    background: linear-gradient(90deg, rgba(0, 122, 255, 0.02) 0%, white 10%);
  }
/* ======================================== */
/* Notification Icon */
/* ======================================== */
.notification-icon {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.2rem;
  color: white;
  margin-right: 12px;
  flex-shrink: 0;
}
/* ======================================== */
/* Notification Content */
/* ======================================== */
.notification-content {
  flex: 1;
  min-width: 0;
}
.notification-title {
  font-size: 16px;
  font-weight: 600;
  color: #1d1d1f;
  margin-bottom: 4px;
  line-height: 1.3;
}
.notification-body {
  font-size: 14px;
  color: #424242;
  margin-bottom: 8px;
  line-height: 1.4;
}
.notification-time {
  font-size: 12px;
  color: #8e8e93;
  display: flex;
  align-items: center;
}
/* ======================================== */
/* Notification Actions */
/* ======================================== */
.notification-actions {
  opacity: 0;
  transition: opacity 0.2s ease;
}
.notification-card:hover .notification-actions {
  opacity: 1;
}
.btn-mark-read {
  background: #f2f2f7;
  border: none;
  border-radius: 6px;
  padding: 4px 8px;
  font-size: 11px;
  color: var(--secondary-color);
  transition: background-color 0.2s ease;
}
.btn-mark-read:hover {
    background: #e5e5ea;
    color: #0056cc;
  }
.unread-indicator {
  width: 8px;
  height: 8px;
  background: var(--secondary-color);
  border-radius: 50%;
  margin-left: 8px;
}
/* ======================================== */
/* Animation */
/* ======================================== */
@keyframes slideInUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* ======================================== */
/* Loading State */
/* ======================================== */
.loading-state {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 40px;
  color: #8e8e93;
}
/* ======================================== */
/* Responsive */
/* ======================================== */
@media (max-width: 576px) {
  .notification-card {
    margin-bottom: 8px;
    padding: 12px;
    border-radius: 8px;
  }

  .notification-icon {
    width: 36px;
    height: 36px;
    margin-right: 10px;
  }

  .notification-title {
    font-size: 15px;
  }

  .notification-body {
    font-size: 13px;
  }
}
/* ======================================== */
/* Empty State */
/* ======================================== */
.notifications-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 60px 24px;
}
.notifications-empty__icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 20px;
}
.notifications-empty__icon i {
    font-size: 32px;
    color: var(--gray-400);
  }
.notifications-empty__title {
  font-size: 18px;
  font-weight: 600;
  color: var(--gray-700);
  margin: 0 0 8px;
}
.notifications-empty__text {
  font-size: 14px;
  color: var(--gray-500);
  margin: 0;
  max-width: 240px;
}
/* ======================================== */
/* Load More Button */
/* ======================================== */
.load-more-notifications-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  font-size: 14px;
  font-weight: 500;
  color: var(--gray-600);
  background: transparent;
  border: none;
  text-decoration: none;
  transition: all 0.2s ease;
}
.load-more-notifications-btn i {
    font-size: 14px;
    transition: transform 0.2s ease;
  }
.load-more-notifications-btn:hover {
    color: var(--primary-color);
    text-decoration: none;
  }
.load-more-notifications-btn:hover i {
      transform: translateY(2px);
    }
.load-more-notifications-btn:active {
    transform: scale(0.98);
  }
/* ========================================================================== */
/* QR Validator - Validador de órdenes presenciales */
/* ========================================================================== */
/* ======================================== */
/* Status Toast */
/* ======================================== */
.qr-validator-index .status-toast {
    margin-bottom: 1rem;
    animation: slideIn 0.3s ease;
  }
:is(.qr-validator-index .status-toast) i {
      font-size: 1.125rem;
    }
:is(.qr-validator-index .status-toast) span {
      font-weight: 500;
    }
.qr-validator-index {

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

  /* ======================================== */
  /* Main Title */
  /* ======================================== */
}
.qr-validator-index .main-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 500;
    color: #2c3e50;
    margin-bottom: 1.5rem;
    font-size: 1rem;
  }
/* ======================================== */
/* QR Scanner Section */
/* ======================================== */
:is(.qr-validator-index .qr-scanner-section) .card-qr {
      border: none;
      border-radius: 12px;
      box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
      margin-bottom: 1rem;
      overflow: hidden;
    }
:is(:is(.qr-validator-index .qr-scanner-section) .card-qr) .card-body {
        padding: 1rem;
        background-color: #fff;
      }
/* ======================================== */
/* Orders Section */
/* ======================================== */
:is(.qr-validator-index .orders-section) .card-qr {
      border: none;
      border-radius: 12px;
      box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
      margin-bottom: 1.5rem;
      overflow: hidden;
    }
:is(:is(.qr-validator-index .orders-section) .card-qr) .card-header-qr {
        background: linear-gradient(135deg, var(--gray-50) 0%, var(--gray-200) 100%);
        border-bottom: 1px solid var(--gray-300);
        padding: 1.25rem 1.5rem;
      }
:is(:is(:is(.qr-validator-index .orders-section) .card-qr) .card-header-qr) h3 {
          font-family: 'Poppins', sans-serif !important;
          font-weight: 500 !important;
          font-size: 1.125rem !important;
          color: var(--gray-700) !important;
          text-transform: uppercase;
          letter-spacing: 0.5px;
          margin-bottom: 0;
        }
:is(:is(.qr-validator-index .orders-section) .card-qr) .card-body-qr {
        padding: 0;
        background-color: #fff;
      }
/* ======================================== */
/* Order Cards */
/* ======================================== */
.qr-validator-index .order-card {
    background: #fff;
    border: 1px solid var(--gray-200);
    border-radius: 10px;
    margin-bottom: 1rem;
    overflow: hidden;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
  }
.qr-validator-index .order-card-header {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding: 1rem 1.25rem;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
    gap: 1rem;
  }
.qr-validator-index .order-card-info {
    flex: 1;
    min-width: 0;
  }
.qr-validator-index .order-card-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    font-size: 0.8rem;
    color: var(--gray-600);
    margin-bottom: 0.5rem;
  }
:is(.qr-validator-index .order-card-meta) i {
      color: var(--gray-400);
      margin-right: 0.25rem;
    }
.qr-validator-index .order-card-number {
    font-weight: 600;
    color: var(--gray-700);
  }
.qr-validator-index .order-card-customer {
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--gray-800);
  }
:is(.qr-validator-index .order-card-customer) i {
      color: var(--gray-400);
      margin-right: 0.375rem;
    }
.qr-validator-index .order-card-summary {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 0.5rem;
    flex-shrink: 0;
  }
.qr-validator-index .order-card-total {
    font-size: 1.125rem;
    font-weight: 600;
    color: var(--primary-color);
  }
.qr-validator-index .badge-status {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.25rem 0.625rem;
    font-size: 0.7rem;
    font-weight: 500;
    border-radius: 20px;
    text-transform: lowercase;
  }
:is(.qr-validator-index .badge-status) i {
      font-size: 0.65rem;
    }
.badge-success:is(.qr-validator-index .badge-status) {
      background: #dcfce7;
      color: #166534;
    }
.badge-warning:is(.qr-validator-index .badge-status) {
      background: #fef3c7;
      color: #92400e;
    }
/* Order Items */
.qr-validator-index .order-card-items {
    padding: 0;
  }
.qr-validator-index .order-item {
    padding: 0.875rem 1.25rem;
    border-bottom: 1px solid var(--gray-100);
  }
:is(.qr-validator-index .order-item):last-child {
      border-bottom: none;
    }
.qr-validator-index .order-item-name {
    font-size: 0.875rem;
    font-weight: 400;
    color: var(--gray-800);
    margin-bottom: 0.375rem;
  }
.qr-validator-index .order-item-qty {
    display: inline-block;
    background: var(--gray-100);
    color: var(--gray-600);
    font-weight: 500;
    font-size: 0.75rem;
    padding: 0.125rem 0.375rem;
    border-radius: 4px;
    margin-right: 0.25rem;
  }
.qr-validator-index .order-item-ingredients {
    padding-left: 0.5rem;
  }
.qr-validator-index .ingredient-group {
    font-size: 0.8rem;
    line-height: 1.6;
  }
.qr-validator-index .ingredient-category {
    color: var(--primary-color);
    font-weight: 500;
  }
.qr-validator-index .ingredient-list {
    color: var(--gray-600);
  }
/* Order Action */
.qr-validator-index .order-card-action {
    padding: 0.875rem 1.25rem;
    background: var(--gray-50);
    border-top: 1px solid var(--gray-200);
  }
/* Responsive */
@media (max-width: 576px) {
    .qr-validator-index .order-card-header {
      flex-direction: column;
    }

    .qr-validator-index .order-card-summary {
      flex-direction: row;
      justify-content: space-between;
      align-items: center;
      width: 100%;
    }
  }
/* ========================================================================== */
/* Store Show - Vista individual de tienda (cliente) */
/* ========================================================================== */
/* ======================================== */
/* Main Container */
/* ======================================== */
.main-nav-store {
  /* Hereda max-width de .container de Bootstrap */
  margin-top: 60px;
  padding: 0 16px;
  background: var(--gray-50);
  min-height: 100vh;
  overflow-x: hidden;
}
@media (max-width: 768px) {
.main-nav-store {
    padding: 0 12px;
}
  }
/* ======================================== */
/* Store Header - Mobile First (BEM) */
/* ======================================== */
.store-header {
  position: relative;
  width: 100%;
  margin-bottom: 16px;
  border-radius: 0 0 var(--border-radius-xl) var(--border-radius-xl);
  overflow: hidden;
  background: var(--gray-100);
}
.store-header__skeleton {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--gray-100);
  z-index: 1;
}
.store-header__media,
.store-header__carousel {
  position: relative;
  width: 100%;
  height: 190px;
}
@media (min-width: 768px) {
.store-header__media,
.store-header__carousel {
    height: 280px;
}
  }
@media (min-width: 1024px) {
.store-header__media,
.store-header__carousel {
    height: 350px;
}
  }
.store-header__carousel .carousel-inner,.store-header__carousel .carousel-item {
    width: 100%;
    height: 100%;
  }
.store-header__carousel .carousel-control-prev,.store-header__carousel .carousel-control-next {
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.4);
    border-radius: 50%;
    top: 50%;
    transform: translateY(-50%);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    opacity: 1;
  }
:is(.store-header__carousel .carousel-control-prev,.store-header__carousel .carousel-control-next):hover {
      background: rgba(0, 0, 0, 0.6);
    }
.store-header__carousel .carousel-control-prev {
    left: 16px;
  }
.store-header__carousel .carousel-control-next {
    right: 16px;
  }
.store-header__img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.store-header__overlay {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 65%;
  background: linear-gradient(to top,
    rgba(0, 0, 0, 0.85) 0%,
    rgba(0, 0, 0, 0.5) 40%,
    transparent 100%);
  pointer-events: none;
  z-index: 1;
}
.store-header__info {
  position: absolute;
  bottom: 16px;
  left: 16px;
  right: 70px;
  z-index: 2;
}
@media (min-width: 768px) {
.store-header__info {
    bottom: 24px;
    left: 24px;
    right: 90px;
}
  }
.store-header__name {
  color: white;
  font-size: 20px;
  font-weight: 700;
  margin: 0 0 8px 0;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  line-height: 1.2;
}
@media (min-width: 768px) {
.store-header__name {
    font-size: 26px;
}
  }
@media (min-width: 1024px) {
.store-header__name {
    font-size: 30px;
}
  }
.store-header__status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 20px;
  backdrop-filter: blur(5px);
}
.store-header__status i {
    font-size: 6px;
  }
.store-header__status--open {
  background: transparent;
  color: var(--primary-color);
}
.store-header__status--closed {
  background: transparent;
  color: #f87171;
}
.store-header__actions {
  position: absolute;
  bottom: 16px;
  right: 16px;
  display: flex;
  gap: 10px;
  z-index: 2;
}
@media (min-width: 768px) {
.store-header__actions {
    bottom: 24px;
    right: 24px;
}
  }
.store-header__btn {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, 0.3);
  backdrop-filter: blur(5px);
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  transition: all 0.2s ease;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
  text-decoration: none;
}
.store-header__btn:hover,.store-header__btn:active {
    background: rgba(0, 0, 0, 0.3);
    transform: scale(1.05);
    color: white;
    text-decoration: none;
  }
@media (min-width: 768px) {
.store-header__btn {
    width: 48px;
    height: 48px;
    font-size: 20px;
}
  }
/* ======================================== */
/* Legacy Carousel & Header (mantener compatibilidad) */
/* ======================================== */
.carousel-wrapper {
  margin-bottom: 24px;
  border-radius: 25px;
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  background: white;
}
#carouselPromotionalImages:not(.store-header__carousel) {
  width: 100%;
  height: 200px;
  border-radius: 0 0 25px 25px;
  overflow: hidden;
  position: relative;
  background: var(--gray-100);
}
#carouselPromotionalImages:not(.store-header__carousel) .carousel-inner,#carouselPromotionalImages:not(.store-header__carousel) .carousel-item {
    width: 100%;
    height: 100%;
  }
#carouselPromotionalImages:not(.store-header__carousel) .carousel-item img {
    width: 100%;
    height: 100%;
    -o-object-position: center;
       object-position: center;
    transition: transform 0.3s ease;
  }
#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-prev,#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-next {
    width: 40px;
    height: 40px;
    background: rgba(0, 0, 0, 0.5);
    border-radius: 50%;
    top: 50%;
    transform: translateY(-50%);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }
:is(#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-prev,#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-next):hover {
      background: rgba(0, 0, 0, 0.7);
    }
#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-prev {
    left: 16px;
  }
#carouselPromotionalImages:not(.store-header__carousel) .carousel-control-next {
    right: 16px;
  }
@media (min-width: 768px) {
#carouselPromotionalImages:not(.store-header__carousel) {
    height: 320px;
}
  }
@media (min-width: 1024px) {
#carouselPromotionalImages:not(.store-header__carousel) {
    height: 400px;
}
  }
/* ======================================== */
/* Legacy Store Header Image Container */
/* ======================================== */
.container-img {
  width: 100%;
  height: 200px;
  position: relative;
  border-radius: var(--border-radius-lg);
  border-radius: 0 0 var(--border-radius-lg) var(--border-radius-lg);
  overflow: hidden;
  background: var(--gray-100);
}
.container-img .header-img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
       object-fit: cover;
    display: block;
  }
@media (min-width: 768px) {
.container-img {
    height: 320px;
}
  }
@media (min-width: 1024px) {
.container-img {
    height: 400px;
}
  }
/* ======================================== */
/* Legacy Store Title Overlay */
/* ======================================== */
.item_title-store {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  padding: 40px 20px 20px;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8) 0%, rgba(0, 0, 0, 0.4) 50%, transparent 100%);
}
.item_title-store h1,.item_title-store h3 {
    color: white;
    font-size: 24px;
    font-weight: 700;
    margin: 0;
    text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
  }
@media (max-width: 768px) {
.item_title-store h1,.item_title-store h3 {
      font-size: 20px;
  }
    }
.item_title-store small {
    color: rgba(255, 255, 255, 0.9);
    font-size: 14px;
    font-weight: 500;
  }
/* ======================================== */
/* Legacy See More Button */
/* ======================================== */
.carousel-see-more {
  position: absolute;
  bottom: 16px;
  right: 16px;
  z-index: 10;
}
.see-more {
  background: rgba(255, 255, 255, 0.95) !important;
  color: var(--gray-800) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  padding: 5px 10px !important;
  border-radius: var(--border-radius-md) !important;
  border: none !important;
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transition: all 0.2s ease;
}
.see-more:hover {
    background: white !important;
    transform: translateY(-2px);
    box-shadow: var(--shadow-lg);
  }
/* ======================================== */
/* Follow Button */
/* ======================================== */
.follow-action {
  position: absolute;
  top: 70px;
  right: 20px;
  z-index: 20;
  background: rgba(255, 255, 255, 0.95);
  padding: 8px;
  border-radius: 50%;
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  cursor: pointer;
  transition: all 0.2s ease;
}
.follow-action:hover {
    background: white;
    transform: scale(1.05);
  }
.follow-action i {
    color: var(--gray-600);
    font-size: 18px;
  }
.active-follow:is(.follow-action i) {
      color: var(--danger-color);
    }
/* ======================================== */
/* Fixed Bottom Bar (Cart) */
/* ======================================== */
.fixed-bottom-bar {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% - 32px);
  max-width: 400px;
  background: var(--primary-color);
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-xl);
  z-index: 1000;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
}
.view-cart-button {
  display: block;
  width: 100%;
  background: var(--primary-color);
  color: white;
  border: none;
  border-radius: var(--border-radius-lg);
  padding: 16px;
  font-weight: 600;
  font-size: 16px;
  cursor: pointer;
  transition: all 0.2s ease;
  text-decoration: none;
  text-align: center;
}
.view-cart-button:hover {
    transform: translateY(-2px);
    color: white;
    text-decoration: none;
  }
.items-count {
  margin-top: 8px;
  font-size: 14px;
  opacity: 0.9;
}
/* ======================================== */
/* Utility Classes */
/* ======================================== */
.no-tick {
  background-image: none !important;
}
.bg-highlight {
  background: var(--gray-100);
  border-radius: var(--border-radius-lg);
}
.mobile-name {
  font-size: 1.2rem;
  font-weight: 600;
}
@media (max-width: 768px) {
.mobile-name {
    font-size: 1.1rem;
}
  }
.space-card {
  margin: 16px 0;
}
.margin-b {
  margin-top: 16px;
}
/* ======================================== */
/* Time Remaining */
/* ======================================== */
.time-remaining-container {
  position: absolute;
  bottom: 8px;
  left: 8px;
  background: rgba(0, 0, 0, 0.7);
  border-radius: var(--border-radius-sm);
  padding: 4px 8px;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}
.time-remaining {
  color: white;
  font-size: 12px;
  font-weight: 600;
  margin: 0;
}
/* ======================================== */
/* Messages & States */
/* ======================================== */
.no-discounts-message {
  background: var(--gray-100);
  color: var(--gray-700);
  text-align: center;
  padding: 24px;
  margin: 24px 0;
  border-radius: var(--border-radius-lg);
  font-weight: 600;
  border: 1px solid var(--gray-200);
}
.no-results {
  background: rgba(255, 59, 48, 0.1);
  color: var(--danger-color);
  border: 1px solid rgba(255, 59, 48, 0.2);
  padding: 24px;
  margin: 24px 0;
  border-radius: var(--border-radius-lg);
  text-align: center;
}
.no-results p {
    margin: 0;
    font-size: 16px;
    font-weight: 500;
  }
/* ======================================== */
/* QR Code Styles */
/* ======================================== */
.qr-info {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  padding: 24px;
}
.qr-code-container {
  text-align: center;
  padding: 24px;
  background: white;
  border-radius: var(--border-radius-lg);
  box-shadow: var(--shadow-md);
}
.qr-code-image {
  max-width: 100%;
  height: auto;
  border: 1px solid var(--gray-200);
  padding: 16px;
  background: white;
  border-radius: var(--border-radius-md);
}
.download-qr {
  text-align: center;
  margin-top: 24px;
}
.img-preview {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 16px 0;
  border: 1px solid var(--gray-200);
  border-radius: var(--border-radius-md);
  box-shadow: var(--shadow-sm);
}
/* ======================================== */
/* Step Progress */
/* ======================================== */
.step-progress-wrapper {
  position: relative;
  margin: 32px 0;
}
.step-progress-bar {
  position: absolute;
  top: 50%;
  left: 0;
  height: 4px;
  width: 100%;
  background: var(--gray-200);
  border-radius: 2px;
  z-index: 1;
  transform: translateY(-50%);
}
.step-progress-bar::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 0%;
    background: var(--primary-color);
    border-radius: 2px;
    transition: width 0.4s ease;
    z-index: 2;
  }
.step-indicator {
  position: relative;
  z-index: 3;
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 120px;
  padding: 12px 20px;
  border-radius: var(--border-radius-xl);
  background: white;
  font-weight: 600;
  color: var(--gray-600);
  border: 2px solid var(--gray-200);
  transition: all 0.3s ease;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  box-shadow: var(--shadow-sm);
}
.step-indicator.active {
    background: var(--primary-color);
    color: white;
    border-color: var(--primary-color);
    box-shadow: var(--shadow-lg);
    transform: scale(1.05);
  }
.step-indicator.completed {
    background: var(--gray-600);
    color: white;
    border-color: var(--gray-600);
    box-shadow: var(--shadow-md);
  }
@media (max-width: 480px) {
.step-indicator {
    min-width: 100px;
    padding: 8px 12px;
    font-size: 14px;
}
  }
.video-wrapper {
  width: 100%;
  max-width: 450px;
  margin: 0 auto 24px;
  border-radius: var(--border-radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
}
/* ======================================== */
/* Sections Navigation - Mobile First (BEM) */
/* ======================================== */
.sections-nav {
  background: white;
  padding: 0;
  margin: 0 -12px 16px;
  overflow: hidden;

  /* Oculto por defecto - no ocupa espacio */
  opacity: 0;
  height: 0;
  visibility: hidden;
  pointer-events: none;
}
.sections-nav.sticky {
    position: fixed;
    top: 60px;
    left: 0;
    right: 0;
    z-index: 1000;
    opacity: 1;
    height: auto;
    visibility: visible;
    pointer-events: auto;
    padding: 10px 0;
    margin: 0;
    border-bottom: 1px solid var(--gray-100);
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.06);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    background: rgba(255, 255, 255, 0.95);
  }
@media (min-width: 768px) {
.sections-nav {
    margin: 0 0 20px;
    border-radius: var(--border-radius-md);
}
  }
.sections-nav__track {
  display: flex;
  gap: 8px;
  padding: 0 16px;
  overflow-x: auto;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;

  /* Ocultar scrollbar */
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.sections-nav__track::-webkit-scrollbar {
    display: none;
  }
/* Desktop: constrain to Bootstrap container widths */
@media (min-width: 768px) {
.sections-nav__track {
    max-width: 720px;
    margin: 0 auto;
    padding: 0 20px;
    gap: 10px;
}
  }
@media (min-width: 992px) {
.sections-nav__track {
    max-width: 960px;
}
  }
@media (min-width: 1200px) {
.sections-nav__track {
    max-width: 1140px;
}
  }
@media (min-width: 1400px) {
.sections-nav__track {
    max-width: 1320px;
}
  }
.sections-nav__item {
  flex-shrink: 0;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 500;
  color: var(--gray-600);
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 20px;
  text-decoration: none;
  white-space: nowrap;
  transition: all 0.2s ease;
  -webkit-tap-highlight-color: transparent;
}
.sections-nav__item:hover {
    background: var(--gray-100);
    color: var(--gray-700);
    text-decoration: none;
  }
.sections-nav__item:active {
    transform: scale(0.97);
  }
.sections-nav__item.active {
    background: var(--store-primary, var(--primary-color));
    color: white;
    border-color: var(--store-primary, var(--primary-color));
    font-weight: 600;
  }
@media (max-width: 768px) {
.sections-nav__item {
    padding: 7px 14px;
    font-size: 12px;
}
  }
.sections-nav__item--hot {
  background: #fef2f2;
  color: #dc2626;
  border-color: #fecaca;
}
.sections-nav__item--hot:hover {
    background: #fee2e2;
    border-color: #fca5a5;
  }
.sections-nav__item--hot.active {
    background: #fee2e2;
    color: #dc2626;
    border-color: #f87171;
    font-weight: 600;
  }
/* ======================================== */
/* Legacy Sections Navigation */
/* ======================================== */
.sections-container {
  display: flex;
  max-width: 100%;
  cursor: pointer;
  overflow-x: auto;
  padding: 8px 20px;
  gap: 8px;
  background: white;

  /* Oculto por defecto - no ocupa espacio */
  opacity: 0;
  visibility: hidden;
  height: 0;
  margin: 0;
  padding: 0;
  transform: translateY(-10px);

  /* Transición suave */
  transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1),
              box-shadow 0.25s cubic-bezier(0.4, 0, 0.2, 1),
              background-color 0.25s cubic-bezier(0.4, 0, 0.2, 1),
              opacity 0.25s ease-in-out,
              height 0.25s ease-in-out;

  /* Scrollbar styling */
}
.sections-container::-webkit-scrollbar {
    display: none;
  }
.sections-container {
  -ms-overflow-style: none;
  scrollbar-width: none;

  /* Cuando se vuelve sticky */
}
.sections-container.sticky {
    position: fixed;
    top: 60px;
    left: 0;
    right: 0;
    z-index: 1000;
    border-bottom: 1px solid var(--gray-100);
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
    backdrop-filter: blur(20px);
    background: rgba(255, 255, 255, 0.95);

    /* Mostrar con dimensiones normales */
    opacity: 1;
    visibility: visible;
    height: auto;
    padding: 8px 20px;
    transform: translate3d(0, 0, 0);
    -webkit-transform: translate3d(0, 0, 0);
    will-change: auto;
    contain: layout style paint;
  }
#margin-b {
  margin-bottom: 55px;
}
/* Section title for product categories */
.section-title {
  padding-top: 90px;
  margin-top: -70px;
  display: block;
  text-align: left;
  margin-left: 20px;
  color: var(--gray-800);
  font-weight: 600;
}
/* Button container for sections */
.button-section {
  display: inline-block;
  background: transparent;
  border: none;
  padding: 4px 2px;
  margin: 0;
  outline: none !important;
  box-shadow: none !important;
}
.button-section:focus,.button-section:active,.button-section:focus-visible {
    outline: none !important;
    border: none !important;
    box-shadow: none !important;
  }
/* Section links styling */
.section-link {
  display: inline-block;
  background: var(--gray-50);
  color: var(--gray-600);
  text-decoration: none !important;
  padding: 6px 12px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  border: 1px solid var(--gray-200) !important;
  outline: none !important;
  box-shadow: none !important;
  position: relative;
  letter-spacing: 0.25px;
}
.section-link:focus,.section-link:active,.section-link:focus-visible,.section-link:visited {
    outline: none !important;
    border: 1px solid var(--gray-200) !important;
    box-shadow: none !important;
    text-decoration: none !important;
  }
.section-link:hover {
    background: var(--gray-100);
    color: var(--gray-700);
    text-decoration: none;
    transform: none;
    border: 1px solid var(--gray-300) !important;
  }
.section-link.active {
    background: var(--primary-color);
    color: white;
    border: 1px solid var(--primary-color) !important;
    font-weight: 600;
  }
/* Estilo especial para descuentos */
.section-link[data-section="section-hot-descuento"] {
    background: #fef2f2;
    color: #dc2626;
    border: 1px solid #fecaca !important;
  }
.section-link[data-section="section-hot-descuento"]:hover {
      background: #fef2f2;
      border: 1px solid #f87171 !important;
    }
@media (max-width: 768px) {
.section-link {
    font-size: 12px;
    padding: 5px 10px;
}
  }
/* Section decoration title */
.decoration-section {
  font-size: 24px;
  font-weight: 600;
  color: var(--gray-800);
  margin: 32px 0 20px 0;
  padding: 0 4px;
  position: relative;
}
.decoration-section:after {
    content: '';
    position: absolute;
    bottom: -8px;
    left: 4px;
    width: 60px;
    height: 3px;
    background: linear-gradient(135deg, var(--primary-color), var(--success-color));
    border-radius: 2px;
  }
@media (max-width: 768px) {
.decoration-section {
    font-size: 20px;
    margin: 24px 0 16px 0;
}
  }
/* ======================================== */
/* PWA Install Banner */
/* ======================================== */
[data-controller="pwa"] .install-pwa-banner {
    background: linear-gradient(135deg, var(--secondary-color), #5ac8fa);
    color: white;
    border-radius: var(--border-radius-lg);
    padding: 16px 20px;
    margin: 16px 0;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
  }
:is([data-controller="pwa"] .install-pwa-banner)::before {
      content: '';
      position: absolute;
      top: 0;
      left: -100%;
      width: 100%;
      height: 100%;
      background: linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);
      transition: left 0.5s ease;
    }
:is([data-controller="pwa"] .install-pwa-banner):hover::before {
      left: 100%;
    }
:is([data-controller="pwa"] .install-pwa-banner) .install-text {
      font-weight: 600;
      margin-bottom: 8px;
    }
:is([data-controller="pwa"] .install-pwa-banner) .install-description {
      font-size: 14px;
      opacity: 0.9;
    }
:is([data-controller="pwa"] .install-pwa-banner) .install-button {
      background: rgba(255, 255, 255, 0.2);
      border: 1px solid rgba(255, 255, 255, 0.3);
      color: white;
      border-radius: var(--border-radius-md);
      padding: 8px 16px;
      font-weight: 600;
      margin-top: 12px;
      transition: all 0.2s ease;
    }
:is(:is([data-controller="pwa"] .install-pwa-banner) .install-button):hover {
        background: rgba(255, 255, 255, 0.3);
        transform: translateY(-2px);
      }
/* ======================================== */
/* Skeleton Loading */
/* ======================================== */
.placeholder-card {
  background: var(--gray-100);
  border-radius: var(--border-radius-lg);
  position: relative;
  overflow: hidden;
}
.placeholder-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: -100%;
    width: 100%;
    height: 100%;
    background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.4), transparent);
    animation: shimmer 2s infinite;
  }
.skeleton-text {
  background: var(--gray-200);
  border-radius: 4px;
  height: 16px;
  margin: 8px 0;
  animation: pulse 1.5s ease-in-out infinite alternate;
}
.skeleton-text.skeleton-title {
    height: 20px;
    width: 60%;
  }
.skeleton-text.skeleton-subtitle {
    height: 14px;
    width: 80%;
  }
.skeleton-text.skeleton-price {
    height: 18px;
    width: 40%;
    margin-top: 16px;
  }
/* ======================================== */
/* Animations */
/* ======================================== */
@keyframes shimmer {
  0% { left: -100%; }
  100% { left: 100%; }
}
@keyframes pulse {
  0% { opacity: 0.6; }
  100% { opacity: 1; }
}
@keyframes ring {
  0%, 20%, 50%, 80%, 100% { transform: rotate(0deg); }
  10%, 30% { transform: rotate(-10deg); }
  40%, 60% { transform: rotate(10deg); }
}
@keyframes hotPulse {
  0%, 100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(255, 59, 48, 0.4);
  }
  50% {
    transform: scale(1.02);
    box-shadow: 0 0 0 8px rgba(255, 59, 48, 0);
  }
}
/* ======================================== */
/* iOS Optimizations */
/* ======================================== */
@supports (-webkit-touch-callout: none) {
  .menu_item.thumbs {
    -webkit-tap-highlight-color: transparent;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
         user-select: none;
  }

  .view-cart-button,
  .see-more,
  .follow-action {
    -webkit-appearance: none;
    -moz-appearance: none;
         appearance: none;
    -webkit-tap-highlight-color: transparent;
  }
}
/* ======================================== */
/* Touch Feedback */
/* ======================================== */
@media (hover: none) and (pointer: coarse) {
  .menu_item.thumbs:active {
    transform: scale(0.98);
    transition: transform 0.1s ease;
  }

  .view-cart-button:active,
  .see-more:active {
    transform: scale(0.95);
  }
}
/* ======================================== */
/* Landscape Mode */
/* ======================================== */
@media (orientation: landscape) and (max-height: 500px) {
  .carousel-wrapper,
  .container-img {
    height: 200px;
  }
}
/* ======================================== */
/* High DPI Displays */
/* ======================================== */
@media (min-resolution: 192dpi) {
  .product-image,
  .carousel-img,
  .header-img {
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
  }
}
/* ======================================== */
/* Accessibility */
/* ======================================== */
.menu_item.thumbs:focus-within,
.view-cart-button:focus,
.see-more:focus,
.follow-action:focus {
  outline: 3px solid var(--secondary-color);
  outline-offset: 2px;
}
@media (prefers-contrast: high) {
  .menu_item.thumbs {
    border: 2px solid;
  }

  .discount-banner-menu,
  .discount-banner-menu-hot {
    border: 1px solid white;
  }

  .view-cart-button {
    border: 2px solid white;
  }
}
@media (prefers-reduced-motion: reduce) {
  * {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }

  .discount-banner-menu-hot {
    animation: none !important;
  }

  .placeholder-card::before {
    animation: none;
  }

  [data-notifications-target="button"] i {
    animation: none;
  }
}
/* ======================================== */
/* Print Styles */
/* ======================================== */
@media print {
  .fixed-bottom-bar,
  .follow-action,
  .see-more,
  .carousel-control-prev,
  .carousel-control-next,
  .discount-banner-menu,
  .discount-banner-menu-hot {
    display: none !important;
  }

  .main-nav-store {
    background: white;
    color: black;
  }

  .menu_item.thumbs {
    box-shadow: none;
    border: 1px solid #ddd;
  }
}
/* ======================================== */
/* GPU Performance */
/* ======================================== */
.product-image,
.view-cart-button,
.see-more,
.follow-action i,
.step-indicator,
.carousel-item img {
  transform: translateZ(0);
  backface-visibility: hidden;
  perspective: 1000px;
}
.menu_item.thumbs h4,
.menu_item.thumbs p,
.decoration-section,
.modal-title {
  font-display: swap;
}
/* ======================================== */
/* Fallbacks */
/* ======================================== */
@supports not (backdrop-filter: blur(10px)) {
  .see-more,
  .follow-action,
  .carousel-control-prev,
  .carousel-control-next {
    background: rgba(255, 255, 255, 0.9) !important;
  }
}
/* ======================================== */
/* Box Sizing */
/* ======================================== */
* {
  box-sizing: border-box;
}
/* ======================================== */
/* Legacy Cleanup */
/* ======================================== */
.decoration-section:not(.decoration-section:first-of-type) {
  font-size: inherit;
}
.discount-banner-menu:not(:first-of-type),
.discount-banner-menu-hot:not(:first-of-type) {
  display: none;
}
.ellipsis:not(.ellipsis:first-of-type) {
  display: inherit;
  -webkit-line-clamp: inherit;
  line-clamp: inherit;
}
/* Performance */
.menu-gallery {
  will-change: transform;
}
/* ======================================== */
/* Store Info Modal */
/* ======================================== */
#modalStore .modal-dialog {
    max-width: 600px;
  }
#modalStore .modal-content {
    border-radius: var(--border-radius-lg);
    border: none;
    box-shadow: var(--shadow-xl);
  }
#modalStore .modal-header {
    background: linear-gradient(var(--primary-color));
    color: white;
    border-radius: var(--border-radius-lg) var(--border-radius-lg) 0 0;
    padding: 12px;
    border: none;
  }
:is(#modalStore .modal-header) .modal-title {
      color: white !important;
      font-size: 24px;
      font-weight: 500 !important;
    }
:is(#modalStore .modal-header) .btn-close {
      filter: brightness(0) invert(1);
      opacity: 0.8;
    }
:is(:is(#modalStore .modal-header) .btn-close):hover {
        opacity: 1;
      }
#modalStore .modal-body {
    padding: 32px 24px;
    background: white;
  }
:is(#modalStore .modal-body) .text-center p {
      font-size: 16px;
      line-height: 1.6;
      color: var(--gray-600);
      margin-bottom: 24px;
    }
:is(#modalStore .modal-body) h6 {
      color: var(--gray-800) !important;
      font-size: 18px;
      font-weight: 700;
      margin: 24px 0 16px 0;
      display: flex;
      align-items: center;
      gap: 8px;
    }
:is(:is(#modalStore .modal-body) h6)::before {
        content: '';
        width: 4px;
        height: 20px;
        background: var(--primary-color);
        border-radius: 2px;
      }
:is(#modalStore .modal-body) .list-group {
      border-radius: var(--border-radius-md);
      overflow: hidden;
      box-shadow: var(--shadow-sm);
    }
:is(:is(#modalStore .modal-body) .list-group) .list-group-item {
        border: none;
        padding: 16px;
        font-size: 14px;
        font-weight: 500;
        transition: background-color 0.2s ease;
        border-radius: 20px;
      }
:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item):not(:last-child) {
          border-bottom: 1px solid var(--gray-100);
        }
.bg-secondary:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) {
          background: var(--primary-color) !important;
          color: white !important;
          font-weight: 500;
        }
.bg-secondary:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) i {
            color: white !important;
          }
.text-muted:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) {
          background: var(--gray-50);
          color: var(--gray-500) !important;
        }
:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) i {
          margin-right: 12px;
          width: 16px;
          text-align: center;
        }
.fa-clock:is(:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) i) {
            color: var(--success-color);
          }
.fa-times-circle:is(:is(:is(:is(#modalStore .modal-body) .list-group) .list-group-item) i) {
            color: var(--danger-color);
          }
:is(#modalStore .modal-body) hr {
      margin: 32px 0;
      border: none;
      height: 1px;
      background: var(--gray-200);
      opacity: 1;
    }
/* Store Contact Info */
:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item {
        display: flex;
        align-items: center;
        padding: 12px 0;
        border-bottom: 1px solid var(--gray-50);
      }
:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item):last-child {
          border-bottom: none;
        }
:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-label {
          font-weight: 600;
          color: var(--gray-700);
          margin-right: 8px;
          min-width: 80px;
        }
:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-link {
          color: var(--primary-color);
          text-decoration: none;
          font-weight: 500;
        }
:is(:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-link) a {
            color: inherit;
            text-decoration: none;
          }
:is(:is(:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-link) a):hover {
              color: #228b3d;
              text-decoration: underline;
            }
:is(:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-link):hover {
            color: #228b3d;
            text-decoration: underline;
          }
:is(:is(:is(#modalStore .modal-body) .store-contact-info) .contact-item) .contact-value {
          color: var(--gray-500);
          font-weight: 500;
        }
/* Store Features (pet-friendly, wifi, etc.) */
:is(:is(#modalStore .modal-body) .store-features) .feature-item {
        display: flex;
        align-items: center;
        padding: 16px;
        background: var(--gray-50);
        border-radius: 8px;
        margin-bottom: 12px;
        transition: all 0.2s ease;
        border: 1px solid var(--gray-200);
      }
:is(:is(:is(#modalStore .modal-body) .store-features) .feature-item):hover {
          background: var(--gray-200);
          border-color: var(--gray-300);
        }
:is(:is(:is(#modalStore .modal-body) .store-features) .feature-item) i {
          font-size: 18px;
          min-width: 24px;
          text-align: center;
        }
:is(:is(:is(#modalStore .modal-body) .store-features) .feature-item) .feature-content {
          display: flex;
          align-items: center;
          justify-content: space-between;
          width: 100%;
        }
:is(:is(:is(:is(#modalStore .modal-body) .store-features) .feature-item) .feature-content) .feature-text {
            font-size: 15px;
            font-weight: 500;
            flex: 1;
          }
:is(:is(:is(:is(#modalStore .modal-body) .store-features) .feature-item) .feature-content) .feature-badge {
            font-size: 12px;
            padding: 6px 12px;
            border-radius: 20px;
            font-weight: 600;
            white-space: nowrap;
          }
/* Store Actions - Styles moved to components/_buttons.css (.store-action-btn) */
/* ========================================================================== */
/* Shopping Sales - Historial de compras del usuario */
/* ========================================================================== */
/* ======================================== */
/* Main Container */
/* ======================================== */
.shopping-sales {
  padding-top: 60px;
  min-height: 100vh;
  background: var(--gray-50);
}
/* ======================================== */
/* Savings Header */
/* ======================================== */
.shopping-sales__header {
  position: fixed;
  top: 60px;
  left: 0;
  right: 0;
  z-index: 100;
  background: var(--primary-color);
  padding: 12px 16px;
}
.shopping-sales__savings {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  max-width: 600px;
  margin: 0 auto;
}
.shopping-sales__savings-label {
  font-size: 16px;
  color: rgba(255, 255, 255, 0.9);
  font-weight: 500;
}
.shopping-sales__savings-amount {
  font-size: 20px;
  font-weight: 600;
  color: white;
}
@media (min-width: 768px) {
.shopping-sales__savings-amount {
    font-size: 24px;
}
  }
/* ======================================== */
/* Content Area */
/* ======================================== */
.shopping-sales__content {
  padding: 16px;
  padding-top: 70px;
  max-width: 600px;
  margin: 0 auto;
}
@media (min-width: 768px) {
.shopping-sales__content {
    padding: 24px;
    padding-top: 80px;
}
  }
.shopping-sales__list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
/* ======================================== */
/* Load More Button */
/* ======================================== */
.shopping-sales__load-more {
  margin-top: 20px;
  text-align: center;
}
.shopping-sales__load-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 500;
  color: var(--primary-color);
  background: white;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s ease;
}
.shopping-sales__load-btn:hover {
    background: var(--gray-50);
    border-color: var(--primary-color);
    text-decoration: none;
  }
/* ======================================== */
/* Empty State */
/* ======================================== */
.shopping-sales__empty {
  text-align: center;
  padding: 60px 20px;
  background: white;
  border-radius: 16px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
.shopping-sales__empty-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 20px;
  border-radius: 50%;
  background: var(--gray-100);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 32px;
  color: var(--gray-400);
}
.shopping-sales__empty-title {
  font-size: 18px;
  font-weight: 600;
  color: var(--gray-700);
  margin: 0 0 8px;
}
.shopping-sales__empty-text {
  font-size: 14px;
  color: var(--gray-500);
  margin: 0 0 24px;
  max-width: 280px;
  margin-left: auto;
  margin-right: auto;
}
.shopping-sales__empty-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 24px;
  font-size: 14px;
  font-weight: 600;
  color: white;
  background: var(--primary-color);
  border-radius: 12px;
  text-decoration: none;
  transition: all 0.2s ease;
}
.shopping-sales__empty-btn:hover {
    background: #2a9d5a;
    transform: translateY(-2px);
    text-decoration: none;
    color: white;
  }
.shopping-sales__empty-btn i {
    font-size: 14px;
  }
/* ========================================================================== */
/* Order Receipt Card */
/* ========================================================================== */
.order-receipt {
  background: white;
  border-radius: 16px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.06);
}
/* ======================================== */
/* Receipt Header */
/* ======================================== */
.order-receipt__header {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px;
  background: white;
  text-decoration: none;
  transition: background 0.2s ease;
}
.order-receipt__header:hover {
    background: var(--gray-50);
    text-decoration: none;
  }
.order-receipt__avatar {
  flex-shrink: 0;
}
.order-receipt__avatar-img {
  width: 48px;
  height: 48px;
  border-radius: 12px;
  -o-object-fit: cover;
     object-fit: cover;
  border: 1px solid var(--gray-100);
}
@media (min-width: 768px) {
.order-receipt__avatar-img {
    width: 56px;
    height: 56px;
}
  }
.order-receipt__store-info {
  flex: 1;
  min-width: 0;
}
.order-receipt__store-row {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: nowrap;
  margin-bottom: 4px;
}
.order-receipt__store-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 140px;
}
@media (min-width: 400px) {
.order-receipt__store-name {
    max-width: 180px;
}
  }
/* ======================================== */
/* Status Pill */
/* ======================================== */
.order-receipt__status-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 600;
  border-radius: 10px;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}
.order-receipt__status-pill i {
    font-size: 5px;
  }
.order-receipt__status-pill--delivered {
  background: rgba(34, 197, 94, 0.1);
  color: #22c55e;
}
.order-receipt__status-pill--pending {
  background: rgba(251, 191, 36, 0.1);
  color: #f59e0b;
}
/* ======================================== */
/* Meta (fecha + order number) */
/* ======================================== */
.order-receipt__meta {
  font-size: 11px;
  color: var(--gray-400);
  margin: 0;
  display: flex;
  align-items: center;
  gap: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.order-receipt__separator {
  margin: 0 6px;
  color: var(--gray-300);
}
.order-receipt__order-number {
  font-family: 'SF Mono', 'Monaco', 'Roboto Mono', monospace;
  font-weight: 500;
  color: var(--gray-500);
}
.order-receipt__payment-method {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--gray-500);
  margin: 0 0 2px;
}
.order-receipt__payment-method i {
    font-size: 10px;
    color: var(--gray-400);
  }
.order-receipt__total {
  flex-shrink: 0;
  text-align: right;
}
.order-receipt__total-label {
  display: block;
  font-size: 11px;
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 2px;
}
.order-receipt__total-amount {
  font-size: 16px;
  font-weight: 600;
  color: var(--gray-800);
}
@media (min-width: 768px) {
.order-receipt__total-amount {
    font-size: 20px;
}
  }
/* ======================================== */
/* Products List */
/* ======================================== */
.order-receipt__products {
  border-top: 1px solid var(--gray-100);
}
.order-receipt__item {
  padding: 6px 10px;
  border-bottom: 1px solid var(--gray-50);
}
.order-receipt__item:last-child {
    border-bottom: none;
  }
.order-receipt__item-main {
  display: flex;
  align-items: center;
  gap: 8px;
}
.order-receipt__item-name {
  flex: 1;
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-700);
  line-height: 1.3;
}
@media (min-width: 768px) {
.order-receipt__item-name {
    font-size: 15px;
}
  }
.order-receipt__item-qty {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-500);
  padding: 2px 8px;
  background: var(--gray-100);
  border-radius: 6px;
}
.order-receipt__item-price {
  flex-shrink: 0;
  font-size: 12px;
  font-weight: 600;
  color: var(--primary-color);
  min-width: 70px;
  text-align: right;
}
@media (min-width: 768px) {
.order-receipt__item-price {
    font-size: 15px;
    min-width: 80px;
}
  }
/* ======================================== */
/* Ingredients */
/* ======================================== */
.order-receipt__ingredients {
  margin-top: 8px;
  padding: 10px 12px;
  background: var(--gray-50);
  border-radius: 8px;
}
.order-receipt__ingredients-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
}
.order-receipt__ingredients.expanded .order-receipt__ingredients-content {
  max-height: 300px;
}
.order-receipt__ingredient-group {
  font-size: 12px;
  color: var(--gray-600);
  line-height: 1.5;
  margin-bottom: 4px;
}
.order-receipt__ingredient-group:last-child {
    margin-bottom: 0;
  }
.order-receipt__ingredient-group strong {
    color: var(--gray-700);
    font-weight: 600;
  }
.order-receipt__show-more {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 0;
  margin-top: 6px;
  font-size: 12px;
  font-weight: 500;
  color: var(--primary-color);
  background: none;
  border: none;
  cursor: pointer;
  transition: color 0.2s ease;
}
.order-receipt__show-more:hover {
    color: #2a9d5a;
    text-decoration: underline;
  }
/* ======================================== */
/* Receipt Footer (solo para QR pendiente) */
/* ======================================== */
.order-receipt__footer {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 20px 16px;
  background: var(--gray-50);
  border-top: 1px solid var(--gray-100);
}
/* ======================================== */
/* QR Code */
/* ======================================== */
.order-receipt__qr {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.order-receipt__qr-img {
  width: 120px;
  height: 120px;
  border-radius: 12px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}
@media (min-width: 768px) {
.order-receipt__qr-img {
    width: 140px;
    height: 140px;
}
  }
.order-receipt__qr-hint {
  font-size: 12px;
  color: var(--gray-500);
  text-align: center;
  line-height: 1.4;
}
/* ========================================================================== */
/* Legacy Support - Keep old classes working */
/* ========================================================================== */
.savigs {
  margin-top: 60px;
  padding: 10px;
}
.card-saving {
  margin-top: 75px;
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
  padding: 0 16px;
}
.load-more-orders {
  text-align: center;
  padding: 20px;
}
.receipt-container {
  padding: 5px;
  box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--gray-200);
}
.receipt-card {
  padding: 0;
  display: flex;
  flex-direction: column;
}
.total-item {
  font-size: 16px;
  font-weight: 600;
  color: var(--primary-color);
  margin: 4px 0 0 0;
}
.img-qr {
  height: 180px;
  width: 180px;
  border-radius: 12px;
}
/* ========================================================================== */
/* Products Form - Formulario de creación/edición de productos */
/* ========================================================================== */
.product-form {
  font-family: 'Poppins', sans-serif;

  /* Form container */
}
.product-form .form-container {
    background: #fff;
    border-radius: 12px;
    box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
    padding: 2rem;
    border: 1px solid var(--gray-200);
  }
/* Form title */
.product-form .form-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1.5rem;
    color: #2c3e50;
    margin-bottom: 1.5rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--gray-200);
  }
/* Form inputs wrapper */
.product-form .form-inputs {
    margin-bottom: 1.5rem;
  }
/* Form groups */
.product-form .form-group {
    margin-bottom: 1.25rem;
  }
:is(.product-form .form-group) label,:is(.product-form .form-group) .form-label {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.875rem;
      color: var(--gray-700);
      margin-bottom: 0.5rem;
      display: block;
    }
:is(.product-form .form-group) .form-control {
      font-family: 'Poppins', sans-serif;
      font-size: 0.9rem;
      padding: 0.625rem 0.875rem;
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      transition: all 0.2s ease;
      background-color: #fff;
    }
:is(:is(.product-form .form-group) .form-control):focus {
        border-color: var(--primary-color);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
        outline: none;
      }
:is(:is(.product-form .form-group) .form-control)::-moz-placeholder {
        color: #adb5bd;
        font-style: italic;
      }
:is(:is(.product-form .form-group) .form-control)::placeholder {
        color: #adb5bd;
        font-style: italic;
      }
/* Select styling */
:is(.product-form .form-group) select.form-control {
      -webkit-appearance: none;
         -moz-appearance: none;
              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-repeat: no-repeat;
      background-position: right 0.75rem center;
      background-size: 16px 12px;
      padding-right: 2.5rem;
    }
/* Textarea styling */
:is(.product-form .form-group) textarea.form-control {
      min-height: 100px;
      resize: vertical;
    }
/* Trix editor styling */
.product-form .trix-editor-container {
    margin-bottom: 1.25rem;
    /* Reservar espacio para evitar CLS cuando Trix inicializa */
    min-height: 200px;
  }
:is(.product-form .trix-editor-container) label {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.875rem;
      color: var(--gray-700);
      margin-bottom: 0.5rem;
      display: block;
    }
:is(.product-form .trix-editor-container) trix-editor {
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      min-height: 120px;
      padding: 0.75rem;
      font-family: 'Poppins', sans-serif;
      font-size: 0.9rem;
    }
:is(:is(.product-form .trix-editor-container) trix-editor):focus {
        border-color: var(--primary-color);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
        outline: none;
      }
:is(.product-form .trix-editor-container) trix-toolbar {
      border: 1px solid var(--gray-300);
      border-bottom: none;
      border-radius: 6px 6px 0 0;
      background: var(--gray-50);
      padding: 0.5rem;
    }
:is(:is(.product-form .trix-editor-container) trix-toolbar) .trix-button {
        border: 1px solid transparent;
        border-radius: 4px;
      }
:is(:is(:is(.product-form .trix-editor-container) trix-toolbar) .trix-button):hover {
          background: var(--gray-200);
        }
.trix-active:is(:is(:is(.product-form .trix-editor-container) trix-toolbar) .trix-button) {
          background: var(--gray-300);
        }
/* Form check / switch styling */
.product-form .form-check.form-switch {
    padding-left: 2.5em;
    margin-bottom: 1rem;
  }
:is(.product-form .form-check.form-switch) .form-check-input {
      width: 2.5em;
      height: 1.25em;
      margin-left: -2.5em;
      cursor: pointer;
      border: 1px solid var(--gray-300);
      background-color: var(--gray-200);
    }
:is(:is(.product-form .form-check.form-switch) .form-check-input):checked {
        background-color: var(--primary-color);
        border-color: var(--primary-color);
      }
:is(:is(.product-form .form-check.form-switch) .form-check-input):focus {
        border-color: var(--primary-color);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.25);
      }
:is(.product-form .form-check.form-switch) .form-check-label,:is(.product-form .form-check.form-switch) label {
      font-family: 'Poppins', sans-serif;
      font-weight: 400;
      font-size: 0.875rem;
      color: var(--gray-700);
      cursor: pointer;
      padding-left: 0.5rem;
    }
/* Ingredients section */
.product-form #ingredientSelection {
    margin-top: 1rem;
    padding: 1rem;
    background: var(--gray-50);
    border-radius: 8px;
    border: 1px solid var(--gray-200);
  }
:is(.product-form #ingredientSelection) h5 {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.95rem;
      color: var(--gray-700);
      margin-bottom: 1rem;
    }
:is(.product-form #ingredientSelection) .card {
      border: 1px solid var(--gray-200);
      border-radius: 8px;
      overflow: hidden;
      box-shadow: none;
    }
:is(:is(.product-form #ingredientSelection) .card) .card-header {
        background: #fff;
        border-bottom: 1px solid var(--gray-200);
        padding: 0.875rem 1rem;
        display: flex;
        flex-wrap: wrap;
        align-items: center;
        gap: 0.75rem;
      }
:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) span.fw-bold {
          font-family: 'Poppins', sans-serif;
          font-weight: 600;
          font-size: 0.9rem;
          color: #2c3e50;
          flex-shrink: 0;
        }
/* Container for max ingredients and required checkbox */
:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center {
          display: flex;
          align-items: center;
          gap: 1rem;
          flex-wrap: wrap;

          /* Label for max ingredients */
        }
:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) label.me-2 {
            font-family: 'Poppins', sans-serif;
            font-size: 0.8rem;
            font-weight: 500;
            color: var(--gray-500);
            margin: 0;
            white-space: nowrap;
          }
/* Select for max ingredients */
:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-select-sm,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) select.form-select,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .select.form-group,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-group.select {
            font-family: 'Poppins', sans-serif;
            font-size: 0.8rem;
            padding: 0.25rem 1.75rem 0.25rem 0.5rem;
            border-radius: 4px;
            border: 1px solid var(--gray-300);
            min-width: 75px;
            background-color: #fff;
            height: auto;
            line-height: 1.4;
            margin: 0 !important;
            position: relative;
            top: 2px;
          }
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-select-sm,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) select.form-select,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .select.form-group,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-group.select):focus {
              border-color: var(--primary-color);
              box-shadow: 0 0 0 0.15rem rgba(40, 167, 69, 0.2);
            }
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-select-sm,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) select.form-select,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .select.form-group,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-group.select):disabled {
              background-color: var(--gray-50);
              color: #adb5bd;
            }
/* Reset SimpleForm wrapper if present */
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-select-sm,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) select.form-select,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .select.form-group,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-group.select) select {
              font-family: 'Poppins', sans-serif;
              font-size: 0.8rem;
              border: none;
              padding: 0;
              margin: 0;
              background: transparent;
            }
/* Required checkbox container - targeting SimpleForm boolean wrapper */
:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"] {
            display: flex !important;
            align-items: center !important;
            margin: 0 !important;
            padding-left: 0 !important;
            gap: 0.5rem !important;
            flex-wrap: nowrap !important;
          }
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) .form-check-input,:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) input[type="checkbox"] {
              width: 1em !important;
              height: 1em !important;
              margin: 0 !important;
              cursor: pointer;
              border: 1px solid var(--gray-300);
              flex-shrink: 0;
            }
:is(:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) .form-check-input,:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) input[type="checkbox"]):checked {
                background-color: var(--primary-color) !important;
                border-color: var(--primary-color) !important;
              }
:is(:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) .form-check-input,:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) input[type="checkbox"]):focus {
                box-shadow: 0 0 0 0.15rem rgba(40, 167, 69, 0.2) !important;
              }
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) label,:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .boolean,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) .form-check,:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-header) .d-flex.align-items-center) div[class*="boolean"]) .form-check-label {
              font-family: 'Poppins', sans-serif !important;
              font-size: 0.8rem !important;
              font-weight: 500 !important;
              color: var(--gray-500) !important;
              margin: 0 !important;
              padding: 0 !important;
              cursor: pointer;
              white-space: nowrap !important;
              order: 1;
            }
:is(:is(.product-form #ingredientSelection) .card) .card-body {
        padding: 1rem;
        background: #fff;
      }
:is(:is(:is(.product-form #ingredientSelection) .card) .card-body) .form-check {
          margin-bottom: 0.5rem;
          padding-left: 1.5em;
        }
:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-body) .form-check) .form-check-input {
            cursor: pointer;
            width: 1em;
            height: 1em;
          }
:is(:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-body) .form-check) .form-check-input):checked {
              background-color: var(--primary-color);
              border-color: var(--primary-color);
            }
:is(:is(:is(:is(.product-form #ingredientSelection) .card) .card-body) .form-check) .form-check-label {
            font-size: 0.85rem;
            color: var(--gray-700);
            cursor: pointer;
          }
/* ======================================== */
/* Ingredient Category Cards - BEM */
/* ======================================== */
.product-form .ingredient-section-title {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 1rem;
    color: var(--gray-700);
    margin-bottom: 0.5rem;
  }
.product-form .ingredient-category-card {
    border-radius: 10px;
    margin-bottom: 16px;
    overflow: hidden;
    transition: all 0.25s ease;
  }
/* Estado Inactivo */
.product-form .ingredient-category-card--inactive {
    border: 1px solid var(--gray-200);
    background: var(--gray-50);
  }
:is(.product-form .ingredient-category-card--inactive) .ingredient-category-card__header {
      background: white;
    }
:is(.product-form .ingredient-category-card--inactive) .ingredient-category-card__body {
      background: white;
    }
/* Estado Activo */
.product-form .ingredient-category-card--active {
    border: 1px solid var(--primary-color);
    border-left: 4px solid var(--primary-color);
    background: white;
    box-shadow: 0 2px 8px rgba(40, 167, 69, 0.1);
  }
:is(.product-form .ingredient-category-card--active) .ingredient-category-card__header {
      background: linear-gradient(to right, rgba(40, 167, 69, 0.08), white);
    }
:is(.product-form .ingredient-category-card--active) .ingredient-category-card__body {
      background: white;
    }
/* Header */
.product-form .ingredient-category-card__header {
    padding: 14px 16px;
    border-bottom: 1px solid var(--gray-100);
  }
.product-form .ingredient-category-card__name {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 0.95rem;
    color: var(--gray-800);
    display: flex;
    align-items: center;
    gap: 8px;
  }
.product-form .ingredient-category-card__badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 20px;
    height: 20px;
    border-radius: 50%;
    background: var(--primary-color);
    color: white;
    font-size: 11px;
    font-weight: 700;
    opacity: 0;
    transform: scale(0.5);
    transition: all 0.2s ease;
  }
.visible:is(.product-form .ingredient-category-card__badge) {
      opacity: 1;
      transform: scale(1);
    }
/* Controles */
.product-form .ingredient-category-controls {
    display: none;
    flex-wrap: wrap;
    align-items: center;
    gap: 16px;
    padding: 12px 16px;
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-100);
  }
.visible:is(.product-form .ingredient-category-controls) {
      display: flex;
    }
.product-form .control-group {
    display: flex;
    align-items: center;
    gap: 6px;
  }
.product-form .control-group--checkbox {
    margin-left: auto;
  }
@media (max-width: 576px) {
.product-form .control-group--checkbox {
      margin-left: 0;
      width: 100%;
  }
    }
.product-form .control-label {
    font-family: 'Poppins', sans-serif;
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--gray-500);
    display: flex;
    align-items: center;
    gap: 4px;
    cursor: help;
    white-space: nowrap;
  }
:is(.product-form .control-label) i {
      font-size: 0.75rem;
      color: var(--gray-400);
    }
.product-form .control-label--checkbox {
    cursor: pointer;
    gap: 6px;
  }
:is(.product-form .control-label--checkbox) .form-check-input {
      margin: 0;
      width: 16px;
      height: 16px;
    }
.product-form .control-input {
    font-family: 'Poppins', sans-serif;
    font-size: 0.85rem;
    padding: 4px 8px;
    border-radius: 6px;
    border: 1px solid var(--gray-300);
    background: white;
    text-align: center;
    width: 60px;
  }
:is(.product-form .control-input):focus {
      border-color: var(--primary-color);
      box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.15);
      outline: none;
    }
:is(.product-form .control-input):disabled {
      background: var(--gray-100);
      color: var(--gray-400);
    }
/* Fix para el select de max_ingredients dentro de SimpleForm wrapper */
.product-form .control-group .form-group,.product-form .control-group .select,.product-form .control-group div[class*="select"] {
    margin: 0 !important;
    padding: 0 !important;
  }
:is(.product-form .control-group .form-group,.product-form .control-group .select,.product-form .control-group div[class*="select"]) select.control-input,:is(.product-form .control-group .form-group,.product-form .control-group .select,.product-form .control-group div[class*="select"]) select.form-select {
      width: 80px !important;
      padding: 4px 8px !important;
      -moz-appearance: menulist !important;
           appearance: menulist !important;
      -webkit-appearance: menulist !important;
      color: var(--gray-700) !important;
      cursor: pointer;
      font-size: 0.85rem;
      height: auto;
      line-height: 1.4;
    }
:is(:is(.product-form .control-group .form-group,.product-form .control-group .select,.product-form .control-group div[class*="select"]) select.control-input,:is(.product-form .control-group .form-group,.product-form .control-group .select,.product-form .control-group div[class*="select"]) select.form-select):disabled {
        cursor: not-allowed;
        color: var(--gray-400) !important;
        background-color: var(--gray-100) !important;
      }
/* Body */
.product-form .ingredient-category-card__body {
    padding: 12px 16px;
  }
.product-form .ingredient-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 0;
    border-bottom: 1px solid var(--gray-100);
    transition: background 0.15s ease;
  }
:is(.product-form .ingredient-item):last-child {
      border-bottom: none;
    }
:is(.product-form .ingredient-item):hover {
      background: var(--gray-50);
      margin: 0 -16px;
      padding: 8px 16px;
    }
.product-form .ingredient-checkbox {
    width: 18px;
    height: 18px;
    border-radius: 4px;
    border: 2px solid var(--gray-300);
    cursor: pointer;
    flex-shrink: 0;
  }
:is(.product-form .ingredient-checkbox):checked {
      background-color: var(--primary-color);
      border-color: var(--primary-color);
    }
:is(.product-form .ingredient-checkbox):focus {
      box-shadow: 0 0 0 2px rgba(40, 167, 69, 0.2);
    }
.product-form .ingredient-label {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex: 1;
    cursor: pointer;
    font-family: 'Poppins', sans-serif;
  }
.product-form .ingredient-name {
    font-size: 0.9rem;
    color: var(--gray-700);
  }
.product-form .ingredient-price {
    font-size: 0.85rem;
    font-weight: 500;
    color: var(--gray-500);
  }
/* Footer */
.product-form .ingredient-category-card__footer {
    display: none;
    padding: 10px 16px;
    background: var(--gray-50);
    font-family: 'Poppins', sans-serif;
    font-size: 0.8rem;
    color: var(--gray-500);
    border-top: 1px solid var(--gray-100);
  }
.visible:is(.product-form .ingredient-category-card__footer) {
      display: block;
    }
/* Discount form section */
.product-form .discount-form {
    margin-top: 1rem;
    padding: 1.25rem;
    background: linear-gradient(135deg, #e8f5e9 0%, #dcf5e0 100%);
    border: 1px solid #c8e6c9;
    border-radius: 8px;
  }
:is(.product-form .discount-form) .form-group {
      margin-bottom: 1rem;
    }
:is(:is(.product-form .discount-form) .form-group) label {
        font-size: 0.85rem;
        color: #2e7d32;
      }
:is(.product-form .discount-form) #discounted-price-display {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.9rem;
      padding: 0.75rem;
      background: #fff;
      border-radius: 6px;
      margin-top: 0.5rem;
    }
/* Week days selector */
.product-form .week-days {
    margin-top: 1rem;
  }
:is(:is(.product-form .week-days) .selectize-control) .selectize-input {
        border: 1px solid var(--gray-300);
        border-radius: 6px;
        padding: 0.5rem 0.75rem;
        font-size: 0.875rem;
      }
.focus:is(:is(:is(.product-form .week-days) .selectize-control) .selectize-input) {
          border-color: var(--primary-color);
          box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
        }
/* Stock input section */
.product-form #stock_input {
    margin-top: 0.5rem;
    padding: 1rem;
    background: var(--gray-50);
    border-radius: 6px;
    border: 1px solid var(--gray-200);
  }
/* File upload section */
.product-form .image-upload-section {
    margin-top: 1.5rem;
    padding: 1.25rem;
    background: var(--gray-50);
    border-radius: 8px;
    border: 1px dashed var(--gray-300);
  }
:is(.product-form .image-upload-section) small.text-success {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.85rem;
    }
:is(.product-form .image-upload-section) .form-control[type="file"] {
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      padding: 0.5rem;
      font-size: 0.85rem;
      background: #fff;
      cursor: pointer;
    }
:is(:is(.product-form .image-upload-section) .form-control[type="file"]):hover {
        border-color: var(--primary-color);
      }
:is(:is(.product-form .image-upload-section) .form-control[type="file"])::file-selector-button {
        background: var(--primary-color);
        color: white;
        border: none;
        padding: 0.375rem 0.75rem;
        border-radius: 4px;
        margin-right: 0.75rem;
        font-family: 'Poppins', sans-serif;
        font-weight: 500;
        font-size: 0.8rem;
        cursor: pointer;
      }
:is(:is(:is(.product-form .image-upload-section) .form-control[type="file"])::file-selector-button):hover {
          background: #218838;
        }
/* Image preview */
.product-form .image-container {
    margin-top: 0.75rem;
  }
:is(.product-form .image-container) .img-preview {
      border-radius: 8px;
      border: 1px solid var(--gray-200);
      box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
    }
:is(.product-form .image-container) .btn-danger {
      font-size: 0.7rem;
      padding: 0.25rem 0.5rem;
      border-radius: 4px;
    }
/* Reservar espacio para selects que serán Selectize (evita CLS) */
.product-form select.selectize-max2,.product-form select.selectize-max1,.product-form .week-days select {
    min-height: 42px;
  }
/* Selectize improvements */
:is(.product-form .selectize-control) .selectize-input {
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      box-shadow: none;
      font-family: 'Poppins', sans-serif;
      font-size: 0.875rem;
      padding: 0.5rem 0.75rem;
      min-height: 42px;
    }
.focus:is(:is(.product-form .selectize-control) .selectize-input) {
        border-color: var(--primary-color);
        box-shadow: 0 0 0 0.2rem rgba(40, 167, 69, 0.15);
      }
:is(:is(.product-form .selectize-control) .selectize-input) .item {
        background: #e8f5e9;
        color: #2e7d32;
        border: 1px solid #c8e6c9;
        border-radius: 4px;
        padding: 0.125rem 0.5rem;
        font-size: 0.8rem;
        margin: 0.125rem;
      }
:is(.product-form .selectize-control) .selectize-dropdown {
      border: 1px solid var(--gray-300);
      border-radius: 6px;
      box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
      margin-top: 2px;
    }
:is(:is(.product-form .selectize-control) .selectize-dropdown) .option {
        padding: 0.5rem 0.75rem;
        font-size: 0.875rem;
      }
.active:is(:is(:is(.product-form .selectize-control) .selectize-dropdown) .option) {
          background: #e8f5e9;
          color: #2e7d32;
        }
:is(:is(:is(.product-form .selectize-control) .selectize-dropdown) .option):hover {
          background: var(--gray-50);
        }
/* Form actions / submit button */
.product-form .form-actions {
    margin-top: 2rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--gray-200);
  }
:is(.product-form .form-actions) .btn-success {
      font-family: 'Poppins', sans-serif;
      font-weight: 500;
      font-size: 0.9rem;
      padding: 0.75rem 2rem;
      border-radius: 6px;
      background: var(--primary-color);
      border: none;
      transition: all 0.2s ease;
    }
:is(:is(.product-form .form-actions) .btn-success):hover {
        background: #218838;
        transform: translateY(-1px);
        box-shadow: 0 4px 8px rgba(40, 167, 69, 0.3);
      }
:is(:is(.product-form .form-actions) .btn-success):active {
        transform: translateY(0);
      }
/* No results / empty state */
.product-form .no-results {
    text-align: center;
    padding: 3rem 2rem;
    background: var(--gray-50);
    border-radius: 12px;
    border: 1px dashed var(--gray-300);
  }
:is(.product-form .no-results) p {
      font-family: 'Poppins', sans-serif;
      font-size: 1rem;
      color: var(--gray-500);
      margin: 0;
    }
:is(:is(.product-form .no-results) p) strong {
        color: var(--gray-700);
      }
:is(:is(.product-form .no-results) p) a {
        color: var(--primary-color);
        font-weight: 500;
        text-decoration: none;
      }
:is(:is(:is(.product-form .no-results) p) a):hover {
          text-decoration: underline;
        }
/* Error messages */
.product-form .text-danger {
    font-family: 'Poppins', sans-serif;
    font-size: 0.8rem;
    margin-top: 0.25rem;
  }
/* Hints */
.product-form .form-text,.product-form .hint {
    font-family: 'Poppins', sans-serif;
    font-size: 0.8rem;
    color: var(--gray-500);
    margin-top: 0.25rem;
  }
/* ======================================== */
/* Form Spinner */
/* ======================================== */
#spinner {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 0.9);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
}
#spinner .loader {
    border: 4px solid #f3f3f3;
    border-top: 4px solid var(--primary-color);
    border-radius: 50%;
    width: 50px;
    height: 50px;
    animation: spin 1s linear infinite;
  }
@keyframes spin {
  0% { transform: rotate(0deg); }
  100% { transform: rotate(360deg); }
}
/* ========================================================================== */
/* MercadoPago Connect - Página de conexión con MercadoPago */
/* ========================================================================== */
.mercadopago-connect-card {
  max-width: 480px;
  margin: 2rem auto;
  padding: 2.5rem 2rem;
  background: #fff;
  border-radius: 16px;
  box-shadow: 0 4px 24px rgba(0, 0, 0, 0.08);
  text-align: center;
}
/* Logo */
.mp-logo {
  margin-bottom: 1.5rem;
}
.mp-logo img {
    height: 48px;
    width: auto;
  }
/* Título y subtítulo */
.mp-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gray-800);
  margin-bottom: 0.5rem;
}
.mp-subtitle {
  font-size: 0.9375rem;
  color: var(--gray-500);
  margin-bottom: 2rem;
}
.mp-subtitle strong {
    color: var(--gray-700);
  }
/* Beneficios */
.mp-benefits {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
  margin-bottom: 2rem;
  flex-wrap: wrap;
}
.mp-benefit {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.mp-benefit i {
    font-size: 1.5rem;
    color: #00b1ea;
  }
.mp-benefit span {
    font-size: 0.8125rem;
    color: var(--gray-600);
    font-weight: 500;
  }
/* Botón MercadoPago */
.btn-mercadopago {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 2rem;
  background: linear-gradient(135deg, #00b1ea 0%, #009ee3 100%);
  color: #fff;
  font-size: 1rem;
  font-weight: 600;
  border: none;
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.2s ease;
  box-shadow: 0 4px 12px rgba(0, 177, 234, 0.3);
}
.btn-mercadopago:hover {
    background: linear-gradient(135deg, #009ee3 0%, #008ecc 100%);
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(0, 177, 234, 0.4);
    color: #fff;
  }
.btn-mercadopago:active {
    transform: translateY(0);
  }
.btn-mercadopago i {
    font-size: 1.25rem;
  }
/* Disclaimer */
.mp-disclaimer {
  margin-top: 1.5rem;
  font-size: 0.8125rem;
  color: var(--gray-400);
}
/* Estado conectado */
.mp-connected .mp-logo {
    margin-bottom: 1rem;
  }
.mp-connected .mp-title {
    color: #166534;
  }
.mp-connected .mp-subtitle {
    margin-bottom: 0;
  }
.mp-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.375rem 1rem;
  border-radius: 20px;
  font-size: 0.875rem;
  font-weight: 500;
  margin-bottom: 1rem;
}
.mp-status-badge.connected {
    background: #dcfce7;
    color: #166534;
  }
.mp-status-badge i {
    font-size: 0.875rem;
  }
/* Responsive */
@media (max-width: 576px) {
  .mercadopago-connect-card {
    margin: 1rem;
    padding: 2rem 1.5rem;
  }

  .mp-benefits {
    flex-direction: column;
    gap: 1rem;
  }

  .mp-benefit {
    flex-direction: row;
    gap: 0.75rem;
  }

    .mp-benefit i {
      font-size: 1.25rem;
    }
}
/* ========================================================================== */
/* Roles Page - Gestión de equipo */
/* ========================================================================== */
.dashboard-roles-page {
  padding-top: 60px;
}
.roles-page-header {
  margin-bottom: 1.5rem;
}
.roles-page-header .page-title {
  font-size: 1.5rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
}
.roles-page-header .page-subtitle {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin: 0.25rem 0 0 0;
}
/* Store Cards */
.roles-stores-list {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
}
.roles-store-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--gray-200);
  overflow: hidden;
}
.roles-store-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--gray-200);
}
.roles-store-header .store-info {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.roles-store-header .store-icon {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-100);
  border-radius: 8px;
  color: var(--gray-600);
}
.roles-store-header .store-name {
  font-size: 1rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
}
/* Team Table */
.team-table {
  width: 100%;
}
.team-table th {
  padding: 0.75rem 1rem;
  font-size: 0.6875rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--gray-500);
  background: var(--gray-50);
  border-bottom: 1px solid var(--gray-200);
  text-align: left;
}
.team-table td {
  padding: 0.75rem 1rem;
  vertical-align: middle;
  border-bottom: 1px solid var(--gray-100);
}
.team-table tr:last-child td {
  border-bottom: none;
}
.team-table tr:hover {
  background: var(--gray-50);
}
/* Member Cell */
.member-cell {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.member-avatar {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--primary-color);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
  border-radius: 50%;
}
.member-name {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-800);
}
.member-email {
  display: block;
  font-size: 0.75rem;
  color: var(--gray-500);
}
/* Badges */
.badge-role {
  display: inline-block;
  padding: 0.25rem 0.5rem;
  background: var(--gray-100);
  color: var(--gray-600);
  font-size: 0.6875rem;
  font-weight: 500;
  border-radius: 4px;
}
.badge-role.badge-admin {
  background: #dbeafe;
  color: #1d4ed8;
}
.badge-status {
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  padding: 0.25rem 0.5rem;
  border-radius: 100px;
  font-size: 0.6875rem;
  font-weight: 500;
}
.badge-status.badge-success {
  background: #dcfce7;
  color: #16a34a;
}
.badge-status.badge-pending {
  background: #fef3c7;
  color: #d97706;
}
.badge-permission {
  display: inline-block;
  padding: 0.125rem 0.375rem;
  background: var(--gray-100);
  color: var(--gray-600);
  font-size: 0.625rem;
  border-radius: 3px;
  margin-right: 0.25rem;
}
.badge-permission.badge-more {
  background: var(--gray-200);
  color: var(--gray-700);
}
.no-permissions {
  color: var(--gray-400);
}
/* Table Actions */
.actions-cell {
  display: flex;
  gap: 0.25rem;
  justify-content: flex-end;
}
.btn-table-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 6px;
  color: var(--gray-500);
  text-decoration: none;
  transition: all 0.15s ease;
}
.btn-table-action:hover {
  background: var(--gray-100);
  color: var(--gray-700);
}
.btn-table-action.btn-table-danger:hover {
  background: #fef2f2;
  color: #dc2626;
  border-color: #fecaca;
}
/* Empty State */
.roles-empty-state {
  text-align: center;
  padding: 3rem 1.5rem;
}
.roles-empty-state .empty-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto 1rem;
  background: var(--gray-100);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-400);
  font-size: 1.5rem;
}
.roles-empty-state .empty-text {
  color: var(--gray-500);
  margin: 0 0 1rem 0;
}
/* ========================================================================== */
/* Roles Form - Invitar/Editar miembros */
/* ========================================================================== */
.roles-form-page {
  padding-top: 60px;
}
.roles-form-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--gray-200);
  overflow: hidden;
}
.roles-form-card .card-header {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--gray-200);
  background: #fff;
}
.roles-form-card .card-header h2 {
  font-size: 1.125rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
}
.roles-form-card .card-body {
  padding: 1.5rem;
}
/* Form Fields */
.roles-form-card .form-group {
  margin-bottom: 1.25rem;
}
.roles-form-card .form-label {
  display: block;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: 0.5rem;
}
.roles-form-card .form-control {
  width: 100%;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.roles-form-card .form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(50, 183, 104, 0.1);
  outline: none;
}
.roles-form-card .form-control:disabled {
  background: var(--gray-100);
  color: var(--gray-500);
}
.roles-form-card .form-hint {
  font-size: 0.75rem;
  color: var(--gray-500);
  margin-top: 0.375rem;
}
/* Checkbox */
.roles-form-card .form-check {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  margin-bottom: 0.25rem;
}
.roles-form-card .form-check-input {
  width: 1rem;
  height: 1rem;
  margin-top: 0.125rem;
  accent-color: var(--primary-color);
}
.roles-form-card .form-check-label {
  font-size: 0.875rem;
  color: var(--gray-700);
}
/* Permissions Section */
.roles-form-card .permissions-section {
  margin-top: 1.5rem;
}
.roles-form-card .permissions-title {
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-700);
  margin-bottom: 0.25rem;
}
.roles-form-card .permissions-subtitle {
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin-bottom: 1rem;
}
/* Permission Groups */
.permission-group {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  margin-bottom: 0.75rem;
  overflow: hidden;
}
.permission-group-header {
  padding: 0.625rem 1rem;
  background: var(--gray-100);
  border-bottom: 1px solid var(--gray-200);
}
.permission-group-header strong {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-700);
}
.permission-group-body {
  padding: 0.75rem 1rem;
}
.permission-group-body .form-check {
  margin-bottom: 0.5rem;
}
.permission-group-body .form-check:last-child {
  margin-bottom: 0;
}
/* Form Actions */
.roles-form-actions {
  display: flex;
  gap: 0.75rem;
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--gray-200);
}
.btn-cancel-role {
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-600);
  background: #fff;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  text-decoration: none;
  transition: all 0.15s ease;
}
.btn-cancel-role:hover {
  background: var(--gray-100);
  color: var(--gray-700);
}
/* Mobile */
@media (max-width: 768px) {
  .roles-form-card .card-body {
    padding: 1rem;
  }

  .roles-form-actions {
    flex-direction: column;
  }

  .roles-form-actions .btn {
    width: 100%;
    justify-content: center;
  }
}
/* ========================================================================== */
/* Profile Page - Editar perfil de usuario */
/* ========================================================================== */
.profile-page {
  padding-top: 60px;
  min-height: calc(100vh - 60px);
  background: var(--gray-50);
}
.profile-card {
  background: #fff;
  border-radius: 12px;
  border: 1px solid var(--gray-200);
  overflow: hidden;
}
/* Card Header */
.profile-card .card-header {
  padding: 1.5rem;
  border-bottom: 1px solid var(--gray-200);
  background: #fff;
  text-align: center;
}
.profile-card .profile-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 1rem;
  background: var(--gray-100);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--primary-color);
  font-size: 1.75rem;
}
.profile-card .card-header h2 {
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 0.25rem 0;
}
.profile-card .card-header p {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin: 0;
}
/* Card Body */
.profile-card .card-body {
  padding: 1.5rem;
}
/* Form Sections */
.profile-section {
  margin-bottom: 1.5rem;
}
.profile-section:last-child {
  margin-bottom: 0;
}
.profile-section-title {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 1rem;
  padding-bottom: 0.5rem;
  border-bottom: 1px solid var(--gray-200);
}
.profile-section-title i {
  color: var(--primary-color);
}
/* Form Fields */
.profile-card .form-group {
  margin-bottom: 1rem;
}
.profile-card .form-label {
  display: block;
  font-size: 0.8125rem;
  font-weight: 500;
  color: var(--gray-600);
  margin-bottom: 0.375rem;
}
.profile-card .form-control {
  width: 100%;
  padding: 0.625rem 0.875rem;
  font-size: 0.875rem;
  border: 1px solid var(--gray-300);
  border-radius: 8px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
}
.profile-card .form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 3px rgba(50, 183, 104, 0.1);
  outline: none;
}
.profile-card .form-control:disabled,
.profile-card .form-control[readonly] {
  background: var(--gray-100);
  color: var(--gray-500);
  cursor: not-allowed;
}
.profile-card .form-hint {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  color: var(--gray-500);
  margin-top: 0.375rem;
}
.profile-card .form-hint i {
  font-size: 0.75rem;
}
/* Alert */
.profile-card .alert {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  border-radius: 8px;
  margin-bottom: 1rem;
}
.profile-card .alert-warning {
  background: #fef3c7;
  color: #92400e;
  border: 1px solid #fcd34d;
}
.profile-card .alert-danger {
  background: #fef2f2;
  color: #991b1b;
  border: 1px solid #fecaca;
}
/* Form Actions */
.profile-form-actions {
  margin-top: 1.5rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--gray-200);
}
.btn-profile-submit {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.75rem 1.5rem;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #fff;
  background: var(--primary-color);
  border: none;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s ease;
}
.btn-profile-submit:hover {
  background: var(--primary-hover);
}
/* Card Footer */
.profile-card .card-footer {
  padding: 1rem 1.5rem;
  background: var(--gray-50);
  border-top: 1px solid var(--gray-200);
  text-align: center;
}
.profile-card .card-footer small {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  color: var(--gray-500);
}
/* Mobile */
@media (max-width: 768px) {
  .profile-page {
    padding-top: 60px;
  }

  .profile-card .card-body {
    padding: 1rem;
  }

  .profile-card .card-header {
    padding: 1.25rem 1rem;
  }
}
/* ========================================================================== */
/* Store Form - Formulario de creación/edición de tienda */
/* ========================================================================== */
/* ======================================== */
/* Cards */
/* ======================================== */
.store-form-card {
  background: #fff;
  border-radius: 16px;
  border: 1px solid var(--gray-200);
  overflow: visible;
  transition: box-shadow 0.2s ease;
}
.store-form-card:hover {
  box-shadow: var(--shadow-lg);
}
.store-form-card-header {
  padding: 1.25rem 1.5rem;
  border-bottom: 1px solid var(--gray-100);
  background: var(--gray-50);
  border-radius: 16px 16px 0 0;
}
.store-form-card-header h6 {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  font-size: 1rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0;
}
.store-form-card-header h6 i {
  width: 36px;
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(50, 183, 104, 0.1);
  color: var(--primary-color);
  border-radius: 10px;
  font-size: 1rem;
}
.store-form-card .card-body {
  padding: 1.5rem;
}
/* ======================================== */
/* Form Groups */
/* ======================================== */
.store-form-card .mb-4,
.store-form-card .mb-3 {
  margin-bottom: 1.5rem !important;
}
.store-form-card .mb-4:last-child,
.store-form-card .mb-3:last-child {
  margin-bottom: 0 !important;
}
/* ======================================== */
/* Labels */
/* ======================================== */
.store-form-card .form-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-700);
  margin-bottom: 0.5rem;
}
.store-form-card .form-label i {
  color: var(--gray-400);
  font-size: 0.875rem;
}
.store-form-card .form-label .text-danger {
  color: var(--danger-color);
  font-weight: 400;
}
/* ======================================== */
/* Inputs */
/* ======================================== */
.store-form-card .form-control {
  width: 100%;
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  transition: all 0.2s ease;
  background: #fff;
  font-size: 14px;
  font-weight: 500;
}
.store-form-card .form-control:focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 4px rgba(50, 183, 104, 0.1);
  outline: none;
}
.store-form-card .form-control::-moz-placeholder {
  color: var(--gray-400);
}
.store-form-card .form-control::placeholder {
  color: var(--gray-400);
}
/* ======================================== */
/* Form Text / Hints */
/* ======================================== */
.store-form-card .form-text {
  display: flex;
  align-items: center;
  gap: 0.375rem;
  font-size: 0.8125rem;
  color: var(--gray-500);
  margin-top: 0.5rem;
}
.store-form-card .form-text i {
  color: var(--warning-color);
  font-size: 0.75rem;
}
/* ======================================== */
/* Invalid Feedback */
/* ======================================== */
.store-form-card .invalid-feedback {
  font-size: 0.8125rem;
  color: var(--danger-color);
  margin-top: 0.375rem;
}
/* ======================================== */
/* Select (Selectize) */
/* ======================================== */
.store-form-card .selectize-control .selectize-input {
  padding: 0.5rem 0.75rem;
  font-size: 12px;
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  box-shadow: none;
  transition: all 0.2s ease;
}
.store-form-card .selectize-control .selectize-input .item {
  font-size: 12px;
  font-weight: 500;
}
.store-form-card .selectize-control .selectize-input.focus {
  border-color: var(--primary-color);
  box-shadow: 0 0 0 4px rgba(50, 183, 104, 0.1);
}
.store-form-card .selectize-dropdown {
  font-size: 12px;
}
.store-form-card .selectize-dropdown .option {
  padding: 0.5rem 0.75rem;
}
/* ======================================== */
/* Tips Box */
/* ======================================== */
.store-form-tips {
  background: linear-gradient(135deg, rgba(50, 183, 104, 0.08) 0%, rgba(0, 122, 255, 0.05) 100%);
  border: 1px solid rgba(50, 183, 104, 0.2);
  border-radius: 12px;
  padding: 1rem 1.25rem;
}
.store-form-tips .tips-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--primary-color);
  margin-bottom: 0.75rem;
}
.store-form-tips .tips-header i {
  font-size: 1rem;
}
.store-form-tips ul {
  margin: 0;
  padding-left: 1.25rem;
}
.store-form-tips li {
  font-size: 0.8125rem;
  color: var(--gray-600);
  margin-bottom: 0.375rem;
  line-height: 1.5;
}
.store-form-tips li:last-child {
  margin-bottom: 0;
}
/* ======================================== */
/* Input Groups */
/* ======================================== */
.store-form-card .input-group .form-control {
  border-radius: 10px;
}
.store-form-card .input-group .input-group-text {
  background: var(--gray-50);
  border: 1.5px solid var(--gray-200);
  border-right: none;
  border-radius: 10px 0 0 10px;
  color: var(--gray-500);
}
.store-form-card .input-group .form-control {
  border-radius: 0 10px 10px 0;
}
/* ======================================== */
/* Step Progress (Wizard) */
/* ======================================== */
.store-steps-wrapper {
  max-width: 700px;
  margin: 0 auto 2rem;
  padding: 0 1rem;
}
.store-steps {
  display: flex;
  justify-content: space-between;
  position: relative;
}
/* Línea conectora */
.store-steps::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 40px;
  right: 40px;
  height: 2px;
  background: var(--gray-200);
  z-index: 1;
}
/* Línea de progreso */
.store-steps-progress {
  position: absolute;
  top: 20px;
  left: 40px;
  height: 2px;
  background: var(--primary-color);
  z-index: 2;
  transition: width 0.4s ease;
  width: 0%;
}
/* Step individual */
.store-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  z-index: 3;
  flex: 1;
}
.store-step-circle {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--gray-200);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-400);
  transition: all 0.3s ease;
  margin-bottom: 0.5rem;
}
.store-step-circle i {
  font-size: 1rem;
}
.store-step-label {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--gray-400);
  text-align: center;
  transition: color 0.3s ease;
  white-space: nowrap;
}
/* Estado Activo */
.store-step.active .store-step-circle {
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
  box-shadow: 0 0 0 4px rgba(50, 183, 104, 0.2);
}
.store-step.active .store-step-label {
  color: var(--primary-color);
  font-weight: 600;
}
/* Estado Completado */
.store-step.completed .store-step-circle {
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}
.store-step.completed .store-step-label {
  color: var(--gray-600);
}
/* ======================================== */
/* Header del Formulario */
/* ======================================== */
.store-form-header {
  text-align: center;
  margin-bottom: 1.5rem;
  padding-top: 1.5rem;
}
.store-form-header h2 {
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--gray-800);
  margin: 0 0 0.25rem 0;
}
.store-form-header p {
  font-size: 0.9375rem;
  color: var(--gray-500);
  margin: 0;
}
/* ======================================== */
/* Navegación del Formulario */
/* ======================================== */
.store-form-nav {
  background: #fff;
  border-radius: 8px;
  border: 1px solid var(--gray-200);
  padding: 0.875rem 1.25rem;
  margin-top: 2rem;
}
.store-form-nav-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
}
.store-form-nav-hint {
  font-size: 0.8125rem;
  color: var(--gray-500);
  text-align: center;
  flex: 1;
}
.btn-store-prev,
.btn-store-next {
  display: inline-flex;
  align-items: center;
  gap: 0.375rem;
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  font-weight: 500;
  border-radius: 6px;
  transition: all 0.2s ease;
  cursor: pointer;
  text-decoration: none;
}
.btn-store-prev {
  background: #fff;
  color: var(--gray-600);
  border: 1px solid var(--gray-300);
}
.btn-store-prev:hover {
  background: var(--gray-50);
  border-color: var(--gray-400);
  color: var(--gray-700);
}
.btn-store-prev:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.btn-store-next {
  background: var(--primary-color);
  color: #fff;
  border: none;
}
.btn-store-next:hover {
  background: #2a9d5a;
  color: #fff;
}
.btn-store-next i,
.btn-store-prev i {
  font-size: 0.75rem;
}
/* ======================================== */
/* Schedule (Step 2 - Horarios) */
/* ======================================== */
.schedule-day-row {
  padding: 0.875rem 0;
}
.schedule-day-row.border-bottom {
  border-color: var(--gray-100) !important;
}
.schedule-day-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.75rem;
}
.schedule-day-check {
  width: 18px;
  height: 18px;
  cursor: pointer;
}
.schedule-day-check:checked {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
.schedule-day-label {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-700);
  cursor: pointer;
  margin: 0;
}
.schedule-times {
  margin-left: 2rem;
}
.schedule-times-card {
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 8px;
  padding: 0.75rem;
}
.schedule-times-card .form-control-sm {
  font-size: 12px;
  padding: 0.375rem 0.5rem;
  border-radius: 6px;
}
.schedule-times-card label {
  font-size: 11px;
  font-weight: 500;
  color: var(--gray-500);
  margin-bottom: 0.25rem;
}
/* ======================================== */
/* Map (Ubicación) */
/* ======================================== */
.store-map-container {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--gray-200);
}
.store-map {
  height: 250px;
  width: 100%;
}
/* ======================================== */
/* Services (Servicios adicionales) */
/* ======================================== */
.services-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}
.service-option {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  background: var(--gray-50);
  border: 1px solid var(--gray-100);
  border-radius: 10px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.service-option:hover {
  background: #fff;
  border-color: var(--gray-200);
}
.service-option:has(input:checked) {
  background: rgba(50, 183, 104, 0.05);
  border-color: var(--primary-color);
}
.service-option .form-check-input {
  width: 18px;
  height: 18px;
  margin: 0;
  flex-shrink: 0;
}
.service-option .form-check-input:checked {
  background-color: var(--primary-color);
  border-color: var(--primary-color);
}
.service-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.service-icon i {
  font-size: 1rem;
}
.service-icon-blue {
  background: rgba(25, 118, 210, 0.1);
  color: #1976d2;
}
.service-icon-green {
  background: rgba(50, 183, 104, 0.1);
  color: var(--primary-color);
}
.service-icon-orange {
  background: rgba(255, 152, 0, 0.1);
  color: #ff9800;
}
.service-info {
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.service-name {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-700);
}
.service-desc {
  font-size: 0.75rem;
  color: var(--gray-500);
}
/* ======================================== */
/* Image Upload (Step 3 - Imágenes) */
/* ======================================== */
.image-upload-header {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 1rem;
}
.image-upload-icon {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.image-upload-icon i {
  font-size: 1.25rem;
}
.image-upload-icon-avatar {
  background: rgba(50, 183, 104, 0.1);
  color: var(--primary-color);
}
.image-upload-icon-header {
  background: rgba(0, 122, 255, 0.1);
  color: #007aff;
}
.image-upload-icon-promo {
  background: rgba(255, 152, 0, 0.1);
  color: #ff9800;
}
.image-upload-icon-video {
  background: rgba(233, 30, 99, 0.1);
  color: #e91e63;
}
.image-upload-info {
  flex: 1;
  min-width: 0;
}
.image-upload-title {
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--gray-800);
  margin: 0 0 0.125rem 0;
}
.image-upload-desc {
  font-size: 0.75rem;
  color: var(--gray-500);
}
.image-upload-help {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  border: 1px solid var(--gray-200);
  background: #fff;
  color: var(--gray-400);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.image-upload-help:hover {
  border-color: var(--primary-color);
  color: var(--primary-color);
  background: rgba(50, 183, 104, 0.05);
}
.image-upload-help i {
  font-size: 0.875rem;
}
/* Video Preview */
.video-preview-container {
  border-radius: 10px;
  overflow: hidden;
  border: 1px solid var(--gray-200);
  background: var(--gray-50);
  min-height: 180px;
}
.video-preview-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 180px;
  color: var(--gray-400);
  gap: 0.5rem;
}
.video-preview-placeholder i {
  font-size: 2rem;
}
.video-preview-placeholder span {
  font-size: 0.8125rem;
}
.video-preview-container iframe {
  width: 100%;
  height: 180px;
  border: none;
}
/* ======================================== */
/* Submit (Step 4 - Enviar) */
/* ======================================== */
.store-submit-card {
  text-align: center;
  padding: 1rem;
}
.store-submit-card .card-body {
  padding: 2rem 1.5rem;
}
.submit-success-icon {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--primary-color) 0%, #2a9d5a 100%);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 1.5rem;
  box-shadow: 0 8px 24px rgba(50, 183, 104, 0.3);
}
.submit-success-icon i {
  font-size: 2rem;
  color: #fff;
}
.submit-title {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--gray-800);
  margin: 0 0 0.5rem 0;
}
.submit-subtitle {
  font-size: 0.875rem;
  color: var(--gray-500);
  margin: 0 0 2rem 0;
}
.submit-checklist {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-width: 320px;
  margin: 0 auto 2rem;
}
.submit-check-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.75rem 1rem;
  background: var(--gray-50);
  border-radius: 10px;
  text-align: left;
}
.submit-check-icon {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.submit-check-icon i {
  font-size: 1rem;
}
.submit-check-icon-info {
  background: rgba(50, 183, 104, 0.1);
  color: var(--primary-color);
}
.submit-check-icon-clock {
  background: rgba(0, 122, 255, 0.1);
  color: #007aff;
}
.submit-check-icon-images {
  background: rgba(255, 152, 0, 0.1);
  color: #ff9800;
}
.submit-check-text {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.125rem;
}
.submit-check-title {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--gray-700);
}
.submit-check-desc {
  font-size: 0.75rem;
  color: var(--gray-500);
}
.submit-check-done {
  color: var(--primary-color);
  font-size: 1.125rem;
  flex-shrink: 0;
}
.submit-action {
  margin-top: 1.5rem;
}
.btn-submit-store {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  padding: 0.875rem 2rem;
  font-size: 1rem;
  font-weight: 600;
  color: #fff;
  background: linear-gradient(135deg, var(--primary-color) 0%, #2a9d5a 100%);
  border: none;
  border-radius: 12px;
  cursor: pointer;
  transition: all 0.3s ease;
  box-shadow: 0 4px 16px rgba(50, 183, 104, 0.3);
}
.btn-submit-store:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(50, 183, 104, 0.4);
}
.btn-submit-store:active {
  transform: translateY(0);
}
.btn-submit-store i {
  font-size: 1.125rem;
}
.submit-security {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
  font-size: 0.75rem;
  color: var(--gray-500);
  margin: 1rem 0 0 0;
}
.submit-security i {
  color: var(--primary-color);
}
/* ======================================== */
/* Mobile Responsive */
/* ======================================== */
@media (max-width: 768px) {
  .store-form-card .card-body {
    padding: 1rem;
  }

  .store-form-card-header {
    padding: 1rem;
  }

  .store-form-card-header h6 i {
    width: 32px;
    height: 32px;
    font-size: 0.875rem;
  }

  /* Steps mobile */
  .store-steps-wrapper {
    margin-bottom: 1.5rem;
  }

  .store-steps::before {
    left: 20px;
    right: 20px;
  }

  .store-steps-progress {
    left: 20px;
  }

  .store-step-circle {
    width: 36px;
    height: 36px;
    font-size: 0.8125rem;
  }

  .store-step-label {
    font-size: 0.6875rem;
  }

  /* Header mobile */
  .store-form-header {
    padding-top: 1rem;
  }

  .store-form-header h2 {
    font-size: 1.25rem;
  }

  /* Nav mobile */
  .store-form-nav {
    padding: 0.75rem 1rem;
  }

  .store-form-nav-hint {
    display: none;
  }

  .btn-store-prev,
  .btn-store-next {
    padding: 0.5rem 0.875rem;
    font-size: 0.8125rem;
  }

  /* Schedule mobile */
  .schedule-times {
    margin-left: 1.5rem;
  }

  .schedule-times-card {
    padding: 0.5rem;
  }

  /* Services mobile */
  .service-option {
    padding: 0.75rem;
  }

  .service-icon {
    width: 32px;
    height: 32px;
  }

  .service-icon i {
    font-size: 0.875rem;
  }

  /* Map mobile */
  .store-map {
    height: 200px;
  }

  /* Image upload mobile */
  .image-upload-icon {
    width: 36px;
    height: 36px;
  }

  .image-upload-icon i {
    font-size: 1rem;
  }

  .image-upload-title {
    font-size: 0.8125rem;
  }

  .video-preview-container,
  .video-preview-placeholder {
    min-height: 150px;
    height: 150px;
  }

  /* Submit mobile */
  .store-submit-card .card-body {
    padding: 1.5rem 1rem;
  }

  .submit-success-icon {
    width: 64px;
    height: 64px;
  }

  .submit-success-icon i {
    font-size: 1.5rem;
  }

  .submit-title {
    font-size: 1.125rem;
  }

  .submit-checklist {
    max-width: 100%;
  }

  .btn-submit-store {
    width: 100%;
    padding: 0.75rem 1.5rem;
  }
}
/* ========================================================================== */
/* QR Generator - Vista de código QR de la tienda */
/* ========================================================================== */
.qr-generator-page {
  padding: 0;
}
.qr-generator-page .breadcrumb {
  margin-bottom: 1rem;
}
/* ======================================== */
/* QR Display Card */
/* ======================================== */
.qr-display-card {
  text-align: center;
}
.qr-display-frame {
  display: inline-block;
  padding: 1.5rem;
  background: linear-gradient(135deg, #f8f9fa 0%, #fff 100%);
  border: 2px dashed var(--gray-200);
  border-radius: 16px;
  margin-bottom: 1.5rem;
  position: relative;
}
.qr-display-frame::before {
  content: '';
  position: absolute;
  inset: 8px;
  border: 1px solid var(--gray-100);
  border-radius: 12px;
  pointer-events: none;
}
.qr-display-frame img {
  max-width: 220px;
  height: auto;
  border-radius: 8px;
}
.qr-no-image {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 3rem 2rem;
  color: var(--gray-400);
  gap: 0.75rem;
}
.qr-no-image i {
  font-size: 3rem;
}
.qr-no-image span {
  font-size: 0.875rem;
}
/* Download Buttons */
.qr-download-actions {
  display: flex;
  justify-content: center;
  gap: 0.75rem;
}
.btn-qr-download {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.625rem 1.25rem;
  font-size: 0.875rem;
  font-weight: 500;
  border-radius: 10px;
  text-decoration: none;
  transition: all 0.2s ease;
}
.btn-qr-download-primary {
  background: var(--primary-color);
  color: #fff;
  border: none;
}
.btn-qr-download-primary:hover {
  background: #2a9d5a;
  color: #fff;
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(50, 183, 104, 0.3);
}
.btn-qr-download-secondary {
  background: #fff;
  color: var(--gray-600);
  border: 1.5px solid var(--gray-200);
}
.btn-qr-download-secondary:hover {
  background: var(--gray-50);
  border-color: var(--gray-300);
  color: var(--gray-700);
}
/* ======================================== */
/* URL Box */
/* ======================================== */
.qr-url-box {
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  padding: 1rem;
  margin-bottom: 1.5rem;
}
.qr-url-label {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 0.5rem;
}
.qr-url-label i {
  color: var(--primary-color);
}
.qr-url-content {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  padding: 0.5rem 0.75rem;
}
.qr-url-text {
  flex: 1;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--primary-color);
  word-break: break-all;
  min-width: 0;
}
.btn-copy-url {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--gray-50);
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  color: var(--gray-500);
  cursor: pointer;
  transition: all 0.2s ease;
  flex-shrink: 0;
}
.btn-copy-url:hover {
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}
.btn-copy-url.copied {
  background: var(--primary-color);
  border-color: var(--primary-color);
  color: #fff;
}
/* ======================================== */
/* Stats Box */
/* ======================================== */
.qr-stats-box {
  background: #fff;
  border: 1px solid var(--gray-200);
  border-radius: 12px;
  padding: 1.25rem;
  margin-bottom: 1.5rem;
}
.qr-stats-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--gray-500);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 1rem;
}
.qr-stats-header i {
  color: #007aff;
}
.qr-stats-value {
  display: flex;
  align-items: baseline;
  gap: 0.5rem;
  margin-bottom: 0.75rem;
}
.qr-stats-number {
  font-size: 2.5rem;
  font-weight: 500;
  color: var(--gray-800);
  line-height: 1;
}
.qr-stats-label {
  font-size: 0.875rem;
  color: var(--gray-500);
}
.qr-stats-bar {
  height: 8px;
  background: var(--gray-100);
  border-radius: 4px;
  overflow: hidden;
}
.qr-stats-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--primary-color) 0%, #2a9d5a 100%);
  border-radius: 4px;
  transition: width 0.5s ease;
  min-width: 5%;
}
/* ======================================== */
/* Tips Box (reutiliza store-form-tips) */
/* ======================================== */
.qr-tips-box {
  background: linear-gradient(135deg, rgba(50, 183, 104, 0.08) 0%, rgba(0, 122, 255, 0.05) 100%);
  border: 1px solid rgba(50, 183, 104, 0.2);
  border-radius: 12px;
  padding: 1rem 1.25rem;
}
.qr-tips-header {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.875rem;
  font-weight: 600;
  color: var(--primary-color);
  margin-bottom: 0.75rem;
}
.qr-tips-header i {
  font-size: 1rem;
}
.qr-tips-box ul {
  margin: 0;
  padding-left: 1.25rem;
}
.qr-tips-box li {
  font-size: 0.8125rem;
  color: var(--gray-600);
  margin-bottom: 0.375rem;
  line-height: 1.5;
}
.qr-tips-box li:last-child {
  margin-bottom: 0;
}
/* ======================================== */
/* Back Button */
/* ======================================== */
.qr-back-link {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.875rem;
  font-weight: 500;
  color: var(--gray-600);
  text-decoration: none;
  border: 1px solid var(--gray-200);
  border-radius: 8px;
  transition: all 0.2s ease;
}
.qr-back-link:hover {
  background: var(--gray-50);
  border-color: var(--gray-300);
  color: var(--gray-700);
}
/* ======================================== */
/* Mobile Responsive */
/* ======================================== */
@media (max-width: 991px) {
  .qr-display-frame {
    padding: 1rem;
  }

  .qr-display-frame img {
    max-width: 180px;
  }

  .qr-download-actions {
    flex-direction: column;
  }

  .btn-qr-download {
    width: 100%;
    justify-content: center;
  }
}
@media (max-width: 576px) {
  .qr-generator-page {
    padding: 1rem 0;
  }

  .qr-stats-number {
    font-size: 2rem;
  }

  .store-form-card .card-body {
    padding: 1rem;
  }
}
/* ==========================================================================
   7. Vendor overrides (ajustes específicos a librerías)
   ========================================================================== */
/* ========================================================================== */
/* FilePond - File upload customization */
/* ========================================================================== */
.filepond-wrapper {
  width: 100%;
  max-width: 250px;
  margin-bottom: 1.5rem;
}
@media (max-width: 576px) {
  .filepond-wrapper {
    max-width: 100%;
  }
}
.filepond--item {
  max-height: 200px;
}
/* ========================================================================== */
/* Date Range Picker - Date picker customization */
/* ========================================================================== */
.daterangepicker {
  position: absolute;
  color: inherit;
  background-color: #fff;
  border-radius: 4px;
  border: 1px solid #ddd;
  width: 278px;
  max-width: none;
  padding: 0;
  margin-top: 7px;
  top: 100px;
  left: 20px;
  z-index: 3001;
  display: none;
  font-family: arial;
  font-size: 15px;
  line-height: 1em;
}
.daterangepicker:before,
.daterangepicker:after {
  position: absolute;
  display: inline-block;
  border-bottom-color: rgba(0, 0, 0, 0.2);
  content: '';
}
.daterangepicker:before {
  top: -7px;
  border-right: 7px solid transparent;
  border-left: 7px solid transparent;
  border-bottom: 7px solid #ccc;
}
.daterangepicker:after {
  top: -6px;
  border-right: 6px solid transparent;
  border-bottom: 6px solid #fff;
  border-left: 6px solid transparent;
}
.daterangepicker.opensleft:before {
  right: 9px;
}
.daterangepicker.opensleft:after {
  right: 10px;
}
.daterangepicker.openscenter:before,
.daterangepicker.openscenter:after {
  left: 0;
  right: 0;
  width: 0;
  margin-left: auto;
  margin-right: auto;
}
.daterangepicker.opensright:before {
  left: 9px;
}
.daterangepicker.opensright:after {
  left: 10px;
}
.daterangepicker.drop-up {
  margin-top: -7px;
}
.daterangepicker.drop-up:before {
  top: initial;
  bottom: -7px;
  border-bottom: initial;
  border-top: 7px solid #ccc;
}
.daterangepicker.drop-up:after {
  top: initial;
  bottom: -6px;
  border-bottom: initial;
  border-top: 6px solid #fff;
}
.daterangepicker.single .daterangepicker .ranges,
.daterangepicker.single .drp-calendar {
  float: none;
}
.daterangepicker.single .drp-selected {
  display: none;
}
.daterangepicker.show-calendar .drp-calendar {
  display: block;
}
.daterangepicker.show-calendar .drp-buttons {
  display: block;
}
.daterangepicker.auto-apply .drp-buttons {
  display: none;
}
.daterangepicker .drp-calendar {
  display: none;
  max-width: 270px;
}
.daterangepicker .drp-calendar.left {
  padding: 8px 0 8px 8px;
}
.daterangepicker .drp-calendar.right {
  padding: 8px;
}
.daterangepicker .drp-calendar.single .calendar-table {
  border: none;
}
.daterangepicker .calendar-table .next span,
.daterangepicker .calendar-table .prev span {
  color: #fff;
  border: solid black;
  border-width: 0 2px 2px 0;
  border-radius: 0;
  display: inline-block;
  padding: 3px;
}
.daterangepicker .calendar-table .next span {
  transform: rotate(-45deg);
}
.daterangepicker .calendar-table .prev span {
  transform: rotate(135deg);
}
.daterangepicker .calendar-table th,
.daterangepicker .calendar-table td {
  white-space: nowrap;
  text-align: center;
  vertical-align: middle;
  min-width: 32px;
  width: 32px;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  border-radius: 4px;
  border: 1px solid transparent;
  cursor: pointer;
}
.daterangepicker .calendar-table {
  border: 1px solid #fff;
  border-radius: 4px;
  background-color: #fff;
}
.daterangepicker .calendar-table table {
  width: 100%;
  margin: 0;
  border-spacing: 0;
  border-collapse: collapse;
}
.daterangepicker td.available:hover,
.daterangepicker th.available:hover {
  background-color: #eee;
  border-color: transparent;
  color: inherit;
}
.daterangepicker td.week,
.daterangepicker th.week {
  font-size: 80%;
  color: #ccc;
}
.daterangepicker td.off,
.daterangepicker td.off.in-range,
.daterangepicker td.off.start-date,
.daterangepicker td.off.end-date {
  background-color: #fff;
  border-color: transparent;
  color: #999;
}
.daterangepicker td.in-range {
  background-color: #ebf4f8;
  border-color: transparent;
  color: #000;
  border-radius: 0;
}
.daterangepicker td.start-date {
  border-radius: 4px 0 0 4px;
}
.daterangepicker td.end-date {
  border-radius: 0 4px 4px 0;
}
.daterangepicker td.start-date.end-date {
  border-radius: 4px;
}
.daterangepicker td.active,
.daterangepicker td.active:hover {
  background-color: #357ebd;
  border-color: transparent;
  color: #fff;
}
.daterangepicker th.month {
  width: auto;
}
.daterangepicker td.disabled,
.daterangepicker option.disabled {
  color: #999;
  cursor: not-allowed;
  text-decoration: line-through;
}
.daterangepicker select.monthselect,
.daterangepicker select.yearselect {
  font-size: 12px;
  padding: 1px;
  height: auto;
  margin: 0;
  cursor: default;
}
.daterangepicker select.monthselect {
  margin-right: 2%;
  width: 56%;
}
.daterangepicker select.yearselect {
  width: 40%;
}
.daterangepicker select.hourselect,
.daterangepicker select.minuteselect,
.daterangepicker select.secondselect,
.daterangepicker select.ampmselect {
  width: 50px;
  margin: 0 auto;
  background: #eee;
  border: 1px solid #eee;
  padding: 2px;
  outline: 0;
  font-size: 12px;
}
.daterangepicker .calendar-time {
  text-align: center;
  margin: 4px auto 0 auto;
  line-height: 30px;
  position: relative;
}
.daterangepicker .calendar-time select.disabled {
  color: #ccc;
  cursor: not-allowed;
}
.daterangepicker .drp-buttons {
  clear: both;
  text-align: right;
  padding: 8px;
  border-top: 1px solid #ddd;
  display: none;
  line-height: 12px;
  vertical-align: middle;
}
.daterangepicker .drp-selected {
  display: inline-block;
  font-size: 12px;
  padding-right: 8px;
}
.daterangepicker .drp-buttons .btn {
  margin-left: 8px;
  font-size: 12px;
  font-weight: bold;
  padding: 4px 8px;
}
.daterangepicker.show-ranges.single.rtl .drp-calendar.left {
  border-right: 1px solid #ddd;
}
.daterangepicker.show-ranges.single.ltr .drp-calendar.left {
  border-left: 1px solid #ddd;
}
.daterangepicker.show-ranges.rtl .drp-calendar.right {
  border-right: 1px solid #ddd;
}
.daterangepicker.show-ranges.ltr .drp-calendar.left {
  border-left: 1px solid #ddd;
}
.daterangepicker .ranges {
  float: none;
  text-align: left;
  margin: 0;
}
.daterangepicker.show-calendar .ranges {
  margin-top: 8px;
}
.daterangepicker .ranges ul {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  width: 100%;
}
.daterangepicker .ranges li {
  font-size: 12px;
  padding: 8px 12px;
  cursor: pointer;
}
.daterangepicker .ranges li:hover {
  background-color: #eee;
}
.daterangepicker .ranges li.active {
  background-color: #08c;
  color: #fff;
}
/* Responsive */
@media (min-width: 564px) {
  .daterangepicker {
    width: auto;
    direction: ltr;
    text-align: left;
  }

  .daterangepicker .ranges ul {
    width: 140px;
  }

  .daterangepicker.single .ranges ul {
    width: 100%;
  }

  .daterangepicker.single .drp-calendar.left {
    clear: none;
  }

  .daterangepicker.single .ranges,
  .daterangepicker.single .drp-calendar {
    float: left;
  }

  .daterangepicker .drp-calendar.left {
    clear: left;
    margin-right: 0;
  }

  .daterangepicker .drp-calendar.left .calendar-table {
    border-right: none;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
    padding-right: 8px;
  }

  .daterangepicker .drp-calendar.right {
    margin-left: 0;
  }

  .daterangepicker .drp-calendar.right .calendar-table {
    border-left: none;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
  }

  .daterangepicker .ranges,
  .daterangepicker .drp-calendar {
    float: left;
  }
}
@media (min-width: 730px) {
  .daterangepicker .ranges {
    width: auto;
    float: left;
  }

  .daterangepicker.rtl .ranges {
    float: right;
  }

  .daterangepicker .drp-calendar.left {
    clear: none !important;
  }
}
/* ========================================================================== */
/* ActionText - Rails ActionText/Trix customization */
/* ========================================================================== */
/*
 * Provides a drop-in pointer for the default Trix stylesheet that will format the toolbar and
 * the trix-editor content (whether displayed or under editing).
 */
.trix-content {
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto,
    'Helvetica Neue', Arial, 'Noto Sans', 'Apple Color Emoji', 'Segoe UI Emoji',
    'Segoe UI Symbol', sans-serif;
  font-size: 14px;
  line-height: 1.6;
}
.trix-content .attachment-gallery > action-text-attachment,
.trix-content .attachment-gallery > .attachment {
  flex: 1 0 33%;
  padding: 0 0.5em;
  max-width: 33%;
}
.trix-content .attachment-gallery.attachment-gallery--2 > action-text-attachment,
.trix-content .attachment-gallery.attachment-gallery--2 > .attachment,
.trix-content .attachment-gallery.attachment-gallery--4 > action-text-attachment,
.trix-content .attachment-gallery.attachment-gallery--4 > .attachment {
  flex-basis: 50%;
  max-width: 50%;
}
.trix-content action-text-attachment .attachment {
  padding: 0 !important;
  max-width: 100% !important;
}
/* Hide file upload button */
trix-toolbar [data-trix-button-group="file-tools"] {
  display: none;
}
/* Hide link button */
trix-toolbar [data-trix-action="link"] {
  display: none;
}
/* List styling */
trix-editor ul,
trix-editor ol,
.trix-content ul,
.trix-content ol {
  padding-left: 1.5rem;
  margin: 0.5rem 0;
}
trix-editor ul li,
.trix-content ul li {
  list-style-type: disc;
}
trix-editor ol li,
.trix-content ol li {
  list-style-type: decimal;
}
trix-editor li,
.trix-content li {
  margin-bottom: 0.25rem;
}
.trix-editor-custom {
  margin-top: 0px;
}
/* ==========================================================================
   8. Themes
   ========================================================================== */
/* ========================================================================== */
/* Theme Default - Verde (#32b768) + negro */
/* ========================================================================== */
/* Este es el tema actual de GreatFoods */
/* Futuro: Los temas serán seleccionables por tienda */
/* Las variables de colores ya están definidas en base/_variables.scss */
/* Este archivo sirve como documentación y placeholder para el sistema de themes */
/* Paleta del tema default: */
/* --primary-color: #32b768 (Verde principal) */
/* --secondary-color: #007aff (Azul) */
/* --danger-color: #ff3b30 (Rojo) */
/* --warning-color: #ff9500 (Naranja) */
/* --success-color: #34c759 (Verde éxito) */
/* --dark-color: #111827 (Negro) */
/* Cuando se implemente el sistema de themes, cada tema sobrescribirá */
/* estas variables CSS para cambiar la apariencia de la tienda. */
/* ==========================================================================
   9. Base styles
   ========================================================================== */
body {
  font-family: 'Poppins', -apple-system, BlinkMacSystemFont, sans-serif;
}

/*# sourceMappingURL=/assets/application-0f030e99.css.map */