@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;0,500;0,700;0,900;1,300;1,400;1,500;1,700;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');
@import url("//fa672.pages.dev/css/all.min.css");

/*!
 * IonicNet CSS Framework v1.0
 * Lightweight grid and utility framework
 */

/*
Breakpoints Reference:
Extra small  None   <576px
Small        sm     ≥576px
Medium       md     ≥768px
Large        lg     ≥992px
Extra large  xl     ≥1200px
XXL          xxl    ≥1400px

Spacing Scale:
0 = 0
1 = 0.25rem (2.5px)
2 = 0.5rem (5px)
3 = 1rem (10px)
4 = 1.5rem (15px)
5 = 3rem (30px)

REM Conversion:
With html font-size: 62.5%, 1rem = 10px
So 1.6rem = 16px, 2.4rem = 24px, etc.
*/

/* ===================================
   CSS VARIABLES (Customize Here!)
   =================================== */
:root {
  /* Spacing Scale */
  --ion-spacing-0: 0;
  --ion-spacing-1: 0.5rem;
  --ion-spacing-2: 1rem;
  --ion-spacing-3: 1.5rem;
  --ion-spacing-4: 2rem;
  --ion-spacing-5: 3rem;
  --ion-spacing-6: 4rem;
  --ion-spacing-7: 5rem;
  --ion-spacing-8: 6rem;
   --ion-spacing-9: 7rem;
  --ion-spacing-10: 8rem;
  --ion-spacing-11: 9rem;
 --ion-spacing-10: 10rem;
 
  /* Grid Gutters */
  --ion-gutter-x: 1.5rem;
  --ion-gutter-y: 0;
  
  /* Container Max Widths */
  --ion-container-sm: 94%;
  --ion-container-md: 94%;
  --ion-container-lg: 96.8%;
  --ion-container-xl: 95%;
  --ion-container-xxl: 86%;
  --ion-container-1500: 1400px;
  --ion-container-1700: 1685px;
  
  /* Color Palette */
   --ion-blue: #0d6efd;
  --ion-indigo: #6610f2;
  --ion-purple: #6f42c1;
  --ion-pink: #d63384;
  --ion-red: #dc3545;
  --ion-orange: #fd7e14;
  --ion-yellow: #ffc107;
  --ion-green: #198754;
  --ion-teal: #20c997;
  --ion-cyan: #0dcaf0;
  --ion-black: #000;
  --ion-white: #fff;
  --ion-gray: #6c757d;
  --ion-gray-dark: #343a40;
  --ion-gray-100: #f8f9fa;
  --ion-gray-200: #e9ecef;
  --ion-gray-300: #dee2e6;
  --ion-gray-400: #ced4da;
  --ion-gray-500: #adb5bd;
  --ion-gray-600: #6c757d;
  --ion-gray-700: #495057;
  --ion-gray-800: #343a40;
  --ion-gray-900: #212529;
  --ion-primary: #0d6efd;
  --ion-secondary: #6c757d;
  --ion-success: #198754;
  --ion-info: #0dcaf0;
  --ion-warning: #ffc107;
  --ion-danger: #dc3545;
  --ion-light: #f8f9fa;
  --ion-dark: #212529;
  --ion-primary-rgb: 13, 110, 253;
  --ion-secondary-rgb: 108, 117, 125;
  --ion-success-rgb: 25, 135, 84;
  --ion-info-rgb: 13, 202, 240;
  --ion-warning-rgb: 255, 193, 7;
  --ion-danger-rgb: 220, 53, 69;
  --ion-light-rgb: 248, 249, 250;
  --ion-dark-rgb: 33, 37, 41;
  --ion-primary-text-emphasis: #052c65;
  --ion-secondary-text-emphasis: #2b2f32;
  --ion-success-text-emphasis: #0a3622;
  --ion-info-text-emphasis: #055160;
  --ion-warning-text-emphasis: #664d03;
  --ion-danger-text-emphasis: #58151c;
  --ion-light-text-emphasis: #495057;
  --ion-dark-text-emphasis: #495057;
  --ion-primary-bg-subtle: #cfe2ff;
  --ion-secondary-bg-subtle: #e2e3e5;
  --ion-success-bg-subtle: #d1e7dd;
  --ion-info-bg-subtle: #cff4fc;
  --ion-warning-bg-subtle: #fff3cd;
  --ion-danger-bg-subtle: #f8d7da;
  --ion-light-bg-subtle: #fcfcfd;
  --ion-dark-bg-subtle: #ced4da;
  --ion-primary-border-subtle: #9ec5fe;
  --ion-secondary-border-subtle: #c4c8cb;
  --ion-success-border-subtle: #a3cfbb;
  --ion-info-border-subtle: #9eeaf9;
  --ion-warning-border-subtle: #ffe69c;
  --ion-danger-border-subtle: #f1aeb5;
  --ion-light-border-subtle: #e9ecef;
  --ion-dark-border-subtle: #adb5bd;
  --ion-white-rgb: 255, 255, 255;
  --ion-black-rgb: 0, 0, 0;
  --ion-gradient: linear-gradient(180deg, rgba(255, 255, 255, 0.15), rgba(255, 255, 255, 0));
  --ion-body-font-family: var(--ion-font-sans-serif);
  --ion-body-font-size: 1rem;
  --ion-body-font-weight: 400;
  --ion-body-line-height: 1.5;
  --ion-body-color: #212529;
  --ion-body-color-rgb: 33, 37, 41;
  --ion-body-bg: #fff;
  --ion-body-bg-rgb: 255, 255, 255;
  --ion-emphasis-color: #000;
  --ion-emphasis-color-rgb: 0, 0, 0;
  --ion-secondary-color: rgba(33, 37, 41, 0.75);
  --ion-secondary-color-rgb: 33, 37, 41;
  --ion-secondary-bg: #e9ecef;
  --ion-secondary-bg-rgb: 233, 236, 239;
  --ion-tertiary-color: rgba(33, 37, 41, 0.5);
  --ion-tertiary-color-rgb: 33, 37, 41;
  --ion-tertiary-bg: #f8f9fa;
  --ion-tertiary-bg-rgb: 248, 249, 250;
  --ion-heading-color: inherit;
  --ion-link-color: #0d6efd;
  --ion-link-color-rgb: 13, 110, 253;
  --ion-link-decoration: underline;
  --ion-link-hover-color: #0a58ca;
  --ion-link-hover-color-rgb: 10, 88, 202;
  --ion-code-color: #d63384;
  --ion-highlight-color: #212529;
  --ion-highlight-bg: #fff3cd;
  --ion-border-width: 1px;
  --ion-border-style: solid;
  --ion-border-color: #ccc;
  --ion-border-color-translucent: rgba(0, 0, 0, 0.175);
  --ion-border-radius: 0.375rem;
  --ion-border-radius-sm: 0.25rem;
  --ion-border-radius-lg: 0.5rem;
  --ion-border-radius-xl: 1rem;
  --ion-border-radius-xxl: 2rem;
  --ion-border-radius-2xl: var(--ion-border-radius-xxl);
  --ion-border-radius-pill: 50rem;
  --ion-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.15);
  --ion-box-shadow-sm: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.075);
  --ion-box-shadow-lg: 0 1rem 3rem rgba(0, 0, 0, 0.175);
  --ion-box-shadow-inset: inset 0 1px 2px rgba(0, 0, 0, 0.075);
  --ion-focus-ring-width: 0.25rem;
  --ion-focus-ring-opacity: 0.25;
  --ion-focus-ring-color: rgba(13, 110, 253, 0.25);
  --ion-form-valid-color: #198754;
  --ion-form-valid-border-color: #198754;
  --ion-form-invalid-color: #dc3545;
  --ion-form-invalid-border-color: #dc3545;
  --ion-color-primary: #005BA8;
  --ion-color-secondary: #FBD010;
  --ion-color-dark: #231F20;
  --ion-color-light: #ffffff;
  --ion-color-gray:#F6F6F6;
  --ion-color-royal:#2E3192;
  --ion-color-light-green:#83CEC5;
  /* Focus Ring (Accessibility) */
  --ion-focus-ring-color: #005BA8;
  --ion-focus-ring-width: 3px;
  --ion-focus-ring-offset: 2px;
  
  /* Button - Primary */
  --ion-btn-primary-bg: #005BA8;
  --ion-btn-primary-color: #fff;
  --ion-btn-primary-hover-bg: #FBD010;
  --ion-btn-primary-hover-color: #000;
  
  /* Button - Secondary */
  --ion-btn-secondary-bg: #FBD010;
  --ion-btn-secondary-color: #000;
  --ion-btn-secondary-hover-bg: #e5be0a;
  --ion-btn-secondary-hover-color: #000;
  
  /* Button - Tertiary */
  --ion-btn-tertiary-bg: #C94E28;
  --ion-btn-tertiary-color: #fff;
  --ion-btn-tertiary-hover-bg: #002581;
  --ion-btn-tertiary-hover-color: #fff;
  
  /* Button Sizing */
  --ion-btn-padding-y: 0.8rem;
  --ion-btn-padding-x: 2rem;
  --ion-btn-font-size: 1.6rem;
  --ion-btn-border-radius: 3rem;
  
  /* Body Defaults */
  --ion-body-color: #231F20;
  --ion-body-font-size: 1.6rem;
  --ion-body-line-height: 1.6;
  --ion-body-font-family: 'Roboto', sans-serif;
 /* headings */
   --ion-page-heading-color:#022873;
   --ion-default-heading-color:#231F20;
 
}

/* ===================================
   RESET & DEFAULTS
   =================================== */
*, *:after, *:before { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
html { box-sizing: border-box; font-size: 62.5%; text-rendering: optimizeLegibility; -ms-text-size-adjust: 100%; -webkit-text-size-adjust: 100%; }
body { color:#231F20; font-family: "inter", sans-serif; font-size: 1.6em; line-height: 1.6; font-weight: 400; margin: 0; padding: 0; background: #FEFEFE }

/* ===================================
   ACCESSIBILITY UTILITIES
   =================================== */
/* Screen Reader Only */
.ion-sr-only,
.sr-only,
.sr-only-focusable:not(:focus):not(:focus-within) {
  position: absolute !important;
  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;
}

/* Accessible Element (Skip Links, etc) */
.accessible_elem {
  clip: rect(1px 1px 1px 1px); /* IE 6/7 */
  clip: rect(1px, 1px, 1px, 1px);
  height: 1px;
  overflow: hidden;
  position: absolute;
  word-wrap: normal !important;
  word-break: normal;
  white-space: nowrap;
  width: 1px;
}

.accessible_elem:focus {
  background-color: #f1f1f1;
  border-radius: 3px;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
  clip: auto !important;
  -webkit-clip-path: none;
  clip-path: none;
  color: #21759b;
  display: block;
  font-weight: 700;
  height: auto;
  right: 5px;
  line-height: normal;
  padding: 15px 23px 14px;
  text-decoration: none;
  top: 5px;
  width: auto;
  z-index: 100000;
}

/* Skip Link */
.skip a {
  position: absolute;
  left: -10000px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}

.skip a:focus {
  position: static;
  width: auto;
  height: auto;
}

h1,.h1, h2,.h2, h3,.h3, h4,.h4, h5,.h5, h6,.h6 { margin-top: 0; margin-bottom: 1rem; font-weight: 400; letter-spacing: normal !important; text-rendering: optimizeLegibility;line-height: 1.3; color: var(--ion-default-heading-color) }
h1,.h1{font-size:3rem}
h2,.h2{font-size:2.6rem}
h3,.h3{font-size:2.2rem}
h4,.h4{font-size:1.8rem}
h5,.h5{font-size:1.6rem}
h6,.h6{font-size:1.5rem}
@media (max-width:680px) {
h1,.h1, h2,.h2, h3,.h3, h4,.h4, h5,.h5, h6,.h6 { margin-bottom: .5rem; }
}
.article_heading { margin-bottom:3rem;}
.article_heading h1 { margin-bottom:0rem; font-weight:500; font-size: clamp(2.4rem, 1.8rem + 2.5vw, 4rem); color: var(--ion-page-heading-color) }
/* ===================================
   FOCUS UTILITIES
   =================================== */
/* Default focus ring for all interactive elements */
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible,
[tabindex]:focus-visible {
  outline: 2px solid #000; 
  outline-offset: 2px;
  background-color: #FFF3CD;
  color: #000;
}
/* Remove default focus for mouse clicks */
a:focus:not(:focus-visible),
button:focus:not(:focus-visible),
input:focus:not(:focus-visible),
textarea:focus:not(:focus-visible),
select:focus:not(:focus-visible),
[tabindex]:focus:not(:focus-visible) {
  outline: none;
}
/* Custom focus class */
.ion-focus-ring:focus {
  outline: var(--ion-focus-ring-width) solid var(--ion-focus-ring-color);
  outline-offset: var(--ion-focus-ring-offset);
}

/* Remove focus for mouse users (keeps it for keyboard) */
.ion-focus-ring:focus:not(:focus-visible) {

}

/* ===================================
   SITE WRAPPER
   =================================== */
.ion-wrapper {
  display: flex;
  flex-direction: column;
  position: relative;
  width: 100%;
  min-height: 100vh;
}

/* ===================================
   SEMANTIC HTML5 ELEMENTS
   =================================== */
main {
  display: block;
  position: relative;
  flex: 1 0 auto;
}

article {
  display: block;
  position: relative;
 margin-bottom:7rem;padding-top: 2rem
}

header {
  display: block;
  position: relative;
}

footer {
  display: block;
  position: relative;
}

section {
  display: block;
  position: relative;
}

nav {
  display: block;
  position: relative;
}

aside {
  display: block;
  position: relative;
}
table {
  caption-side: bottom;
  border-collapse: collapse;
 width: 100%; margin-top: 2rem
}
tbody, td, tfoot, th, thead, tr {
    border-color: inherit;
    border-style: solid;
    border-width: 0;
 text-align: left;
}
thead{    background: #CFEADD;
    border-bottom: .2rem solid white; }
p { margin: 0 0 1.5rem; }
img,svg {vertical-align: middle;line-height: 0;display: inline-block; }
img { max-width: 100%; height: auto}
/* Links */
a { color:#0E74B2; }
a:hover { color:#2E3192; text-decoration: none; }
a img { border: none; line-height: 0; }
.disabled1 a:first-child, a.disabled { pointer-events: none; }
hr { padding-top: 1rem; margin-bottom: 2rem; margin-top: 0; border-width: 0; border-bottom: 1px solid #D6D6D6; box-sizing: content-box; ; display: block; overflow: hidden; clear: both }
b, strong { font-weight:600; }
.uppercase { text-transform: uppercase; }
.odd_row .columns { margin: 0 }
.odd_row .columns:first-child { float: right; margin-left: 4% }
figure { margin: 0; overflow: hidden; position: relative; }
iframe{display: block;}
:target {scroll-margin-top:150px;}
.gotohome{cursor: pointer}
/* Lists */
ul { padding-left: 0; margin-top: 0; margin-left:2rem; list-style-type: disc; margin-bottom: 1.5rem }
ul ul{list-style-type: circle; margin-bottom: 0 }
li { margin-bottom: 0;  }
ol { margin-bottom: 20px; list-style-type: decimal; list-style-position:outside; padding-left: 2rem; margin-left:1rem}
ol li {  margin-bottom: 5px; }
ol ol{margin-top: .5rem !important; margin-bottom: .5rem !important}
ol.letters, ol[type="a"]{list-style-type:lower-alpha}
ol li ol{list-style-type:lower-alpha}
ol li ol li ol, ol[type="i"] {list-style-type: lower-roman !important}
ol ol, ol ul, ul ol, ul ul {margin-bottom: 0}
article li{margin-bottom:.5rem}
article li:last-child{margin-bottom: 0}

ul.columns2 { -webkit-columns: 2; -moz-columns: 2; columns: 2; line-height: 2.6rem; margin-top: 15px; }
ul.columns3 { -webkit-columns: 3; -moz-columns: 3; columns: 3; line-height: 2.6rem; margin-top: 15px; }
ul.columns4 { -webkit-columns: 4; -moz-columns: 4; columns: 4; line-height: 2.6rem; margin-top: 15px; }
@media (max-width:1072px) {
ul.columns4 { -webkit-columns: 3; -moz-columns: 3; columns: 3; }
}
@media (max-width:820px) {
ul.columns3 { -webkit-columns: 2; -moz-columns: 2; columns: 2; }
ul.columns4 { -webkit-columns: 2; -moz-columns: 2; columns: 2; }
}
@media (max-width:400px) {
ul.columns2, ul.columns3, ul.columns4 { -webkit-columns: 1; -moz-columns: 1; columns: 1; }
}

/* ===================================
   CONTAINER SYSTEM
   =================================== */
.ion-container,
.ion-container-fluid,
.ion-container-sm,
.ion-container-md,
.ion-container-lg,
.ion-container-xl,
.ion-container-xxl {
  width: 100%;
  padding-right: 0.75rem;
  padding-left: 0.75rem;
  margin-right: auto;
  margin-left: auto;
}

/* Container Max Widths */
@media (min-width: 576px) {
  .ion-container-sm, 
  .ion-container {
    max-width: var(--ion-container-sm);
  }
}

@media (min-width: 768px) {
  .ion-container-md,
  .ion-container-sm,
  .ion-container {
    max-width: var(--ion-container-md);
  }
}

@media (min-width: 992px) {
  .ion-container-lg,
  .ion-container-md,
  .ion-container-sm,
  .ion-container {
    max-width: var(--ion-container-lg);
  }
}

@media (min-width: 1200px) {
  .ion-container-xl,
  .ion-container-lg,
  .ion-container-md,
  .ion-container-sm,
  .ion-container {
    max-width: var(--ion-container-xl);
  }
}

@media (min-width: 1400px) {
  .ion-container-xxl,
  .ion-container-xl,
  .ion-container-lg,
  .ion-container-md,
  .ion-container-sm,
  .ion-container {
    max-width: var(--ion-container-xxl);
  }
}

@media (min-width: 1500px) {
  .ion-container {
    max-width: var(--ion-container-1500);
  }
}

@media (min-width: 1700px) {
  .ion-container {
    max-width: var(--ion-container-1700);
  }
}

/* ===================================
   ROW SYSTEM
   =================================== */
.ion-row {
  --ion-gutter-x: 1.5rem;
  --ion-gutter-y: 0;
  display: flex;
  flex-wrap: wrap;
  margin-right: calc(var(--ion-gutter-x) * -0.5);
  margin-left: calc(var(--ion-gutter-x) * -0.5);
  margin-top: calc(var(--ion-gutter-y) * -1);
}

.ion-row > * {
  flex-shrink: 0;
  width: 100%;
  max-width: 100%;
  padding-right: calc(var(--ion-gutter-x) * 0.5);
  padding-left: calc(var(--ion-gutter-x) * 0.5);
  margin-top: var(--ion-gutter-y);
}

/* ===================================
   COLUMN SYSTEM - BASE
   =================================== */
.ion-col {
  flex: 1 0 0;
}

.ion-col-auto {flex: 0 0 auto;width: auto;}
.ion-col-1 { flex: 0 0 auto; width: 8.33333333%; }
.ion-col-2 { flex: 0 0 auto; width: 16.66666667%; }
.ion-col-3 { flex: 0 0 auto; width: 25%; }
.ion-col-4 { flex: 0 0 auto; width: 33.33333333%; }
.ion-col-5 { flex: 0 0 auto; width: 41.66666667%; }
.ion-col-6 { flex: 0 0 auto; width: 50%; }
.ion-col-7 { flex: 0 0 auto; width: 58.33333333%; }
.ion-col-8 { flex: 0 0 auto; width: 66.66666667%; }
.ion-col-9 { flex: 0 0 auto; width: 75%; }
.ion-col-10 { flex: 0 0 auto; width: 83.33333333%; }
.ion-col-11 { flex: 0 0 auto; width: 91.66666667%; }
.ion-col-12 { flex: 0 0 auto; width: 100%; }

/* ===================================
   COLUMN SYSTEM - SMALL (≥576px)
   =================================== */
@media (min-width: 576px) {
  .ion-col-sm { flex: 1 0 0; }
  .ion-col-sm-auto { flex: 0 0 auto; width: auto; }
  .ion-col-sm-1 { flex: 0 0 auto; width: 8.33333333%; }
  .ion-col-sm-2 { flex: 0 0 auto; width: 16.66666667%; }
  .ion-col-sm-3 { flex: 0 0 auto; width: 25%; }
  .ion-col-sm-4 { flex: 0 0 auto; width: 33.33333333%; }
  .ion-col-sm-5 { flex: 0 0 auto; width: 41.66666667%; }
  .ion-col-sm-6 { flex: 0 0 auto; width: 50%; }
  .ion-col-sm-7 { flex: 0 0 auto; width: 58.33333333%; }
  .ion-col-sm-8 { flex: 0 0 auto; width: 66.66666667%; }
  .ion-col-sm-9 { flex: 0 0 auto; width: 75%; }
  .ion-col-sm-10 { flex: 0 0 auto; width: 83.33333333%; }
  .ion-col-sm-11 { flex: 0 0 auto; width: 91.66666667%; }
  .ion-col-sm-12 { flex: 0 0 auto; width: 100%; }
}

/* ===================================
   COLUMN SYSTEM - MEDIUM (≥768px)
   =================================== */
@media (min-width: 768px) {
  .ion-col-md { flex: 1 0 0; }
  .ion-col-md-auto { flex: 0 0 auto; width: auto; }
  .ion-col-md-1 { flex: 0 0 auto; width: 8.33333333%; }
  .ion-col-md-2 { flex: 0 0 auto; width: 16.66666667%; }
  .ion-col-md-3 { flex: 0 0 auto; width: 25%; }
  .ion-col-md-4 { flex: 0 0 auto; width: 33.33333333%; }
  .ion-col-md-5 { flex: 0 0 auto; width: 41.66666667%; }
  .ion-col-md-6 { flex: 0 0 auto; width: 50%; }
  .ion-col-md-7 { flex: 0 0 auto; width: 58.33333333%; }
  .ion-col-md-8 { flex: 0 0 auto; width: 66.66666667%; }
  .ion-col-md-9 { flex: 0 0 auto; width: 75%; }
  .ion-col-md-10 { flex: 0 0 auto; width: 83.33333333%; }
  .ion-col-md-11 { flex: 0 0 auto; width: 91.66666667%; }
  .ion-col-md-12 { flex: 0 0 auto; width: 100%; }
}

/* ===================================
   COLUMN SYSTEM - LARGE (≥992px)
   =================================== */
@media (min-width: 992px) {
  .ion-col-lg { flex: 1 0 0; }
  .ion-col-lg-auto { flex: 0 0 auto; width: auto; }
  .ion-col-lg-1 { flex: 0 0 auto; width: 8.33333333%; }
  .ion-col-lg-2 { flex: 0 0 auto; width: 16.66666667%; }
  .ion-col-lg-3 { flex: 0 0 auto; width: 25%; }
  .ion-col-lg-4 { flex: 0 0 auto; width: 33.33333333%; }
  .ion-col-lg-5 { flex: 0 0 auto; width: 41.66666667%; }
  .ion-col-lg-6 { flex: 0 0 auto; width: 50%; }
  .ion-col-lg-7 { flex: 0 0 auto; width: 58.33333333%; }
  .ion-col-lg-8 { flex: 0 0 auto; width: 66.66666667%; }
  .ion-col-lg-9 { flex: 0 0 auto; width: 75%; }
  .ion-col-lg-10 { flex: 0 0 auto; width: 83.33333333%; }
  .ion-col-lg-11 { flex: 0 0 auto; width: 91.66666667%; }
  .ion-col-lg-12 { flex: 0 0 auto; width: 100%; }
}

/* ===================================
   COLUMN SYSTEM - EXTRA LARGE (≥1200px)
   =================================== */
@media (min-width: 1200px) {
  .ion-col-xl { flex: 1 0 0; }
  .ion-col-xl-auto { flex: 0 0 auto; width: auto; }
  .ion-col-xl-1 { flex: 0 0 auto; width: 8.33333333%; }
  .ion-col-xl-2 { flex: 0 0 auto; width: 16.66666667%; }
  .ion-col-xl-3 { flex: 0 0 auto; width: 25%; }
  .ion-col-xl-4 { flex: 0 0 auto; width: 33.33333333%; }
  .ion-col-xl-5 { flex: 0 0 auto; width: 41.66666667%; }
  .ion-col-xl-6 { flex: 0 0 auto; width: 50%; }
  .ion-col-xl-7 { flex: 0 0 auto; width: 58.33333333%; }
  .ion-col-xl-8 { flex: 0 0 auto; width: 66.66666667%; }
  .ion-col-xl-9 { flex: 0 0 auto; width: 75%; }
  .ion-col-xl-10 { flex: 0 0 auto; width: 83.33333333%; }
  .ion-col-xl-11 { flex: 0 0 auto; width: 91.66666667%; }
  .ion-col-xl-12 { flex: 0 0 auto; width: 100%; }
}

/* ===================================
   COLUMN SYSTEM - XXL (≥1400px)
   =================================== */
@media (min-width: 1400px) {
  .ion-col-xxl { flex: 1 0 0; }
  .ion-col-xxl-auto { flex: 0 0 auto; width: auto; }
  .ion-col-xxl-1 { flex: 0 0 auto; width: 8.33333333%; }
  .ion-col-xxl-2 { flex: 0 0 auto; width: 16.66666667%; }
  .ion-col-xxl-3 { flex: 0 0 auto; width: 25%; }
  .ion-col-xxl-4 { flex: 0 0 auto; width: 33.33333333%; }
  .ion-col-xxl-5 { flex: 0 0 auto; width: 41.66666667%; }
  .ion-col-xxl-6 { flex: 0 0 auto; width: 50%; }
  .ion-col-xxl-7 { flex: 0 0 auto; width: 58.33333333%; }
  .ion-col-xxl-8 { flex: 0 0 auto; width: 66.66666667%; }
  .ion-col-xxl-9 { flex: 0 0 auto; width: 75%; }
  .ion-col-xxl-10 { flex: 0 0 auto; width: 83.33333333%; }
  .ion-col-xxl-11 { flex: 0 0 auto; width: 91.66666667%; }
  .ion-col-xxl-12 { flex: 0 0 auto; width: 100%; }
}

/* ===================================
   PADDING UTILITIES
   =================================== */
/* Padding - All Sides */
.ion-p-0 { padding: var(--ion-spacing-0) !important; }
.ion-p-1 { padding: var(--ion-spacing-1) !important; }
.ion-p-2 { padding: var(--ion-spacing-2) !important; }
.ion-p-3 { padding: var(--ion-spacing-3) !important; }
.ion-p-4 { padding: var(--ion-spacing-4) !important; }
.ion-p-5 { padding: var(--ion-spacing-5) !important; }
.ion-p-6 { padding: var(--ion-spacing-6) !important; }
.ion-p-7 { padding: var(--ion-spacing-7) !important; }
.ion-p-8 { padding: var(--ion-spacing-8) !important; }
.ion-p-9 { padding: var(--ion-spacing-9) !important; }
.ion-p-10 { padding: var(--ion-spacing-10) !important; }
.ion-p-11 { padding: var(--ion-spacing-11) !important; }
.ion-p-12 { padding: var(--ion-spacing-12) !important; }

/* Padding - Horizontal */
.ion-px-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
.ion-px-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
.ion-px-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
.ion-px-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
.ion-px-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
.ion-px-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
.ion-px-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
.ion-px-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
.ion-px-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
.ion-px-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
.ion-px-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
.ion-px-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
.ion-px-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

/* Padding - Vertical */
.ion-py-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
.ion-py-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
.ion-py-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
.ion-py-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
.ion-py-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
.ion-py-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
.ion-py-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
.ion-py-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
.ion-py-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
.ion-py-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
.ion-py-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
.ion-py-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
.ion-py-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

/* Padding - Top */
.ion-pt-0 { padding-top: var(--ion-spacing-0) !important; }
.ion-pt-1 { padding-top: var(--ion-spacing-1) !important; }
.ion-pt-2 { padding-top: var(--ion-spacing-2) !important; }
.ion-pt-3 { padding-top: var(--ion-spacing-3) !important; }
.ion-pt-4 { padding-top: var(--ion-spacing-4) !important; }
.ion-pt-5 { padding-top: var(--ion-spacing-5) !important; }
.ion-pt-6 { padding-top: var(--ion-spacing-6) !important; }
.ion-pt-7 { padding-top: var(--ion-spacing-7) !important; }
.ion-pt-8 { padding-top: var(--ion-spacing-8) !important; }
.ion-pt-9 { padding-top: var(--ion-spacing-9) !important; }
.ion-pt-10 { padding-top: var(--ion-spacing-10) !important; }
.ion-pt-11 { padding-top: var(--ion-spacing-11) !important; }
.ion-pt-12 { padding-top: var(--ion-spacing-12) !important; }

/* Padding - End (Right in LTR) */
.ion-pe-0 { padding-right: var(--ion-spacing-0) !important; }
.ion-pe-1 { padding-right: var(--ion-spacing-1) !important; }
.ion-pe-2 { padding-right: var(--ion-spacing-2) !important; }
.ion-pe-3 { padding-right: var(--ion-spacing-3) !important; }
.ion-pe-4 { padding-right: var(--ion-spacing-4) !important; }
.ion-pe-5 { padding-right: var(--ion-spacing-5) !important; }
.ion-pe-6 { padding-right: var(--ion-spacing-6) !important; }
.ion-pe-7 { padding-right: var(--ion-spacing-7) !important; }
.ion-pe-8 { padding-right: var(--ion-spacing-8) !important; }
.ion-pe-9 { padding-right: var(--ion-spacing-9) !important; }
.ion-pe-10 { padding-right: var(--ion-spacing-10) !important; }
.ion-pe-11 { padding-right: var(--ion-spacing-11) !important; }
.ion-pe-12 { padding-right: var(--ion-spacing-12) !important; }

/* Padding - Bottom */
.ion-pb-0 { padding-bottom: var(--ion-spacing-0) !important; }
.ion-pb-1 { padding-bottom: var(--ion-spacing-1) !important; }
.ion-pb-2 { padding-bottom: var(--ion-spacing-2) !important; }
.ion-pb-3 { padding-bottom: var(--ion-spacing-3) !important; }
.ion-pb-4 { padding-bottom: var(--ion-spacing-4) !important; }
.ion-pb-5 { padding-bottom: var(--ion-spacing-5) !important; }
.ion-pb-6 { padding-bottom: var(--ion-spacing-6) !important; }
.ion-pb-7 { padding-bottom: var(--ion-spacing-7) !important; }
.ion-pb-8 { padding-bottom: var(--ion-spacing-8) !important; }
.ion-pb-9 { padding-bottom: var(--ion-spacing-9) !important; }
.ion-pb-10 { padding-bottom: var(--ion-spacing-10) !important; }
.ion-pb-11 { padding-bottom: var(--ion-spacing-11) !important; }
.ion-pb-12 { padding-bottom: var(--ion-spacing-12) !important; }

/* Padding - Start (Left in LTR) */
.ion-ps-0 { padding-left: var(--ion-spacing-0) !important; }
.ion-ps-1 { padding-left: var(--ion-spacing-1) !important; }
.ion-ps-2 { padding-left: var(--ion-spacing-2) !important; }
.ion-ps-3 { padding-left: var(--ion-spacing-3) !important; }
.ion-ps-4 { padding-left: var(--ion-spacing-4) !important; }
.ion-ps-5 { padding-left: var(--ion-spacing-5) !important; }
.ion-ps-6 { padding-left: var(--ion-spacing-6) !important; }
.ion-ps-7 { padding-left: var(--ion-spacing-7) !important; }
.ion-ps-8 { padding-left: var(--ion-spacing-8) !important; }
.ion-ps-9 { padding-left: var(--ion-spacing-9) !important; }
.ion-ps-10 { padding-left: var(--ion-spacing-10) !important; }
.ion-ps-11 { padding-left: var(--ion-spacing-11) !important; }
.ion-ps-12 { padding-left: var(--ion-spacing-12) !important; }

/* ===================================
   RESPONSIVE PADDING UTILITIES - SM
   =================================== */
/* SM - ≥576px */
@media (min-width: 576px) {
  .ion-p-sm-0 { padding: var(--ion-spacing-0) !important; }
  .ion-p-sm-1 { padding: var(--ion-spacing-1) !important; }
  .ion-p-sm-2 { padding: var(--ion-spacing-2) !important; }
  .ion-p-sm-3 { padding: var(--ion-spacing-3) !important; }
  .ion-p-sm-4 { padding: var(--ion-spacing-4) !important; }
  .ion-p-sm-5 { padding: var(--ion-spacing-5) !important; }
  .ion-p-sm-6 { padding: var(--ion-spacing-6) !important; }
  .ion-p-sm-7 { padding: var(--ion-spacing-7) !important; }
  .ion-p-sm-8 { padding: var(--ion-spacing-8) !important; }
  .ion-p-sm-9 { padding: var(--ion-spacing-9) !important; }
  .ion-p-sm-10 { padding: var(--ion-spacing-10) !important; }
  .ion-p-sm-11 { padding: var(--ion-spacing-11) !important; }
  .ion-p-sm-12 { padding: var(--ion-spacing-12) !important; }

  .ion-px-sm-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
  .ion-px-sm-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
  .ion-px-sm-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
  .ion-px-sm-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
  .ion-px-sm-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
  .ion-px-sm-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
  .ion-px-sm-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
  .ion-px-sm-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
  .ion-px-sm-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
  .ion-px-sm-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
  .ion-px-sm-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
  .ion-px-sm-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
  .ion-px-sm-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

  .ion-py-sm-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
  .ion-py-sm-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
  .ion-py-sm-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
  .ion-py-sm-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
  .ion-py-sm-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
  .ion-py-sm-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
  .ion-py-sm-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
  .ion-py-sm-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
  .ion-py-sm-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
  .ion-py-sm-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
  .ion-py-sm-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
  .ion-py-sm-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
  .ion-py-sm-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

  .ion-pt-sm-0 { padding-top: var(--ion-spacing-0) !important; }
  .ion-pt-sm-1 { padding-top: var(--ion-spacing-1) !important; }
  .ion-pt-sm-2 { padding-top: var(--ion-spacing-2) !important; }
  .ion-pt-sm-3 { padding-top: var(--ion-spacing-3) !important; }
  .ion-pt-sm-4 { padding-top: var(--ion-spacing-4) !important; }
  .ion-pt-sm-5 { padding-top: var(--ion-spacing-5) !important; }
  .ion-pt-sm-6 { padding-top: var(--ion-spacing-6) !important; }
  .ion-pt-sm-7 { padding-top: var(--ion-spacing-7) !important; }
  .ion-pt-sm-8 { padding-top: var(--ion-spacing-8) !important; }
  .ion-pt-sm-9 { padding-top: var(--ion-spacing-9) !important; }
  .ion-pt-sm-10 { padding-top: var(--ion-spacing-10) !important; }
  .ion-pt-sm-11 { padding-top: var(--ion-spacing-11) !important; }
  .ion-pt-sm-12 { padding-top: var(--ion-spacing-12) !important; }

  .ion-pe-sm-0 { padding-right: var(--ion-spacing-0) !important; }
  .ion-pe-sm-1 { padding-right: var(--ion-spacing-1) !important; }
  .ion-pe-sm-2 { padding-right: var(--ion-spacing-2) !important; }
  .ion-pe-sm-3 { padding-right: var(--ion-spacing-3) !important; }
  .ion-pe-sm-4 { padding-right: var(--ion-spacing-4) !important; }
  .ion-pe-sm-5 { padding-right: var(--ion-spacing-5) !important; }
  .ion-pe-sm-6 { padding-right: var(--ion-spacing-6) !important; }
  .ion-pe-sm-7 { padding-right: var(--ion-spacing-7) !important; }
  .ion-pe-sm-8 { padding-right: var(--ion-spacing-8) !important; }
  .ion-pe-sm-9 { padding-right: var(--ion-spacing-9) !important; }
  .ion-pe-sm-10 { padding-right: var(--ion-spacing-10) !important; }
  .ion-pe-sm-11 { padding-right: var(--ion-spacing-11) !important; }
  .ion-pe-sm-12 { padding-right: var(--ion-spacing-12) !important; }

  .ion-pb-sm-0 { padding-bottom: var(--ion-spacing-0) !important; }
  .ion-pb-sm-1 { padding-bottom: var(--ion-spacing-1) !important; }
  .ion-pb-sm-2 { padding-bottom: var(--ion-spacing-2) !important; }
  .ion-pb-sm-3 { padding-bottom: var(--ion-spacing-3) !important; }
  .ion-pb-sm-4 { padding-bottom: var(--ion-spacing-4) !important; }
  .ion-pb-sm-5 { padding-bottom: var(--ion-spacing-5) !important; }
  .ion-pb-sm-6 { padding-bottom: var(--ion-spacing-6) !important; }
  .ion-pb-sm-7 { padding-bottom: var(--ion-spacing-7) !important; }
  .ion-pb-sm-8 { padding-bottom: var(--ion-spacing-8) !important; }
  .ion-pb-sm-9 { padding-bottom: var(--ion-spacing-9) !important; }
  .ion-pb-sm-10 { padding-bottom: var(--ion-spacing-10) !important; }
  .ion-pb-sm-11 { padding-bottom: var(--ion-spacing-11) !important; }
  .ion-pb-sm-12 { padding-bottom: var(--ion-spacing-12) !important; }

  .ion-ps-sm-0 { padding-left: var(--ion-spacing-0) !important; }
  .ion-ps-sm-1 { padding-left: var(--ion-spacing-1) !important; }
  .ion-ps-sm-2 { padding-left: var(--ion-spacing-2) !important; }
  .ion-ps-sm-3 { padding-left: var(--ion-spacing-3) !important; }
  .ion-ps-sm-4 { padding-left: var(--ion-spacing-4) !important; }
  .ion-ps-sm-5 { padding-left: var(--ion-spacing-5) !important; }
  .ion-ps-sm-6 { padding-left: var(--ion-spacing-6) !important; }
  .ion-ps-sm-7 { padding-left: var(--ion-spacing-7) !important; }
  .ion-ps-sm-8 { padding-left: var(--ion-spacing-8) !important; }
  .ion-ps-sm-9 { padding-left: var(--ion-spacing-9) !important; }
  .ion-ps-sm-10 { padding-left: var(--ion-spacing-10) !important; }
  .ion-ps-sm-11 { padding-left: var(--ion-spacing-11) !important; }
  .ion-ps-sm-12 { padding-left: var(--ion-spacing-12) !important; }
}

/* ===================================
   RESPONSIVE PADDING UTILITIES - MD
   =================================== */
/* MD - ≥768px */
@media (min-width: 768px) {
  .ion-p-md-0 { padding: var(--ion-spacing-0) !important; }
  .ion-p-md-1 { padding: var(--ion-spacing-1) !important; }
  .ion-p-md-2 { padding: var(--ion-spacing-2) !important; }
  .ion-p-md-3 { padding: var(--ion-spacing-3) !important; }
  .ion-p-md-4 { padding: var(--ion-spacing-4) !important; }
  .ion-p-md-5 { padding: var(--ion-spacing-5) !important; }
  .ion-p-md-6 { padding: var(--ion-spacing-6) !important; }
  .ion-p-md-7 { padding: var(--ion-spacing-7) !important; }
  .ion-p-md-8 { padding: var(--ion-spacing-8) !important; }
  .ion-p-md-9 { padding: var(--ion-spacing-9) !important; }
  .ion-p-md-10 { padding: var(--ion-spacing-10) !important; }
  .ion-p-md-11 { padding: var(--ion-spacing-11) !important; }
  .ion-p-md-12 { padding: var(--ion-spacing-12) !important; }

  .ion-px-md-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
  .ion-px-md-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
  .ion-px-md-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
  .ion-px-md-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
  .ion-px-md-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
  .ion-px-md-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
  .ion-px-md-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
  .ion-px-md-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
  .ion-px-md-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
  .ion-px-md-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
  .ion-px-md-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
  .ion-px-md-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
  .ion-px-md-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

  .ion-py-md-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
  .ion-py-md-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
  .ion-py-md-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
  .ion-py-md-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
  .ion-py-md-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
  .ion-py-md-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
  .ion-py-md-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
  .ion-py-md-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
  .ion-py-md-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
  .ion-py-md-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
  .ion-py-md-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
  .ion-py-md-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
  .ion-py-md-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

  .ion-pt-md-0 { padding-top: var(--ion-spacing-0) !important; }
  .ion-pt-md-1 { padding-top: var(--ion-spacing-1) !important; }
  .ion-pt-md-2 { padding-top: var(--ion-spacing-2) !important; }
  .ion-pt-md-3 { padding-top: var(--ion-spacing-3) !important; }
  .ion-pt-md-4 { padding-top: var(--ion-spacing-4) !important; }
  .ion-pt-md-5 { padding-top: var(--ion-spacing-5) !important; }
  .ion-pt-md-6 { padding-top: var(--ion-spacing-6) !important; }
  .ion-pt-md-7 { padding-top: var(--ion-spacing-7) !important; }
  .ion-pt-md-8 { padding-top: var(--ion-spacing-8) !important; }
  .ion-pt-md-9 { padding-top: var(--ion-spacing-9) !important; }
  .ion-pt-md-10 { padding-top: var(--ion-spacing-10) !important; }
  .ion-pt-md-11 { padding-top: var(--ion-spacing-11) !important; }
  .ion-pt-md-12 { padding-top: var(--ion-spacing-12) !important; }

  .ion-pe-md-0 { padding-right: var(--ion-spacing-0) !important; }
  .ion-pe-md-1 { padding-right: var(--ion-spacing-1) !important; }
  .ion-pe-md-2 { padding-right: var(--ion-spacing-2) !important; }
  .ion-pe-md-3 { padding-right: var(--ion-spacing-3) !important; }
  .ion-pe-md-4 { padding-right: var(--ion-spacing-4) !important; }
  .ion-pe-md-5 { padding-right: var(--ion-spacing-5) !important; }
  .ion-pe-md-6 { padding-right: var(--ion-spacing-6) !important; }
  .ion-pe-md-7 { padding-right: var(--ion-spacing-7) !important; }
  .ion-pe-md-8 { padding-right: var(--ion-spacing-8) !important; }
  .ion-pe-md-9 { padding-right: var(--ion-spacing-9) !important; }
  .ion-pe-md-10 { padding-right: var(--ion-spacing-10) !important; }
  .ion-pe-md-11 { padding-right: var(--ion-spacing-11) !important; }
  .ion-pe-md-12 { padding-right: var(--ion-spacing-12) !important; }

  .ion-pb-md-0 { padding-bottom: var(--ion-spacing-0) !important; }
  .ion-pb-md-1 { padding-bottom: var(--ion-spacing-1) !important; }
  .ion-pb-md-2 { padding-bottom: var(--ion-spacing-2) !important; }
  .ion-pb-md-3 { padding-bottom: var(--ion-spacing-3) !important; }
  .ion-pb-md-4 { padding-bottom: var(--ion-spacing-4) !important; }
  .ion-pb-md-5 { padding-bottom: var(--ion-spacing-5) !important; }
  .ion-pb-md-6 { padding-bottom: var(--ion-spacing-6) !important; }
  .ion-pb-md-7 { padding-bottom: var(--ion-spacing-7) !important; }
  .ion-pb-md-8 { padding-bottom: var(--ion-spacing-8) !important; }
  .ion-pb-md-9 { padding-bottom: var(--ion-spacing-9) !important; }
  .ion-pb-md-10 { padding-bottom: var(--ion-spacing-10) !important; }
  .ion-pb-md-11 { padding-bottom: var(--ion-spacing-11) !important; }
  .ion-pb-md-12 { padding-bottom: var(--ion-spacing-12) !important; }

  .ion-ps-md-0 { padding-left: var(--ion-spacing-0) !important; }
  .ion-ps-md-1 { padding-left: var(--ion-spacing-1) !important; }
  .ion-ps-md-2 { padding-left: var(--ion-spacing-2) !important; }
  .ion-ps-md-3 { padding-left: var(--ion-spacing-3) !important; }
  .ion-ps-md-4 { padding-left: var(--ion-spacing-4) !important; }
  .ion-ps-md-5 { padding-left: var(--ion-spacing-5) !important; }
  .ion-ps-md-6 { padding-left: var(--ion-spacing-6) !important; }
  .ion-ps-md-7 { padding-left: var(--ion-spacing-7) !important; }
  .ion-ps-md-8 { padding-left: var(--ion-spacing-8) !important; }
  .ion-ps-md-9 { padding-left: var(--ion-spacing-9) !important; }
  .ion-ps-md-10 { padding-left: var(--ion-spacing-10) !important; }
  .ion-ps-md-11 { padding-left: var(--ion-spacing-11) !important; }
  .ion-ps-md-12 { padding-left: var(--ion-spacing-12) !important; }
}

/* ===================================
   RESPONSIVE PADDING UTILITIES - LG
   =================================== */
/* LG - ≥992px */
@media (min-width: 992px) {
  .ion-p-lg-0 { padding: var(--ion-spacing-0) !important; }
  .ion-p-lg-1 { padding: var(--ion-spacing-1) !important; }
  .ion-p-lg-2 { padding: var(--ion-spacing-2) !important; }
  .ion-p-lg-3 { padding: var(--ion-spacing-3) !important; }
  .ion-p-lg-4 { padding: var(--ion-spacing-4) !important; }
  .ion-p-lg-5 { padding: var(--ion-spacing-5) !important; }
  .ion-p-lg-6 { padding: var(--ion-spacing-6) !important; }
  .ion-p-lg-7 { padding: var(--ion-spacing-7) !important; }
  .ion-p-lg-8 { padding: var(--ion-spacing-8) !important; }
  .ion-p-lg-9 { padding: var(--ion-spacing-9) !important; }
  .ion-p-lg-10 { padding: var(--ion-spacing-10) !important; }
  .ion-p-lg-11 { padding: var(--ion-spacing-11) !important; }
  .ion-p-lg-12 { padding: var(--ion-spacing-12) !important; }

  .ion-px-lg-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
  .ion-px-lg-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
  .ion-px-lg-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
  .ion-px-lg-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
  .ion-px-lg-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
  .ion-px-lg-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
  .ion-px-lg-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
  .ion-px-lg-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
  .ion-px-lg-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
  .ion-px-lg-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
  .ion-px-lg-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
  .ion-px-lg-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
  .ion-px-lg-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

  .ion-py-lg-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
  .ion-py-lg-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
  .ion-py-lg-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
  .ion-py-lg-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
  .ion-py-lg-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
  .ion-py-lg-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
  .ion-py-lg-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
  .ion-py-lg-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
  .ion-py-lg-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
  .ion-py-lg-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
  .ion-py-lg-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
  .ion-py-lg-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
  .ion-py-lg-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

  .ion-pt-lg-0 { padding-top: var(--ion-spacing-0) !important; }
  .ion-pt-lg-1 { padding-top: var(--ion-spacing-1) !important; }
  .ion-pt-lg-2 { padding-top: var(--ion-spacing-2) !important; }
  .ion-pt-lg-3 { padding-top: var(--ion-spacing-3) !important; }
  .ion-pt-lg-4 { padding-top: var(--ion-spacing-4) !important; }
  .ion-pt-lg-5 { padding-top: var(--ion-spacing-5) !important; }
  .ion-pt-lg-6 { padding-top: var(--ion-spacing-6) !important; }
  .ion-pt-lg-7 { padding-top: var(--ion-spacing-7) !important; }
  .ion-pt-lg-8 { padding-top: var(--ion-spacing-8) !important; }
  .ion-pt-lg-9 { padding-top: var(--ion-spacing-9) !important; }
  .ion-pt-lg-10 { padding-top: var(--ion-spacing-10) !important; }
  .ion-pt-lg-11 { padding-top: var(--ion-spacing-11) !important; }
  .ion-pt-lg-12 { padding-top: var(--ion-spacing-12) !important; }

  .ion-pe-lg-0 { padding-right: var(--ion-spacing-0) !important; }
  .ion-pe-lg-1 { padding-right: var(--ion-spacing-1) !important; }
  .ion-pe-lg-2 { padding-right: var(--ion-spacing-2) !important; }
  .ion-pe-lg-3 { padding-right: var(--ion-spacing-3) !important; }
  .ion-pe-lg-4 { padding-right: var(--ion-spacing-4) !important; }
  .ion-pe-lg-5 { padding-right: var(--ion-spacing-5) !important; }
  .ion-pe-lg-6 { padding-right: var(--ion-spacing-6) !important; }
  .ion-pe-lg-7 { padding-right: var(--ion-spacing-7) !important; }
  .ion-pe-lg-8 { padding-right: var(--ion-spacing-8) !important; }
  .ion-pe-lg-9 { padding-right: var(--ion-spacing-9) !important; }
  .ion-pe-lg-10 { padding-right: var(--ion-spacing-10) !important; }
  .ion-pe-lg-11 { padding-right: var(--ion-spacing-11) !important; }
  .ion-pe-lg-12 { padding-right: var(--ion-spacing-12) !important; }

  .ion-pb-lg-0 { padding-bottom: var(--ion-spacing-0) !important; }
  .ion-pb-lg-1 { padding-bottom: var(--ion-spacing-1) !important; }
  .ion-pb-lg-2 { padding-bottom: var(--ion-spacing-2) !important; }
  .ion-pb-lg-3 { padding-bottom: var(--ion-spacing-3) !important; }
  .ion-pb-lg-4 { padding-bottom: var(--ion-spacing-4) !important; }
  .ion-pb-lg-5 { padding-bottom: var(--ion-spacing-5) !important; }
  .ion-pb-lg-6 { padding-bottom: var(--ion-spacing-6) !important; }
  .ion-pb-lg-7 { padding-bottom: var(--ion-spacing-7) !important; }
  .ion-pb-lg-8 { padding-bottom: var(--ion-spacing-8) !important; }
  .ion-pb-lg-9 { padding-bottom: var(--ion-spacing-9) !important; }
  .ion-pb-lg-10 { padding-bottom: var(--ion-spacing-10) !important; }
  .ion-pb-lg-11 { padding-bottom: var(--ion-spacing-11) !important; }
  .ion-pb-lg-12 { padding-bottom: var(--ion-spacing-12) !important; }

  .ion-ps-lg-0 { padding-left: var(--ion-spacing-0) !important; }
  .ion-ps-lg-1 { padding-left: var(--ion-spacing-1) !important; }
  .ion-ps-lg-2 { padding-left: var(--ion-spacing-2) !important; }
  .ion-ps-lg-3 { padding-left: var(--ion-spacing-3) !important; }
  .ion-ps-lg-4 { padding-left: var(--ion-spacing-4) !important; }
  .ion-ps-lg-5 { padding-left: var(--ion-spacing-5) !important; }
  .ion-ps-lg-6 { padding-left: var(--ion-spacing-6) !important; }
  .ion-ps-lg-7 { padding-left: var(--ion-spacing-7) !important; }
  .ion-ps-lg-8 { padding-left: var(--ion-spacing-8) !important; }
  .ion-ps-lg-9 { padding-left: var(--ion-spacing-9) !important; }
  .ion-ps-lg-10 { padding-left: var(--ion-spacing-10) !important; }
  .ion-ps-lg-11 { padding-left: var(--ion-spacing-11) !important; }
  .ion-ps-lg-12 { padding-left: var(--ion-spacing-12) !important; }
}

/* ===================================
   RESPONSIVE PADDING UTILITIES - XL
   =================================== */
/* XL - ≥1200px */
@media (min-width: 1200px) {
  .ion-p-xl-0 { padding: var(--ion-spacing-0) !important; }
  .ion-p-xl-1 { padding: var(--ion-spacing-1) !important; }
  .ion-p-xl-2 { padding: var(--ion-spacing-2) !important; }
  .ion-p-xl-3 { padding: var(--ion-spacing-3) !important; }
  .ion-p-xl-4 { padding: var(--ion-spacing-4) !important; }
  .ion-p-xl-5 { padding: var(--ion-spacing-5) !important; }
  .ion-p-xl-6 { padding: var(--ion-spacing-6) !important; }
  .ion-p-xl-7 { padding: var(--ion-spacing-7) !important; }
  .ion-p-xl-8 { padding: var(--ion-spacing-8) !important; }
  .ion-p-xl-9 { padding: var(--ion-spacing-9) !important; }
  .ion-p-xl-10 { padding: var(--ion-spacing-10) !important; }
  .ion-p-xl-11 { padding: var(--ion-spacing-11) !important; }
  .ion-p-xl-12 { padding: var(--ion-spacing-12) !important; }

  .ion-px-xl-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
  .ion-px-xl-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
  .ion-px-xl-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
  .ion-px-xl-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
  .ion-px-xl-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
  .ion-px-xl-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
  .ion-px-xl-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
  .ion-px-xl-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
  .ion-px-xl-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
  .ion-px-xl-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
  .ion-px-xl-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
  .ion-px-xl-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
  .ion-px-xl-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

  .ion-py-xl-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
  .ion-py-xl-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
  .ion-py-xl-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
  .ion-py-xl-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
  .ion-py-xl-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
  .ion-py-xl-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
  .ion-py-xl-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
  .ion-py-xl-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
  .ion-py-xl-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
  .ion-py-xl-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
  .ion-py-xl-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
  .ion-py-xl-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
  .ion-py-xl-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

  .ion-pt-xl-0 { padding-top: var(--ion-spacing-0) !important; }
  .ion-pt-xl-1 { padding-top: var(--ion-spacing-1) !important; }
  .ion-pt-xl-2 { padding-top: var(--ion-spacing-2) !important; }
  .ion-pt-xl-3 { padding-top: var(--ion-spacing-3) !important; }
  .ion-pt-xl-4 { padding-top: var(--ion-spacing-4) !important; }
  .ion-pt-xl-5 { padding-top: var(--ion-spacing-5) !important; }
  .ion-pt-xl-6 { padding-top: var(--ion-spacing-6) !important; }
  .ion-pt-xl-7 { padding-top: var(--ion-spacing-7) !important; }
  .ion-pt-xl-8 { padding-top: var(--ion-spacing-8) !important; }
  .ion-pt-xl-9 { padding-top: var(--ion-spacing-9) !important; }
  .ion-pt-xl-10 { padding-top: var(--ion-spacing-10) !important; }
  .ion-pt-xl-11 { padding-top: var(--ion-spacing-11) !important; }
  .ion-pt-xl-12 { padding-top: var(--ion-spacing-12) !important; }

  .ion-pe-xl-0 { padding-right: var(--ion-spacing-0) !important; }
  .ion-pe-xl-1 { padding-right: var(--ion-spacing-1) !important; }
  .ion-pe-xl-2 { padding-right: var(--ion-spacing-2) !important; }
  .ion-pe-xl-3 { padding-right: var(--ion-spacing-3) !important; }
  .ion-pe-xl-4 { padding-right: var(--ion-spacing-4) !important; }
  .ion-pe-xl-5 { padding-right: var(--ion-spacing-5) !important; }
  .ion-pe-xl-6 { padding-right: var(--ion-spacing-6) !important; }
  .ion-pe-xl-7 { padding-right: var(--ion-spacing-7) !important; }
  .ion-pe-xl-8 { padding-right: var(--ion-spacing-8) !important; }
  .ion-pe-xl-9 { padding-right: var(--ion-spacing-9) !important; }
  .ion-pe-xl-10 { padding-right: var(--ion-spacing-10) !important; }
  .ion-pe-xl-11 { padding-right: var(--ion-spacing-11) !important; }
  .ion-pe-xl-12 { padding-right: var(--ion-spacing-12) !important; }

  .ion-pb-xl-0 { padding-bottom: var(--ion-spacing-0) !important; }
  .ion-pb-xl-1 { padding-bottom: var(--ion-spacing-1) !important; }
  .ion-pb-xl-2 { padding-bottom: var(--ion-spacing-2) !important; }
  .ion-pb-xl-3 { padding-bottom: var(--ion-spacing-3) !important; }
  .ion-pb-xl-4 { padding-bottom: var(--ion-spacing-4) !important; }
  .ion-pb-xl-5 { padding-bottom: var(--ion-spacing-5) !important; }
  .ion-pb-xl-6 { padding-bottom: var(--ion-spacing-6) !important; }
  .ion-pb-xl-7 { padding-bottom: var(--ion-spacing-7) !important; }
  .ion-pb-xl-8 { padding-bottom: var(--ion-spacing-8) !important; }
  .ion-pb-xl-9 { padding-bottom: var(--ion-spacing-9) !important; }
  .ion-pb-xl-10 { padding-bottom: var(--ion-spacing-10) !important; }
  .ion-pb-xl-11 { padding-bottom: var(--ion-spacing-11) !important; }
  .ion-pb-xl-12 { padding-bottom: var(--ion-spacing-12) !important; }

  .ion-ps-xl-0 { padding-left: var(--ion-spacing-0) !important; }
  .ion-ps-xl-1 { padding-left: var(--ion-spacing-1) !important; }
  .ion-ps-xl-2 { padding-left: var(--ion-spacing-2) !important; }
  .ion-ps-xl-3 { padding-left: var(--ion-spacing-3) !important; }
  .ion-ps-xl-4 { padding-left: var(--ion-spacing-4) !important; }
  .ion-ps-xl-5 { padding-left: var(--ion-spacing-5) !important; }
  .ion-ps-xl-6 { padding-left: var(--ion-spacing-6) !important; }
  .ion-ps-xl-7 { padding-left: var(--ion-spacing-7) !important; }
  .ion-ps-xl-8 { padding-left: var(--ion-spacing-8) !important; }
  .ion-ps-xl-9 { padding-left: var(--ion-spacing-9) !important; }
  .ion-ps-xl-10 { padding-left: var(--ion-spacing-10) !important; }
  .ion-ps-xl-11 { padding-left: var(--ion-spacing-11) !important; }
  .ion-ps-xl-12 { padding-left: var(--ion-spacing-12) !important; }
}

/* ===================================
   RESPONSIVE PADDING UTILITIES - XXL
   =================================== */
/* XXL - ≥1400px */
@media (min-width: 1400px) {
  .ion-p-xxl-0 { padding: var(--ion-spacing-0) !important; }
  .ion-p-xxl-1 { padding: var(--ion-spacing-1) !important; }
  .ion-p-xxl-2 { padding: var(--ion-spacing-2) !important; }
  .ion-p-xxl-3 { padding: var(--ion-spacing-3) !important; }
  .ion-p-xxl-4 { padding: var(--ion-spacing-4) !important; }
  .ion-p-xxl-5 { padding: var(--ion-spacing-5) !important; }
  .ion-p-xxl-6 { padding: var(--ion-spacing-6) !important; }
  .ion-p-xxl-7 { padding: var(--ion-spacing-7) !important; }
  .ion-p-xxl-8 { padding: var(--ion-spacing-8) !important; }
  .ion-p-xxl-9 { padding: var(--ion-spacing-9) !important; }
  .ion-p-xxl-10 { padding: var(--ion-spacing-10) !important; }
  .ion-p-xxl-11 { padding: var(--ion-spacing-11) !important; }
  .ion-p-xxl-12 { padding: var(--ion-spacing-12) !important; }

  .ion-px-xxl-0 { padding-left: var(--ion-spacing-0) !important; padding-right: var(--ion-spacing-0) !important; }
  .ion-px-xxl-1 { padding-left: var(--ion-spacing-1) !important; padding-right: var(--ion-spacing-1) !important; }
  .ion-px-xxl-2 { padding-left: var(--ion-spacing-2) !important; padding-right: var(--ion-spacing-2) !important; }
  .ion-px-xxl-3 { padding-left: var(--ion-spacing-3) !important; padding-right: var(--ion-spacing-3) !important; }
  .ion-px-xxl-4 { padding-left: var(--ion-spacing-4) !important; padding-right: var(--ion-spacing-4) !important; }
  .ion-px-xxl-5 { padding-left: var(--ion-spacing-5) !important; padding-right: var(--ion-spacing-5) !important; }
  .ion-px-xxl-6 { padding-left: var(--ion-spacing-6) !important; padding-right: var(--ion-spacing-6) !important; }
  .ion-px-xxl-7 { padding-left: var(--ion-spacing-7) !important; padding-right: var(--ion-spacing-7) !important; }
  .ion-px-xxl-8 { padding-left: var(--ion-spacing-8) !important; padding-right: var(--ion-spacing-8) !important; }
  .ion-px-xxl-9 { padding-left: var(--ion-spacing-9) !important; padding-right: var(--ion-spacing-9) !important; }
  .ion-px-xxl-10 { padding-left: var(--ion-spacing-10) !important; padding-right: var(--ion-spacing-10) !important; }
  .ion-px-xxl-11 { padding-left: var(--ion-spacing-11) !important; padding-right: var(--ion-spacing-11) !important; }
  .ion-px-xxl-12 { padding-left: var(--ion-spacing-12) !important; padding-right: var(--ion-spacing-12) !important; }

  .ion-py-xxl-0 { padding-top: var(--ion-spacing-0) !important; padding-bottom: var(--ion-spacing-0) !important; }
  .ion-py-xxl-1 { padding-top: var(--ion-spacing-1) !important; padding-bottom: var(--ion-spacing-1) !important; }
  .ion-py-xxl-2 { padding-top: var(--ion-spacing-2) !important; padding-bottom: var(--ion-spacing-2) !important; }
  .ion-py-xxl-3 { padding-top: var(--ion-spacing-3) !important; padding-bottom: var(--ion-spacing-3) !important; }
  .ion-py-xxl-4 { padding-top: var(--ion-spacing-4) !important; padding-bottom: var(--ion-spacing-4) !important; }
  .ion-py-xxl-5 { padding-top: var(--ion-spacing-5) !important; padding-bottom: var(--ion-spacing-5) !important; }
  .ion-py-xxl-6 { padding-top: var(--ion-spacing-6) !important; padding-bottom: var(--ion-spacing-6) !important; }
  .ion-py-xxl-7 { padding-top: var(--ion-spacing-7) !important; padding-bottom: var(--ion-spacing-7) !important; }
  .ion-py-xxl-8 { padding-top: var(--ion-spacing-8) !important; padding-bottom: var(--ion-spacing-8) !important; }
  .ion-py-xxl-9 { padding-top: var(--ion-spacing-9) !important; padding-bottom: var(--ion-spacing-9) !important; }
  .ion-py-xxl-10 { padding-top: var(--ion-spacing-10) !important; padding-bottom: var(--ion-spacing-10) !important; }
  .ion-py-xxl-11 { padding-top: var(--ion-spacing-11) !important; padding-bottom: var(--ion-spacing-11) !important; }
  .ion-py-xxl-12 { padding-top: var(--ion-spacing-12) !important; padding-bottom: var(--ion-spacing-12) !important; }

  .ion-pt-xxl-0 { padding-top: var(--ion-spacing-0) !important; }
  .ion-pt-xxl-1 { padding-top: var(--ion-spacing-1) !important; }
  .ion-pt-xxl-2 { padding-top: var(--ion-spacing-2) !important; }
  .ion-pt-xxl-3 { padding-top: var(--ion-spacing-3) !important; }
  .ion-pt-xxl-4 { padding-top: var(--ion-spacing-4) !important; }
  .ion-pt-xxl-5 { padding-top: var(--ion-spacing-5) !important; }
  .ion-pt-xxl-6 { padding-top: var(--ion-spacing-6) !important; }
  .ion-pt-xxl-7 { padding-top: var(--ion-spacing-7) !important; }
  .ion-pt-xxl-8 { padding-top: var(--ion-spacing-8) !important; }
  .ion-pt-xxl-9 { padding-top: var(--ion-spacing-9) !important; }
  .ion-pt-xxl-10 { padding-top: var(--ion-spacing-10) !important; }
  .ion-pt-xxl-11 { padding-top: var(--ion-spacing-11) !important; }
  .ion-pt-xxl-12 { padding-top: var(--ion-spacing-12) !important; }

  .ion-pe-xxl-0 { padding-right: var(--ion-spacing-0) !important; }
  .ion-pe-xxl-1 { padding-right: var(--ion-spacing-1) !important; }
  .ion-pe-xxl-2 { padding-right: var(--ion-spacing-2) !important; }
  .ion-pe-xxl-3 { padding-right: var(--ion-spacing-3) !important; }
  .ion-pe-xxl-4 { padding-right: var(--ion-spacing-4) !important; }
  .ion-pe-xxl-5 { padding-right: var(--ion-spacing-5) !important; }
  .ion-pe-xxl-6 { padding-right: var(--ion-spacing-6) !important; }
  .ion-pe-xxl-7 { padding-right: var(--ion-spacing-7) !important; }
  .ion-pe-xxl-8 { padding-right: var(--ion-spacing-8) !important; }
  .ion-pe-xxl-9 { padding-right: var(--ion-spacing-9) !important; }
  .ion-pe-xxl-10 { padding-right: var(--ion-spacing-10) !important; }
  .ion-pe-xxl-11 { padding-right: var(--ion-spacing-11) !important; }
  .ion-pe-xxl-12 { padding-right: var(--ion-spacing-12) !important; }

  .ion-pb-xxl-0 { padding-bottom: var(--ion-spacing-0) !important; }
  .ion-pb-xxl-1 { padding-bottom: var(--ion-spacing-1) !important; }
  .ion-pb-xxl-2 { padding-bottom: var(--ion-spacing-2) !important; }
  .ion-pb-xxl-3 { padding-bottom: var(--ion-spacing-3) !important; }
  .ion-pb-xxl-4 { padding-bottom: var(--ion-spacing-4) !important; }
  .ion-pb-xxl-5 { padding-bottom: var(--ion-spacing-5) !important; }
  .ion-pb-xxl-6 { padding-bottom: var(--ion-spacing-6) !important; }
  .ion-pb-xxl-7 { padding-bottom: var(--ion-spacing-7) !important; }
  .ion-pb-xxl-8 { padding-bottom: var(--ion-spacing-8) !important; }
  .ion-pb-xxl-9 { padding-bottom: var(--ion-spacing-9) !important; }
  .ion-pb-xxl-10 { padding-bottom: var(--ion-spacing-10) !important; }
  .ion-pb-xxl-11 { padding-bottom: var(--ion-spacing-11) !important; }
  .ion-pb-xxl-12 { padding-bottom: var(--ion-spacing-12) !important; }

  .ion-ps-xxl-0 { padding-left: var(--ion-spacing-0) !important; }
  .ion-ps-xxl-1 { padding-left: var(--ion-spacing-1) !important; }
  .ion-ps-xxl-2 { padding-left: var(--ion-spacing-2) !important; }
  .ion-ps-xxl-3 { padding-left: var(--ion-spacing-3) !important; }
  .ion-ps-xxl-4 { padding-left: var(--ion-spacing-4) !important; }
  .ion-ps-xxl-5 { padding-left: var(--ion-spacing-5) !important; }
  .ion-ps-xxl-6 { padding-left: var(--ion-spacing-6) !important; }
  .ion-ps-xxl-7 { padding-left: var(--ion-spacing-7) !important; }
  .ion-ps-xxl-8 { padding-left: var(--ion-spacing-8) !important; }
  .ion-ps-xxl-9 { padding-left: var(--ion-spacing-9) !important; }
  .ion-ps-xxl-10 { padding-left: var(--ion-spacing-10) !important; }
  .ion-ps-xxl-11 { padding-left: var(--ion-spacing-11) !important; }
  .ion-ps-xxl-12 { padding-left: var(--ion-spacing-12) !important; }
}

/* ===================================
   MARGIN UTILITIES
   =================================== */
/* Margin - All Sides */
.ion-m-0 { margin: var(--ion-spacing-0) !important; }
.ion-m-1 { margin: var(--ion-spacing-1) !important; }
.ion-m-2 { margin: var(--ion-spacing-2) !important; }
.ion-m-3 { margin: var(--ion-spacing-3) !important; }
.ion-m-4 { margin: var(--ion-spacing-4) !important; }
.ion-m-5 { margin: var(--ion-spacing-5) !important; }
.ion-m-6 { margin: var(--ion-spacing-6) !important; }
.ion-m-7 { margin: var(--ion-spacing-7) !important; }
.ion-m-8 { margin: var(--ion-spacing-8) !important; }
.ion-m-9 { margin: var(--ion-spacing-9) !important; }
.ion-m-10 { margin: var(--ion-spacing-10) !important; }
.ion-m-11 { margin: var(--ion-spacing-11) !important; }
.ion-m-12 { margin: var(--ion-spacing-12) !important; }
.ion-m-auto { margin: auto !important; }

/* Margin - Horizontal */
.ion-mx-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
.ion-mx-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
.ion-mx-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
.ion-mx-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
.ion-mx-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
.ion-mx-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
.ion-mx-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
.ion-mx-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
.ion-mx-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
.ion-mx-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
.ion-mx-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
.ion-mx-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
.ion-mx-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
.ion-mx-auto { margin-left: auto !important; margin-right: auto !important; }

/* Margin - Vertical */
.ion-my-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
.ion-my-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
.ion-my-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
.ion-my-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
.ion-my-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
.ion-my-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
.ion-my-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
.ion-my-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
.ion-my-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
.ion-my-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
.ion-my-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
.ion-my-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
.ion-my-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
.ion-my-auto { margin-top: auto !important; margin-bottom: auto !important; }

/* Margin - Top */
.ion-mt-0 { margin-top: var(--ion-spacing-0) !important; }
.ion-mt-1 { margin-top: var(--ion-spacing-1) !important; }
.ion-mt-2 { margin-top: var(--ion-spacing-2) !important; }
.ion-mt-3 { margin-top: var(--ion-spacing-3) !important; }
.ion-mt-4 { margin-top: var(--ion-spacing-4) !important; }
.ion-mt-5 { margin-top: var(--ion-spacing-5) !important; }
.ion-mt-6 { margin-top: var(--ion-spacing-6) !important; }
.ion-mt-7 { margin-top: var(--ion-spacing-7) !important; }
.ion-mt-8 { margin-top: var(--ion-spacing-8) !important; }
.ion-mt-9 { margin-top: var(--ion-spacing-9) !important; }
.ion-mt-10 { margin-top: var(--ion-spacing-10) !important; }
.ion-mt-11 { margin-top: var(--ion-spacing-11) !important; }
.ion-mt-12 { margin-top: var(--ion-spacing-12) !important; }
.ion-mt-auto { margin-top: auto !important; }

/* Margin - End (Right in LTR) */
.ion-me-0 { margin-right: var(--ion-spacing-0) !important; }
.ion-me-1 { margin-right: var(--ion-spacing-1) !important; }
.ion-me-2 { margin-right: var(--ion-spacing-2) !important; }
.ion-me-3 { margin-right: var(--ion-spacing-3) !important; }
.ion-me-4 { margin-right: var(--ion-spacing-4) !important; }
.ion-me-5 { margin-right: var(--ion-spacing-5) !important; }
.ion-me-6 { margin-right: var(--ion-spacing-6) !important; }
.ion-me-7 { margin-right: var(--ion-spacing-7) !important; }
.ion-me-8 { margin-right: var(--ion-spacing-8) !important; }
.ion-me-9 { margin-right: var(--ion-spacing-9) !important; }
.ion-me-10 { margin-right: var(--ion-spacing-10) !important; }
.ion-me-11 { margin-right: var(--ion-spacing-11) !important; }
.ion-me-12 { margin-right: var(--ion-spacing-12) !important; }
.ion-me-auto { margin-right: auto !important; }

/* Margin - Bottom */
.ion-mb-0 { margin-bottom: var(--ion-spacing-0) !important; }
.ion-mb-1 { margin-bottom: var(--ion-spacing-1) !important; }
.ion-mb-2 { margin-bottom: var(--ion-spacing-2) !important; }
.ion-mb-3 { margin-bottom: var(--ion-spacing-3) !important; }
.ion-mb-4 { margin-bottom: var(--ion-spacing-4) !important; }
.ion-mb-5 { margin-bottom: var(--ion-spacing-5) !important; }
.ion-mb-6 { margin-bottom: var(--ion-spacing-6) !important; }
.ion-mb-7 { margin-bottom: var(--ion-spacing-7) !important; }
.ion-mb-8 { margin-bottom: var(--ion-spacing-8) !important; }
.ion-mb-9 { margin-bottom: var(--ion-spacing-9) !important; }
.ion-mb-10 { margin-bottom: var(--ion-spacing-10) !important; }
.ion-mb-11 { margin-bottom: var(--ion-spacing-11) !important; }
.ion-mb-12 { margin-bottom: var(--ion-spacing-12) !important; }
.ion-mb-auto { margin-bottom: auto !important; }

/* Margin - Start (Left in LTR) */
.ion-ms-0 { margin-left: var(--ion-spacing-0) !important; }
.ion-ms-1 { margin-left: var(--ion-spacing-1) !important; }
.ion-ms-2 { margin-left: var(--ion-spacing-2) !important; }
.ion-ms-3 { margin-left: var(--ion-spacing-3) !important; }
.ion-ms-4 { margin-left: var(--ion-spacing-4) !important; }
.ion-ms-5 { margin-left: var(--ion-spacing-5) !important; }
.ion-ms-6 { margin-left: var(--ion-spacing-6) !important; }
.ion-ms-7 { margin-left: var(--ion-spacing-7) !important; }
.ion-ms-8 { margin-left: var(--ion-spacing-8) !important; }
.ion-ms-9 { margin-left: var(--ion-spacing-9) !important; }
.ion-ms-10 { margin-left: var(--ion-spacing-10) !important; }
.ion-ms-11 { margin-left: var(--ion-spacing-11) !important; }
.ion-ms-12 { margin-left: var(--ion-spacing-12) !important; }
.ion-ms-auto { margin-left: auto !important; }

/* ===================================
   RESPONSIVE MARGIN UTILITIES - SM
   =================================== */
/* SM - ≥576px */
@media (min-width: 576px) {
  .ion-m-sm-0 { margin: var(--ion-spacing-0) !important; }
  .ion-m-sm-1 { margin: var(--ion-spacing-1) !important; }
  .ion-m-sm-2 { margin: var(--ion-spacing-2) !important; }
  .ion-m-sm-3 { margin: var(--ion-spacing-3) !important; }
  .ion-m-sm-4 { margin: var(--ion-spacing-4) !important; }
  .ion-m-sm-5 { margin: var(--ion-spacing-5) !important; }
  .ion-m-sm-6 { margin: var(--ion-spacing-6) !important; }
  .ion-m-sm-7 { margin: var(--ion-spacing-7) !important; }
  .ion-m-sm-8 { margin: var(--ion-spacing-8) !important; }
  .ion-m-sm-9 { margin: var(--ion-spacing-9) !important; }
  .ion-m-sm-10 { margin: var(--ion-spacing-10) !important; }
  .ion-m-sm-11 { margin: var(--ion-spacing-11) !important; }
  .ion-m-sm-12 { margin: var(--ion-spacing-12) !important; }
  .ion-m-sm-auto { margin: auto !important; }

  .ion-mx-sm-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
  .ion-mx-sm-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
  .ion-mx-sm-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
  .ion-mx-sm-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
  .ion-mx-sm-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
  .ion-mx-sm-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
  .ion-mx-sm-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
  .ion-mx-sm-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
  .ion-mx-sm-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
  .ion-mx-sm-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
  .ion-mx-sm-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
  .ion-mx-sm-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
  .ion-mx-sm-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
  .ion-mx-sm-auto { margin-left: auto !important; margin-right: auto !important; }

  .ion-my-sm-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
  .ion-my-sm-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
  .ion-my-sm-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
  .ion-my-sm-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
  .ion-my-sm-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
  .ion-my-sm-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
  .ion-my-sm-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
  .ion-my-sm-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
  .ion-my-sm-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
  .ion-my-sm-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
  .ion-my-sm-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
  .ion-my-sm-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
  .ion-my-sm-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
  .ion-my-sm-auto { margin-top: auto !important; margin-bottom: auto !important; }

  .ion-mt-sm-0 { margin-top: var(--ion-spacing-0) !important; }
  .ion-mt-sm-1 { margin-top: var(--ion-spacing-1) !important; }
  .ion-mt-sm-2 { margin-top: var(--ion-spacing-2) !important; }
  .ion-mt-sm-3 { margin-top: var(--ion-spacing-3) !important; }
  .ion-mt-sm-4 { margin-top: var(--ion-spacing-4) !important; }
  .ion-mt-sm-5 { margin-top: var(--ion-spacing-5) !important; }
  .ion-mt-sm-6 { margin-top: var(--ion-spacing-6) !important; }
  .ion-mt-sm-7 { margin-top: var(--ion-spacing-7) !important; }
  .ion-mt-sm-8 { margin-top: var(--ion-spacing-8) !important; }
  .ion-mt-sm-9 { margin-top: var(--ion-spacing-9) !important; }
  .ion-mt-sm-10 { margin-top: var(--ion-spacing-10) !important; }
  .ion-mt-sm-11 { margin-top: var(--ion-spacing-11) !important; }
  .ion-mt-sm-12 { margin-top: var(--ion-spacing-12) !important; }
  .ion-mt-sm-auto { margin-top: auto !important; }

  .ion-me-sm-0 { margin-right: var(--ion-spacing-0) !important; }
  .ion-me-sm-1 { margin-right: var(--ion-spacing-1) !important; }
  .ion-me-sm-2 { margin-right: var(--ion-spacing-2) !important; }
  .ion-me-sm-3 { margin-right: var(--ion-spacing-3) !important; }
  .ion-me-sm-4 { margin-right: var(--ion-spacing-4) !important; }
  .ion-me-sm-5 { margin-right: var(--ion-spacing-5) !important; }
  .ion-me-sm-6 { margin-right: var(--ion-spacing-6) !important; }
  .ion-me-sm-7 { margin-right: var(--ion-spacing-7) !important; }
  .ion-me-sm-8 { margin-right: var(--ion-spacing-8) !important; }
  .ion-me-sm-9 { margin-right: var(--ion-spacing-9) !important; }
  .ion-me-sm-10 { margin-right: var(--ion-spacing-10) !important; }
  .ion-me-sm-11 { margin-right: var(--ion-spacing-11) !important; }
  .ion-me-sm-12 { margin-right: var(--ion-spacing-12) !important; }
  .ion-me-sm-auto { margin-right: auto !important; }

  .ion-mb-sm-0 { margin-bottom: var(--ion-spacing-0) !important; }
  .ion-mb-sm-1 { margin-bottom: var(--ion-spacing-1) !important; }
  .ion-mb-sm-2 { margin-bottom: var(--ion-spacing-2) !important; }
  .ion-mb-sm-3 { margin-bottom: var(--ion-spacing-3) !important; }
  .ion-mb-sm-4 { margin-bottom: var(--ion-spacing-4) !important; }
  .ion-mb-sm-5 { margin-bottom: var(--ion-spacing-5) !important; }
  .ion-mb-sm-6 { margin-bottom: var(--ion-spacing-6) !important; }
  .ion-mb-sm-7 { margin-bottom: var(--ion-spacing-7) !important; }
  .ion-mb-sm-8 { margin-bottom: var(--ion-spacing-8) !important; }
  .ion-mb-sm-9 { margin-bottom: var(--ion-spacing-9) !important; }
  .ion-mb-sm-10 { margin-bottom: var(--ion-spacing-10) !important; }
  .ion-mb-sm-11 { margin-bottom: var(--ion-spacing-11) !important; }
  .ion-mb-sm-12 { margin-bottom: var(--ion-spacing-12) !important; }
  .ion-mb-sm-auto { margin-bottom: auto !important; }

  .ion-ms-sm-0 { margin-left: var(--ion-spacing-0) !important; }
  .ion-ms-sm-1 { margin-left: var(--ion-spacing-1) !important; }
  .ion-ms-sm-2 { margin-left: var(--ion-spacing-2) !important; }
  .ion-ms-sm-3 { margin-left: var(--ion-spacing-3) !important; }
  .ion-ms-sm-4 { margin-left: var(--ion-spacing-4) !important; }
  .ion-ms-sm-5 { margin-left: var(--ion-spacing-5) !important; }
  .ion-ms-sm-6 { margin-left: var(--ion-spacing-6) !important; }
  .ion-ms-sm-7 { margin-left: var(--ion-spacing-7) !important; }
  .ion-ms-sm-8 { margin-left: var(--ion-spacing-8) !important; }
  .ion-ms-sm-9 { margin-left: var(--ion-spacing-9) !important; }
  .ion-ms-sm-10 { margin-left: var(--ion-spacing-10) !important; }
  .ion-ms-sm-11 { margin-left: var(--ion-spacing-11) !important; }
  .ion-ms-sm-12 { margin-left: var(--ion-spacing-12) !important; }
  .ion-ms-sm-auto { margin-left: auto !important; }
}

/* ===================================
   RESPONSIVE MARGIN UTILITIES - MD
   =================================== */
/* MD - ≥768px */
@media (min-width: 768px) {
  .ion-m-md-0 { margin: var(--ion-spacing-0) !important; }
  .ion-m-md-1 { margin: var(--ion-spacing-1) !important; }
  .ion-m-md-2 { margin: var(--ion-spacing-2) !important; }
  .ion-m-md-3 { margin: var(--ion-spacing-3) !important; }
  .ion-m-md-4 { margin: var(--ion-spacing-4) !important; }
  .ion-m-md-5 { margin: var(--ion-spacing-5) !important; }
  .ion-m-md-6 { margin: var(--ion-spacing-6) !important; }
  .ion-m-md-7 { margin: var(--ion-spacing-7) !important; }
  .ion-m-md-8 { margin: var(--ion-spacing-8) !important; }
  .ion-m-md-9 { margin: var(--ion-spacing-9) !important; }
  .ion-m-md-10 { margin: var(--ion-spacing-10) !important; }
  .ion-m-md-11 { margin: var(--ion-spacing-11) !important; }
  .ion-m-md-12 { margin: var(--ion-spacing-12) !important; }
  .ion-m-md-auto { margin: auto !important; }

  .ion-mx-md-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
  .ion-mx-md-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
  .ion-mx-md-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
  .ion-mx-md-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
  .ion-mx-md-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
  .ion-mx-md-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
  .ion-mx-md-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
  .ion-mx-md-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
  .ion-mx-md-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
  .ion-mx-md-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
  .ion-mx-md-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
  .ion-mx-md-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
  .ion-mx-md-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
  .ion-mx-md-auto { margin-left: auto !important; margin-right: auto !important; }

  .ion-my-md-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
  .ion-my-md-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
  .ion-my-md-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
  .ion-my-md-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
  .ion-my-md-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
  .ion-my-md-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
  .ion-my-md-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
  .ion-my-md-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
  .ion-my-md-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
  .ion-my-md-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
  .ion-my-md-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
  .ion-my-md-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
  .ion-my-md-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
  .ion-my-md-auto { margin-top: auto !important; margin-bottom: auto !important; }

  .ion-mt-md-0 { margin-top: var(--ion-spacing-0) !important; }
  .ion-mt-md-1 { margin-top: var(--ion-spacing-1) !important; }
  .ion-mt-md-2 { margin-top: var(--ion-spacing-2) !important; }
  .ion-mt-md-3 { margin-top: var(--ion-spacing-3) !important; }
  .ion-mt-md-4 { margin-top: var(--ion-spacing-4) !important; }
  .ion-mt-md-5 { margin-top: var(--ion-spacing-5) !important; }
  .ion-mt-md-6 { margin-top: var(--ion-spacing-6) !important; }
  .ion-mt-md-7 { margin-top: var(--ion-spacing-7) !important; }
  .ion-mt-md-8 { margin-top: var(--ion-spacing-8) !important; }
  .ion-mt-md-9 { margin-top: var(--ion-spacing-9) !important; }
  .ion-mt-md-10 { margin-top: var(--ion-spacing-10) !important; }
  .ion-mt-md-11 { margin-top: var(--ion-spacing-11) !important; }
  .ion-mt-md-12 { margin-top: var(--ion-spacing-12) !important; }
  .ion-mt-md-auto { margin-top: auto !important; }

  .ion-me-md-0 { margin-right: var(--ion-spacing-0) !important; }
  .ion-me-md-1 { margin-right: var(--ion-spacing-1) !important; }
  .ion-me-md-2 { margin-right: var(--ion-spacing-2) !important; }
  .ion-me-md-3 { margin-right: var(--ion-spacing-3) !important; }
  .ion-me-md-4 { margin-right: var(--ion-spacing-4) !important; }
  .ion-me-md-5 { margin-right: var(--ion-spacing-5) !important; }
  .ion-me-md-6 { margin-right: var(--ion-spacing-6) !important; }
  .ion-me-md-7 { margin-right: var(--ion-spacing-7) !important; }
  .ion-me-md-8 { margin-right: var(--ion-spacing-8) !important; }
  .ion-me-md-9 { margin-right: var(--ion-spacing-9) !important; }
  .ion-me-md-10 { margin-right: var(--ion-spacing-10) !important; }
  .ion-me-md-11 { margin-right: var(--ion-spacing-11) !important; }
  .ion-me-md-12 { margin-right: var(--ion-spacing-12) !important; }
  .ion-me-md-auto { margin-right: auto !important; }

  .ion-mb-md-0 { margin-bottom: var(--ion-spacing-0) !important; }
  .ion-mb-md-1 { margin-bottom: var(--ion-spacing-1) !important; }
  .ion-mb-md-2 { margin-bottom: var(--ion-spacing-2) !important; }
  .ion-mb-md-3 { margin-bottom: var(--ion-spacing-3) !important; }
  .ion-mb-md-4 { margin-bottom: var(--ion-spacing-4) !important; }
  .ion-mb-md-5 { margin-bottom: var(--ion-spacing-5) !important; }
  .ion-mb-md-6 { margin-bottom: var(--ion-spacing-6) !important; }
  .ion-mb-md-7 { margin-bottom: var(--ion-spacing-7) !important; }
  .ion-mb-md-8 { margin-bottom: var(--ion-spacing-8) !important; }
  .ion-mb-md-9 { margin-bottom: var(--ion-spacing-9) !important; }
  .ion-mb-md-10 { margin-bottom: var(--ion-spacing-10) !important; }
  .ion-mb-md-11 { margin-bottom: var(--ion-spacing-11) !important; }
  .ion-mb-md-12 { margin-bottom: var(--ion-spacing-12) !important; }
  .ion-mb-md-auto { margin-bottom: auto !important; }

  .ion-ms-md-0 { margin-left: var(--ion-spacing-0) !important; }
  .ion-ms-md-1 { margin-left: var(--ion-spacing-1) !important; }
  .ion-ms-md-2 { margin-left: var(--ion-spacing-2) !important; }
  .ion-ms-md-3 { margin-left: var(--ion-spacing-3) !important; }
  .ion-ms-md-4 { margin-left: var(--ion-spacing-4) !important; }
  .ion-ms-md-5 { margin-left: var(--ion-spacing-5) !important; }
  .ion-ms-md-6 { margin-left: var(--ion-spacing-6) !important; }
  .ion-ms-md-7 { margin-left: var(--ion-spacing-7) !important; }
  .ion-ms-md-8 { margin-left: var(--ion-spacing-8) !important; }
  .ion-ms-md-9 { margin-left: var(--ion-spacing-9) !important; }
  .ion-ms-md-10 { margin-left: var(--ion-spacing-10) !important; }
  .ion-ms-md-11 { margin-left: var(--ion-spacing-11) !important; }
  .ion-ms-md-12 { margin-left: var(--ion-spacing-12) !important; }
  .ion-ms-md-auto { margin-left: auto !important; }
}

/* ===================================
   RESPONSIVE MARGIN UTILITIES - LG
   =================================== */
/* LG - ≥992px */
@media (min-width: 992px) {
  .ion-m-lg-0 { margin: var(--ion-spacing-0) !important; }
  .ion-m-lg-1 { margin: var(--ion-spacing-1) !important; }
  .ion-m-lg-2 { margin: var(--ion-spacing-2) !important; }
  .ion-m-lg-3 { margin: var(--ion-spacing-3) !important; }
  .ion-m-lg-4 { margin: var(--ion-spacing-4) !important; }
  .ion-m-lg-5 { margin: var(--ion-spacing-5) !important; }
  .ion-m-lg-6 { margin: var(--ion-spacing-6) !important; }
  .ion-m-lg-7 { margin: var(--ion-spacing-7) !important; }
  .ion-m-lg-8 { margin: var(--ion-spacing-8) !important; }
  .ion-m-lg-9 { margin: var(--ion-spacing-9) !important; }
  .ion-m-lg-10 { margin: var(--ion-spacing-10) !important; }
  .ion-m-lg-11 { margin: var(--ion-spacing-11) !important; }
  .ion-m-lg-12 { margin: var(--ion-spacing-12) !important; }
  .ion-m-lg-auto { margin: auto !important; }

  .ion-mx-lg-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
  .ion-mx-lg-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
  .ion-mx-lg-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
  .ion-mx-lg-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
  .ion-mx-lg-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
  .ion-mx-lg-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
  .ion-mx-lg-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
  .ion-mx-lg-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
  .ion-mx-lg-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
  .ion-mx-lg-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
  .ion-mx-lg-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
  .ion-mx-lg-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
  .ion-mx-lg-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
  .ion-mx-lg-auto { margin-left: auto !important; margin-right: auto !important; }

  .ion-my-lg-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
  .ion-my-lg-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
  .ion-my-lg-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
  .ion-my-lg-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
  .ion-my-lg-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
  .ion-my-lg-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
  .ion-my-lg-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
  .ion-my-lg-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
  .ion-my-lg-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
  .ion-my-lg-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
  .ion-my-lg-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
  .ion-my-lg-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
  .ion-my-lg-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
  .ion-my-lg-auto { margin-top: auto !important; margin-bottom: auto !important; }

  .ion-mt-lg-0 { margin-top: var(--ion-spacing-0) !important; }
  .ion-mt-lg-1 { margin-top: var(--ion-spacing-1) !important; }
  .ion-mt-lg-2 { margin-top: var(--ion-spacing-2) !important; }
  .ion-mt-lg-3 { margin-top: var(--ion-spacing-3) !important; }
  .ion-mt-lg-4 { margin-top: var(--ion-spacing-4) !important; }
  .ion-mt-lg-5 { margin-top: var(--ion-spacing-5) !important; }
  .ion-mt-lg-6 { margin-top: var(--ion-spacing-6) !important; }
  .ion-mt-lg-7 { margin-top: var(--ion-spacing-7) !important; }
  .ion-mt-lg-8 { margin-top: var(--ion-spacing-8) !important; }
  .ion-mt-lg-9 { margin-top: var(--ion-spacing-9) !important; }
  .ion-mt-lg-10 { margin-top: var(--ion-spacing-10) !important; }
  .ion-mt-lg-11 { margin-top: var(--ion-spacing-11) !important; }
  .ion-mt-lg-12 { margin-top: var(--ion-spacing-12) !important; }
  .ion-mt-lg-auto { margin-top: auto !important; }

  .ion-me-lg-0 { margin-right: var(--ion-spacing-0) !important; }
  .ion-me-lg-1 { margin-right: var(--ion-spacing-1) !important; }
  .ion-me-lg-2 { margin-right: var(--ion-spacing-2) !important; }
  .ion-me-lg-3 { margin-right: var(--ion-spacing-3) !important; }
  .ion-me-lg-4 { margin-right: var(--ion-spacing-4) !important; }
  .ion-me-lg-5 { margin-right: var(--ion-spacing-5) !important; }
  .ion-me-lg-6 { margin-right: var(--ion-spacing-6) !important; }
  .ion-me-lg-7 { margin-right: var(--ion-spacing-7) !important; }
  .ion-me-lg-8 { margin-right: var(--ion-spacing-8) !important; }
  .ion-me-lg-9 { margin-right: var(--ion-spacing-9) !important; }
  .ion-me-lg-10 { margin-right: var(--ion-spacing-10) !important; }
  .ion-me-lg-11 { margin-right: var(--ion-spacing-11) !important; }
  .ion-me-lg-12 { margin-right: var(--ion-spacing-12) !important; }
  .ion-me-lg-auto { margin-right: auto !important; }

  .ion-mb-lg-0 { margin-bottom: var(--ion-spacing-0) !important; }
  .ion-mb-lg-1 { margin-bottom: var(--ion-spacing-1) !important; }
  .ion-mb-lg-2 { margin-bottom: var(--ion-spacing-2) !important; }
  .ion-mb-lg-3 { margin-bottom: var(--ion-spacing-3) !important; }
  .ion-mb-lg-4 { margin-bottom: var(--ion-spacing-4) !important; }
  .ion-mb-lg-5 { margin-bottom: var(--ion-spacing-5) !important; }
  .ion-mb-lg-6 { margin-bottom: var(--ion-spacing-6) !important; }
  .ion-mb-lg-7 { margin-bottom: var(--ion-spacing-7) !important; }
  .ion-mb-lg-8 { margin-bottom: var(--ion-spacing-8) !important; }
  .ion-mb-lg-9 { margin-bottom: var(--ion-spacing-9) !important; }
  .ion-mb-lg-10 { margin-bottom: var(--ion-spacing-10) !important; }
  .ion-mb-lg-11 { margin-bottom: var(--ion-spacing-11) !important; }
  .ion-mb-lg-12 { margin-bottom: var(--ion-spacing-12) !important; }
  .ion-mb-lg-auto { margin-bottom: auto !important; }

  .ion-ms-lg-0 { margin-left: var(--ion-spacing-0) !important; }
  .ion-ms-lg-1 { margin-left: var(--ion-spacing-1) !important; }
  .ion-ms-lg-2 { margin-left: var(--ion-spacing-2) !important; }
  .ion-ms-lg-3 { margin-left: var(--ion-spacing-3) !important; }
  .ion-ms-lg-4 { margin-left: var(--ion-spacing-4) !important; }
  .ion-ms-lg-5 { margin-left: var(--ion-spacing-5) !important; }
  .ion-ms-lg-6 { margin-left: var(--ion-spacing-6) !important; }
  .ion-ms-lg-7 { margin-left: var(--ion-spacing-7) !important; }
  .ion-ms-lg-8 { margin-left: var(--ion-spacing-8) !important; }
  .ion-ms-lg-9 { margin-left: var(--ion-spacing-9) !important; }
  .ion-ms-lg-10 { margin-left: var(--ion-spacing-10) !important; }
  .ion-ms-lg-11 { margin-left: var(--ion-spacing-11) !important; }
  .ion-ms-lg-12 { margin-left: var(--ion-spacing-12) !important; }
  .ion-ms-lg-auto { margin-left: auto !important; }
}

/* ===================================
   RESPONSIVE MARGIN UTILITIES - XL
   =================================== */
/* XL - ≥1200px */
@media (min-width: 1200px) {
  .ion-m-xl-0 { margin: var(--ion-spacing-0) !important; }
  .ion-m-xl-1 { margin: var(--ion-spacing-1) !important; }
  .ion-m-xl-2 { margin: var(--ion-spacing-2) !important; }
  .ion-m-xl-3 { margin: var(--ion-spacing-3) !important; }
  .ion-m-xl-4 { margin: var(--ion-spacing-4) !important; }
  .ion-m-xl-5 { margin: var(--ion-spacing-5) !important; }
  .ion-m-xl-6 { margin: var(--ion-spacing-6) !important; }
  .ion-m-xl-7 { margin: var(--ion-spacing-7) !important; }
  .ion-m-xl-8 { margin: var(--ion-spacing-8) !important; }
  .ion-m-xl-9 { margin: var(--ion-spacing-9) !important; }
  .ion-m-xl-10 { margin: var(--ion-spacing-10) !important; }
  .ion-m-xl-11 { margin: var(--ion-spacing-11) !important; }
  .ion-m-xl-12 { margin: var(--ion-spacing-12) !important; }
  .ion-m-xl-auto { margin: auto !important; }

  .ion-mx-xl-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
  .ion-mx-xl-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
  .ion-mx-xl-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
  .ion-mx-xl-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
  .ion-mx-xl-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
  .ion-mx-xl-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
  .ion-mx-xl-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
  .ion-mx-xl-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
  .ion-mx-xl-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
  .ion-mx-xl-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
  .ion-mx-xl-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
  .ion-mx-xl-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
  .ion-mx-xl-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
  .ion-mx-xl-auto { margin-left: auto !important; margin-right: auto !important; }

  .ion-my-xl-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
  .ion-my-xl-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
  .ion-my-xl-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
  .ion-my-xl-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
  .ion-my-xl-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
  .ion-my-xl-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
  .ion-my-xl-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
  .ion-my-xl-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
  .ion-my-xl-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
  .ion-my-xl-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
  .ion-my-xl-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
  .ion-my-xl-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
  .ion-my-xl-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
  .ion-my-xl-auto { margin-top: auto !important; margin-bottom: auto !important; }

  .ion-mt-xl-0 { margin-top: var(--ion-spacing-0) !important; }
  .ion-mt-xl-1 { margin-top: var(--ion-spacing-1) !important; }
  .ion-mt-xl-2 { margin-top: var(--ion-spacing-2) !important; }
  .ion-mt-xl-3 { margin-top: var(--ion-spacing-3) !important; }
  .ion-mt-xl-4 { margin-top: var(--ion-spacing-4) !important; }
  .ion-mt-xl-5 { margin-top: var(--ion-spacing-5) !important; }
  .ion-mt-xl-6 { margin-top: var(--ion-spacing-6) !important; }
  .ion-mt-xl-7 { margin-top: var(--ion-spacing-7) !important; }
  .ion-mt-xl-8 { margin-top: var(--ion-spacing-8) !important; }
  .ion-mt-xl-9 { margin-top: var(--ion-spacing-9) !important; }
  .ion-mt-xl-10 { margin-top: var(--ion-spacing-10) !important; }
  .ion-mt-xl-11 { margin-top: var(--ion-spacing-11) !important; }
  .ion-mt-xl-12 { margin-top: var(--ion-spacing-12) !important; }
  .ion-mt-xl-auto { margin-top: auto !important; }

  .ion-me-xl-0 { margin-right: var(--ion-spacing-0) !important; }
  .ion-me-xl-1 { margin-right: var(--ion-spacing-1) !important; }
  .ion-me-xl-2 { margin-right: var(--ion-spacing-2) !important; }
  .ion-me-xl-3 { margin-right: var(--ion-spacing-3) !important; }
  .ion-me-xl-4 { margin-right: var(--ion-spacing-4) !important; }
  .ion-me-xl-5 { margin-right: var(--ion-spacing-5) !important; }
  .ion-me-xl-6 { margin-right: var(--ion-spacing-6) !important; }
  .ion-me-xl-7 { margin-right: var(--ion-spacing-7) !important; }
  .ion-me-xl-8 { margin-right: var(--ion-spacing-8) !important; }
  .ion-me-xl-9 { margin-right: var(--ion-spacing-9) !important; }
  .ion-me-xl-10 { margin-right: var(--ion-spacing-10) !important; }
  .ion-me-xl-11 { margin-right: var(--ion-spacing-11) !important; }
  .ion-me-xl-12 { margin-right: var(--ion-spacing-12) !important; }
  .ion-me-xl-auto { margin-right: auto !important; }

  .ion-mb-xl-0 { margin-bottom: var(--ion-spacing-0) !important; }
  .ion-mb-xl-1 { margin-bottom: var(--ion-spacing-1) !important; }
  .ion-mb-xl-2 { margin-bottom: var(--ion-spacing-2) !important; }
  .ion-mb-xl-3 { margin-bottom: var(--ion-spacing-3) !important; }
  .ion-mb-xl-4 { margin-bottom: var(--ion-spacing-4) !important; }
  .ion-mb-xl-5 { margin-bottom: var(--ion-spacing-5) !important; }
  .ion-mb-xl-6 { margin-bottom: var(--ion-spacing-6) !important; }
  .ion-mb-xl-7 { margin-bottom: var(--ion-spacing-7) !important; }
  .ion-mb-xl-8 { margin-bottom: var(--ion-spacing-8) !important; }
  .ion-mb-xl-9 { margin-bottom: var(--ion-spacing-9) !important; }
  .ion-mb-xl-10 { margin-bottom: var(--ion-spacing-10) !important; }
  .ion-mb-xl-11 { margin-bottom: var(--ion-spacing-11) !important; }
  .ion-mb-xl-12 { margin-bottom: var(--ion-spacing-12) !important; }
  .ion-mb-xl-auto { margin-bottom: auto !important; }

  .ion-ms-xl-0 { margin-left: var(--ion-spacing-0) !important; }
  .ion-ms-xl-1 { margin-left: var(--ion-spacing-1) !important; }
  .ion-ms-xl-2 { margin-left: var(--ion-spacing-2) !important; }
  .ion-ms-xl-3 { margin-left: var(--ion-spacing-3) !important; }
  .ion-ms-xl-4 { margin-left: var(--ion-spacing-4) !important; }
  .ion-ms-xl-5 { margin-left: var(--ion-spacing-5) !important; }
  .ion-ms-xl-6 { margin-left: var(--ion-spacing-6) !important; }
  .ion-ms-xl-7 { margin-left: var(--ion-spacing-7) !important; }
  .ion-ms-xl-8 { margin-left: var(--ion-spacing-8) !important; }
  .ion-ms-xl-9 { margin-left: var(--ion-spacing-9) !important; }
  .ion-ms-xl-10 { margin-left: var(--ion-spacing-10) !important; }
  .ion-ms-xl-11 { margin-left: var(--ion-spacing-11) !important; }
  .ion-ms-xl-12 { margin-left: var(--ion-spacing-12) !important; }
  .ion-ms-xl-auto { margin-left: auto !important; }
}

/* ===================================
   RESPONSIVE MARGIN UTILITIES - XXL
   =================================== */
/* XXL - ≥1400px */
@media (min-width: 1400px) {
  .ion-m-xxl-0 { margin: var(--ion-spacing-0) !important; }
  .ion-m-xxl-1 { margin: var(--ion-spacing-1) !important; }
  .ion-m-xxl-2 { margin: var(--ion-spacing-2) !important; }
  .ion-m-xxl-3 { margin: var(--ion-spacing-3) !important; }
  .ion-m-xxl-4 { margin: var(--ion-spacing-4) !important; }
  .ion-m-xxl-5 { margin: var(--ion-spacing-5) !important; }
  .ion-m-xxl-6 { margin: var(--ion-spacing-6) !important; }
  .ion-m-xxl-7 { margin: var(--ion-spacing-7) !important; }
  .ion-m-xxl-8 { margin: var(--ion-spacing-8) !important; }
  .ion-m-xxl-9 { margin: var(--ion-spacing-9) !important; }
  .ion-m-xxl-10 { margin: var(--ion-spacing-10) !important; }
  .ion-m-xxl-11 { margin: var(--ion-spacing-11) !important; }
  .ion-m-xxl-12 { margin: var(--ion-spacing-12) !important; }
  .ion-m-xxl-auto { margin: auto !important; }

  .ion-mx-xxl-0 { margin-left: var(--ion-spacing-0) !important; margin-right: var(--ion-spacing-0) !important; }
  .ion-mx-xxl-1 { margin-left: var(--ion-spacing-1) !important; margin-right: var(--ion-spacing-1) !important; }
  .ion-mx-xxl-2 { margin-left: var(--ion-spacing-2) !important; margin-right: var(--ion-spacing-2) !important; }
  .ion-mx-xxl-3 { margin-left: var(--ion-spacing-3) !important; margin-right: var(--ion-spacing-3) !important; }
  .ion-mx-xxl-4 { margin-left: var(--ion-spacing-4) !important; margin-right: var(--ion-spacing-4) !important; }
  .ion-mx-xxl-5 { margin-left: var(--ion-spacing-5) !important; margin-right: var(--ion-spacing-5) !important; }
  .ion-mx-xxl-6 { margin-left: var(--ion-spacing-6) !important; margin-right: var(--ion-spacing-6) !important; }
  .ion-mx-xxl-7 { margin-left: var(--ion-spacing-7) !important; margin-right: var(--ion-spacing-7) !important; }
  .ion-mx-xxl-8 { margin-left: var(--ion-spacing-8) !important; margin-right: var(--ion-spacing-8) !important; }
  .ion-mx-xxl-9 { margin-left: var(--ion-spacing-9) !important; margin-right: var(--ion-spacing-9) !important; }
  .ion-mx-xxl-10 { margin-left: var(--ion-spacing-10) !important; margin-right: var(--ion-spacing-10) !important; }
  .ion-mx-xxl-11 { margin-left: var(--ion-spacing-11) !important; margin-right: var(--ion-spacing-11) !important; }
  .ion-mx-xxl-12 { margin-left: var(--ion-spacing-12) !important; margin-right: var(--ion-spacing-12) !important; }
  .ion-mx-xxl-auto { margin-left: auto !important; margin-right: auto !important; }

  .ion-my-xxl-0 { margin-top: var(--ion-spacing-0) !important; margin-bottom: var(--ion-spacing-0) !important; }
  .ion-my-xxl-1 { margin-top: var(--ion-spacing-1) !important; margin-bottom: var(--ion-spacing-1) !important; }
  .ion-my-xxl-2 { margin-top: var(--ion-spacing-2) !important; margin-bottom: var(--ion-spacing-2) !important; }
  .ion-my-xxl-3 { margin-top: var(--ion-spacing-3) !important; margin-bottom: var(--ion-spacing-3) !important; }
  .ion-my-xxl-4 { margin-top: var(--ion-spacing-4) !important; margin-bottom: var(--ion-spacing-4) !important; }
  .ion-my-xxl-5 { margin-top: var(--ion-spacing-5) !important; margin-bottom: var(--ion-spacing-5) !important; }
  .ion-my-xxl-6 { margin-top: var(--ion-spacing-6) !important; margin-bottom: var(--ion-spacing-6) !important; }
  .ion-my-xxl-7 { margin-top: var(--ion-spacing-7) !important; margin-bottom: var(--ion-spacing-7) !important; }
  .ion-my-xxl-8 { margin-top: var(--ion-spacing-8) !important; margin-bottom: var(--ion-spacing-8) !important; }
  .ion-my-xxl-9 { margin-top: var(--ion-spacing-9) !important; margin-bottom: var(--ion-spacing-9) !important; }
  .ion-my-xxl-10 { margin-top: var(--ion-spacing-10) !important; margin-bottom: var(--ion-spacing-10) !important; }
  .ion-my-xxl-11 { margin-top: var(--ion-spacing-11) !important; margin-bottom: var(--ion-spacing-11) !important; }
  .ion-my-xxl-12 { margin-top: var(--ion-spacing-12) !important; margin-bottom: var(--ion-spacing-12) !important; }
  .ion-my-xxl-auto { margin-top: auto !important; margin-bottom: auto !important; }

  .ion-mt-xxl-0 { margin-top: var(--ion-spacing-0) !important; }
  .ion-mt-xxl-1 { margin-top: var(--ion-spacing-1) !important; }
  .ion-mt-xxl-2 { margin-top: var(--ion-spacing-2) !important; }
  .ion-mt-xxl-3 { margin-top: var(--ion-spacing-3) !important; }
  .ion-mt-xxl-4 { margin-top: var(--ion-spacing-4) !important; }
  .ion-mt-xxl-5 { margin-top: var(--ion-spacing-5) !important; }
  .ion-mt-xxl-6 { margin-top: var(--ion-spacing-6) !important; }
  .ion-mt-xxl-7 { margin-top: var(--ion-spacing-7) !important; }
  .ion-mt-xxl-8 { margin-top: var(--ion-spacing-8) !important; }
  .ion-mt-xxl-9 { margin-top: var(--ion-spacing-9) !important; }
  .ion-mt-xxl-10 { margin-top: var(--ion-spacing-10) !important; }
  .ion-mt-xxl-11 { margin-top: var(--ion-spacing-11) !important; }
  .ion-mt-xxl-12 { margin-top: var(--ion-spacing-12) !important; }
  .ion-mt-xxl-auto { margin-top: auto !important; }

  .ion-me-xxl-0 { margin-right: var(--ion-spacing-0) !important; }
  .ion-me-xxl-1 { margin-right: var(--ion-spacing-1) !important; }
  .ion-me-xxl-2 { margin-right: var(--ion-spacing-2) !important; }
  .ion-me-xxl-3 { margin-right: var(--ion-spacing-3) !important; }
  .ion-me-xxl-4 { margin-right: var(--ion-spacing-4) !important; }
  .ion-me-xxl-5 { margin-right: var(--ion-spacing-5) !important; }
  .ion-me-xxl-6 { margin-right: var(--ion-spacing-6) !important; }
  .ion-me-xxl-7 { margin-right: var(--ion-spacing-7) !important; }
  .ion-me-xxl-8 { margin-right: var(--ion-spacing-8) !important; }
  .ion-me-xxl-9 { margin-right: var(--ion-spacing-9) !important; }
  .ion-me-xxl-10 { margin-right: var(--ion-spacing-10) !important; }
  .ion-me-xxl-11 { margin-right: var(--ion-spacing-11) !important; }
  .ion-me-xxl-12 { margin-right: var(--ion-spacing-12) !important; }
  .ion-me-xxl-auto { margin-right: auto !important; }

  .ion-mb-xxl-0 { margin-bottom: var(--ion-spacing-0) !important; }
  .ion-mb-xxl-1 { margin-bottom: var(--ion-spacing-1) !important; }
  .ion-mb-xxl-2 { margin-bottom: var(--ion-spacing-2) !important; }
  .ion-mb-xxl-3 { margin-bottom: var(--ion-spacing-3) !important; }
  .ion-mb-xxl-4 { margin-bottom: var(--ion-spacing-4) !important; }
  .ion-mb-xxl-5 { margin-bottom: var(--ion-spacing-5) !important; }
  .ion-mb-xxl-6 { margin-bottom: var(--ion-spacing-6) !important; }
  .ion-mb-xxl-7 { margin-bottom: var(--ion-spacing-7) !important; }
  .ion-mb-xxl-8 { margin-bottom: var(--ion-spacing-8) !important; }
  .ion-mb-xxl-9 { margin-bottom: var(--ion-spacing-9) !important; }
  .ion-mb-xxl-10 { margin-bottom: var(--ion-spacing-10) !important; }
  .ion-mb-xxl-11 { margin-bottom: var(--ion-spacing-11) !important; }
  .ion-mb-xxl-12 { margin-bottom: var(--ion-spacing-12) !important; }
  .ion-mb-xxl-auto { margin-bottom: auto !important; }

  .ion-ms-xxl-0 { margin-left: var(--ion-spacing-0) !important; }
  .ion-ms-xxl-1 { margin-left: var(--ion-spacing-1) !important; }
  .ion-ms-xxl-2 { margin-left: var(--ion-spacing-2) !important; }
  .ion-ms-xxl-3 { margin-left: var(--ion-spacing-3) !important; }
  .ion-ms-xxl-4 { margin-left: var(--ion-spacing-4) !important; }
  .ion-ms-xxl-5 { margin-left: var(--ion-spacing-5) !important; }
  .ion-ms-xxl-6 { margin-left: var(--ion-spacing-6) !important; }
  .ion-ms-xxl-7 { margin-left: var(--ion-spacing-7) !important; }
  .ion-ms-xxl-8 { margin-left: var(--ion-spacing-8) !important; }
  .ion-ms-xxl-9 { margin-left: var(--ion-spacing-9) !important; }
  .ion-ms-xxl-10 { margin-left: var(--ion-spacing-10) !important; }
  .ion-ms-xxl-11 { margin-left: var(--ion-spacing-11) !important; }
  .ion-ms-xxl-12 { margin-left: var(--ion-spacing-12) !important; }
  .ion-ms-xxl-auto { margin-left: auto !important; }
}

/* ===================================
   GUTTER UTILITIES
   =================================== */
/* Gutter - Both X and Y */
.ion-g-0 { --ion-gutter-x: var(--ion-spacing-0); --ion-gutter-y: var(--ion-spacing-0); }
.ion-g-1 { --ion-gutter-x: var(--ion-spacing-1); --ion-gutter-y: var(--ion-spacing-1); }
.ion-g-2 { --ion-gutter-x: var(--ion-spacing-2); --ion-gutter-y: var(--ion-spacing-2); }
.ion-g-3 { --ion-gutter-x: var(--ion-spacing-3); --ion-gutter-y: var(--ion-spacing-3); }
.ion-g-4 { --ion-gutter-x: var(--ion-spacing-4); --ion-gutter-y: var(--ion-spacing-4); }
.ion-g-5 { --ion-gutter-x: var(--ion-spacing-5); --ion-gutter-y: var(--ion-spacing-5); }
.ion-g-6 { --ion-gutter-x: var(--ion-spacing-6); --ion-gutter-y: var(--ion-spacing-6); }
.ion-g-7 { --ion-gutter-x: var(--ion-spacing-7); --ion-gutter-y: var(--ion-spacing-7); }
.ion-g-8 { --ion-gutter-x: var(--ion-spacing-8); --ion-gutter-y: var(--ion-spacing-8); }
.ion-g-9 { --ion-gutter-x: var(--ion-spacing-9); --ion-gutter-y: var(--ion-spacing-9); }
.ion-g-10 { --ion-gutter-x: var(--ion-spacing-10); --ion-gutter-y: var(--ion-spacing-10); }
.ion-g-11 { --ion-gutter-x: var(--ion-spacing-11); --ion-gutter-y: var(--ion-spacing-11); }
.ion-g-12 { --ion-gutter-x: var(--ion-spacing-12); --ion-gutter-y: var(--ion-spacing-12); }

/* Gutter - X (Horizontal) */
.ion-gx-0 { --ion-gutter-x: var(--ion-spacing-0); }
.ion-gx-1 { --ion-gutter-x: var(--ion-spacing-1); }
.ion-gx-2 { --ion-gutter-x: var(--ion-spacing-2); }
.ion-gx-3 { --ion-gutter-x: var(--ion-spacing-3); }
.ion-gx-4 { --ion-gutter-x: var(--ion-spacing-4); }
.ion-gx-5 { --ion-gutter-x: var(--ion-spacing-5); }
.ion-gx-6 { --ion-gutter-x: var(--ion-spacing-6); }
.ion-gx-7 { --ion-gutter-x: var(--ion-spacing-7); }
.ion-gx-8 { --ion-gutter-x: var(--ion-spacing-8); }
.ion-gx-9 { --ion-gutter-x: var(--ion-spacing-9); }
.ion-gx-10 { --ion-gutter-x: var(--ion-spacing-10); }
.ion-gx-11 { --ion-gutter-x: var(--ion-spacing-11); }
.ion-gx-12 { --ion-gutter-x: var(--ion-spacing-12); }

/* Gutter - Y (Vertical) */
.ion-gy-0 { --ion-gutter-y: var(--ion-spacing-0); }
.ion-gy-1 { --ion-gutter-y: var(--ion-spacing-1); }
.ion-gy-2 { --ion-gutter-y: var(--ion-spacing-2); }
.ion-gy-3 { --ion-gutter-y: var(--ion-spacing-3); }
.ion-gy-4 { --ion-gutter-y: var(--ion-spacing-4); }
.ion-gy-5 { --ion-gutter-y: var(--ion-spacing-5); }
.ion-gy-6 { --ion-gutter-y: var(--ion-spacing-6); }
.ion-gy-7 { --ion-gutter-y: var(--ion-spacing-7); }
.ion-gy-8 { --ion-gutter-y: var(--ion-spacing-8); }
.ion-gy-9 { --ion-gutter-y: var(--ion-spacing-9); }
.ion-gy-10 { --ion-gutter-y: var(--ion-spacing-10); }
.ion-gy-11 { --ion-gutter-y: var(--ion-spacing-11); }
.ion-gy-12 { --ion-gutter-y: var(--ion-spacing-12); }
/* ===================================
   TEXT ALIGNMENT
   =================================== */
/* Logical properties (start/end) */
.ion-text-start { text-align: left !important; }
.ion-text-center { text-align: center !important; }
.ion-text-end { text-align: right !important; }

/* Legacy properties (left/right) for backwards compatibility */
.ion-text-left { text-align: left !important; }
.ion-text-right { text-align: right !important; }

/* Text Alignment - Responsive */
@media (min-width: 576px) {
  .ion-text-sm-start { text-align: left !important; }
  .ion-text-sm-center { text-align: center !important; }
  .ion-text-sm-end { text-align: right !important; }
  .ion-text-sm-left { text-align: left !important; }
  .ion-text-sm-right { text-align: right !important; }
}

@media (min-width: 768px) {
  .ion-text-md-start { text-align: left !important; }
  .ion-text-md-center { text-align: center !important; }
  .ion-text-md-end { text-align: right !important; }
  .ion-text-md-left { text-align: left !important; }
  .ion-text-md-right { text-align: right !important; }
}

@media (min-width: 992px) {
  .ion-text-lg-start { text-align: left !important; }
  .ion-text-lg-center { text-align: center !important; }
  .ion-text-lg-end { text-align: right !important; }
  .ion-text-lg-left { text-align: left !important; }
  .ion-text-lg-right { text-align: right !important; }
}

@media (min-width: 1200px) {
  .ion-text-xl-start { text-align: left !important; }
  .ion-text-xl-center { text-align: center !important; }
  .ion-text-xl-end { text-align: right !important; }
  .ion-text-xl-left { text-align: left !important; }
  .ion-text-xl-right { text-align: right !important; }
}

@media (min-width: 1400px) {
  .ion-text-xxl-start { text-align: left !important; }
  .ion-text-xxl-center { text-align: center !important; }
  .ion-text-xxl-end { text-align: right !important; }
  .ion-text-xxl-left { text-align: left !important; }
  .ion-text-xxl-right { text-align: right !important; }
}

/* ===================================
   FLEXBOX UTILITIES
   =================================== */
.ion-d-flex { display: flex !important; }
.ion-d-inline-flex { display: inline-flex !important; }
.ion-d-block { display: block !important; }
.ion-d-inline-block { display: inline-block !important; }
.ion-d-none { display: none !important; }

/* Flex Direction */
.ion-flex-row { flex-direction: row !important; }
.ion-flex-column { flex-direction: column !important; }
.ion-flex-row-reverse { flex-direction: row-reverse !important; }
.ion-flex-column-reverse { flex-direction: column-reverse !important; }

/* Justify Content */
.ion-justify-content-start { justify-content: flex-start !important; }
.ion-justify-content-end { justify-content: flex-end !important; }
.ion-justify-content-center { justify-content: center !important; }
.ion-justify-content-between { justify-content: space-between !important; }
.ion-justify-content-around { justify-content: space-around !important; }
.ion-justify-content-evenly { justify-content: space-evenly !important; }

/* Align Items */
.ion-align-items-start { align-items: flex-start !important; }
.ion-align-items-end { align-items: flex-end !important; }
.ion-align-items-center { align-items: center !important; }
.ion-align-items-baseline { align-items: baseline !important; }
.ion-align-items-stretch { align-items: stretch !important; }

/* Align Content */
.ion-align-content-start { align-content: flex-start !important; }
.ion-align-content-end { align-content: flex-end !important; }
.ion-align-content-center { align-content: center !important; }
.ion-align-content-between { align-content: space-between !important; }
.ion-align-content-around { align-content: space-around !important; }
.ion-align-content-stretch { align-content: stretch !important; }

/* Align Self */
.ion-align-self-start { align-self: flex-start !important; }
.ion-align-self-end { align-self: flex-end !important; }
.ion-align-self-center { align-self: center !important; }
.ion-align-self-baseline { align-self: baseline !important; }
.ion-align-self-stretch { align-self: stretch !important; }

/* Flex Wrap */
.ion-flex-wrap { flex-wrap: wrap !important; }
.ion-flex-nowrap { flex-wrap: nowrap !important; }
.ion-flex-wrap-reverse { flex-wrap: wrap-reverse !important; }

/* Flex Grow & Shrink */
.ion-flex-grow-0 { flex-grow: 0 !important; }
.ion-flex-grow-1 { flex-grow: 1 !important; }
.ion-flex-shrink-0 { flex-shrink: 0 !important; }
.ion-flex-shrink-1 { flex-shrink: 1 !important; }

/* ===================================
   BUTTON STYLES
   =================================== */
.ion-btn {
  display: inline-block;
  font-size: var(--ion-btn-font-size);
  font-weight: 500;
  line-height: 1.3;
  padding: var(--ion-btn-padding-y) var(--ion-btn-padding-x);
  border: none;
  border-radius: var(--ion-btn-border-radius);
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s ease;
}

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

.ion-btn-primary:hover,
.ion-btn-primary:focus {
  background: var(--ion-btn-primary-hover-bg)!important;
  color: var(--ion-btn-primary-hover-color)!important;
  text-decoration: none;
}

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

.ion-btn-secondary:hover,
.ion-btn-secondary:focus {
  background: var(--ion-btn-secondary-hover-bg)!important;
  color: var(--ion-btn-secondary-hover-color)!important;
  text-decoration: none;
}

.ion-btn-tertiary {
  background: var(--ion-btn-tertiary-bg)!important;
  color: var(--ion-btn-tertiary-color)!important;
}

.ion-btn-tertiary:hover,
.ion-btn-tertiary:focus {
  background: var(--ion-btn-tertiary-hover-bg)!important;
  color: var(--ion-btn-tertiary-hover-color)!important;
  text-decoration: none;
}

/* ===================================
   FORM CONTROLS
   =================================== */
input[type="text"],
input[type="email"],
input[type="password"],
input[type="number"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="date"],
input[type="time"],
input[type="datetime-local"],
textarea,
select,
.ion-form-control {
  display: inline-block;
  width: 100%;
  padding: .7rem 1rem;
  font-size: 1.6rem;
  font-family: inherit;
  line-height: 1.5;
  color: var(--ion-body-color);
  background-color: #fff;
  background-clip: padding-box;
  border: 1px solid #ced4da;
  border-radius: 0.4rem;
  transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="password"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="url"]:focus,
input[type="search"]:focus,
input[type="date"]:focus,
input[type="time"]:focus,
input[type="datetime-local"]:focus,
textarea:focus,
select:focus,
.ion-form-control:focus {
  color: var(--ion-body-color);
  background-color: #fff;
  border-color: var(--ion-focus-ring-color);
  box-shadow: 0 0 0 0.2rem rgba(0, 91, 168, 0.25);
}

/* Disabled state */
input:disabled,
textarea:disabled,
select:disabled,
.ion-form-control:disabled {
  background-color: #e9ecef;
  opacity: 1;
  cursor: not-allowed;
}

/* Textarea specific */
textarea {
  min-height: 10rem;
  resize: vertical;
}

/* Select specific */
select {
  cursor: pointer;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background-color: #fff !important;
}

select:not([multiple]):not([size]) {
  background-color: #fff !important;
  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 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 16px 12px;
  padding-right: 3.5rem;
}


/* Form Select (specific class) */
.ion-form-select {
  display: block;
  width: 100%;
  padding: .7rem 1rem;
  font-size: 1.6rem;
  font-family: inherit;
  line-height: 1.5;
  color: var(--ion-body-color);
  background-color: #fff;
  border: 1px solid #ced4da;
  border-radius: 0.4rem;
  cursor: pointer;
  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 5l6 6 6-6'/%3e%3c/svg%3e");
  background-repeat: no-repeat;
  background-position: right 1rem center;
  background-size: 16px 12px;
  padding-right: 3.5rem;
}

form img{padding:0 !important; border:none !important}
/* ===================================
   ORDER UTILITIES
   =================================== */
.ion-order-first { order: -1 !important; }
.ion-order-0 { order: 0 !important; }
.ion-order-1 { order: 1 !important; }
.ion-order-2 { order: 2 !important; }
.ion-order-3 { order: 3 !important; }
.ion-order-4 { order: 4 !important; }
.ion-order-5 { order: 5 !important; }
.ion-order-last { order: 6 !important; }

/* Order - Responsive Small */
@media (min-width: 576px) {
  .ion-order-sm-first { order: -1 !important; }
  .ion-order-sm-0 { order: 0 !important; }
  .ion-order-sm-1 { order: 1 !important; }
  .ion-order-sm-2 { order: 2 !important; }
  .ion-order-sm-3 { order: 3 !important; }
  .ion-order-sm-4 { order: 4 !important; }
  .ion-order-sm-5 { order: 5 !important; }
  .ion-order-sm-last { order: 6 !important; }
}

/* Order - Responsive Medium */
@media (min-width: 768px) {
  .ion-order-md-first { order: -1 !important; }
  .ion-order-md-0 { order: 0 !important; }
  .ion-order-md-1 { order: 1 !important; }
  .ion-order-md-2 { order: 2 !important; }
  .ion-order-md-3 { order: 3 !important; }
  .ion-order-md-4 { order: 4 !important; }
  .ion-order-md-5 { order: 5 !important; }
  .ion-order-md-last { order: 6 !important; }
}

/* Order - Responsive Large */
@media (min-width: 992px) {
  .ion-order-lg-first { order: -1 !important; }
  .ion-order-lg-0 { order: 0 !important; }
  .ion-order-lg-1 { order: 1 !important; }
  .ion-order-lg-2 { order: 2 !important; }
  .ion-order-lg-3 { order: 3 !important; }
  .ion-order-lg-4 { order: 4 !important; }
  .ion-order-lg-5 { order: 5 !important; }
  .ion-order-lg-last { order: 6 !important; }
}

/* Order - Responsive XL */
@media (min-width: 1200px) {
  .ion-order-xl-first { order: -1 !important; }
  .ion-order-xl-0 { order: 0 !important; }
  .ion-order-xl-1 { order: 1 !important; }
  .ion-order-xl-2 { order: 2 !important; }
  .ion-order-xl-3 { order: 3 !important; }
  .ion-order-xl-4 { order: 4 !important; }
  .ion-order-xl-5 { order: 5 !important; }
  .ion-order-xl-last { order: 6 !important; }
}

/* ===================================
   DISPLAY UTILITIES - RESPONSIVE
   =================================== */
@media (min-width: 576px) {
  .ion-d-sm-flex { display: flex !important; }
  .ion-d-sm-inline-flex { display: inline-flex !important; }
  .ion-d-sm-block { display: block !important; }
  .ion-d-sm-inline-block { display: inline-block !important; }
  .ion-d-sm-none { display: none !important; }
}

@media (min-width: 768px) {
  .ion-d-md-flex { display: flex !important; }
  .ion-d-md-inline-flex { display: inline-flex !important; }
  .ion-d-md-block { display: block !important; }
  .ion-d-md-inline-block { display: inline-block !important; }
  .ion-d-md-none { display: none !important; }
}

@media (min-width: 992px) {
  .ion-d-lg-flex { display: flex !important; }
  .ion-d-lg-inline-flex { display: inline-flex !important; }
  .ion-d-lg-block { display: block !important; }
  .ion-d-lg-inline-block { display: inline-block !important; }
  .ion-d-lg-none { display: none !important; }
}

@media (min-width: 1200px) {
  .ion-d-xl-flex { display: flex !important; }
  .ion-d-xl-inline-flex { display: inline-flex !important; }
  .ion-d-xl-block { display: block !important; }
  .ion-d-xl-inline-block { display: inline-block !important; }
  .ion-d-xl-none { display: none !important; }
}
/* ===================================
   RESPONSIVE GUTTER UTILITIES
   (Using CSS Variables - Bootstrap pattern)
   =================================== */

/* Small (sm) - ≥576px */
@media (min-width: 576px) {
  .ion-g-sm-0, .ion-gx-sm-0 { --ion-gutter-x: var(--ion-spacing-0); }
  .ion-g-sm-0, .ion-gy-sm-0 { --ion-gutter-y: var(--ion-spacing-0); }
  
  .ion-g-sm-1, .ion-gx-sm-1 { --ion-gutter-x: var(--ion-spacing-1); }
  .ion-g-sm-1, .ion-gy-sm-1 { --ion-gutter-y: var(--ion-spacing-1); }
  
  .ion-g-sm-2, .ion-gx-sm-2 { --ion-gutter-x: var(--ion-spacing-2); }
  .ion-g-sm-2, .ion-gy-sm-2 { --ion-gutter-y: var(--ion-spacing-2); }
  
  .ion-g-sm-3, .ion-gx-sm-3 { --ion-gutter-x: var(--ion-spacing-3); }
  .ion-g-sm-3, .ion-gy-sm-3 { --ion-gutter-y: var(--ion-spacing-3); }
  
  .ion-g-sm-4, .ion-gx-sm-4 { --ion-gutter-x: var(--ion-spacing-4); }
  .ion-g-sm-4, .ion-gy-sm-4 { --ion-gutter-y: var(--ion-spacing-4); }
  
  .ion-g-sm-5, .ion-gx-sm-5 { --ion-gutter-x: var(--ion-spacing-5); }
  .ion-g-sm-5, .ion-gy-sm-5 { --ion-gutter-y: var(--ion-spacing-5); }
}

/* Medium (md) - ≥768px */
@media (min-width: 768px) {
  .ion-g-md-0, .ion-gx-md-0 { --ion-gutter-x: var(--ion-spacing-0); }
  .ion-g-md-0, .ion-gy-md-0 { --ion-gutter-y: var(--ion-spacing-0); }
  
  .ion-g-md-1, .ion-gx-md-1 { --ion-gutter-x: var(--ion-spacing-1); }
  .ion-g-md-1, .ion-gy-md-1 { --ion-gutter-y: var(--ion-spacing-1); }
  
  .ion-g-md-2, .ion-gx-md-2 { --ion-gutter-x: var(--ion-spacing-2); }
  .ion-g-md-2, .ion-gy-md-2 { --ion-gutter-y: var(--ion-spacing-2); }
  
  .ion-g-md-3, .ion-gx-md-3 { --ion-gutter-x: var(--ion-spacing-3); }
  .ion-g-md-3, .ion-gy-md-3 { --ion-gutter-y: var(--ion-spacing-3); }
  
  .ion-g-md-4, .ion-gx-md-4 { --ion-gutter-x: var(--ion-spacing-4); }
  .ion-g-md-4, .ion-gy-md-4 { --ion-gutter-y: var(--ion-spacing-4); }
  
  .ion-g-md-5, .ion-gx-md-5 { --ion-gutter-x: var(--ion-spacing-5); }
  .ion-g-md-5, .ion-gy-md-5 { --ion-gutter-y: var(--ion-spacing-5); }
}

/* Large (lg) - ≥992px */
@media (min-width: 992px) {
  .ion-g-lg-0, .ion-gx-lg-0 { --ion-gutter-x: var(--ion-spacing-0); }
  .ion-g-lg-0, .ion-gy-lg-0 { --ion-gutter-y: var(--ion-spacing-0); }
  
  .ion-g-lg-1, .ion-gx-lg-1 { --ion-gutter-x: var(--ion-spacing-1); }
  .ion-g-lg-1, .ion-gy-lg-1 { --ion-gutter-y: var(--ion-spacing-1); }
  
  .ion-g-lg-2, .ion-gx-lg-2 { --ion-gutter-x: var(--ion-spacing-2); }
  .ion-g-lg-2, .ion-gy-lg-2 { --ion-gutter-y: var(--ion-spacing-2); }
  
  .ion-g-lg-3, .ion-gx-lg-3 { --ion-gutter-x: var(--ion-spacing-3); }
  .ion-g-lg-3, .ion-gy-lg-3 { --ion-gutter-y: var(--ion-spacing-3); }
  
  .ion-g-lg-4, .ion-gx-lg-4 { --ion-gutter-x: var(--ion-spacing-4); }
  .ion-g-lg-4, .ion-gy-lg-4 { --ion-gutter-y: var(--ion-spacing-4); }
  
  .ion-g-lg-5, .ion-gx-lg-5 { --ion-gutter-x: var(--ion-spacing-5); }
  .ion-g-lg-5, .ion-gy-lg-5 { --ion-gutter-y: var(--ion-spacing-5); }
}

/* Extra Large (xl) - ≥1200px */
@media (min-width: 1200px) {
  .ion-g-xl-0, .ion-gx-xl-0 { --ion-gutter-x: var(--ion-spacing-0); }
  .ion-g-xl-0, .ion-gy-xl-0 { --ion-gutter-y: var(--ion-spacing-0); }
  
  .ion-g-xl-1, .ion-gx-xl-1 { --ion-gutter-x: var(--ion-spacing-1); }
  .ion-g-xl-1, .ion-gy-xl-1 { --ion-gutter-y: var(--ion-spacing-1); }
  
  .ion-g-xl-2, .ion-gx-xl-2 { --ion-gutter-x: var(--ion-spacing-2); }
  .ion-g-xl-2, .ion-gy-xl-2 { --ion-gutter-y: var(--ion-spacing-2); }
  
  .ion-g-xl-3, .ion-gx-xl-3 { --ion-gutter-x: var(--ion-spacing-3); }
  .ion-g-xl-3, .ion-gy-xl-3 { --ion-gutter-y: var(--ion-spacing-3); }
  
  .ion-g-xl-4, .ion-gx-xl-4 { --ion-gutter-x: var(--ion-spacing-4); }
  .ion-g-xl-4, .ion-gy-xl-4 { --ion-gutter-y: var(--ion-spacing-4); }
  
  .ion-g-xl-5, .ion-gx-xl-5 { --ion-gutter-x: var(--ion-spacing-5); }
  .ion-g-xl-5, .ion-gy-xl-5 { --ion-gutter-y: var(--ion-spacing-5); }
}

/* XXL (xxl) - ≥1400px */
@media (min-width: 1400px) {
  .ion-g-xxl-0, .ion-gx-xxl-0 { --ion-gutter-x: var(--ion-spacing-0); }
  .ion-g-xxl-0, .ion-gy-xxl-0 { --ion-gutter-y: var(--ion-spacing-0); }
  
  .ion-g-xxl-1, .ion-gx-xxl-1 { --ion-gutter-x: var(--ion-spacing-1); }
  .ion-g-xxl-1, .ion-gy-xxl-1 { --ion-gutter-y: var(--ion-spacing-1); }
  
  .ion-g-xxl-2, .ion-gx-xxl-2 { --ion-gutter-x: var(--ion-spacing-2); }
  .ion-g-xxl-2, .ion-gy-xxl-2 { --ion-gutter-y: var(--ion-spacing-2); }
  
  .ion-g-xxl-3, .ion-gx-xxl-3 { --ion-gutter-x: var(--ion-spacing-3); }
  .ion-g-xxl-3, .ion-gy-xxl-3 { --ion-gutter-y: var(--ion-spacing-3); }
  
  .ion-g-xxl-4, .ion-gx-xxl-4 { --ion-gutter-x: var(--ion-spacing-4); }
  .ion-g-xxl-4, .ion-gy-xxl-4 { --ion-gutter-y: var(--ion-spacing-4); }
  
  .ion-g-xxl-5, .ion-gx-xxl-5 { --ion-gutter-x: var(--ion-spacing-5); }
  .ion-g-xxl-5, .ion-gy-xxl-5 { --ion-gutter-y: var(--ion-spacing-5); }
}

/* ===================================
   BORDER UTILITIES
   =================================== */
/* Border - All Sides */
.ion-border { border: 1px solid #dee2e6 !important; }
.ion-border-0 { border: 0 !important; }

/* Border - Individual Sides */
.ion-border-top { border-top: 1px solid #dee2e6 !important; }
.ion-border-top-0 { border-top: 0 !important; }

.ion-border-end { border-right: 1px solid #dee2e6 !important; }
.ion-border-end-0 { border-right: 0 !important; }

.ion-border-bottom { border-bottom: 1px solid #dee2e6 !important; }
.ion-border-bottom-0 { border-bottom: 0 !important; }

.ion-border-start { border-left: 1px solid #dee2e6 !important; }
.ion-border-start-0 { border-left: 0 !important; }

/* Border - Legacy names */
.ion-border-right { border-right: 1px solid #dee2e6 !important; }
.ion-border-right-0 { border-right: 0 !important; }

.ion-border-left { border-left: 1px solid #dee2e6 !important; }
.ion-border-left-0 { border-left: 0 !important; }

/* Border Colors */
.ion-border-primary { border-color: var(--ion-color-primary) !important; }
.ion-border-secondary { border-color: var(--ion-color-secondary) !important; }
.ion-border-dark { border-color: var(--ion-color-dark) !important; }
.ion-border-light { border-color: var(--ion-color-light) !important; }
.ion-border-white { border-color: #fff !important; }

/* Border Radius */
.ion-rounded { border-radius: 0.25rem !important; }
.ion-rounded-0 { border-radius: 0 !important; }
.ion-rounded-1 { border-radius: 0.2rem !important; }
.ion-rounded-2 { border-radius: 0.25rem !important; }
.ion-rounded-3 { border-radius: 0.3rem !important; }
.ion-rounded-4 { border-radius: 0.375rem !important; }
.ion-rounded-5 { border-radius: 0.5rem !important; }
.ion-rounded-circle { border-radius: 50% !important; }
.ion-rounded-pill { border-radius: 50rem !important; }

/* Border Width */
.ion-border-1 { border-width: 1px !important; }
.ion-border-2 { border-width: 2px !important; }
.ion-border-3 { border-width: 3px !important; }
.ion-border-4 { border-width: 4px !important; }
.ion-border-5 { border-width: 5px !important; }
/* ===================================
   WIDTH UTILITIES
   =================================== */
.ion-w-25 { width: 25% !important; }
.ion-w-50 { width: 50% !important; }
.ion-w-75 { width: 75% !important; }
.ion-w-100 { width: 100% !important; }
.ion-w-auto { width: auto !important; }

/* ===================================
   HEIGHT UTILITIES
   =================================== */
.ion-h-25 { height: 25% !important; }
.ion-h-50 { height: 50% !important; }
.ion-h-75 { height: 75% !important; }
.ion-h-100 { height: 100% !important; }
.ion-h-auto { height: auto !important; }

/* ===================================
   MAX WIDTH UTILITIES
   =================================== */
.ion-mw-100 { max-width: 100% !important; }

/* ===================================
   MAX HEIGHT UTILITIES
   =================================== */
.ion-mh-100 { max-height: 100% !important; }

/* ===================================
   VIEWPORT WIDTH
   =================================== */
.ion-vw-100 { width: 100vw !important; }

/* ===================================
   VIEWPORT HEIGHT
   =================================== */
.ion-vh-100 { height: 100vh !important; }
.ion-min-vh-100 { min-height: 100vh !important; }


.ion-table {
  --ion-table-color-type: initial;
  --ion-table-bg-type: initial;
  --ion-table-color-state: initial;
  --ion-table-bg-state: initial;
  --ion-table-color: var(--ion-emphasis-color);
  --ion-table-border-color: var(--ion-border-color);
  --ion-table-accent-bg: transparent;
  --ion-table-striped-color: var(--ion-emphasis-color);
  --ion-table-striped-bg: rgba(var(--ion-emphasis-color-rgb), 0.05);
  --ion-table-active-color: var(--ion-emphasis-color);
  --ion-table-active-bg: rgba(var(--ion-emphasis-color-rgb), 0.1);
  --ion-table-hover-color: var(--ion-emphasis-color);
  --ion-table-hover-bg: rgba(var(--ion-emphasis-color-rgb), 0.075);
  width: 100%;
  margin-bottom: 1rem;
  vertical-align: top;
  border-color: var(--ion-table-border-color);
}
.ion-table > :not(caption) > * > * {
  padding: 0.5rem 0.5rem;
  color: var(--ion-table-color-state, var(--ion-table-color-type, var(--ion-table-color)));
  background-color: var(--ion-table-bg);
  border-bottom-width: var(--ion-border-width);
  box-shadow: inset 0 0 0 9999px var(--ion-table-bg-state, var(--ion-table-bg-type, var(--ion-table-accent-bg)));
}

.ion-table > tbody {
  vertical-align: inherit;
}
.ion-table > thead {
  vertical-align: bottom;
 text-align: left
}

.ion-table-group-divider {
  border-top: calc(var(--ion-border-width) * 2) solid currentcolor;
}

.caption-top {
  caption-side: top;
}

.ion-table-sm > :not(caption) > * > * {
  padding: 0.5rem 0.5rem;
}

.ion-table-bordered > :not(caption) > * {
  border-width: var(--ion-border-width) 0;
}
.ion-table-bordered > :not(caption) > * > * {
  border-width: 0 var(--ion-border-width);
}

.ion-table-borderless > :not(caption) > * > * {
  border-bottom-width: 0;
}
.ion-table-borderless > :not(:first-child) {
  border-top-width: 0;
}

.ion-table-striped > tbody > tr:nth-of-type(odd) > * {
  --ion-table-color-type: var(--ion-table-striped-color);
  --ion-table-bg-type: var(--ion-table-striped-bg);
}

.ion-table-striped-columns > :not(caption) > tr > :nth-child(even) {
  --ion-table-color-type: var(--ion-table-striped-color);
  --ion-table-bg-type: var(--ion-table-striped-bg);
}

.ion-table-active {
  --ion-table-color-state: var(--ion-table-active-color);
  --ion-table-bg-state: var(--ion-table-active-bg);
}

.ion-table-hover > tbody > tr:hover > * {
  --ion-table-color-state: var(--ion-table-hover-color);
  --ion-table-bg-state: var(--ion-table-hover-bg);
}





.ion-table-responsive {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}

@media (max-width: 575.98px) {
  .ion-table-responsive-sm {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 767.98px) {
  .ion-table-responsive-md {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 991.98px) {
  .ion-table-responsive-lg {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 1199.98px) {
  .ion-table-responsive-xl {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
@media (max-width: 1399.98px) {
  .ion-table-responsive-xxl {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.ion-alert {
  --ion-alert-bg: transparent;
  --ion-alert-padding-x: 1rem;
  --ion-alert-padding-y: 1rem;
  --ion-alert-margin-bottom: 1rem;
  --ion-alert-color: inherit;
  --ion-alert-border-color: transparent;
  --ion-alert-border: var(--ion-border-width) solid var(--ion-alert-border-color);
  --ion-alert-border-radius: var(--ion-border-radius);
  --ion-alert-link-color: inherit;
  position: relative;
  padding: var(--ion-alert-padding-y) var(--ion-alert-padding-x);
  margin-bottom: var(--ion-alert-margin-bottom);
  color: var(--ion-alert-color);
  background-color: var(--ion-alert-bg);
  border: var(--ion-alert-border);
  border-radius: var(--ion-alert-border-radius);
}

.ion-alert-heading {
  color: inherit;
}

.ion-alert-link {
  font-weight: 700;
  color: var(--ion-alert-link-color);
}

.ion-alert-dismissible {
  padding-right: 3rem;
}
.ion-alert-dismissible .btn-close {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  padding: 1.25rem 1rem;
}

.ion-alert-primary {
  --ion-alert-color: var(--ion-primary-text-emphasis);
  --ion-alert-bg: var(--ion-primary-bg-subtle);
  --ion-alert-border-color: var(--ion-primary-border-subtle);
  --ion-alert-link-color: var(--ion-primary-text-emphasis);
}

.ion-alert-secondary {
  --ion-alert-color: var(--ion-secondary-text-emphasis);
  --ion-alert-bg: var(--ion-secondary-bg-subtle);
  --ion-alert-border-color: var(--ion-secondary-border-subtle);
  --ion-alert-link-color: var(--ion-secondary-text-emphasis);
}

.ion-alert-success {
  --ion-alert-color: var(--ion-success-text-emphasis);
  --ion-alert-bg: var(--ion-success-bg-subtle);
  --ion-alert-border-color: var(--ion-success-border-subtle);
  --ion-alert-link-color: var(--ion-success-text-emphasis);
}

.ion-alert-info {
  --ion-alert-color: var(--ion-body-color);
  --ion-alert-bg: var(--ion-info-bg-subtle);
  --ion-alert-border-color: var(--ion-info-border-subtle);
  --ion-alert-link-color: var(--ion-info-text-emphasis);
}

.ion-alert-warning {
  --ion-alert-color: var(--ion-warning-text-emphasis);
  --ion-alert-bg: var(--ion-warning-bg-subtle);
  --ion-alert-border-color: var(--ion-warning-border-subtle);
  --ion-alert-link-color: var(--ion-warning-text-emphasis);
}

.ion-alert-danger {
  --ion-alert-color: var(--ion-danger-text-emphasis);
  --ion-alert-bg: var(--ion-danger-bg-subtle);
  --ion-alert-border-color: var(--ion-danger-border-subtle);
  --ion-alert-link-color: var(--ion-danger-text-emphasis);
}

.ion-alert-light {
  --ion-alert-color: var(--ion-light-text-emphasis);
  --ion-alert-bg: var(--ion-light-bg-subtle);
  --ion-alert-border-color: var(--ion-light-border-subtle);
  --ion-alert-link-color: var(--ion-light-text-emphasis);
}

.ion-alert-dark {
  --ion-alert-color: var(--ion-dark-text-emphasis);
  --ion-alert-bg: var(--ion-dark-bg-subtle);
  --ion-alert-border-color: var(--ion-dark-border-subtle);
  --ion-alert-link-color: var(--ion-dark-text-emphasis);
}

.alignleft{float:left;margin:0 1.5rem 1rem 0}
.alignright{float:right;margin:0 0 1rem 1.5rem}
.aligncenter, .centered{display:block;margin:0 auto 1.5rem}
.wp-caption{max-width:100%;text-align:center}
.wp-caption img{margin:0; padding: .5rem}
.wp-caption-text{margin-top:.5rem;}
.gallery{display:grid;gap:2rem;margin:0 0 2rem}
.gallery-item{margin:0; background:#F5F5F5; border: .1rem solid #CFCFCF;padding: .5rem }
.gallery img{width:100%;height:auto;display:block}
.gallery-caption{margin-top:.5rem}
.gallery-columns-1{grid-template-columns:1fr}
.gallery-columns-2{grid-template-columns:repeat(2,1fr)}
.gallery-columns-3{grid-template-columns:repeat(3,1fr)}
.gallery-columns-4{grid-template-columns:repeat(4,1fr)}
.gallery-columns-5{grid-template-columns:repeat(5,1fr)}
.gallery-columns-6{grid-template-columns:repeat(6,1fr)}
.gallery-columns-7{grid-template-columns:repeat(7,1fr)}
.gallery-columns-8{grid-template-columns:repeat(8,1fr)}
.gallery-columns-9{grid-template-columns:repeat(9,1fr)}
@media(max-width:768px){.alignleft,.alignright{float:none;display:block;margin:0 0 1.5rem;max-width:100%}.gallery{grid-template-columns:1fr!important}}

@media only screen and (max-width:1024px) {
.alignleft, .alignright { max-width: 400px }
}
@media only screen and (max-width:800px) {
.alignleft, .alignright { max-width: 300px }
}
@media only screen and (max-width:615px) {
.alignleft, .alignright { max-width: 100%; width: 100%; display: block; float: none; margin: 0 0 1.5rem !important; }
}
/*WP*/
body.admin-bar #wpadminbar { position: fixed !important }
li#wp-admin-bar-wp-logo { display: none !important }
#wp-admin-bar-my-account .ab-item { font-size: 0 !important; }
#wp-admin-bar-my-account .ab-sub-wrapper .ab-item { font-size: inherit !important; }
html li#wp-admin-bar-epc_purge_menu { display: none !important }
a.lwa-links-remember, form.lwa-remember { display: none !important; }

/*Menu Helper*/




/*library alerts*/
.relative{position: relative}
.library-alerts-container {width: 100%;padding: 1.5rem 0rem 1rem 0rem ;box-sizing: border-box; background-color:#FBD010 ;color: #000;margin-top: 0rem;position: relative;border-bottom: .2rem solid #800020; font-size: 1.7rem; font-weight: 500}
.alerticon {position: absolute;left:0rem;top:0rem;font-size: 3.1rem;color:#800020; font-weight: bold}
.library-alert-content p:last-child {margin-bottom: 0;}
.single-alert {border-bottom: .1rem solid #fff;display: block;padding: .4rem 0;line-height: 1.4;margin-left:3rem; margin-right: 4.5rem}
.single-alert:last-child {border-bottom: none}
.single-alert p {margin-bottom: 0;margin-top: 1rem}
.single-alert p:first-of-type {margin-top: .5px}
.btn-close-alert {background-color: rgba(0, 0, 0, 0.1);border: none;font-size: 24px;line-height: 1;color: #333;cursor: pointer;padding: 0;width: 30px;height: 30px;align-items: center;justify-content: center;border-radius: 50%;position: absolute;right: 1rem;top:0rem}
.btn-close-alert:hover {background-color: #000;color: #fff;}
.btn-close-alert:focus {outline: 2px solid #333;outline-offset: 2px;}

/*FA*/
.fa, .fa-brands, .fa-classic, .fa-duotone, .fa-light, .fa-regular, .fa-sharp, .fa-sharp-solid, .fa-solid, .fa-thin, .fab, .fad, .fal, .far, .fas, .fasl, .fasr, .fass, .fast,
.fat {-moz-osx-font-smoothing: grayscale;-webkit-font-smoothing: antialiased;display: var(--fa-display, inline-block);font-style: normal;font-variant: normal;line-height: 1;text-rendering: auto;}
.fa-classic, .fa-light, .fa-regular, .fa-solid, .fa-thin, .fal, .far, .fas, .fat {font-family: "Font Awesome 6 Pro";}


/*ionicnet translator*/
body > div:not(.ion-wrapper) svg {display: none !important;}
html .skiptranslate {display: none !important;}
html .skiptranslate iframe {position: relative !important;}
.goog-te-banner-frame.skiptranslate, #google_translate_element_hidden, .goog-te-gadget {display: none !important;}
html.translated-ltr body, html.translated-rtl body {top: 0 !important;}
.header-translate {display: inline-block;}
.translate-container {display: inline-block;position: relative;}
.translate-label {display: inline-block;margin-right: 10px;font-weight: 500;font-size: 14px;color: #333;vertical-align: middle;}
.translate-dropdown {display: inline-block;position: relative;}
.dropdown-header {display: inline-flex;align-items: center;justify-content: space-between;padding: 0;background: transparent;border: 0px solid #e1e4e8;border-radius: 8px;cursor: pointer;transition: all 0.3s ease;user-select: none;white-space: nowrap;min-width: fit-content;color: #000;}
.dropdown-header:hover {color:#022873;}
.selected-option {display: flex;align-items: center;gap: 5px;}
.selected-flag {font-size: 20px;line-height: 1;display: flex;align-items: center;width: 20px;height: 20px;}
.selected-text {font-size: 16px;font-weight: 500;white-space: nowrap;}
.dropdown-arrow {display: flex;align-items: center;margin-left:5px;}
.dropdown-arrow svg {transition: transform 0.3s ease;color: #586069;}
.dropdown-options {position: absolute;top: calc(100% + 5px);left: 0;background: #ffffff;border: 2px solid #e1e4e8;border-radius: 8px;box-shadow: 0 10px 40px rgba(0, 0, 0, 0.1);z-index: 9999;overflow: visible;animation: slideDown 0.2s ease;min-width: 100%;width: max-content;}
.translate-dropdown[data-position="above"] .dropdown-options {top: auto;bottom: calc(100% + 5px);animation: slideUp 0.2s ease;}
@keyframes slideDown {from {opacity: 0;transform: translateY(-10px);}to {opacity: 1;transform: translateY(0);}}
@keyframes slideUp {from {opacity: 0;transform: translateY(10px);}to {opacity: 1;transform: translateY(0);}}
.options-wrapper {max-height: none;overflow: visible;}
.options-list {padding: 5px;}
.dropdown-option {display: flex;align-items: center;gap: 4px;padding: 4px 8px;cursor: pointer;border-radius: 6px;transition: all 0.2s ease;text-align: left;white-space: nowrap;}
.dropdown-option:hover, .dropdown-option.hover {background: #f6f8fa;}
.dropdown-option.selected {background: #e3f2fd;color: #0366d6;}
.option-flag {font-size: 20px;line-height: 1;width:18px !important;height:auto !important; background-position: center center !important; background-repeat: no-repeat !important}
.option-text {flex: 1;display: flex;flex-direction: column;gap: 2px;}
.option-name {font-size: 14px;font-weight: 500;color: #24292e;}
.option-native {font-size: 12px;color: #586069;}
.theme-dark .dropdown-header {background: #1f2937;border-color: #374151;color: #f3f4f6;}
.theme-dark .dropdown-header:hover {border-color: #60a5fa;}
.theme-dark .selected-text, .theme-dark .option-name {color: #f3f4f6;}
.theme-dark .dropdown-options {background: #1f2937;border-color: #374151;}
.theme-dark .dropdown-option:hover, .theme-dark .dropdown-option.hover {background: #374151;}
.theme-dark .dropdown-option.selected {background: #1e3a8a;}
.theme-minimal .dropdown-header {background: transparent;border: 1px solid #d1d5da;border-radius: 4px;}
.theme-minimal .dropdown-options {border: 1px solid #d1d5da;border-radius: 4px;box-shadow: 0 3px 12px rgba(0, 0, 0, 0.08);}
.theme-gradient .dropdown-header {background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);border: none;color: white;}
.theme-gradient .selected-text {color: white;}
.theme-gradient .dropdown-arrow svg {color: white;}
.theme-gradient .dropdown-option:hover {background: linear-gradient(135deg, #f093fb 0%, #f5576c 100%);color: white;}
.theme-gradient .dropdown-option:hover .option-name {color: white;}
@media (max-width: 768px) {.translate-dropdown {min-width: auto;}.dropdown-options {max-width: 90vw;}}




/*Ionicnet Fetaured Slider*/
.slider-container,.slider-container-static {margin: 0 auto; position: relative;display: block;  }
.slider-text-wrap {position: relative;display: block; padding:2rem 2rem 2rem 2.5rem; background:var(--ion-color-gray); box-shadow: 0 1px 5px rgba(0, 0, 0, 0.3); height: 100%; border-radius: 3rem;  margin: .2rem; min-height: 40rem }
@media (min-width: 992px) {.slider-content .row{min-height: 38.2rem;}}
.slider-content {display: flex;  position: relative; z-index: 1; overflow: hidden}
.slide {width: 100%;opacity: 0;position: absolute;transition: opacity 0.2s ease-in-out;display: block; }
.slide.active {opacity: 1;position: relative;z-index: 1}
.slider-text {padding: 0 2rem;}
h2.slider-title{font-weight:600; font-size:2rem; margin-bottom:.4rem  }
@media (min-width:768px) h2.slider-title{font-size:3rem; }}
.slider-wrap{display: block}
.slider-wrap img {line-height: 0;border: .1rem solid #ECECEC;border-radius: 3rem; display:block; width: 100%; height: auto}
.slider-controls {display: flex;justify-content: center;gap: 1rem;margin: 1rem 0;}
.slider-controls button {border: 1px solid #ccc;border-radius: 50%;cursor: pointer;transition: background-color 0.3s;line-height: 0; width: 3.8rem; height: 3.8rem; background:#1B6DB6; color: #fff}
.slider-controls button svg path {fill: #fff;}
svg.play-icon{margin-left: .3rem}
.slider-controls button:hover {background-color:#FDC809;}
.slider-controls button:hover svg path {fill:#000;}
.slider-dots {display: flex;gap: 0.85rem;margin-top: 1rem;justify-content: flex-end; padding-right: 1rem; padding-left: 1rem}
.dot {width: 30px;height: 30px;border-radius: 50%;border: 1px solid #ccc;cursor: pointer;display: flex;align-items: center;justify-content: center;font-size: 1.6rem; font-weight: 600; background:#1B6DB6; color: #fff}
.dot.active, .dot:hover  {background-color:#FDC809;color:#000;}
.hidden {display: none;}
.slider-count {display: inline-block}
.slider-controls {float: left}
.slider-list {background: #fff; color: #000;font-size: 1.6rem;border: 1px solid #000;border-radius: 0;width: auto;height: 36px;padding: 0 .5rem;display: inline-block;vertical-align: top;cursor: pointer;line-height: 2.1;float: left;margin-right: 0.8rem;}
@media (max-width: 991px) {.slider-dots { display: none !important}}
/* When slides stack vertically (under 992px) */
/* For mobile / stacked layout */
@media (max-width:767px) {
.slider-controls {justify-content: center;}
.slider-controls button.prev-btn,  .slider-controls button.next-btn {border: 1px solid #ccc;border-radius:0;cursor: pointer;transition: background-color 0.3s;line-height: 0;width:2.5rem;height:12rem;background:#1B6DB6;color: #fff;}
.slider-controls button.prev-btn svg path ,  .slider-controls button.next-btn svg path  {fill: #fff;}
.slider-text-wrap{padding-left: 3.5rem; padding-right: 3.5rem}
.slider-controls .prev-btn,
.slider-controls .next-btn {position: absolute;top: 40%;transform: translateY(-40%);z-index: 5;}
.slider-controls .prev-btn {left: .3rem;}
.slider-controls .next-btn {right: .3rem;}
.slider-controls .play-pause-btn {position: relative;margin-top: 2rem;transform: none;}
.slider-text {padding: 0 }	
}
/*ionicNET-ics-list*/
/*ionicNET-ics-list*/
.IN-programs-list{ display: block; overflow: hidden; border-radius: 2rem; background:var(--ion-color-gray); box-shadow: 0 2px 5px 0 rgb(0 0 0 / 16%), 0 1px 2px 0 rgb(0 0 0 / 12%); position: relative; padding-bottom: 1rem}
.IN-programs-list h2{ padding:1rem 1rem; margin-bottom: 0;font-size:2rem;  text-align: center; border-bottom: .4rem solid #FDC809;background: #2D3192; font-weight: 600; color: #fff}
.IN-programs-list-footer a{ padding: .5rem; margin-bottom: 0; color: #fff; display: block; text-align: center; text-decoration: none; font-weight: 500;}
.IN-programs-list-body{display:block; padding: 1rem; height:38rem; position: relative; overflow: hidden; padding-left: .5rem }
.in-evlist-date{ width:5.5rem !important; height:5.5rem; padding-top:.5rem;text-align: center;font-size: 1.6rem;font-weight: bold;line-height: 1.1; margin-right: 1rem; flex-wrap: nowrap; flex-shrink: 0; border-top: .0rem solid;margin-left: 0; border-radius:50%; display: flex;flex-direction: column;justify-content: center;align-items: center; background:#2D3192; color: #fff; box-shadow: 0 2px 5px 0 rgb(0 0 0 / 16%), 0 1px 2px 0 rgb(0 0 0 / 12%); }
.page-template-kids .IN-programs-list h2{background:#FCC808; color:#000}
.page-template-kids .in-evlist-date{ background:#FCC808; color:#000}
span.e-month{display:block}
span.e-day{display: block;font-size:2.2rem }
.in-evlist-single{text-decoration: none; line-height: 1.2; display: flex;  padding: .5rem; border-bottom: solid .1rem #ccc; color: #231F20; width: 100%; align-items: center; padding-top: 0; padding-bottom: .8rem; margin-bottom:.8rem}
a.in-evlist-info{margin-left: auto}
a.in-evlist-single .in-evlist-title{font-size: 1.7rem; font-weight: 500; margin-bottom:.2rem; display: block}
.in-evlist-single:not(.upcoming-event) {display: none;}
@media (max-width: 1400px) {
.in-evlist-date{ width:4.8rem !important; height:4.8rem;  }
span.e-day {font-size: 1.6rem;}
a.in-evlist-single .in-evlist-title{font-size: 1.6rem}
}

.ionScrollbar {-ms-touch-action: pinch-zoom;touch-action: pinch-zoom;}
.ionScrollbar ul, .ionScrollbar ul li{margin: 0; padding: 0; list-style: none}
.ionScrollbar.mCS_no_scrollbar, .ionScrollbar.mCS_touch_action {-ms-touch-action: auto;touch-action: auto;}
.ionScrollBox {position: relative;overflow: hidden;height: 100%;max-width: 100%;outline: none;direction: ltr;}
.ionSB_container {display: block;width: auto;height: auto;}
.ionSB_inside > .ionSB_container {margin-right:2rem;padding: .5rem}
.ionSB_container.mCS_no_scrollbar_y.mCS_y_hidden {margin-right: 0;}
.ionSB_scrollTools {position: absolute;width: 1.6rem;height: auto;left: auto;top: 0;right: 0;bottom: 0;border: .2rem solid #000;border-radius: .7rem;}
.ionSB_draggerContainer {position: absolute;top: 0;left: 0;bottom: 0;right: 0;height: auto;background-color: #fff;background-color: rgba(0,0,0,0.05);}
.ionSB_scrollTools a + .ionSB_draggerContainer {margin: 30px 0;}
.ionSB_draggerRail {width: 2px;height: 100% !important;margin: 0 auto;border-radius: 16px;}
.ionSB_dragger {cursor: pointer;width: 100%;height: 30px;z-index: 1;position: absolute;}
.ionSB_dragger_bar {position: relative;width: 1rem;height: 100%;margin: 0 auto;border-radius: 1rem;background-color: #FDC809;}
.page-template-teens .ionSB_dragger_bar {background-color: #FCBF89;}
.page-template-kids .ionSB_dragger_bar {background-color: #EEB71C;}


/* Ion Accordion */
.ion-single-accordion { margin-bottom: .7rem; border: 0.01rem solid #ccc; border-radius: .5rem; }
.ion-accordion-btn { background-color: var(--ion-color-gray); color:#000 !important; cursor: pointer; padding: .8rem 4.5rem .8rem .8rem; width: 100%; text-align: left; font-size: 1.8rem; transition: 0.4s; position: relative; text-decoration: none; display: flex; align-items: center; justify-content: left; border-top-left-radius: .5rem; border-top-right-radius: .5rem }
.ion-accordion-btn::after { content: "\25BC"; position: absolute; right: 1rem; font-weight: bold; background: white; border-radius: 100%; width: 3rem; height: 3rem; text-align: center; line-height: 3rem; top: 50%; transform: translateY(-50%); font-size: 1.5rem; }
.ion-accordion-btn.ion-btn-opened::after { content: "\25B2"; }
.ion-accordion-btn:hover, .ion-accordion-btn.ion-btn-opened { background-color:#E5E5E5; }
.ion-accordion-panel {background-color: white;}
.ion-accordion-panel-inside {padding: 3rem 3rem 2rem;transform: translateY(-0.5rem);  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1) 0.05s;}
.ion-panel-opened .ion-accordion-panel-inside {transform: translateY(0);}
.ion-accordion-panel {background-color: white;height: 0;overflow: hidden;}
.ion-accordion-panel.is-collapsing {transition: height 0.5s cubic-bezier(0.4, 0, 0.2, 1);}
@media (prefers-reduced-motion: reduce){
.ion-accordion-panel,.ion-accordion-panel.is-collapsing {transition: none;}
}
.ion-tab-icon { display: inline-block; width: 5rem; min-width: 5rem; height: 5rem; margin: 0 1rem 0 0rem; border-radius: 100%; background: white; padding: 0.8rem; border: 0.01rem solid #F1F0F1; }
.ion-tab-icon img { width: 100%; height: auto; line-height: 0; transition: transform .2s ease-in-out;}
.ion-accordion-btn:hover .ion-tab-icon img {transform: rotate(15deg);}
.ion-tab-text { font-size: 1.9rem; font-weight: 500 }
.exptabs { display: block; text-align: right; margin-bottom: 2rem; font-size: 1.6rem }
.exptabs button { border: 1px solid #ccc; font-size: 1.6rem; padding: .5rem }

.hvr-float { display: inline-block; vertical-align: middle; -webkit-transform: perspective(1px) translateZ(0); transform: perspective(1px) translateZ(0); box-shadow: 0 0 1px rgba(0, 0, 0, 0); -webkit-transition-duration: .3s; transition-duration: .3s; -webkit-transition-property: transform; transition-property: transform; -webkit-transition-timing-function: ease-out; transition-timing-function: ease-out; }
.hvr-float:active, .hvr-float:focus, .hvr-float:hover { -webkit-transform: translateY(-8px); transform: translateY(-8px); }
.hvr-icon-grow-rotate { display: inline-block; vertical-align: middle; -webkit-transform: perspective(1px) translateZ(0); transform: perspective(1px) translateZ(0); box-shadow: 0 0 1px rgba(0, 0, 0, 0); }
.hvr-icon-grow-rotate .hvr-icon { -webkit-transform: translateZ(0); transform: translateZ(0); -webkit-transition-duration: .3s; transition-duration: .3s; -webkit-transition-property: transform; transition-property: transform; -webkit-transition-timing-function: ease-out; transition-timing-function: ease-out; }
.hvr-icon-grow-rotate:active .hvr-icon, .hvr-icon-grow-rotate:focus .hvr-icon, .hvr-icon-grow-rotate:hover .hvr-icon { -webkit-transform: scale(1.3) rotate(12deg); transform: scale(1.3) rotate(12deg); }


