/* ==========================================
   FLUID RESPONSIVE PADDING SYSTEM
   ========================================== */

:root {
  /* FOR 1120px DESKTOP (Elementor default) - CURRENTLY ACTIVE */
  --fluid-scale-sm: 0.8vw;   /* Typography-aligned scaling */
  --fluid-scale-md: 1.2vw;
  --fluid-scale-lg: 1.6vw;
  
  /* FOR 1440px DESKTOP (Wider layouts) - SWITCH TO THESE */
  /* --fluid-scale-sm: 0.62vw; */
  /* --fluid-scale-md: 0.93vw; */
  /* --fluid-scale-lg: 1.24vw; */
  
  /* ORIGINAL CONSERVATIVE VALUES */
  /* 1120px: 0.45vw, 0.89vw, 1.34vw */
  /* 1440px: 0.35vw, 0.69vw, 1.04vw */
}

/* ==========================================
   ALL SIDES PADDING
   ========================================== */
.pad-xs { padding: 1rem !important; }
.pad-s  { padding: clamp(1rem, 0.89rem + var(--fluid-scale-sm), 1.5rem)!important; }
.pad-m  { padding: clamp(1.5rem, 1.39rem + var(--fluid-scale-sm), 2rem)!important; }
.pad-l  { padding: clamp(2rem, 1.78rem + var(--fluid-scale-md), 3rem)!important; }
.pad-xl { padding: clamp(3rem, 2.67rem + var(--fluid-scale-lg), 4rem)!important; }

/* ==========================================
   VERTICAL PADDING
   ========================================== */
.pad-tb-s { padding: clamp(1.5rem, 1.28rem + var(--fluid-scale-md), 2.5rem) 0; }
.pad-tb-m { padding: clamp(4rem, 3.78rem + var(--fluid-scale-md), 5rem) 0; }
.pad-tb-l { padding: clamp(7rem, 6.78rem + var(--fluid-scale-md), 8rem) 0; }
.pad-tb-xl { padding: clamp(10rem, 9.78rem + var(--fluid-scale-lg), 12rem) 0; }


/* ==========================================
   HORIZONTAL PADDING
   ========================================== */
.pad-lr-s { padding: 0 clamp(1rem, 0.89rem + var(--fluid-scale-sm), 1.5rem); }
.pad-lr-m { padding: 0 clamp(1.5rem, 1.39rem + var(--fluid-scale-sm), 2rem); }
.pad-lr-l { padding: 0 clamp(2rem, 1.78rem + var(--fluid-scale-md), 3rem); }
.pad-lr-xl { padding: 0 clamp(3rem, 2.67rem + var(--fluid-scale-lg), 4rem); }


/* ==========================================
   DIRECTIONAL PADDING
   ========================================== */
/* Top */
.pad-t-s { padding-top: clamp(1.5rem, 1.28rem + var(--fluid-scale-md), 2.5rem); }
.pad-t-m { padding-top: clamp(4rem, 3.78rem + var(--fluid-scale-md), 5rem); }
.pad-t-l { padding-top: clamp(7rem, 6.78rem + var(--fluid-scale-md), 8rem); }
.pad-t-xl { padding-top: clamp(10rem, 9.78rem + var(--fluid-scale-lg), 12rem); }


/* Bottom */
.pad-b-s { padding-bottom: clamp(1.5rem, 1.28rem + var(--fluid-scale-md), 2.5rem); }
.pad-b-m { padding-bottom: clamp(4rem, 3.78rem + var(--fluid-scale-md), 5rem); }
.pad-b-l { padding-bottom: clamp(7rem, 6.78rem + var(--fluid-scale-md), 8rem); }
.pad-b-xl { padding-bottom: clamp(10rem, 9.78rem + var(--fluid-scale-lg), 12rem); }


/* Left */
.pad-l-s { padding-left: clamp(1rem, 0.89rem + var(--fluid-scale-sm), 1.5rem); }
.pad-l-m { padding-left: clamp(1.5rem, 1.39rem + var(--fluid-scale-sm), 2rem); }
.pad-l-l { padding-left: clamp(2rem, 1.78rem + var(--fluid-scale-md), 3rem); }
.pad-l-xl { padding-left: clamp(3rem, 2.67rem + var(--fluid-scale-lg), 4rem); }


/* Right */
.pad-r-s { padding-right: clamp(1rem, 0.89rem + var(--fluid-scale-sm), 1.5rem); }
.pad-r-m { padding-right: clamp(1.5rem, 1.39rem + var(--fluid-scale-sm), 2rem); }
.pad-r-l { padding-right: clamp(2rem, 1.78rem + var(--fluid-scale-md), 3rem); }
.pad-r-xl { padding-right: clamp(3rem, 2.67rem + var(--fluid-scale-lg), 4rem); }

/* ==========================================
   BUTTON SYSTEM
   ========================================== */

/* Base Animation */
.elementor-button {
  transition: transform 0.3s ease, filter 0.4s ease, background-color 0.3s ease, color 0.3s ease, box-shadow 0.3s ease;
}

.elementor-button:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.1);
  /* filter: brightness(95%); */
}

/* ==========================================
   BUTTON SIZES
   ========================================== */
.button-small .elementor-button {
  font-size: 0.875rem !important;
  padding: 8px 24px !important;
  border-radius: 6px !important;
}

.button-large .elementor-button {
  font-size: 1.125rem !important;
  padding: 16px 40px !important;
  border-radius: 10px !important;
}

/* ==========================================
   BUTTON VARIANTS - PRIMARY (YELLOW)
   ========================================== */

/* Primary Outlined */
.button-outlined .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-primary) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-primary) !important;
}

.button-outlined .elementor-button:hover {
  background-color: var(--e-global-color-primary) !important;
  color: var(--e-global-color-text) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-primary) !important;
}

/* Primary Text */
.button-text .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-primary) !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0px!important;
  text-decoration: underline !important;
}

.button-text .elementor-button:hover {
  background-color: transparent !important;
  color: var(--e-global-color-primary_dark) !important;
}

/* ==========================================
   BUTTON VARIANTS - SECONDARY (BLUE)
   ========================================== */

/* Secondary Filled */
.button-secondary .elementor-button {
  background-color: var(--e-global-color-secondary) !important;
  color: var(--e-global-color-white) !important;
  border: none !important;
}

.button-secondary .elementor-button:hover {
  background-color: var(--e-global-color-accent) !important;
  color: var(--e-global-color-white) !important;
}

/* Secondary Outlined */
.button-secondary-outlined .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-secondary) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-secondary) !important;
}

.button-secondary-outlined .elementor-button:hover {
  background-color: var(--e-global-color-secondary) !important;
  color: var(--e-global-color-white) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-secondary) !important;
}

/* Secondary Text */
.button-secondary-text .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-secondary) !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0px!important;
  text-decoration: underline !important;
}

.button-secondary-text .elementor-button:hover {
  background-color: transparent !important;
  color: var(--e-global-color-accent) !important;
}

/* ==========================================
   BUTTON VARIANTS - BLACK
   ========================================== */

/* Black Filled */
.button-black .elementor-button {
  background-color: var(--e-global-color-text) !important;
  color: var(--e-global-color-white) !important;
  border: none !important;
}

.button-black .elementor-button:hover {
  background-color: var(--e-global-color-headings) !important;
  color: var(--e-global-color-white) !important;
}

/* Black Outlined */
.button-black-outlined .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-text) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-text) !important;
}

.button-black-outlined .elementor-button:hover {
  background-color: var(--e-global-color-text) !important;
  color: var(--e-global-color-white) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-text) !important;
}

/* Black Text */
.button-black-text .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-text) !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0px!important;
  text-decoration: underline !important;
}

.button-black-text .elementor-button:hover {
  background-color: transparent !important;
  color: var(--e-global-color-headings) !important;
}

/* ==========================================
   BUTTON VARIANTS - WHITE (FOR DARK BACKGROUNDS)
   ========================================== */

/* White Filled */
.button-white .elementor-button {
  background-color: var(--e-global-color-white) !important;
  color: var(--e-global-color-text) !important;
  border: none !important;
}

.button-white .elementor-button:hover {
  background-color: var(--e-global-color-subtle) !important;
  color: var(--e-global-color-text) !important;
}

/* White Outlined */
.button-white-outlined .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-white) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-white) !important;
}

.button-white-outlined .elementor-button:hover {
  background-color: var(--e-global-color-white) !important;
  color: var(--e-global-color-text) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-white) !important;
}

/* White Text */
.button-white-text .elementor-button {
  background-color: transparent !important;
  color: var(--e-global-color-white) !important;
  box-shadow: none !important;
  border: none !important;
  padding: 0px!important;
  text-decoration: underline !important;
}

.button-white-text .elementor-button:hover {
  background-color: transparent !important;
  color: rgba(255, 255, 255, 0.8) !important;
}

/* ==========================================
   GLOBAL GRADIENT UTILITIES
   ========================================== */

/* Blue Gradient Background */
.blue-gradient {
  background: linear-gradient(180deg, var(--e-global-color-secondary) 0%, var(--e-global-color-accent) 100%) !important;
}

/* ==========================================
   MISC
   ========================================== */

/* Font Weight Utilities */
.text-regular {
  font-weight: var(--e-global-typography-body-font-weight) !important; /* 400 */
}

.text-medium {
  font-weight: 500 !important;
}

.text-bold {
  font-weight: 700!important;
}

.text-extra-bold {
  font-weight: var(--e-global-typography-display-font-weight) !important; /* 800 */
}

/* Text Transform Utility */
.text-uppercase {
  text-transform: uppercase !important;
}



/* ==========================================
   COOKIEYES INTEGRATION
   ========================================== */

/* General Elements */
.cky-accordion-header .cky-always-active {
  color: var(--e-global-color-primary) !important;
}

.cky-consent-container .cky-consent-bar {
  box-shadow: none !important;
}

.cky-title {
  display: none !important;
}

div[data-cky-tag="detail-powered-by"] {
  display: none !important;
}

/* Typography Integration */
.cky-btn {
  padding: 12px 32px !important;
  font-size: var(--e-global-typography-button-font-size) !important;
  font-family: var(--e-global-typography-button-font-family) !important;
  font-weight: var(--e-global-typography-button-font-weight) !important;
  line-height: var(--e-global-typography-button-line-height) !important;
}

.cky-notice-des p:last-child {
  font-size: var(--e-global-typography-body-font-size) !important;
  font-family: var(--e-global-typography-body-font-family) !important;
  line-height: var(--e-global-typography-body-line-height) !important;
}

.cky-policy {
  font-size: var(--e-global-typography-body-font-size) !important;
  font-family: var(--e-global-typography-body-font-family) !important;
  color: var(--e-global-color-body_text) !important;
  text-decoration: none !important;
}

/* Accept Button Styling - Override inline styles with high specificity */
button.cky-btn.cky-btn-accept[data-cky-tag="accept-button"],
button.cky-btn.cky-btn-accept[data-cky-tag="detail-accept-button"] {
  background-color: var(--e-global-color-primary) !important;
  border-color: var(--e-global-color-primary) !important;
  color: var(--e-global-color-text) !important;
  border: none !important;
}

button.cky-btn.cky-btn-accept[data-cky-tag="accept-button"]:hover,
button.cky-btn.cky-btn-accept[data-cky-tag="detail-accept-button"]:hover {
  background-color: var(--e-global-color-primary_dark) !important;
  border-color: var(--e-global-color-primary_dark) !important;
  color: var(--e-global-color-text) !important;
}

/* Outlined Buttons - Reject, Customize, Preferences */
button.cky-btn.cky-btn-reject,
button.cky-btn.cky-btn-customize,
button.cky-btn.cky-btn-preferences {
  background-color: transparent !important;
  color: var(--e-global-color-primary) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-primary) !important;
  border: none !important;
}

button.cky-btn.cky-btn-reject:hover,
button.cky-btn.cky-btn-customize:hover,
button.cky-btn.cky-btn-preferences:hover {
  background-color: var(--e-global-color-primary) !important;
  color: var(--e-global-color-text) !important;
  box-shadow: inset 0px 0px 0px 2px var(--e-global-color-primary) !important;
}

/* Other Interactive Elements */
button.cky-show-desc-btn:not(:hover):not(:active) {
  color: var(--e-global-color-primary) !important;
}

.cky-show-desc-btn:hover,
.cky-show-desc-btn:focus {
  border-style: none !important;
  color: var(--e-global-color-primary) !important;
  border-width: 0px !important;
}

.cky-btn-close:focus,
.cky-btn-close:hover,
.cky-btn-revisit,
.cky-btn-revisit:hover {
  border-style: none !important;
  background-color: transparent !important;
}

.cky-accordion-btn:hover {
  background-color: transparent !important;
}

.cky-accordion-btn:focus,
.cky-accordion-btn:hover {
  border-style: none !important;
}

.cky-modal.cky-modal-open button:not(.cky-btn-accept):hover {
  background: transparent !important;
  color: var(--e-global-color-primary) !important;
}

.cky-policy:hover {
  color: var(--e-global-color-primary) !important;
}

.cky-revisit-bottom-left:hover::before {
  background: var(--e-global-color-secondary) !important;
}

.cky-revisit-bottom-left:hover::after {
  border-right-color: var(--e-global-color-secondary) !important;
}

.cky-btn-revisit-wrapper {
background-color: var(--e-global-color-secondary)!important;
display:none!important;
}

/* Checkbox Styling */
.cky-switch input[type="checkbox"]:checked {
  background: var(--e-global-color-primary) !important;
}

body .cky-switch input[type="checkbox"] {
  position: relative;
  width: 44px;
  height: 24px;
  margin: 0;
  background: #d0d5d2;
  -webkit-appearance: none;
  border-radius: 50px;
  cursor: pointer;
  outline: 0;
  border: none !important;
  border-style: none !important;
  border-width: 0 !important;
  top: 0;
}

body .cky-switch input[type="checkbox"]:checked {
  background: var(--e-global-color-primary) !important;
}