@charset "UTF-8";
/*!
 * MDCMS CSS v2.0.0 - Feb. 2026
 * Copyright 2026 negraru.com
 */

@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");

:root,
[data-bs-theme="light"] {
  --md-primary: #77b921;
  --md-secondary: #016736;
  --md-primary-rgb: 119, 185, 33;
  --md-secondary-rgb: 1, 103, 54;
  --md-primary-100: rgba(var(--md-primary-rgb), 0.05) !important;
  --md-primary-200: rgba(var(--md-primary-rgb), 0.1) !important;
  --md-primary-300: rgba(var(--md-primary-rgb), 0.15) !important;
  --md-primary-400: rgba(var(--md-primary-rgb), 0.2) !important;
  --md-primary-500: rgba(var(--md-primary-rgb), 0.25) !important;
  --md-primary-600: rgba(var(--md-primary-rgb), 0.3) !important;
  --md-primary-700: rgba(var(--md-primary-rgb), 0.35) !important;
  --md-primary-800: rgba(var(--md-primary-rgb), 0.4) !important;
  --md-primary-900: rgba(var(--md-primary-rgb), 0.45) !important;
  --md-font-sans-serif:
    "Roboto", system-ui, -apple-system, "Segoe UI", "Lato", "Helvetica Neue",
    "Noto Sans", "Liberation Sans", Arial, sans-serif, "Apple Color Emoji",
    "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  --md-font-monospace:
    SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New",
    monospace;
  --md-gradient: linear-gradient(
    180deg,
    rgba(255, 255, 255, 0.15),
    rgba(255, 255, 255, 0)
  );
  --md-gradient-primary: linear-gradient(
    108deg,
    var(--md-primary) 0%,
    var(--md-secondary) 20%,
    var(--md-primary) 50%,
    var(--md-primary) 70%,
    #ff9004 100%
  );
  --md-body-font-family: var(--md-font-sans-serif);
  --md-body-font-size: 1rem;
  --md-body-font-weight: 400;
  --md-body-line-height: 1.8;
  --md-body-color: #4d5259;
  --md-body-background: #fafbfc;
  --md-font-weight-light: 300;
  --md-font-weight-bold: 600;

  /* start nav */
  --md-light-bg: #f8fafc;
  --md-text-dark: #334155;
  --md-text-light: #64748b;
  --md-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  --md-animation-duration: 0.3s;
  /* end nav */

  --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-white: #ffffff;
  --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: var(--md-primary);
  --bs-secondary: #4d5259;
  --bs-success: #198754;
  --bs-info: #0dcaf0;
  --bs-warning: #ffc107;
  --bs-danger: #dc3545;
  --bs-light: #f8f9fa;
  /*--bs-dark: #212529;*/
  --bs-dark: var(--md-secondary);
  --bs-primary-rgb: 241, 93, 34;
  --bs-secondary-rgb: 77, 82, 89;
  --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: 77, 82, 89;
  --bs-white-rgb: 255, 255, 255;
  --bs-black-rgb: 0, 0, 0;
  --bs-body-color-rgb: 33, 37, 41;
  --bs-body-bg-rgb: 255, 255, 255;
  --bs-font-sans-serif: var(--md-font-sans-serif);
  --bs-font-monospace: var(--md-font-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: #4d5259;
  --bs-body-bg: #fafbfc;
  --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: var(--md-primary);
  --bs-link-color-rgb: 13, 110, 253;
  --bs-link-decoration: underline;
  --bs-link-hover-color: var(--md-primary);
  --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: #ebedf0; /* 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;
  --bs-list-group-bg: var(--bs-white);
  --bs-list-group-action-active-bg: var(--bs-white);
  --bs-dropdown-link-active-bg: var(--md-primary);
}

.btn-primary {
  --bs-btn-color: #fff;
  --bs-btn-bg: var(--md-primary);
  --bs-btn-border-color: var(--md-primary);
  --bs-btn-hover-color: #fff;
  --bs-btn-hover-bg: #0b5ed7;
  --bs-btn-hover-border-color: var(--bs-yellow);
  --bs-btn-focus-shadow-rgb: 49, 132, 253;
  --bs-btn-active-color: var(--bs-dark);
  --bs-btn-active-bg: var(--bs-yellow);
  --bs-btn-active-border-color: var(--bs-yellow);
  --bs-btn-active-shadow: inset 0 3px 5px rgba(0, 0, 0, 0.125);
  --bs-btn-disabled-color: #fff;
  --bs-btn-disabled-bg: var(--md-primary);
  --bs-btn-disabled-border-color: var(--md-primary);
}

.btn-outline-primary {
  --bs-btn-color: var(--md-primary);
  --bs-btn-border-color: var(--md-primary);
  --bs-btn-hover-bg: var(--md-primary);
  --bs-btn-hover-border-color: var(--md-primary);
  --bs-btn-active-bg: var(--md-primary);
  --bs-btn-active-border-color: var(--md-primary);
  --bs-btn-disabled-color: var(--md-primary);
  --bs-btn-disabled-border-color: var(--md-primary);
}

.btn-dark,
.btn-secondary {
  --bs-btn-bg: var(--md-secondary);
  --bs-btn-border-color: var(--md-secondary);
  --bs-btn-hover-bg: #000000;
  --bs-btn-disabled-bg: var(--md-secondary);
  --bs-btn-disabled-border-color: var(--md-secondary);
}

.bg-dark {
  background-color: #212529 !important;
}

.bg-gray {
  background-color: var(--bs-gray);
}
.bg-gray-dark {
  background-color: var(--bs-gray-dark);
}
.bg-gray-100 {
  background-color: var(--bs-gray-100);
}
.bg-gray-200 {
  background-color: var(--bs-gray-200);
}
.bg-gray-400 {
  background-color: var(--bs-gray-400);
}
.bg-gray-500 {
  background-color: var(--bs-gray-500);
}
.bg-gray-600 {
  background-color: var(--bs-gray-600);
}
.bg-gray-700 {
  background-color: var(--bs-gray-700);
}
.bg-gray-800 {
  background-color: var(--bs-gray-800);
}
.bg-gray-900 {
  background-color: var(--bs-gray-900);
}

/* ===================================
   BASE & RESET STYLES
   =================================== */

html {
  font-size: 100%;
  height: 100%;
}

html,
body {
  height: 100%;
}

body {
  margin: 0;
  overflow-x: hidden;
  font-family: var(--bs-body-font-family);
  font-size: var(--bs-body-font-size);
  font-weight: var(--md-font-weight-regular);
  line-height: var(--bs-body-line-height);
  color: var(--bs-body-color);
  background-color: var(--bs-body-bg);
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: rgba(22, 28, 45, 0);
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

/* ===================================
   TYPOGRAPHY
   =================================== */

h1,
.h1,
h2,
.h2,
h3,
.h3,
h4,
.h4,
h5,
.h5,
h6,
.h6 {
  margin-top: 0;
  margin-bottom: 0.5rem;
}

h1,
.h1 {
  font-size: clamp(1.5rem, 1.2rem + 1.2vw, 1.75rem);
  line-height: clamp(1.1, 1.05 + 0.05vw, 1.25);
  font-weight: var(--md-font-weight-light);
}

h2,
.h2 {
  font-size: clamp(1.35rem, 1.1rem + 1vw, 1.5rem);
  line-height: clamp(1.1, 1.05 + 0.05vw, 1.2);
  color: var(--bs-primary);
}

h3,
.h3 {
  font-size: clamp(1.2rem, 1rem + 0.85vw, 1.35rem);
  line-height: clamp(1.1, 1.05 + 0.03vw, 1.15);
  color: var(--bs-secondary);
}

h4,
.h4 {
  font-size: clamp(1.1rem, 0.95rem + 0.6vw, 1.2rem);
  line-height: clamp(1.15, 1.1 + 0.03vw, 1.2);
}

h5,
.h5 {
  font-size: clamp(1rem, 0.9rem + 0.45vw, 1.1rem);
  line-height: clamp(1.2, 1.15 + 0.03vw, 1.25);
}

h6,
.h6 {
  font-size: clamp(0.8125rem, 0.8rem + 0.3vw, 1rem);
  line-height: clamp(1.2, 1.15 + 0.02vw, 1.25);
  color: var(--bs-primary);
}

p {
  margin-top: 0;
  margin-bottom: 1rem;
  line-height: var(--bs-body-line-height);
}

b,
strong,
.fw-bold,
.fw-semibold {
  font-weight: var(--md-font-weight-bold);
}

small,
.small {
  font-size: 88.2%;
}

.text-xs {
  font-size: 0.75rem;
}

.text-sm {
  font-size: 0.875rem;
}

.text-lg {
  font-size: 1.25rem;
}

.text-xl {
  font-size: 2.5rem;
}

.fw-100 {
  font-weight: 100;
}
.fw-200 {
  font-weight: 200;
}
.fw-300 {
  font-weight: 300;
}
.fw-400 {
  font-weight: 400;
}
.fw-500 {
  font-weight: 500;
}
.fw-600 {
  font-weight: 600;
}
.fw-700 {
  font-weight: 700;
}
.fw-800 {
  font-weight: 800;
}
.fw-900 {
  font-weight: 900;
}

/* ===================================
   LISTS & TEXT ELEMENTS
   =================================== */

ol,
ul {
  padding-left: 2rem;
  margin-top: 0;
  margin-bottom: 1rem;
}

dl {
  margin-top: 0;
  margin-bottom: 1rem;
}

ol ol,
ul ul,
ol ul,
ul ol {
  margin-bottom: 0;
}

dt {
  font-weight: var(--md-font-weight-bold);
}

dd {
  margin-bottom: 0.5rem;
  margin-left: 0;
}

blockquote {
  margin: 0 0 1rem;
}

abbr[title],
abbr[data-bs-original-title] {
  text-decoration: underline dotted;
  cursor: help;
  text-decoration-skip-ink: none;
}

address {
  margin-bottom: 1rem;
  font-style: normal;
  line-height: inherit;
}

mark,
.mark {
  padding: 0.2em;
  background-color: #fcf8e3;
}

sub,
sup {
  position: relative;
  font-size: 0.75em;
  line-height: 0;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

hr {
  margin: 1rem 0;
  color: var(--bs-gray-300);
  background-color: currentColor;
  border: 0;
  opacity: 1;
  height: 1px;
}

/* ===================================
   LINKS
   =================================== */

a {
  color: var(--bs-primary);
  text-decoration: none;
  transition: color var(--md-transition-duration) ease;
}

a:hover {
  color: var(--bs-secondary);
}

a:not([href]):not([class]),
a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}

.link-primary {
  color: var(--bs-primary);
}

.link-primary:hover,
.link-primary:focus {
  color: var(--bs-secondary);
}

.link-secondary {
  color: var(--bs-secondary);
}

.link-secondary:hover,
.link-secondary:focus {
  color: var(--bs-primary);
}

/* ===================================
   CODE & PRE
   =================================== */

pre,
code,
kbd,
samp {
  font-family: var(--bs-font-monospace);
  font-size: 1em;
  direction: ltr;
  unicode-bidi: bidi-override;
}

pre {
  display: block;
  margin-top: 0;
  margin-bottom: 1rem;
  overflow: auto;
  font-size: 0.8125rem;
}

pre code {
  font-size: inherit;
  color: inherit;
  word-break: normal;
}

code {
  font-size: 0.8125rem;
  color: #d63384;
  word-wrap: break-word;
}

a > code {
  color: inherit;
}

kbd {
  padding: 0.2rem 0.4rem;
  font-size: 0.8125rem;
  color: var(--bs-white);
  background-color: #1b2a4e;
  border-radius: 0.25rem;
}

kbd kbd {
  padding: 0;
  font-size: 1em;
  font-weight: var(--md-font-weight-bold);
}

/* ===================================
   IMAGES & MEDIA
   =================================== */

img,
svg {
  vertical-align: middle;
}

figure {
  margin: 0 0 1rem;
}

iframe {
  overflow: hidden;
}

/* Lazyload background images */
.lazybg {
  background: none !important;
}

/* ===================================
   TABLES
   =================================== */

table {
  caption-side: bottom;
  border-collapse: collapse;
}

caption {
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  color: #869ab8;
  text-align: left;
}

th {
  text-align: inherit;
}

thead,
tbody,
tfoot,
tr,
td,
th {
  border-color: inherit;
  border-style: solid;
  border-width: 0;
}

/* animation home */
.hoja {
  color: #dcdce2;
  position: absolute;
  top: 10%;
  left: 80%;
  margin-left: -400px;
  margin-top: -400px;
  width: 800px;
  height: 800px;
  /*
  font-size: 45px;
  font-weight: 300;
  line-height: 280px;
  -webkit-font-smoothing: antialiased;
  */
}
.hoja:after,
.hoja:before {
  content: "";
  border-radius: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transform-origin: center center;
  transform-origin: center center;
}
.hoja:after {
  box-shadow:
    inset 0 17.5px 0 rgba(250, 250, 0, 0.6),
    inset 17.5px 0 0 rgba(250, 200, 0, 0.6),
    inset 0 -17.5px 0 rgba(250, 150, 0, 0.6),
    inset -17.5px 0 0 rgba(250, 100, 0, 0.6);
  -webkit-animation: rotar 2s -0.5s linear infinite;
  animation: rotar 2s -0.5s linear infinite;
}
.hoja:before {
  box-shadow:
    inset 0 17.5px 0 rgba(0, 250, 250, 0.6),
    inset 17.5px 0 0 rgba(0, 200, 200, 0.6),
    inset 0 -17.5px 0 rgba(0, 150, 200, 0.6),
    inset -17.5px 0 0 rgba(0, 200, 250, 0.6);
  -webkit-animation: rotarIz 2s -0.5s linear infinite;
  animation: rotarIz 2s -0.5s linear infinite;
}
@-webkit-keyframes rotar {
  0% {
    -webkit-transform: rotateZ(0deg) scaleX(1) scaleY(1);
    transform: rotateZ(0deg) scaleX(1) scaleY(1);
  }
  50% {
    -webkit-transform: rotateZ(180deg) scaleX(0.82) scaleY(0.95);
    transform: rotateZ(180deg) scaleX(0.82) scaleY(0.95);
  }
  100% {
    -webkit-transform: rotateZ(360deg) scaleX(1) scaleY(1);
    transform: rotateZ(360deg) scaleX(1) scaleY(1);
  }
}
@keyframes rotar {
  0% {
    -webkit-transform: rotateZ(0deg) scaleX(1) scaleY(1);
    transform: rotateZ(0deg) scaleX(1) scaleY(1);
  }
  50% {
    -webkit-transform: rotateZ(180deg) scaleX(0.82) scaleY(0.95);
    transform: rotateZ(180deg) scaleX(0.82) scaleY(0.95);
  }
  100% {
    -webkit-transform: rotateZ(360deg) scaleX(1) scaleY(1);
    transform: rotateZ(360deg) scaleX(1) scaleY(1);
  }
}
@-webkit-keyframes rotarIz {
  0% {
    -webkit-transform: rotateZ(0deg) scaleX(1) scaleY(1);
    transform: rotateZ(0deg) scaleX(1) scaleY(1);
  }
  50% {
    -webkit-transform: rotateZ(-180deg) scaleX(0.95) scaleY(0.85);
    transform: rotateZ(-180deg) scaleX(0.95) scaleY(0.85);
  }
  100% {
    -webkit-transform: rotateZ(-360deg) scaleX(1) scaleY(1);
    transform: rotateZ(-360deg) scaleX(1) scaleY(1);
  }
}
@keyframes rotarIz {
  0% {
    -webkit-transform: rotateZ(0deg) scaleX(1) scaleY(1);
    transform: rotateZ(0deg) scaleX(1) scaleY(1);
  }
  50% {
    -webkit-transform: rotateZ(-180deg) scaleX(0.95) scaleY(0.85);
    transform: rotateZ(-180deg) scaleX(0.95) scaleY(0.85);
  }
  100% {
    -webkit-transform: rotateZ(-360deg) scaleX(1) scaleY(1);
    transform: rotateZ(-360deg) scaleX(1) scaleY(1);
  }
}
/* end animation home */

/* ===================================
   FORM ELEMENTS
   =================================== */

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]::-webkit-calendar-picker-indicator {
  display: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  appearance: button;
  -webkit-appearance: button;
  cursor: pointer;
}

button:disabled,
[type="button"]:disabled,
[type="reset"]:disabled,
[type="submit"]:disabled {
  cursor: not-allowed;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-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;
  font-size: 1.5rem;
  line-height: inherit;
}

legend + * {
  clear: left;
}

/* Form Custom Styles */
.form-check.form-check-solid .form-check-input {
  background-color: #eef2f8;
  border-color: #eef2f8;
}

.form-check.form-check-solid .form-check-input:checked {
  background-color: var(--bs-primary);
}

.form-control-solid {
  background-color: #eef2f8;
  border-color: #eef2f8;
}

.form-control-solid:focus {
  background-color: #eef2f8;
}

/* Input Group Joined */
.input-group-joined {
  border: 1px solid #c5ccd6;
  border-radius: 0.4375rem;
  transition:
    border-color 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

.input-group-joined:focus-within {
  border-color: transparent;
  box-shadow: 0 0 0 0.25rem rgba(0, 97, 242, 0.25);
}

.input-group-joined .form-control {
  border: none;
}

.input-group-joined .form-control:focus {
  box-shadow: none;
  outline: none;
}

.input-group-joined .input-group-text {
  border: none;
  background-color: var(--bs-white);
}

.input-group-joined-xl .form-control {
  height: 4rem;
  font-size: 1.25rem;
}

.input-group-joined.input-group-solid {
  border: 0;
  background-color: #eef2f8;
}

.input-group-joined.input-group-solid .form-control,
.input-group-joined.input-group-solid .input-group-text {
  background-color: transparent;
}

/* Autocomplete Mail */
.autocomplete {
  position: relative;
  display: inline-block;
}

.autocomplete-items {
  position: absolute;
  border: 1px solid #d4d4d4;
  border-bottom: none;
  border-top: none;
  z-index: 99;
}

.autocomplete-items div {
  padding: 10px;
  cursor: pointer;
  background-color: #fffef6;
  border-bottom: 1px solid #d4d4d4;
}

.autocomplete-items div:hover {
  background-color: #fffbeb;
}

.autocomplete-active {
  background-color: #fef3cd !important;
  color: #000000;
}

/* ===================================
   COLOR UTILITIES
   =================================== */

/* Text Colors */
.text-primary {
  color: var(--md-primary) !important;
}

.text-secondary {
  color: var(--md-secondary) !important;
}

.text-muted {
  color: var(--bs-gray-500) !important;
}

.text-white-75 {
  color: rgba(255, 255, 255, 0.75) !important;
}

.text-white-25 {
  color: rgba(255, 255, 255, 0.25) !important;
}

.text-black-75 {
  color: rgba(0, 0, 0, 0.75) !important;
}

.text-black-25 {
  color: rgba(0, 0, 0, 0.25) !important;
}

/* Gray Text Colors */
.text-gray-100 {
  color: var(--bs-gray-100) !important;
}
.text-gray-200 {
  color: var(--bs-gray-200) !important;
}
.text-gray-300 {
  color: var(--bs-gray-300) !important;
}
.text-gray-400 {
  color: var(--bs-gray-400) !important;
}
.text-gray-500 {
  color: var(--bs-gray-500) !important;
}
.text-gray-600 {
  color: var(--bs-gray-600) !important;
}
.text-gray-700 {
  color: var(--bs-gray-700) !important;
}
.text-gray-800 {
  color: var(--bs-gray-800) !important;
}
.text-gray-900 {
  color: var(--bs-gray-900) !important;
}

/* Background Colors - Gray */
.bg-gray-100 {
  background-color: var(--bs-gray-100) !important;
}
.bg-gray-200 {
  background-color: var(--bs-gray-200) !important;
}
.bg-gray-300 {
  background-color: var(--bs-gray-300) !important;
}
.bg-gray-400 {
  background-color: var(--bs-gray-400) !important;
}
.bg-gray-500 {
  background-color: var(--bs-gray-500) !important;
}
.bg-gray-600 {
  background-color: var(--bs-gray-600) !important;
}
.bg-gray-700 {
  background-color: var(--bs-gray-700) !important;
}
.bg-gray-800 {
  background-color: var(--bs-gray-800) !important;
}
.bg-gray-900 {
  background-color: var(--bs-gray-900) !important;
}

/* Background Colors - Primary */
.bg-primary-100 {
  background-color: var(--md-primary-100) !important;
}
.bg-primary-200 {
  background-color: var(--md-primary-200) !important;
}
.bg-primary-300 {
  background-color: var(--md-primary-300) !important;
}
.bg-primary-400 {
  background-color: var(--md-primary-400) !important;
}
.bg-primary-500 {
  background-color: var(--md-primary-500) !important;
}
.bg-primary-600 {
  background-color: var(--md-primary-600) !important;
}
.bg-primary-700 {
  background-color: var(--md-primary-700) !important;
}
.bg-primary-800 {
  background-color: var(--md-primary-800) !important;
}
.bg-primary-900 {
  background-color: var(--md-primary-900) !important;
}

/* Background Colors - Secondary */
.bg-secondary-100 {
  background-color: var(--md-secondary-100) !important;
}
.bg-secondary-200 {
  background-color: var(--md-secondary-200) !important;
}
.bg-secondary-300 {
  background-color: var(--md-secondary-300) !important;
}
.bg-secondary-400 {
  background-color: var(--md-secondary-400) !important;
}
.bg-secondary-500 {
  background-color: var(--md-secondary-500) !important;
}
.bg-secondary-600 {
  background-color: var(--md-secondary-600) !important;
}
.bg-secondary-700 {
  background-color: var(--md-secondary-700) !important;
}
.bg-secondary-800 {
  background-color: var(--md-secondary-800) !important;
}
.bg-secondary-900 {
  background-color: var(--md-secondary-900) !important;
}

/* Additional Background Utilities */
.bg-white-25 {
  background-color: rgba(255, 255, 255, 0.25) !important;
}

.bg-img-cover {
  background-position: center;
  background-size: cover;
  background-repeat: no-repeat;
}

.bg-img-repeat {
  background-position: top left;
  background-repeat: repeat;
}

/* Border Colors - Gray */
.border-gray-100 {
  border-color: #f2f6fc !important;
}
.border-gray-200 {
  border-color: #e0e5ec !important;
}
.border-gray-300 {
  border-color: #d4dae3 !important;
}
.border-gray-400 {
  border-color: #c5ccd6 !important;
}
.border-gray-500 {
  border-color: #a7aeb8 !important;
}
.border-gray-600 {
  border-color: #69707a !important;
}
.border-gray-700 {
  border-color: #4a515b !important;
}
.border-gray-800 {
  border-color: #363d47 !important;
}
.border-gray-900 {
  border-color: #212832 !important;
}

.typography-headline {
  font-weight: 800;
  letter-spacing: -0.005em;
  font-family:
    "md2",
    SF Pro Display,
    SF Pro Icons,
    Helvetica Neue,
    Helvetica,
    Arial,
    sans-serif;
}

.gradient-primary {
  background: #1d1d1f;
  background-clip: text;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  background-image: var(--md-gradient-primary);
}

/* Gradient Backgrounds */
.text-gradient {
  background: linear-gradient(
    95.07deg,
    var(--bs-primary) -9.16%,
    var(--bs-secondary) 60.12%,
    rgba(var(--bs-primary-rgb), 0.9) 100.48%
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.text-gradient-2 {
  background-image: linear-gradient(
    to right,
    var(--bs-primary),
    var(--bs-secondary)
  );
  opacity: 0.8;
  color: #0d0d0d;
  -webkit-text-fill-color: transparent;
  -webkit-background-clip: text;
  background-clip: text;
  font-weight: 700;
  line-height: 1.5;
}

.bg-gradient-primary-to-secondary {
  background-color: var(--bs-primary) !important;
  background-image: linear-gradient(
    135deg,
    var(--bs-primary) 50%,
    var(--bs-secondary) 100%
  ) !important;
}

.bg-transparent-light {
  color: rgba(255, 255, 255, 0.5) !important;
  background-color: rgba(0, 0, 0, 0.1) !important;
}

.bg-transparent-dark {
  color: rgba(33, 40, 50, 0.5) !important;
  background-color: rgba(33, 40, 50, 0.8) !important;
}

.bg-light-gradient {
  background: linear-gradient(
    180deg,
    rgba(221, 218, 255, 0.2),
    hsla(0, 0%, 100%, 0) 80%
  );
}

.bg-light-gradient-bottom {
  background: linear-gradient(
    1turn,
    rgba(221, 218, 255, 0.3),
    hsla(0, 0%, 100%, 0) 80%
  );
}

.bg-light-gradient-top {
  background: linear-gradient(
    180deg,
    rgba(221, 218, 255, 0.3),
    hsla(0, 0%, 100%, 0) 80%
  );
}

.bg-gradient-mix-shade {
  background: linear-gradient(
    270.06deg,
    #4a52ff 0.05%,
    #c678ff 54.16%,
    #fe5d75 99.95%
  );
}

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

.bg-secondary {
  background-color: var(--bs-secondary) !important;
}

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

.body-color {
  color: var(--bs-body-bg);
}

.icon-sms {
  width: 1.5em !important;
  height: 1.5em !important;
}
/* ===================================
   UTILITY CLASSES
   =================================== */

.clear {
  clear: both;
  position: relative;
  top: 15px;
}

.rounded-xl {
  border-radius: var(--md-border-radius-xl) !important;
}

.pointer {
  cursor: pointer !important;
}

.no-highlight {
  user-select: none !important;
}

.inherit {
  height: inherit !important;
}

.z-1 {
  z-index: 1 !important;
  position: relative !important;
}

.z-2 {
  z-index: 2 !important;
  position: relative !important;
}

.z-4 {
  z-index: 4 !important;
}

.o-visible {
  overflow: visible !important;
}

.o-hidden {
  overflow: hidden !important;
}

.line-height-normal {
  line-height: normal !important;
}

/* ===================================
   SHADOWS & EFFECTS
   =================================== */

.lift {
  box-shadow: var(--md-box-shadow);
  transition:
    transform 0.15s ease-in-out,
    box-shadow 0.15s ease-in-out;
}

.lift:hover {
  transform: translateY(-0.333rem);
  box-shadow: var(--md-box-shadow-lg);
}

.lift:active {
  transform: none;
  box-shadow: var(--md-box-shadow);
}

.lift-sm {
  box-shadow: var(--md-box-shadow-sm);
}

.lift-sm:hover {
  transform: translateY(-0.167rem);
  box-shadow: 0 0.25rem 1rem 0 rgba(33, 40, 50, 0.25);
}

.lift-sm:active {
  transform: none;
  box-shadow: var(--md-box-shadow-sm);
}

.card.lift {
  text-decoration: none;
  color: inherit;
}

/* Shadow Variants */
.shadow-right-sm {
  box-shadow: 0.125rem 0 0.25rem 0 rgba(33, 40, 50, 0.15) !important;
}

.shadow-right {
  box-shadow: 0.15rem 0 1.75rem 0 rgba(33, 40, 50, 0.15) !important;
}

.shadow-right-lg {
  box-shadow: 1rem 0 3rem 0 rgba(33, 40, 50, 0.15) !important;
}

.shadow-left-sm {
  box-shadow: -0.125rem 0 0.25rem 0 rgba(33, 40, 50, 0.15) !important;
}

.shadow-left {
  box-shadow: -0.15rem 0 1.75rem 0 rgba(33, 40, 50, 0.15) !important;
}

.shadow-left-lg {
  box-shadow: -1rem 0 3rem 0 rgba(33, 40, 50, 0.15) !important;
}

/* 3D Effects */
.content-skewed {
  perspective: 1500px !important;
  transform-style: preserve-3d !important;
}

.content-skewed-right {
  perspective-origin: right center !important;
}

.content-skewed-right .content-skewed-item {
  transform: rotateY(30deg) rotateX(15deg) !important;
  backface-visibility: hidden !important;
}

.content-skewed-left {
  perspective-origin: left center !important;
}

.content-skewed-left .content-skewed-item {
  transform: rotateY(-30deg) rotateX(15deg) !important;
  backface-visibility: hidden !important;
}

/* Overlay */
.overlay {
  position: relative;
}

.overlay::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #000;
  opacity: 0.5;
}

.overlay-primary::before {
  background-color: var(--bs-primary) !important;
}

.overlay-secondary::before {
  background-color: var(--bs-secondary) !important;
}

.overlay-70::before {
  opacity: 0.7;
}

/* ===================================
   ANIMATIONS
   =================================== */

@keyframes fadeInUp {
  from {
    opacity: 0;
    margin-top: 0.75rem;
  }
  to {
    opacity: 1;
    margin-top: 0;
  }
}

.animated--fade-in-up {
  animation: fadeInUp 300ms cubic-bezier(0.18, 1.25, 0.4, 1);
}

.animated--fade-in-up.dropdown-menu {
  margin-top: 0;
  top: 0.125rem !important;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.animated--fade-in {
  animation: fadeIn 300ms cubic-bezier(0, 1, 0.4, 1);
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/*  ===================================
    PAGE ANIMATION: BOTTOM TO TOP
    =================================== */

.img-error {
  max-width: 20rem;
}

/* ===================================
   CARDS
   =================================== */

.card {
  perspective: 30rem;
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: var(--md-border-radius);
  box-shadow: 0 0.375rem 0.75rem rgba(140, 152, 164, 0.075);
}

.card .card-header {
  font-weight: var(--md-font-weight-bold);
  padding: 1rem;
  margin-bottom: 0;
  background-color: transparent;
  border-bottom: 1px solid rgba(0, 0, 0, 0.1);
}

.card-footer {
  padding: 0.5rem 1rem;
  border-top: 1px solid rgba(0, 0, 0, 0.1);
}

.card:not([class*="bg-"]) .card-header {
  color: var(--bs-primary);
}

.card-text {
  font-size: 16px;
  line-height: 1.5;
}

.card.bg-dark .card-header,
.card.bg-dark .card-footer {
  border-color: rgba(255, 255, 255, 0.15);
}

.card .card-header .card-header-tabs .nav-link.active {
  background-color: var(--bs-white);
  border-bottom-color: var(--bs-white);
}

.card-header-actions .card-header {
  height: 3.5625rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 0.5625rem;
}

.card-header-actions .card-header .dropdown-menu {
  margin-top: 0;
  top: 0.5625rem !important;
}

/* Card Collapsible */
.card-collapsable .card-header[data-bs-toggle="collapse"],
.card-collapsable .card-header[data-toggle="collapse"] {
  display: flex;
  text-decoration: none;
  position: relative;
  align-items: center;
  justify-content: space-between;
}

.card-collapsable
  .card-header[data-bs-toggle="collapse"]
  .card-collapsable-arrow,
.card-collapsable .card-header[data-toggle="collapse"] .card-collapsable-arrow {
  height: 0.9rem;
  width: 0.9rem;
  display: inline-flex;
  font-size: 0.9rem;
  transition: transform 0.1s ease-in-out;
}

.card-collapsable
  .card-header[data-bs-toggle="collapse"]
  .card-collapsable-arrow
  svg,
.card-collapsable
  .card-header[data-bs-toggle="collapse"]
  .card-collapsable-arrow
  i,
.card-collapsable
  .card-header[data-toggle="collapse"]
  .card-collapsable-arrow
  svg,
.card-collapsable
  .card-header[data-toggle="collapse"]
  .card-collapsable-arrow
  i {
  height: 0.9rem;
  width: 0.9rem;
}

.card-collapsable .card-header[data-bs-toggle="collapse"].collapsed,
.card-collapsable .card-header[data-toggle="collapse"].collapsed {
  border-radius: 0.35rem;
}

.card-collapsable
  .card-header[data-bs-toggle="collapse"].collapsed
  .card-collapsable-arrow,
.card-collapsable
  .card-header[data-toggle="collapse"].collapsed
  .card-collapsable-arrow {
  transform: rotate(-90deg);
}

/* Card Flip Animation */
.flip-card {
  transition: transform 0.6s;
  transform-style: preserve-3d;
}

.img-front {
  position: relative;
  z-index: 2;
}

.img-back {
  position: absolute;
  z-index: 1;
  inset: 0;
  backface-visibility: hidden;
  transform: rotateY(180deg);
}

.card:hover .flip-card {
  transform: rotateY(180deg);
}

/* ===================================
   BUTTONS
   =================================== */

.btn-light {
  color: var(--bs-primary) !important;
}

.btn-light:hover {
  text-decoration: none;
}

/* Theme Switcher Button Icons */
[data-theme-value="light"] svg.bi {
  color: #f59e0b;
  opacity: 1;
}

[data-theme-value="dark"] svg.bi {
  color: #6366f1;
  opacity: 1;
}

[data-theme-value="auto"] svg.bi {
  color: var(--bs-primary);
  opacity: 1;
}

/* Active/Pressed state */
[data-theme-value][aria-pressed="true"] svg.bi {
  opacity: 1;
  color: var(--bs-primary);
}

[data-theme-value][aria-pressed="true"] {
  background-color: var(--bs-gray-200);
  border-color: var(--bs-gray-300);
}

/* Checkmark icon when active */
[data-theme-value][aria-pressed="true"] svg.bi.ms-auto {
  display: inline-block !important;
  color: var(--bs-success);
}

.btn-primary {
  color: var(--bs-white);
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  transition: opacity var(--md-transition-duration) ease;
}

.btn-primary:hover {
  color: var(--bs-white);
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  opacity: 0.75;
}

.btn-outline-primary {
  color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
}

.btn-outline-primary:hover {
  color: var(--bs-white) !important;
  background-color: var(--bs-primary) !important;
  border-color: var(--bs-primary) !important;
  opacity: 0.75;
}

.btn-secondary {
  color: var(--bs-white);
  background-color: var(--bs-secondary) !important;
  border-color: var(--bs-secondary) !important;
}

.btn-secondary:hover {
  color: var(--bs-white);
  background-color: var(--bs-secondary) !important;
  border-color: var(--bs-secondary) !important;
  opacity: 0.75;
}

.btn-outline-secondary {
  color: var(--bs-secondary) !important;
  border-color: var(--bs-secondary) !important;
}

.btn-outline-secondary:hover {
  color: var(--bs-white) !important;
  background-color: var(--bs-secondary) !important;
  border-color: var(--bs-secondary) !important;
}

.btn-sm {
  padding: 0.3rem 1rem 0.2rem 1rem;
}

/* ===================================
   ICONS
   =================================== */

.icon-services {
  fill: var(--bs-secondary);
}

.icon-stack {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 50%;
  height: 2.5rem;
  width: 2.5rem;
  font-size: 1rem;
  background-color: #f2f6fc;
  flex-shrink: 0;
}

.icon-stack svg {
  height: 1rem;
  width: 1rem;
}

.icon-stack-sm {
  height: 2rem;
  width: 2rem;
}

.icon-stack-lg {
  height: 4rem;
  width: 4rem;
  font-size: 1.5rem;
}

.icon-stack-lg svg {
  height: 1.5rem;
  width: 1.5rem;
}

.icon-stack-xl {
  height: 5rem;
  width: 5rem;
  font-size: 1.75rem;
}

.icon-stack-xl svg {
  height: 1.75rem;
  width: 1.75rem;
}

.icon-list-social .icon-list-social-link {
  font-size: 1.25rem;
  margin-right: 0.5rem;
}

.fa-stack {
  position: relative;
  display: inline-block;
  width: 3.5em;
  height: 3.5em;
  margin: 5px;
  line-height: 1em;
  vertical-align: middle;
}

.tag-svg {
  width: 16px;
  fill: var(--bs-primary);
}

.svg-inline-icon {
  display: inline-block;
  font-size: inherit;
  height: 1em;
  overflow: visible;
  vertical-align: -0.125em;
}

.brands svg {
  width: 100%;
  fill: currentColor;
}

.text-arrow-icon {
  line-height: 1;
  display: inline-flex;
  align-items: center;
}

.text-arrow-icon svg {
  margin-left: 0.25rem;
}

.text-arrow-icon.small svg {
  height: 0.875rem;
  width: 0.875rem;
}

/* ===================================
   BADGES
   =================================== */

.badge-sm {
  font-size: 0.75rem;
}

.badge-md {
  font-size: 1rem;
}

.badge-lg {
  font-size: 1.25rem;
}

.badge-marketing {
  padding: 0.5em 1em;
}

/* ===================================
   SECTIONS
   =================================== */

section {
  position: relative;
}

.section-title {
  text-align: center;
  padding-bottom: 30px;
}

.section-title h2 {
  font-size: clamp(1.5rem, 5vw, 2rem);
  font-weight: 700;
  margin-bottom: 20px;
  padding-bottom: 20px;
  position: relative;
  color: var(--bs-primary);
}

.section-title h2::before {
  content: "";
  position: absolute;
  display: block;
  width: 120px;
  height: 1px;
  background: #ddd;
  bottom: 1px;
  left: calc(50% - 60px);
}

.section-title h2::after {
  content: "";
  position: absolute;
  display: block;
  width: 40px;
  height: 3px;
  background: var(--bs-primary);
  bottom: 0;
  left: calc(50% - 20px);
}

.section-title p {
  margin-bottom: 0;
}

/* ===================================
   SHAPES & DIVIDERS
   =================================== */

.shape {
  position: absolute;
  width: 100%;
  overflow: hidden;
  z-index: 2;
}

.shape svg {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
}

.shape.bg-light,
.shape.bg-body,
.shape.bg-primary,
.shape.bg-secondary,
.shape.bg-dark,
.shape.bg-darker {
  background-color: transparent !important;
}

.shape.bg-light,
.shape.bg-body {
  color: var(--bs-white) !important;
}

.shape.bg-primary {
  color: #766df4 !important;
}

.shape.bg-secondary {
  color: #f7f7fc !important;
}

.shape.bg-dark {
  color: #37384e !important;
}

.shape.bg-darker {
  color: #2c2d3f !important;
}

.shape-top,
.shape-bottom {
  width: 100%;
  left: 0;
}

.shape-right,
.shape-left {
  height: 100%;
  left: 0;
  top: 0;
  display: none;
}

.shape-right svg,
.shape-left svg {
  top: -2px;
  width: auto;
  height: calc(100% + 5px);
}

.shape-top {
  top: 0;
  margin-top: -1px;
}

.shape-bottom {
  bottom: 0;
  margin-bottom: -1px;
}

.shape-right svg {
  left: auto;
  right: 0;
  margin-right: -1px;
}

.shape-left svg {
  left: 0;
  right: auto;
  margin-left: -1px;
}

.shape-slant {
  padding-bottom: 8.7%;
}

.shape-curve-side {
  padding-bottom: 8.4%;
}

.shape-curve {
  padding-bottom: 6.2%;
}

/* ===================================
   FOOTER
   =================================== */

.footer {
  font-size: 0.875rem;
}

.footer .footer-brand {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 0.25rem;
}

.footer .footer-brand svg {
  height: 1rem;
}

.footer.footer-dark {
  color: var(--bs-body-color);
}

.footer.footer-dark hr {
  border-color: var(--bs-gray-800);
}

.footer.footer-light {
  color: var(--bs-secondary-color);
}

.text-reset,
.footer a {
  color: inherit !important;
  text-decoration: none !important;
}

.text-reset:hover,
.footer a:hover {
  color: var(--bs-primary);
  text-decoration: underline !important;
}

.text-uppercase-expanded {
  font-weight: var(--md-font-weight-bold);
  letter-spacing: 0.125em;
  text-transform: uppercase;
  margin-top: 1rem;
}

/* ===================================
   ACCORDION
   =================================== */

.accordion-button {
  color: var(--bs-primary) !important;
}

.accordion-button:not(.collapsed) {
  color: var(--bs-primary) !important;
  background-color: var(--bs-light) !important;
}

.alert {
  font-size: 14px !important;
}

/* ===================================
   CAROUSEL
   =================================== */

.carousel.carousel-fade .carousel-item {
  display: block;
  opacity: 0;
  transition: opacity ease-out 0.7s;
}

.carousel.carousel-fade .carousel-item.active {
  opacity: 1 !important;
}

/* ===================================
   DEVICES
   =================================== */

.device-laptop {
  position: relative;
}

.device-laptop .device-container {
  display: block;
  height: auto;
  width: 100%;
  position: relative;
  z-index: 1;
}

.device-laptop .device-screenshot {
  display: block;
  position: absolute;
  top: 6%;
  left: 11.8%;
  height: auto;
  width: 76.57%;
  z-index: 0;
}

/* ===================================
   MEDIA (Before/After Slider)
   =================================== */

.before-txt,
.after-txt {
  writing-mode: vertical-lr;
  text-orientation: upright;
  position: absolute;
}

.before-txt {
  left: 0;
}

.after-txt {
  right: 0;
  top: 0;
}

.ba-slider {
  position: relative;
  overflow: hidden;
}

.ba-slider img {
  width: 100%;
  display: block;
}

.resize {
  position: absolute;
  inset: 0 50% 0 0;
  overflow: hidden;
}

.handle {
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 4px;
  margin-left: -2px;
  background: rgba(0, 0, 0, 0.5);
  cursor: ew-resize;
}

.handle::after {
  position: absolute;
  top: 25%;
  width: 40px;
  height: 40px;
  margin: -20px 0 0 -19px;
  content: "\21d4";
  color: white;
  font-size: 24px;
  text-align: center;
  line-height: 40px;
  background: transparent;
  border-radius: 50%;
  transition: all var(--md-transition-duration) ease;
  box-shadow:
    0 2px 6px rgba(0, 0, 0, 0.3),
    inset 0 2px 0 rgba(255, 255, 255, 0.5),
    inset 0 60px 50px -30px #ffd466;
}

.draggable::after {
  width: 20px;
  height: 20px;
  margin: -10px 0 0 -8px;
  line-height: 20px;
  font-size: 15px;
}

/* ===================================
   CALLOUTS
   =================================== */

.bd-callout {
  padding: 1.25rem;
  margin-block: 1.25rem;
  border: 1px solid #e9ecef;
  border-left-width: 0.25rem;
  border-radius: 0.25rem;
}

.bd-callout h4 {
  margin-bottom: 0.25rem;
}

.bd-callout p:last-child {
  margin-bottom: 0;
}

.bd-callout code {
  border-radius: 0.25rem;
}

.bd-callout + .bd-callout {
  margin-top: -0.25rem;
}

.bd-callout-info {
  border-left-color: #5bc0de;
}

.bd-callout-warning {
  border-left-color: #f0ad4e;
}

.bd-callout-danger {
  border-left-color: #d9534f;
}

/* ===================================
   DOTS
   =================================== */

.dot {
  height: 30px;
  width: 30px;
  background-color: var(--bs-primary);
  border-radius: 50%;
  display: inline-block;
  text-align: center;
  color: #ffffff;
}

.media-img {
  height: 5rem;
  width: 5rem;
}

/* ===================================
   YOUTUBE VIDEO WRAPPER
   =================================== */

.hytPlayerWrap {
  display: inline-block;
  position: relative;
  width: 100%;
}

.hytPlayerWrap.ended::after {
  content: "";
  position: absolute;
  inset: 0;
  cursor: pointer;
  background-color: #eee;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 64px 64px;
  background-image: url(data:image/svg+xml;utf8;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIxMjgiIGhlaWdodD0iMTI4IiB2aWV3Qm94PSIwIDAgNTEwIDUxMCI+PHBhdGggZD0iTTI1NSAxMDJWMEwxMjcuNSAxMjcuNSAyNTUgMjU1VjE1M2M4NC4xNSAwIDE1MyA2OC44NSAxNTMgMTUzcy02OC44NSAxNTMtMTUzIDE1My0xNTMtNjguODUtMTUzLTE1M0g1MWMwIDExMi4yIDkxLjggMjA0IDIwNCAyMDRzMjA0LTkxLjggMjA0LTIwNC05MS44LTIwNC0yMDQtMjA0eiIgZmlsbD0iI0ZGRiIvPjwvc3ZnPg==);
}

.hytPlayerWrap.paused::after {
  content: "";
  position: absolute;
  inset: 0;
  cursor: pointer;
  background-color: #eee;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 40px 40px;
  background-image: url(data:image/svg+xml;utf8;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHZlcnNpb249IjEiIHdpZHRoPSIxNzA2LjY2NyIgaGVpZ2h0PSIxNzA2LjY2NyIgdmlld0JveD0iMCAwIDEyODAgMTI4MCI+PHBhdGggZD0iTTE1Ny42MzUgMi45ODRMMTI2MC45NzkgNjQwIDE1Ny42MzUgMTI3Ny4wMTZ6IiBmaWxsPSIjZmZmIi8+PC9zdmc+);
}

/* ===================================
   BANNER WITH TEXT BOX
   =================================== */

.banner-wrapper {
  position: relative;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  border-radius: 32px;
  overflow: hidden;
}

.banner-wrapper img {
  width: 100%;
  height: auto;
  display: block;
}

.banner-text-box {
  position: absolute;
  bottom: -40px;
  right: -40px;
  padding: 50px;
  max-width: 45%;
  height: 60%;
  z-index: 2;
}

.banner-text-box::before {
  content: "";
  position: absolute;
  inset: 0;
  background-color: #ffffff;
  border-top-left-radius: 80px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.1);
  z-index: -1;
  transform: perspective(1000px) rotateZ(-11deg) rotateX(0deg) rotateY(0deg);
  transform-origin: center center;
}

.banner-text-box h2 {
  font-size: clamp(1.125rem, 4vw, 1.75rem);
  font-weight: 700;
  margin-bottom: 16px;
  color: #222;
}

.banner-text-box p {
  font-size: clamp(0.875rem, 2vw, 1rem);
  line-height: 1.6;
  color: #444;
  margin: 0;
}

/* ===================================
   ORTHO LAYOUT (Smile Assessment)
   =================================== */

.sticky-sidebar {
  position: sticky;
  top: 100px;
}

/* Circular Progress */
@property --p {
  syntax: "<percentage>";
  initial-value: 0%;
  inherits: true;
}

.circular-progress {
  position: relative;
  border: solid 3px var(--bs-primary);
  width: 75px;
  left: 50%;
  transform: translateX(-50%);
  aspect-ratio: 1;
  border-radius: 50%;
  --mask:
    linear-gradient(red, red) padding-box,
    conic-gradient(red var(--p), transparent 0%) border-box;
  -webkit-mask: var(--mask);
  mask: var(--mask);
}

.circular-progress span {
  font-size: 2rem;
  font-weight: 700;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.perc-1 {
  animation: perc1 2s linear 3s forwards;
}
.perc-2 {
  animation: perc2 2s linear 3s forwards;
}
.perc-3 {
  animation: perc3 2s linear 3s forwards;
}
.perc-4 {
  animation: perc4 2s linear 3s forwards;
}
.perc-5 {
  animation: perc5 2s linear 3s forwards;
}

@keyframes perc1 {
  to {
    --p: 20%;
  }
}
@keyframes perc2 {
  to {
    --p: 40%;
  }
}
@keyframes perc3 {
  to {
    --p: 60%;
  }
}
@keyframes perc4 {
  to {
    --p: 80%;
  }
}
@keyframes perc5 {
  to {
    --p: 100%;
  }
}

/* Layout Inside Ortho */
.layout-inside-ortho .h1,
.layout-inside-ortho h1,
.layout-inside-ortho h2,
.layout-inside-ortho h3,
.layout-inside-ortho h4,
.layout-inside-ortho h5,
.layout-inside-ortho p {
  line-height: 1.3;
}

.layout-inside-ortho .ortho-half {
  background-color: var(--bs-primary);
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}

/* Smile Assessment Form */
.layout-inside-ortho [type="radio"] {
  opacity: 0;
  width: 0;
  height: 0;
}

.layout-inside-ortho [type="radio"] + img {
  cursor: pointer;
}

.layout-inside-ortho [type="radio"]:hover + img {
  outline: 2px solid rgb(var(--bs-warning-rgb));
}

.layout-inside-ortho [type="radio"]:checked + img {
  outline: 2px solid rgb(var(--bs-success-rgb));
}

/* ===================================
   MEET OUR DENTISTS
   =================================== */

.meet-our-dentists img {
  transition: all 0.5s ease;
  z-index: 2;
  position: relative;
  filter: grayscale(1);
}

.meet-our-dentists .card:hover img {
  transform: scale(1.2);
  filter: grayscale(0);
}

.meet-our-dentists .card:hover a {
  color: var(--bs-secondary);
}

/* ===================================
   MEDIA QUERIES
   =================================== */

/* Mobile: max-width 600px */
@media (max-width: 600px) {
  .banner-text-box {
    max-width: 65%;
    padding: 30px;
    bottom: -20px;
    right: -40px;
  }

  .banner-text-box h2 {
    font-size: 18px;
  }

  .banner-text-box p {
    font-size: 14px;
  }
}

/* Tablet: max-width 767px */
@media (max-width: 767px) {
  .page-header-ui {
    padding: 1rem 0;
  }
}

/* Medium: max-width 900px */
@media (max-width: 900px) {
  .banner-text-box {
    max-width: 80%;
    bottom: -30px;
    right: -30px;
    height: auto;
    padding: 30px;
    border-radius: 0;
  }

  .banner-text-box h2 {
    font-size: 24px;
  }

  .banner-text-box p {
    font-size: 14px;
  }
}

/* Desktop: min-width 768px */
@media (min-width: 768px) {
  .w-md-50 {
    width: 50% !important;
  }

  .row2-half {
    background: url("https://dental.imgix.net/ds-cosmetic-dentistry.jpg?auto=format&fit=max&dpr=1")
      no-repeat top right / cover;
    position: absolute;
    width: 50%;
    height: 100%;
  }

  /* Data Animations */
  @supports (--css: variables) {
    [data-toggle="animation"] {
      animation-duration: 0.4s;
      animation-timing-function: ease-in-out;
      animation-fill-mode: forwards;
    }

    [data-animation="fadeIn"] {
      opacity: 0;
    }

    [data-animation="fadeIn"].animate {
      animation-name: fadeIn;
    }

    [data-animation="fadeUp"] {
      transform: translateY(1rem);
      opacity: 0;
    }

    [data-animation="fadeUp"].animate {
      animation-name: fadeUp;
    }

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

    [data-animation="fadeDown"] {
      transform: translateY(-1rem);
      opacity: 0;
    }

    [data-animation="fadeDown"].animate {
      animation-name: fadeDown;
    }

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

    [data-animation-order="0"] {
      animation-delay: 0s;
    }
    [data-animation-order="1"] {
      animation-delay: 0.15s;
    }
    [data-animation-order="2"] {
      animation-delay: 0.3s;
    }
    [data-animation-order="3"] {
      animation-delay: 0.45s;
    }
    [data-animation-order="4"] {
      animation-delay: 0.6s;
    }
    [data-animation-order="5"] {
      animation-delay: 0.75s;
    }
    [data-animation-order="6"] {
      animation-delay: 0.9s;
    }
    [data-animation-order="7"] {
      animation-delay: 1.05s;
    }
    [data-animation-order="8"] {
      animation-delay: 1.2s;
    }
    [data-animation-order="9"] {
      animation-delay: 1.35s;
    }
    [data-animation-order="10"] {
      animation-delay: 1.5s;
    }
  }
}

/* Large: min-width 992px */
@media (min-width: 992px) {
  .divider-right {
    border-right: 0.0625rem solid #e0e5ec;
  }
}

.row3img {
  position: absolute;
  height: 100%;
  border-bottom-left-radius: 350% 160px;
  left: 0%;
}

.bgr1 {
  background-image: radial-gradient(
    center bottom,
    ellipse cover,
    #8e7c62,
    #000
  );
  background-image: -o-radial-gradient(
    center bottom,
    ellipse cover,
    #8e7c62,
    #000
  );
  background-image: -ms-radial-gradient(
    center bottom,
    ellipse cover,
    #8e7c62,
    #000
  );
  background-image: -moz-radial-gradient(
    center bottom,
    ellipse cover,
    #8e7c62,
    #000
  );
  background-image: -webkit-radial-gradient(
    center bottom,
    ellipse cover,
    #8e7c62,
    #000
  );
}

.bgr2 {
  background-image: radial-gradient(
    center bottom,
    ellipse cover,
    #7a8985,
    #000
  );
  background-image: -o-radial-gradient(
    center bottom,
    ellipse cover,
    #7a8985,
    #000
  );
  background-image: -ms-radial-gradient(
    center bottom,
    ellipse cover,
    #7a8985,
    #000
  );
  background-image: -moz-radial-gradient(
    center bottom,
    ellipse cover,
    #7a8985,
    #000
  );
  background-image: -webkit-radial-gradient(
    center bottom,
    ellipse cover,
    #7a8985,
    #000
  );
}

.bgr-gradient-1,
.bgr-gradient-2 {
  position: absolute;
  width: 100%;
  height: 150vh;
  top: 0;
  left: 0;
  z-index: -1;
  background-size: cover;
  background-position: top center;
  background-repeat: no-repeat;
}

.bgr-gradient-1 {
  background-image: url("/public/images/bgr-gradient-1.svg");
}

.bgr-gradient-2 {
  background-image: url("/public/images/bgr-gradient-2.svg");
}

.bgr-gradient-3 {
  background-image: url("/public/images/bgr-gradient-3.svg");
}

.bgr-gradient-4 {
  background-image: url("/public/images/bgr-gradient-4.svg");
}

.bgr-gradient-5 {
  background-image: url("/public/images/bgr-gradient-5.svg");
}

.bgr-gradient-6 {
  background-image: url("/public/images/bgr-gradient-6.svg");
}

.bgr-gradient-7 {
  background-image: url("/public/images/bgr-gradient-7.svg");
}

.bgr-gradient-8 {
  background-image: url("/public/images/bgr-gradient-8.svg");
}
/*
@media screen and (max-width: 1124px) {
  .bgr-gradient-1,
  .bgr-gradient-2,
  .bgr-gradient-3,
  .bgr-gradient-4,
  .bgr-gradient-5,
  .bgr-gradient-6,
  .bgr-gradient-7 {
    height: 700px;
    background-size: 150% auto;
  }
}
@media screen and (max-width: 1124px) {
  .bgr-gradient-1,
  .bgr-gradient-2,
  .bgr-gradient-3,
  .bgr-gradient-4,
  .bgr-gradient-5,
  .bgr-gradient-6,
  .bgr-gradient-7 {
    background-size: 200% auto;
  }
}*/

/* Base gradients */
.gradient-base {
  background-repeat: no-repeat;
}

.gradient-1 {
  background:
    linear-gradient(
      180deg,
      rgba(255, 255, 255, 0.01) 0%,
      rgba(255, 255, 255, 1) 85%
    ),
    radial-gradient(
      ellipse at top left,
      rgba(13, 110, 253, 0.25),
      transparent 50%
    ),
    radial-gradient(
      ellipse at top right,
      rgba(255, 228, 132, 0.25),
      transparent 50%
    ),
    radial-gradient(
      ellipse at center right,
      rgba(112, 44, 249, 0.25),
      transparent 50%
    ),
    radial-gradient(
      ellipse at center left,
      rgba(214, 51, 132, 0.25),
      transparent 50%
    );
  background-repeat: no-repeat;
}

.gradient-2 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(
      103.89% 81.75% at 95.41% 106.34%,
      #f5fcf7 6%,
      rgba(245, 252, 247, 0) 79.68%
    ),
    radial-gradient(
      297.85% 151.83% at -21.39% 8.81%,
      #fdf8f8 0%,
      #fdf8f8 15.29%,
      #f9f6fa 21.39%,
      #f2f8fd 40.79%
    );
  background-repeat: no-repeat;
}

.gradient-3 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(120% 90% at 0 100%, #f3fff3 8%, transparent 75%),
    radial-gradient(
      250% 140% at 100% 0,
      #fff3f8 0,
      #fff3f8 18%,
      #f3f8ff 25%,
      #f9f3ff 45%
    );
  background-repeat: no-repeat;
}

.gradient-4 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(90% 110% at 50% 50%, #fff8f3 5%, transparent 82%),
    radial-gradient(
      280% 160% at 30% 20%,
      #f3fffd 0,
      #f3fffd 12%,
      #f3f8ff 18%,
      #fff3f3 38%
    );
  background-repeat: no-repeat;
}

.gradient-5 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(95% 120% at 70% 50%, #f3f7ff 7.5%, transparent 76%),
    radial-gradient(
      270% 160% at 30% 50%,
      #fff3f9 0%,
      #f3fffa 17%,
      #fff3f3 24%,
      #f3fbff 43%
    );
  background-repeat: no-repeat;
}

.gradient-6 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(105% 105% at 50% 0%, #f3f9ff 5.8%, transparent 80%),
    radial-gradient(
      310% 145% at 50% 100%,
      #fff3fb 0%,
      #f3fff6 12%,
      #fff3ff 18%,
      #fff8f3 36%
    );
  background-repeat: no-repeat;
}

.gradient-7 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(100% 80% at 90% 110%, #f8fcf4 5%, transparent 80%),
    radial-gradient(
      300% 160% at -20% 10%,
      #fef8f8 0,
      #fef8f8 15%,
      #f8f6fa 25%,
      #f1f8fc 45%
    );
  background-repeat: no-repeat;
}

.gradient-8 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(105% 70% at 98% 105%, #f9fcf3 6%, transparent 82%),
    radial-gradient(
      290% 155% at -25% 5%,
      #f8f8f8 0%,
      #faf5f9 15%,
      #f3f5fa 25%,
      #ebf5fc 45%
    );
  background-repeat: no-repeat;
}

.gradient-9 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(112% 86% at 107% 98%, #f5faf8 7%, transparent 76%),
    radial-gradient(
      305% 158% at -18% -2%,
      #fbf8f8 0%,
      #faf6f9 17%,
      #f5f4fa 34%,
      #eef6fb 52%
    );
  background-repeat: no-repeat;
}

.gradient-10 {
  background:
    linear-gradient(to bottom, transparent 70%, var(--bs-white) 100%),
    radial-gradient(120% 90% at 80% 110%, #eef5fc 10%, transparent 75%),
    radial-gradient(290% 160% at -20% 15%, #f8fbff 5%, #eef7fe 30%, #e7f3fd 55%);
  background-repeat: no-repeat;
}

.typewrite-text-highlight {
  -webkit-animation: typewrite-text-highlight-colorchange 4s infinite alternate;
}

@-webkit-keyframes typewrite-text-highlight-colorchange {
  0% {
    color: var(--md-primary);
  }
  25% {
    color: #953109;
  }
  50% {
    color: #953109;
  }
  75% {
    color: #c5410d;
  }
  100% {
    color: var(--md-primary);
  }
}

/* ===================================
   DARK MODE
   =================================== */

/* Manual Dark Mode Toggle - Apply dark mode when [data-bs-theme="dark"] is set */
[data-bs-theme="dark"] {
  /* Colors Inverted */
  --bs-light: #2a2c31;
  --bs-dark: #0f0f10;
  --bs-dark-rgb: 15, 15, 16;

  /* Breadcrumb - White arrow divider for dark mode */
  --bs-breadcrumb-divider: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='8'%3E%3Cpath d='M2.5 0L1 1.5 3.5 4 1 6.5 2.5 8l4-4-4-4z' fill='%23ffffff'/%3e%3c/svg%3e");

  /* Gray Scale - Inverted */
  --bs-gray-100: #0b1324;
  --bs-gray-200: #0f172a;
  --bs-gray-300: #1e293b;
  --bs-gray-400: #334155;
  --bs-gray-500: #475569;
  --bs-gray-600: #64748b;
  --bs-gray-700: #94a3b8;
  --bs-gray-800: #cbd5e1;
  --bs-gray-900: #e2e8f0;
  --bs-gray-1000: #f1f5f9;

  /* Body */
  --bs-body-bg: #222529;
  --bs-body-bg-rgb: 34, 37, 41;
  --bs-body-color: #a1a1a8;
  --bs-success: #198754;
  --bs-success-rgb: 25, 135, 84;
  --bs-warning: #ffc107;
  --bs-warning-rgb: 255, 193, 7;
  --bs-danger: #dc3545;
  --bs-danger-rgb: 220, 53, 69;
  --bs-secondary-color: #cbd5e1;
  --bs-border-color: rgba(255, 255, 255, 0.07);
  --bs-border-color-translucent: rgba(255, 255, 255, 0.08);
  --bs-mode: #1b1e21;
  --bs-breadcrumb-divider-color: var(--bs-danger);
}

[data-bs-theme="dark"] .bg-white {
  background-color: var(--bs-dark) !important;
}

[data-bs-theme="dark"] .text-muted {
  color: var(--bs-gray-600) !important;
}

[data-bs-theme="dark"] .card {
  --bs-card-cap-bg: var(--bs-mode);
  --bs-card-bg: var(--bs-mode);
}

[data-bs-theme="dark"] .btn-white.active,
[data-bs-theme="dark"] .btn-white:active,
[data-bs-theme="dark"] .btn-white:focus,
[data-bs-theme="dark"] .btn-white:hover {
  background: var(--bs-gray-800);
}

[data-bs-theme="dark"] .alert-light {
  --bs-alert-bg: var(--bs-gray-600);
  --bs-alert-border-color: var(--bs-gray-600);
}

[data-bs-theme="dark"] .btn-dark {
  --bs-btn-bg: var(--bs-dark) !important;
  --bs-btn-border-color: var(--bs-dark) !important;
}

[data-bs-theme="dark"] hr {
  color: var(--bs-gray-300);
}

[data-bs-theme="dark"] .modal {
  --bs-modal-bg: var(--bs-body-bg);
  --bs-modal-border-color: var(--bs-border-color-translucent);
  --bs-modal-footer-border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] .table-light {
  --bs-table-bg: var(--bs-light);
  --bs-table-color: var(--bs-gray-900);
}

[data-bs-theme="dark"] .offcanvas,
[data-bs-theme="dark"] .offcanvas-xxl,
[data-bs-theme="dark"] .offcanvas-xl,
[data-bs-theme="dark"] .offcanvas-lg,
[data-bs-theme="dark"] .offcanvas-md,
[data-bs-theme="dark"] .offcanvas-sm {
  --bs-offcanvas-bg: var(--bs-body-bg);
}

[data-bs-theme="dark"] .fill-primary {
  fill: var(--bs-primary) !important;
}

[data-bs-theme="dark"] h3,
[data-bs-theme="dark"] .h3 {
  color: var(--bs-white);
}

[data-bs-theme="dark"] .fill-secondary {
  fill: var(--bs-white) !important;
}

[data-bs-theme="dark"] .text-secondary {
  color: var(--bs-white) !important;
}

[data-bs-theme="dark"] .btn-outline-secondary {
  color: var(--bs-white) !important;
  border-color: var(--bs-white) !important;
}

[data-bs-theme="dark"] .text-gradient {
  background: linear-gradient(
    95.07deg,
    var(--bs-primary) -9.16%,
    var(--bs-white) 60.12%,
    rgba(var(--bs-primary-rgb), 0.9) 100.48%
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

[data-bs-theme="dark"] .fill-dark {
  fill: var(--bs-dark) !important;
}

[data-bs-theme="dark"] .text-dark {
  color: var(--bs-dark) !important;
}

[data-bs-theme="dark"] .bg-light {
  background-color: var(--bs-light) !important;
}

[data-bs-theme="dark"] .border-light {
  border-color: var(--bs-light) !important;
}

[data-bs-theme="dark"] .bg-body {
  background-color: var(--bs-body-bg) !important;
}

[data-bs-theme="dark"] .shadow,
[data-bs-theme="dark"] .shadow-lg,
[data-bs-theme="dark"] .shadow-sm {
  box-shadow: none !important;
}

[data-bs-theme="dark"] .btn-close {
  filter: invert(1) grayscale(100%) brightness(300%);
}

[data-bs-theme="dark"] .accordion.accordion-shadow .accordion-button {
  box-shadow: none;
  border: 1px solid var(--bs-gray-200);
}

[data-bs-theme="dark"] .choices .choices__list--dropdown {
  background: var(--bs-dark);
}

[data-bs-theme="dark"] .choices[data-type*="select-one"] .choices__input {
  background: var(--bs-dark);
}

[data-bs-theme="dark"] .dark-mode-switch .btn.active {
  background-color: var(--bs-body-bg) !important;
  border-color: var(--bs-body-bg) !important;
  color: var(--bs-gray);
  box-shadow: 0px 0px 40px rgba(29, 58, 83, 0.15);
}

[data-bs-theme="dark"] .dark-mode-item {
  display: inline-block !important;
}

[data-bs-theme="dark"] .light-mode-item {
  display: none !important;
}

/* Theme Switcher Buttons in Dark Mode */
[data-bs-theme="dark"] [data-theme-value="light"] svg.bi {
  color: #fbbf24;
}

[data-bs-theme="dark"] [data-theme-value="dark"] svg.bi {
  color: #818cf8;
}

[data-bs-theme="dark"] [data-theme-value][aria-pressed="true"] {
  background-color: var(--bs-gray-400);
  border-color: var(--bs-gray-500);
}

[data-bs-theme="dark"] .gradient-1,
[data-bs-theme="dark"] .gradient-2,
[data-bs-theme="dark"] .gradient-3,
[data-bs-theme="dark"] .gradient-4,
[data-bs-theme="dark"] .gradient-5,
[data-bs-theme="dark"] .gradient-6,
[data-bs-theme="dark"] .gradient-7,
[data-bs-theme="dark"] .gradient-8 {
  background:
    linear-gradient(to bottom, transparent 70%, #121212 100%),
    radial-gradient(112% 86% at 107% 98%, #2c2c2c 7%, transparent 76%),
    radial-gradient(
      305% 158% at -18% -2%,
      #333333 0%,
      #222222 17%,
      #2c2c2c 34%,
      #121212 52%
    );
  background-repeat: no-repeat;
}
/* MD Gradients */
--md-gradient: linear-gradient(180deg, rgba(0, 0, 0, 0.15), rgba(0, 0, 0, 0));
/* Adjust primary gradient for dark */
--md-gradient-primary: linear-gradient(
  108deg,
  #b33e5c 0%,
  /* Darker pink */ #d95f8c 20%,
  /* Brighter pink */ var(--md-primary) 50%,
  var(--md-primary) 70%,
  #ffae4a 100% /* Lighter orange end */
);
/* ----------------------------------- Dark Mode END  -------------------------- */
